:root{--bg:#FFF8F0;--bg-card:#FFF;--bg-card-hover:#FFF5EB;--surface:#FFF0E0;--text:#2D1B0E;--text-2:#6B5744;--text-3:#A8937E;--accent:#3B8FD9;--accent-soft:rgba(59,143,217,0.10);--coral:#E85D75;--coral-soft:rgba(232,93,117,0.08);--amber:#F0A03C;--amber-soft:rgba(240,160,60,0.08);--blue:#4A90D9;--blue-soft:rgba(74,144,217,0.08);--radius:16px;--radius-sm:10px;--font:'Outfit',sans-serif;--font-display:'Fraunces',serif;--font-mono:'JetBrains Mono',monospace;--max-w:1200px;--pad:clamp(1.25rem,4vw,3rem)}*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;overflow-x:hidden;background-image:radial-gradient(ellipse 80% 50% at 20% 0,rgba(59,143,217,0.06) 0,transparent 60%),radial-gradient(ellipse 60% 40% at 80% 30%,rgba(240,160,60,0.05) 0,transparent 55%),radial-gradient(ellipse 70% 50% at 50% 80%,rgba(232,93,117,0.04) 0,transparent 50%);background-attachment:fixed}a{color:inherit;text-decoration:none}ul{list-style:none}::selection{background:var(--accent);color:#FFF}.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:1rem var(--pad);background:rgba(255,248,240,0.75);backdrop-filter:blur(24px) saturate(1.4);border-bottom:1px solid rgba(45,27,14,0.06);transition:background .3s}.nav-brand{font-family:var(--font-display);font-size:1.3rem;font-weight:700;letter-spacing:-0.03em}.nav-links{display:flex;align-items:center;gap:1.75rem}.nav-links a{font-size:.82rem;font-weight:500;color:var(--text-2);transition:color .2s}.nav-links a:hover{color:var(--text)}.nav-right{display:flex;align-items:center;gap:1rem}.nav-icon{font-size:1.05rem;color:var(--text-3);transition:color .2s}.nav-icon:hover{color:var(--text)}.nav-btn{background:var(--accent);color:#FFF!important;font-weight:600;font-size:.82rem;padding:.5rem 1.25rem;border-radius:8px;transition:transform .2s,box-shadow .2s}.nav-btn:hover{transform:translateY(-1px);box-shadow:0 4px 16px rgba(59,143,217,0.30)}.hero{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:7rem var(--pad) 5rem;overflow:hidden}.hero-bg-orbs{position:absolute;inset:0;pointer-events:none;overflow:hidden}.orb{position:absolute;border-radius:50%;filter:blur(80px);opacity:.45}.orb--1{width:500px;height:500px;background:radial-gradient(circle,rgba(59,143,217,0.25),transparent 70%);top:-10%;left:10%;animation:orbFloat 12s ease-in-out infinite}.orb--2{width:400px;height:400px;background:radial-gradient(circle,rgba(255,180,120,0.30),transparent 70%);bottom:-5%;right:5%;animation:orbFloat 10s ease-in-out infinite reverse}.orb--3{width:350px;height:350px;background:radial-gradient(circle,rgba(232,93,117,0.18),transparent 70%);top:30%;right:20%;animation:orbFloat 14s ease-in-out infinite 2s}@keyframes orbFloat{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(30px,-20px) scale(1.05)}66%{transform:translate(-20px,15px) scale(0.95)}}.hero-inner{position:relative;z-index:2;max-width:700px}.hero-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.72rem;font-weight:400;color:var(--accent);padding:.4rem 1.1rem;background:var(--accent-soft);border:1px solid rgba(59,143,217,0.20);border-radius:999px;margin-bottom:2.5rem;letter-spacing:.03em;animation:fadeDown .8s ease forwards}.badge-pulse{width:7px;height:7px;background:var(--accent);border-radius:50%;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(0.8)}}.hero-name{font-family:var(--font-display);font-weight:900;line-height:.95;margin-bottom:1.25rem}.hero-first{display:block;font-size:clamp(4rem,10vw,8rem);color:var(--text);opacity:0;animation:fadeUp .7s ease .1s forwards}.hero-last{display:block;font-size:clamp(4rem,10vw,8rem);color:transparent;-webkit-text-stroke:2px var(--accent);opacity:0;animation:fadeUp .7s ease .25s forwards}.hero-role{display:flex;align-items:center;justify-content:center;gap:1rem;font-family:var(--font-mono);font-size:.8rem;color:var(--text-3);letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.5rem;opacity:0;animation:fadeIn .6s ease .5s forwards}.role-line{width:40px;height:1px;background:var(--text-3)}.hero-intro{font-size:1.1rem;color:var(--text-2);max-width:480px;margin:0 auto 2rem;line-height:1.7;opacity:0;animation:fadeIn .6s ease .6s forwards}.hero-stats{display:flex;justify-content:center;gap:2.5rem;margin-bottom:2.5rem;opacity:0;animation:fadeIn .6s ease .7s forwards}.hero-stat{text-align:center}.stat-val{display:block;font-family:var(--font-display);font-size:1.8rem;font-weight:700;color:var(--accent)}.stat-label{font-size:.72rem;color:var(--text-3);font-family:var(--font-mono);letter-spacing:.02em}.hero-ctas{display:flex;gap:1rem;justify-content:center;opacity:0;animation:fadeIn .6s ease .85s forwards}.btn-main{display:inline-flex;align-items:center;gap:.5rem;background:var(--accent);color:#FFF;font-weight:600;font-size:.88rem;padding:.8rem 1.75rem;border-radius:var(--radius-sm);transition:transform .25s,box-shadow .25s}.btn-main:hover{transform:translateY(-2px);box-shadow:0 8px 30px rgba(59,143,217,0.35)}.btn-outline{display:inline-flex;align-items:center;font-weight:500;font-size:.88rem;padding:.8rem 1.75rem;border-radius:var(--radius-sm);border:1px solid rgba(45,27,14,0.12);color:var(--text-2);transition:border-color .2s,color .2s;gap:.5rem}.btn-outline:hover{border-color:rgba(45,27,14,0.25);color:var(--text)}.btn-outline i{margin-right:.4rem}.hero-floaters{position:absolute;inset:0;z-index:1;pointer-events:none}.floater{position:absolute;background:rgba(255,255,255,0.85);backdrop-filter:blur(16px);border:1px solid rgba(45,27,14,0.08);box-shadow:0 4px 20px rgba(45,27,14,0.06);border-radius:var(--radius-sm);padding:.85rem 1.1rem;animation:floatSlow 8s ease-in-out infinite}.floater--1{top:22%;left:5%;animation-delay:0s}.floater--2{top:18%;right:6%;animation-delay:1.5s}.floater--3{bottom:22%;right:10%;animation-delay:3s}@keyframes floatSlow{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}.floater-label{display:block;font-family:var(--font-mono);font-size:.62rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.3rem}.floater-val{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--text)}.floater-val small{font-family:var(--font);font-size:.6rem;color:var(--text-3);font-weight:400}.floater-spark{margin-top:.35rem}.floater-spark svg{width:70px;height:25px}.floater-spark svg path{stroke:var(--accent)}.floater-dots{display:flex;align-items:flex-end;gap:3px;height:30px;margin-top:.35rem}.floater-dots i{width:5px;height:var(--h,50%);background:var(--coral);border-radius:2px;animation:barGrow 1.5s ease-in-out infinite alternate}.floater-dots i:nth-child(2n){animation-delay:.3s}.floater-dots i:nth-child(3n){animation-delay:.6s}@keyframes barGrow{0%{transform:scaleY(0.7)}100%{transform:scaleY(1)}}@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeDown{from{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{to{opacity:1}}.bento-section{padding:clamp(4rem,8vw,7rem) var(--pad);max-width:var(--max-w);margin:0 auto}.bento-header{margin-bottom:3rem}.bento-tag{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--font-mono);font-size:.7rem;font-weight:400;color:var(--accent);letter-spacing:.1em;text-transform:uppercase;margin-bottom:.6rem}.bento-tag i{font-size:.65rem}.bento-title{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.5rem);font-weight:700;line-height:1.1;letter-spacing:-0.02em}.bento-title em{font-style:italic;color:var(--accent)}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.bento-card{background:var(--bg-card);border:1px solid rgba(45,27,14,0.06);border-radius:var(--radius);overflow:hidden;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease;position:relative;box-shadow:0 2px 12px rgba(45,27,14,0.04)}.bento-card:hover{transform:translateY(-4px);border-color:rgba(45,27,14,0.10);box-shadow:0 8px 30px rgba(45,27,14,0.08)}.bento-card--xl{grid-column:1 / -1;display:grid;grid-template-columns:1fr 1fr;min-height:340px}.bento-card--md{grid-column:span 2}.bento-card--sm{padding:1.5rem}.card-layer--bg{position:relative;overflow:hidden}.card-screenshot{width:100%;height:100%;object-fit:cover;object-position:top left;transition:transform .5s ease}.bento-card:hover .card-screenshot{transform:scale(1.03)}.card-content{padding:2rem 2.5rem;display:flex;flex-direction:column;justify-content:center}.card-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap}.card-badge{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.65rem;padding:.25rem .65rem;border-radius:6px;background:rgba(45,27,14,0.04);color:var(--text-2);letter-spacing:.03em;border:1px solid rgba(45,27,14,0.08)}.card-badge i{font-size:.6rem}.card-badge--green{background:var(--accent-soft);color:var(--accent);border-color:rgba(59,143,217,0.20)}.card-badge--coral{background:var(--coral-soft);color:var(--coral);border-color:rgba(232,93,117,0.20)}.card-year{margin-left:auto;font-family:var(--font-mono);font-size:.65rem;color:var(--text-3)}.card-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;margin-bottom:.75rem;letter-spacing:-0.01em}.card-desc{font-size:.88rem;color:var(--text-2);line-height:1.7;margin-bottom:1.25rem}.card-desc strong{color:var(--text);font-weight:600}.card-techs{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:1rem}.card-techs span{display:inline-flex;align-items:center;gap:.3rem;font-family:var(--font-mono);font-size:.65rem;color:var(--text-3);padding:.25rem .6rem;background:rgba(45,27,14,0.03);border:1px solid rgba(45,27,14,0.06);border-radius:5px}.card-techs span i{font-size:.6rem}.card-links{display:flex;gap:.75rem}.card-link{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:500;color:var(--accent);transition:color .2s}.card-link:hover{color:var(--text)}.bento-screenshot{position:relative;overflow:hidden;aspect-ratio:16 / 10}.screenshot-img{width:100%;height:100%;object-fit:cover;object-position:top;transition:transform .5s ease}.bento-screenshot:hover .screenshot-img{transform:scale(1.03)}.screenshot-caption{position:absolute;bottom:0;left:0;right:0;padding:2rem 1.25rem 1rem;background:linear-gradient(to top,rgba(255,248,240,0.92),transparent);font-family:var(--font-mono);font-size:.7rem;color:var(--text-2);display:flex;align-items:center;gap:.4rem}.screenshot-caption i{color:var(--accent);font-size:.65rem}.bento-zw .card-layer--bg{background:linear-gradient(135deg,#F0F8F4 0,#F5FAF7 100%)}.bento-anssi .card-layer--bg{background:linear-gradient(135deg,#F5F0F8 0,#FAF5FC 100%)}.bento-lunea .card-layer--bg{background:linear-gradient(135deg,#EEF4FA 0,#F0F6FC 100%)}.bento-feat{display:flex;flex-direction:column;gap:.6rem}.feat-icon{width:44px;height:44px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--accent);background:var(--accent-soft);border-radius:10px}.feat-icon--amber{color:var(--amber);background:var(--amber-soft)}.feat-icon--coral{color:var(--coral);background:var(--coral-soft)}.feat-icon--blue{color:var(--blue);background:var(--blue-soft)}.bento-feat h4{font-size:.9rem;font-weight:600;color:var(--text)}.bento-feat p{font-size:.78rem;color:var(--text-3);line-height:1.55}.skills-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.skill-card{background:var(--bg-card);border:1px solid rgba(45,27,14,0.06);border-radius:var(--radius);padding:2rem 1.5rem;transition:transform .35s ease,border-color .35s ease,box-shadow .35s ease;box-shadow:0 2px 12px rgba(45,27,14,0.04)}.skill-card:hover{transform:translateY(-4px);border-color:rgba(45,27,14,0.10);box-shadow:0 8px 30px rgba(45,27,14,0.08)}.skill-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.3rem;border-radius:12px;margin-bottom:1.25rem}.skill-card-icon--accent{color:var(--accent);background:var(--accent-soft)}.skill-card-icon--amber{color:var(--amber);background:var(--amber-soft)}.skill-card-icon--coral{color:var(--coral);background:var(--coral-soft)}.skill-card-icon--blue{color:var(--blue);background:var(--blue-soft)}.skill-card h4{font-size:.95rem;font-weight:600;margin-bottom:.85rem}.skill-card-tags{display:flex;flex-wrap:wrap;gap:.35rem}.skill-card-tags span{font-size:.72rem;padding:.25rem .6rem;border-radius:6px;background:rgba(45,27,14,0.03);border:1px solid rgba(45,27,14,0.06);color:var(--text-2);font-family:var(--font-mono)}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.about-bio{grid-column:1 / -1;padding:2rem 2.5rem}.bio-text{font-size:.95rem;color:var(--text-2);line-height:1.75;margin-bottom:.75rem}.bio-text strong{color:var(--text)}.bio-seek{margin-top:1rem;font-size:.88rem;color:var(--accent);font-weight:500;padding:.75rem 1rem;background:var(--accent-soft);border-left:3px solid var(--accent);border-radius:0 8px 8px 0;display:flex;align-items:center;gap:.5rem}.about-card-title{font-family:var(--font-display);font-size:1.1rem;font-weight:500;margin-bottom:1.5rem;color:var(--text);display:flex;align-items:center;gap:.5rem}.about-card-title i{color:var(--accent);font-size:.9rem}.about-formation{padding:2rem 2.5rem}.mini-timeline{display:flex;flex-direction:column}.mt-item{display:flex;gap:1rem;align-items:flex-start;padding:.85rem 0;border-bottom:1px solid rgba(45,27,14,0.06);position:relative}.mt-item:last-child{border-bottom:none}.mt-dot{width:10px;height:10px;border-radius:50%;background:var(--text-3);border:2px solid var(--bg-card);box-shadow:0 0 0 2px var(--text-3);margin-top:.35rem;flex-shrink:0}.mt-item--active .mt-dot{background:var(--accent);box-shadow:0 0 0 2px var(--accent),0 0 10px rgba(59,143,217,0.30)}.mt-date{display:block;font-family:var(--font-mono);font-size:.62rem;color:var(--text-3);letter-spacing:.04em;margin-bottom:.1rem}.mt-info strong{display:block;font-size:.85rem;font-weight:600;color:var(--text)}.mt-sub{display:block;font-size:.75rem;color:var(--text-3);margin-top:.1rem}.about-langues{padding:2rem 2.5rem}.lang-list{display:flex;flex-direction:column;gap:.85rem}.lang-item{display:grid;grid-template-columns:70px 1fr 55px;gap:.75rem;align-items:center}.lang-name{font-size:.82rem;font-weight:500;color:var(--text)}.lang-bar{height:4px;background:rgba(45,27,14,0.06);border-radius:2px;overflow:hidden}.lang-fill{height:100%;width:var(--w);background:linear-gradient(90deg,var(--accent),var(--blue));border-radius:2px;transition:width 1.2s ease}.lang-fill--warm{background:linear-gradient(90deg,var(--amber),var(--coral))}.lang-lvl{font-family:var(--font-mono);font-size:.65rem;color:var(--text-3);text-align:right}.about-interets{padding:2rem 2.5rem}.interets-list{display:flex;flex-direction:column;gap:.85rem}.interet-item{display:flex;align-items:center;gap:.85rem;padding:.65rem .85rem;background:rgba(45,27,14,0.02);border:1px solid rgba(45,27,14,0.06);border-radius:var(--radius-sm);transition:border-color .2s,background .2s}.interet-item:hover{border-color:rgba(45,27,14,0.12);background:rgba(45,27,14,0.04)}.interet-item i{font-size:1rem;color:var(--accent);width:24px;text-align:center}.interet-item span{font-size:.85rem;color:var(--text-2)}.contact-section{padding:clamp(5rem,10vw,8rem) var(--pad);text-align:center;position:relative}.contact-section::before{content:'';position:absolute;top:0;left:50%;transform:translateX(-50%);width:60%;height:1px;background:linear-gradient(90deg,transparent,rgba(45,27,14,0.08),transparent)}.contact-inner{max-width:var(--max-w);margin:0 auto}.contact-big{font-family:var(--font-display);font-size:clamp(3rem,8vw,6rem);font-weight:900;line-height:1;margin:.5rem 0 1rem;letter-spacing:-0.03em}.contact-big em{font-style:normal;color:var(--accent)}.contact-sub{font-size:1rem;color:var(--text-2);max-width:420px;margin:0 auto 3rem;line-height:1.7}.contact-grid{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.contact-card{background:var(--bg-card);border:1px solid rgba(45,27,14,0.06);border-radius:var(--radius);padding:1.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.4rem;min-width:180px;transition:transform .25s,border-color .25s,box-shadow .25s;box-shadow:0 2px 12px rgba(45,27,14,0.04)}.contact-card:hover{transform:translateY(-3px);border-color:rgba(45,27,14,0.10);box-shadow:0 6px 24px rgba(45,27,14,0.08)}.contact-card--accent{background:var(--accent);border-color:var(--accent)}.contact-card--accent .cc-icon,.contact-card--accent .cc-label,.contact-card--accent .cc-value{color:#FFF}.contact-card--accent:hover{border-color:var(--accent);box-shadow:0 8px 30px rgba(59,143,217,0.35)}.cc-icon{font-size:1.25rem;color:var(--text-2);margin-bottom:.25rem}.cc-label{font-family:var(--font-mono);font-size:.62rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em}.cc-value{font-size:.85rem;font-weight:500;color:var(--text)}.footer{padding:2rem var(--pad);border-top:1px solid rgba(45,27,14,0.06)}.footer-inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;justify-content:space-between;font-size:.75rem;color:var(--text-3)}.footer-links{display:flex;gap:1rem}.footer-links a{color:var(--text-3);font-size:.95rem;transition:color .2s}.footer-links a:hover{color:var(--text)}.bento-card--xl::before{content:'';position:absolute;inset:-1px;border-radius:var(--radius);background:linear-gradient(135deg,var(--accent),var(--coral),var(--amber));opacity:0;z-index:-1;transition:opacity .4s ease}.bento-card--xl:hover::before{opacity:.15}.skill-card:hover{box-shadow:0 8px 30px rgba(59,143,217,0.12)}.btn-main{position:relative;overflow:hidden}.btn-main::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.25),transparent);transition:left .5s ease}.btn-main:hover::after{left:120%}.nav-btn{position:relative;overflow:hidden}.nav-btn::after{content:'';position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.2),transparent);transition:left .5s ease}.nav-btn:hover::after{left:120%}.hero-badge{box-shadow:0 0 0 0 rgba(59,143,217,0);animation:fadeDown .8s ease forwards,badgeGlow 3s ease-in-out 1.5s infinite}@keyframes badgeGlow{0%,100%{box-shadow:0 0 0 0 rgba(59,143,217,0)}50%{box-shadow:0 0 20px rgba(59,143,217,0.12)}}.bento-section+.bento-section::before{content:'';display:block;width:60%;height:1px;margin:0 auto 3rem;background:linear-gradient(90deg,transparent,rgba(59,143,217,0.12),rgba(232,93,117,0.08),transparent)}.bento-screenshot:hover{box-shadow:0 12px 40px rgba(45,27,14,0.10)}.contact-card--accent:hover{box-shadow:0 8px 30px rgba(59,143,217,0.35),0 0 0 2px rgba(59,143,217,0.15)}.project-filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.5rem 1.15rem;border:1.5px solid var(--border);border-radius:100px;background:var(--bg-card);color:var(--text-secondary);font-family:var(--font-body);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .25s ease}.filter-btn:hover{border-color:var(--accent);color:var(--accent)}.filter-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}.project-card{transition:transform .35s ease,box-shadow .35s ease,opacity .4s ease}.project-card.filtered-out{opacity:0;transform:scale(0.9);pointer-events:none;position:absolute;visibility:hidden}.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.project-card{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;aspect-ratio:16 / 10;box-shadow:0 4px 20px rgba(45,27,14,0.08);transition:transform .35s ease,box-shadow .35s ease}.project-card:hover{transform:translateY(-6px);box-shadow:0 16px 50px rgba(45,27,14,0.14)}.project-card>img{width:100%;height:100%;object-fit:cover;object-position:top left;transition:transform .5s ease}.project-card:hover>img{transform:scale(1.05)}.project-card-overlay{position:absolute;bottom:0;left:0;right:0;padding:3rem 1.5rem 1.25rem;background:linear-gradient(to top,rgba(0,0,0,0.75) 0,rgba(0,0,0,0.3) 55%,transparent 100%);display:flex;flex-direction:column;gap:.5rem}.project-card-badges{display:flex;gap:.4rem}.project-card-overlay .card-badge{background:rgba(255,255,255,0.15);backdrop-filter:blur(8px);color:#fff;border-color:rgba(255,255,255,0.25)}.project-card-overlay .card-badge--green{background:rgba(59,143,217,0.30);color:#fff;border-color:rgba(59,143,217,0.40)}.project-card-overlay .card-badge--coral{background:rgba(232,93,117,0.30);color:#fff;border-color:rgba(232,93,117,0.40)}.project-card-title{font-family:var(--font-display);font-size:1.4rem;font-weight:700;color:#fff;letter-spacing:-0.01em}.project-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .35s ease,visibility .35s ease}.project-modal.modal-open{opacity:1;visibility:visible}.modal-overlay{position:absolute;inset:0;background:rgba(45,27,14,0.4);backdrop-filter:blur(8px)}.modal-content{position:relative;background:var(--bg-card);border-radius:20px;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;padding:2.5rem;box-shadow:0 25px 80px rgba(45,27,14,0.15);transform:scale(0.95) translateY(20px);transition:transform .35s ease}.project-modal.modal-open .modal-content{transform:scale(1) translateY(0)}.modal-content::-webkit-scrollbar{width:6px}.modal-content::-webkit-scrollbar-track{background:transparent}.modal-content::-webkit-scrollbar-thumb{background:rgba(45,27,14,0.15);border-radius:3px}.modal-close{position:sticky;top:0;float:right;width:40px;height:40px;border:none;background:rgba(45,27,14,0.05);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.1rem;color:var(--text-2);transition:background .2s,transform .2s;z-index:2}.modal-close:hover{background:rgba(45,27,14,0.10);transform:rotate(90deg)}.modal-hero-img{border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem;max-height:400px}.modal-hero-img img{width:100%;height:100%;object-fit:cover;object-position:top left}.modal-header{margin-bottom:2rem}.modal-header .card-title{font-size:2rem}.modal-header .card-desc{max-width:600px}.modal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.modal-screenshot{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:16 / 10}.modal-screenshot img{width:100%;height:100%;object-fit:cover;object-position:top}.modal-screenshot .screenshot-caption{position:absolute;bottom:0;left:0;right:0;padding:2rem 1.25rem 1rem;background:linear-gradient(to top,rgba(255,248,240,0.92),transparent);font-family:var(--font-mono);font-size:.7rem;color:var(--text-2);display:flex;align-items:center;gap:.4rem}.modal-screenshot .screenshot-caption i{color:var(--accent);font-size:.65rem}.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:translateY(0)}.modal-screenshot,.modal-hero-img,.project-card{user-select:none;-webkit-user-select:none}.modal-screenshot::after,.modal-hero-img::after,.project-card::after{content:'© Manal Hassan © Manal Hassan © Manal Hassan';position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:rgba(255,255,255,0.35);text-shadow:0 2px 6px rgba(0,0,0,0.25);letter-spacing:.2em;pointer-events:none;z-index:1;white-space:nowrap;transform:rotate(-20deg) scale(1.2)}.modal-screenshot .screenshot-caption{z-index:2}.project-card-overlay{z-index:2}img{-webkit-user-drag:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;pointer-events:none}.modal-screenshot img,.modal-hero-img img{cursor:zoom-in;pointer-events:auto}.lightbox-img{cursor:zoom-out;pointer-events:auto}.lightbox{position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,0.85);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility .3s ease;cursor:zoom-out}.lightbox.lightbox-open{opacity:1;visibility:visible}.lightbox-img{max-width:92vw;max-height:92vh;object-fit:contain;border-radius:12px;box-shadow:0 20px 80px rgba(0,0,0,0.4);transform:scale(0.9);transition:transform .3s ease}.lightbox.lightbox-open .lightbox-img{transform:scale(1)}.lightbox-close{position:absolute;top:1.25rem;right:1.25rem;width:44px;height:44px;border:none;border-radius:50%;background:rgba(255,255,255,0.15);color:#fff;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,transform .2s}.lightbox-close:hover{background:rgba(255,255,255,0.3);transform:rotate(90deg)}.lightbox-caption{position:absolute;bottom:2rem;left:50%;transform:translateX(-50%);color:#fff;font-size:.92rem;font-weight:500;background:rgba(0,0,0,0.55);padding:.65rem 1.5rem;border-radius:100px;backdrop-filter:blur(12px);white-space:nowrap;pointer-events:none;font-family:var(--font);letter-spacing:.01em;border:1px solid rgba(255,255,255,0.1)}.lightbox-watermark{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-20deg);color:rgba(255,255,255,0.30);font-family:var(--font-display);font-size:2.5rem;font-weight:700;letter-spacing:.2em;pointer-events:none;text-shadow:0 2px 8px rgba(0,0,0,0.3);white-space:nowrap;z-index:2001}@media(max-width:900px){.projects-grid{grid-template-columns:1fr 1fr}.modal-content{padding:1.75rem;width:95%}.modal-header .card-title{font-size:1.5rem}.skills-grid{grid-template-columns:1fr 1fr}.about-grid{grid-template-columns:1fr}.hero-floaters{display:none}.hero-stats{gap:1.5rem}.nav-links{display:none}}@media(max-width:600px){.projects-grid{grid-template-columns:1fr}.modal-content{width:100%;max-height:100vh;border-radius:0;padding:1.25rem}.modal-grid{grid-template-columns:1fr}.modal-hero-img{margin-bottom:1rem}.skills-grid{grid-template-columns:1fr}.nav-icon{display:none}.hero-last{-webkit-text-stroke-width:1.5px}.hero-stats{flex-direction:column;gap:.75rem}.contact-grid{flex-direction:column;align-items:center}}