:root{--bg:#f4f1e9;--bg-2:#ece8dd;--surface:#fff;--ink:#15140f;--ink-2:#56524a;--ink-3:#8c887d;--line:#15140f1f;--line-strong:#15140f3d;--accent:#e8b400;--accent-deep:#c2920a;--black:#141310;--font-display:"Space Grotesk", "Hanken Grotesk", sans-serif;--font-body:"Hanken Grotesk", system-ui, sans-serif;--font-mono:"Space Mono", ui-monospace, monospace;--ease:cubic-bezier(.22, 1, .36, 1);--ease-soft:cubic-bezier(.4, 0, .1, 1);--maxw:1320px}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{font-family:var(--font-body);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.55;overflow-x:hidden}::selection{background:var(--accent);color:var(--ink)}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}img{max-width:100%;display:block}.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,64px)}.eyebrow{font-family:var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--ink-2);align-items:center;gap:10px;font-size:12px;display:inline-flex}.eyebrow:before{content:"";background:var(--ink);width:28px;height:1px}.eyebrow.no-rule:before{display:none}.section-title{font-family:var(--font-display);letter-spacing:-.02em;font-size:clamp(40px,7vw,92px);font-weight:700;line-height:.96}.mark{color:var(--accent-deep)}.mark-block{background:var(--accent);color:var(--ink);padding:0 .12em}.btn{font-family:var(--font-body);transition:transform .4s var(--ease), background .3s, color .3s, box-shadow .3s;white-space:nowrap;border-radius:100px;align-items:center;gap:10px;padding:15px 26px;font-size:15px;font-weight:600;display:inline-flex}.btn:hover{transform:translateY(-2px)}.btn-dark{background:var(--black);color:#fff}.btn-dark:hover{box-shadow:0 14px 34px -12px #00000080}.btn-yellow{background:var(--accent);color:var(--ink)}.btn-yellow:hover{background:var(--accent-deep)}.btn-ghost{border:1.5px solid var(--ink);color:var(--ink);padding:13.5px 24px}.btn-ghost:hover{background:var(--ink);color:#fff}.btn .arr{transition:transform .4s var(--ease)}.btn:hover .arr{transform:translate(4px)}.nav{z-index:80;padding:22px 0;transition:background .4s,box-shadow .4s,padding .4s;position:fixed;inset:0 0 auto}.nav.scrolled{-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line);background:#f4f1e9d1;padding:14px 0}.nav-inner{justify-content:space-between;align-items:center;gap:24px;display:flex}.logo{font-family:var(--font-display);letter-spacing:-.02em;font-size:22px;font-weight:700}.logo .dot{color:var(--accent-deep)}.nav-links{align-items:center;gap:30px;display:flex}.nav-links a{color:var(--ink-2);font-size:14.5px;font-weight:500;transition:color .3s;position:relative}.nav-links a:after{content:"";background:var(--accent);width:0;height:2px;transition:width .35s var(--ease);position:absolute;bottom:-5px;left:0}.nav-links a:hover{color:var(--ink)}.nav-links a:hover:after{width:100%}.nav-right{align-items:center;gap:18px;display:flex}.lang-toggle{border:1.5px solid var(--line-strong);font-family:var(--font-mono);border-radius:100px;align-items:center;font-size:12px;display:flex;overflow:hidden}.lang-toggle button{color:var(--ink-3);letter-spacing:.08em;padding:7px 12px;transition:color .25s}.lang-toggle button.active{background:var(--ink);color:#fff}.nav-burger{flex-direction:column;gap:5px;width:30px;display:none}.nav-burger span{background:var(--ink);border-radius:2px;height:2px;transition:all .3s}.hero{padding-top:132px;padding-bottom:40px;position:relative;overflow:hidden}.hero-grid{grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(24px,5vw,70px);min-height:calc(100vh - 220px);display:grid}.hero-hi{font-family:var(--font-mono);letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);margin-bottom:18px;font-size:14px}.hero-hi .wave{display:inline-block}.hero-title{font-family:var(--font-display);letter-spacing:-.035em;font-size:clamp(52px,9vw,120px);font-weight:700;line-height:.95}.hero-title .mark-block{margin-top:-.08em;display:block}.hero-role-row{flex-wrap:wrap;align-items:center;gap:18px;margin:26px 0 22px;display:flex}.hero-role{font-family:var(--font-display);letter-spacing:-.01em;font-size:clamp(17px,2.2vw,24px);font-weight:500}.hero-role-row .ln{background:var(--ink);flex:0 0 46px;height:1.5px}.hero-desc{color:var(--ink-2);max-width:46ch;margin-bottom:30px;font-size:clamp(16px,1.6vw,18.5px)}.hero-checks{flex-direction:column;gap:11px;margin-bottom:34px;list-style:none;display:flex}.hero-checks li{align-items:center;gap:12px;font-size:15.5px;font-weight:500;display:flex}.hero-checks .tick{background:var(--accent);border-radius:50%;flex:none;place-items:center;width:22px;height:22px;display:grid}.hero-checks .tick svg{width:12px;height:12px}.hero-actions{flex-wrap:wrap;align-items:center;gap:18px;display:flex}.hero-visual{justify-content:center;align-self:stretch;align-items:center;display:flex;position:relative}.hero-photo-wrap{aspect-ratio:1776/2487;width:min(100%,440px);max-height:70vh;position:relative}.hero-blob{background:var(--accent);z-index:0;border-radius:46% 54% 50% 50%/58% 52% 48% 42%;position:absolute;inset:-6% -8%}.hero-photo{z-index:2;object-fit:cover;object-position:50% 18%;border-radius:220px 220px 28px 28px;width:100%;height:100%;position:relative;box-shadow:0 30px 70px -28px #00000073}.hero-badge{z-index:3;background:var(--black);color:#fff;text-align:center;width:116px;height:116px;font-family:var(--font-display);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;padding:12px;font-size:12px;font-weight:600;line-height:1.15;display:flex;position:absolute;bottom:12%;left:-6%;box-shadow:0 18px 40px -16px #00000080}.hero-badge .yr{color:var(--accent);margin-bottom:2px;font-size:24px;line-height:1;display:block}.hero-float{z-index:3;font-family:var(--font-mono);background:var(--surface);border:1px solid var(--line);border-radius:100px;align-items:center;gap:8px;padding:8px 14px;font-size:11px;display:flex;position:absolute;box-shadow:0 10px 26px -14px #0006}.hero-float .dotg{background:#18a558;border-radius:50%;width:8px;height:8px}.hero-float.f1{top:6%;right:-4%}.hero-scrollcue{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);flex-direction:column;align-items:center;gap:8px;font-size:10.5px;display:flex;position:absolute;bottom:18px;left:50%;transform:translate(-50%)}.hero-scrollcue .bar{background:var(--line-strong);width:1.5px;height:38px;position:relative;overflow:hidden}.hero-scrollcue .bar:after{content:"";background:var(--ink);width:100%;height:40%;animation:cue 1.8s var(--ease-soft) infinite;position:absolute;top:0;left:0}@keyframes cue{0%{transform:translateY(-100%)}to{transform:translateY(250%)}}.marquee{background:var(--black);color:#fff;white-space:nowrap;padding:20px 0;overflow:hidden}.marquee-track{gap:0;animation:32s linear infinite marq;display:inline-flex}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-item{font-family:var(--font-display);letter-spacing:.02em;align-items:center;gap:30px;padding:0 30px;font-size:clamp(18px,2.4vw,30px);font-weight:600;display:inline-flex}.marquee-item .star{color:var(--accent);font-size:.7em}@keyframes marq{0%{transform:translate(0)}to{transform:translate(-50%)}}.section{padding:clamp(80px,12vh,150px) 0;position:relative}.section.alt{background:var(--bg-2)}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:56px;display:flex}.section-head .lead{max-width:42ch;color:var(--ink-2);font-size:16.5px}.about{position:relative;overflow:hidden}.about-bg{pointer-events:none;z-index:0;opacity:.5;flex-direction:column;justify-content:center;display:flex;position:absolute;inset:0}.about-bg span{font-family:var(--font-display);letter-spacing:-.03em;color:#0000;-webkit-text-stroke:1.5px #15140f1a;white-space:nowrap;font-size:clamp(70px,16vw,250px);font-weight:700;line-height:.82}.about-bg span.fill{color:#e8b40024;-webkit-text-stroke:0}.about-inner{z-index:1;grid-template-columns:1fr 1fr;align-items:center;gap:clamp(30px,6vw,90px);display:grid;position:relative}.about-intro{font-family:var(--font-display);letter-spacing:-.02em;margin-bottom:26px;font-size:clamp(24px,3.2vw,40px);font-weight:500;line-height:1.18}.about-intro .hl{color:var(--accent-deep)}.about-p{color:var(--ink-2);max-width:50ch;margin-bottom:18px;font-size:17px}.about-right{flex-direction:column;justify-content:center;display:flex}.hproj{background:var(--black);color:#fff;position:relative}.hproj-intro{padding:clamp(70px,11vh,120px) 0 clamp(40px,6vh,70px)}.hproj-intro .eyebrow{color:#fff9}.hproj-intro .eyebrow:before{background:var(--accent)}.hproj-intro .section-title{color:#fff}.hproj-intro .lead{color:#fff9}.hproj-carousel{padding:clamp(40px,6vh,70px) 0 clamp(60px,8vh,100px);position:relative}.hproj-carousel-inner{align-items:center;gap:clamp(16px,2vw,30px);padding:0 clamp(28px,6vw,90px);display:flex}.hproj-nav{color:#fff;cursor:pointer;width:56px;height:56px;transition:all .3s var(--ease);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff0d;border:2px solid #ffffff40;border-radius:50%;flex-shrink:0;place-items:center;display:grid}.hproj-nav:hover:not(.disabled){background:var(--accent);border-color:var(--accent);color:var(--ink);transform:scale(1.08)}.hproj-nav.disabled{opacity:.3;cursor:not-allowed}.hproj-nav svg{width:24px;height:24px}.hproj-slide-container{flex:1;min-height:520px;position:relative;overflow:hidden}.hproj-panel{opacity:0;pointer-events:none;grid-template-columns:1.02fr .98fr;align-items:center;gap:clamp(28px,4vw,70px);transition:all .6s cubic-bezier(.4,0,.2,1);display:grid;position:absolute;inset:0;transform:translate(100px)}.hproj-panel.active{opacity:1;pointer-events:auto;transform:translate(0)}.hproj-panel.prev{opacity:0;transform:translate(-100px)}.hproj-panel.next{opacity:0;transform:translate(100px)}.hproj-ghostnum{font-family:var(--font-display);color:#ffffff09;z-index:0;pointer-events:none;letter-spacing:-.04em;font-size:clamp(200px,40vh,400px);font-weight:700;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.hproj-media{z-index:1;aspect-ratio:4/3;cursor:pointer;width:100%;transition:transform .55s var(--ease), box-shadow .55s var(--ease);border-radius:18px;position:relative;overflow:hidden}.hproj-media:hover{transform:translateY(-6px)scale(1.01);box-shadow:0 20px 60px -20px #00000080}.hproj-info{z-index:1;position:relative}.hproj-idx{font-family:var(--font-mono);letter-spacing:.12em;color:var(--accent);margin-bottom:16px;font-size:13px}.hproj-name{font-family:var(--font-display);letter-spacing:-.03em;margin-bottom:10px;font-size:clamp(38px,5.2vw,76px);font-weight:700;line-height:.95}.hproj-tagline{color:#ffffffb3;max-width:42ch;margin-bottom:22px;font-size:clamp(16px,1.7vw,20px)}.hproj-period{font-family:var(--font-mono);letter-spacing:.06em;color:#ffffff73;align-items:center;gap:8px;margin-bottom:24px;font-size:12px;display:inline-flex}.hproj-tags{flex-wrap:wrap;gap:8px;margin-bottom:30px;display:flex}.tag{font-family:var(--font-mono);letter-spacing:.04em;color:#ffffffd9;border:1px solid #ffffff38;border-radius:100px;padding:6px 13px;font-size:11.5px}.tag.solid{background:var(--accent);color:var(--ink);border-color:var(--accent)}.hproj-progress{align-items:center;gap:18px;max-width:400px;margin:30px auto 0;padding:0 clamp(28px,6vw,90px);display:flex}.hproj-progress .count{font-family:var(--font-mono);color:#fff9;white-space:nowrap;font-size:13px}.hproj-progress .count b{color:#fff}.hproj-bar{background:#ffffff29;border-radius:2px;flex:1;height:2px;position:relative;overflow:hidden}.hproj-bar i{background:var(--accent);height:100%;transition:width .4s var(--ease);position:absolute;top:0;left:0}.hproj-dots{justify-content:center;gap:10px;margin-top:24px;display:flex}.hproj-dot{cursor:pointer;width:10px;height:10px;transition:all .3s var(--ease);background:#ffffff40;border:none;border-radius:50%;padding:0}.hproj-dot:hover{background:#ffffff80;transform:scale(1.2)}.hproj-dot.active{background:var(--accent);transform:scale(1.3)}.ph{text-align:center;background:#1d1c18 repeating-linear-gradient(135deg,#ffffff0d 0 12px,#ffffff05 12px 24px);flex-direction:column;justify-content:center;align-items:center;gap:14px;display:flex;position:absolute;inset:0}.ph .ph-label{font-family:var(--font-mono);letter-spacing:.06em;color:#ffffff8c;padding:0 20px;font-size:12px}.ph .ph-play{background:var(--accent);width:64px;height:64px;color:var(--ink);border-radius:50%;place-items:center;display:grid;box-shadow:0 14px 36px -10px #e8b40099}.ph .ph-play svg{width:24px;height:24px;margin-left:3px}.ph .ph-kind{font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--accent);font-size:10.5px}.ph.light{background-color:#e9e5da;background-image:repeating-linear-gradient(135deg,#0000000d 0 12px,#00000005 12px 24px)}.ph.light .ph-label{color:var(--ink-2)}.xp-list{flex-direction:column;display:flex}.xp-row{border-top:1px solid var(--line);grid-template-columns:auto 1fr auto;align-items:start;gap:clamp(20px,4vw,60px);padding:36px 0;transition:background .4s;display:grid}.xp-list .xp-row:last-child{border-bottom:1px solid var(--line)}.xp-logo{background:var(--black);color:#fff;width:60px;height:60px;font-family:var(--font-display);border-radius:14px;place-items:center;font-size:22px;font-weight:700;display:grid}.xp-role{font-family:var(--font-display);letter-spacing:-.01em;font-size:clamp(22px,2.6vw,30px);font-weight:600}.xp-co{color:var(--ink-2);margin-bottom:16px;font-size:15px;font-weight:500}.xp-co .at{color:var(--accent-deep)}.xp-desc{flex-direction:column;gap:9px;max-width:70ch;list-style:none;display:flex}.xp-desc li{color:var(--ink-2);padding-left:20px;font-size:15px;position:relative}.xp-desc li:before{content:"";background:var(--accent);border-radius:2px;width:7px;height:7px;position:absolute;top:9px;left:0}.xp-tags{flex-wrap:wrap;gap:7px;margin-top:16px;display:flex}.xp-tags .t{font-family:var(--font-mono);border:1px solid var(--line-strong);color:var(--ink-2);border-radius:100px;padding:5px 11px;font-size:11px}.xp-period{font-family:var(--font-mono);color:var(--ink-2);white-space:nowrap;text-align:right;font-size:12.5px}.skills-grid{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.skill-card{background:var(--surface);border:1px solid var(--line);transition:transform .45s var(--ease), box-shadow .45s;border-radius:18px;padding:28px}.skill-card:hover{transform:translateY(-5px);box-shadow:0 22px 50px -28px #00000059}.skill-card h3{font-family:var(--font-display);align-items:center;gap:10px;margin-bottom:18px;font-size:16px;font-weight:600;display:flex}.skill-card h3 .n{font-family:var(--font-mono);color:var(--accent-deep);font-size:12px}.skill-chips{flex-wrap:wrap;gap:8px;display:flex}.chip{font-family:var(--font-mono);background:var(--bg-2);color:var(--ink);border-radius:100px;padding:7px 13px;font-size:12px}.skill-card:hover .chip{background:var(--bg)}.langs{flex-wrap:wrap;align-items:center;gap:20px;margin-top:40px;display:flex}.langs .lab{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);font-size:12px}.langs .lang-badge{align-items:center;gap:9px;font-size:15px;font-weight:600;display:inline-flex}.langs .lang-badge .d{background:var(--accent);border-radius:50%;width:9px;height:9px}.edu-grid{grid-template-columns:1fr 1fr;align-items:start;gap:clamp(40px,6vw,80px);display:grid}.edu-time{padding-left:30px;position:relative}.edu-time:before{content:"";background:var(--line);width:2px;position:absolute;top:6px;bottom:6px;left:6px}.edu-photo-wrap{position:sticky;top:120px}.edu-photo-frame{transition:transform .5s var(--ease), box-shadow .5s;border-radius:20px;position:relative;overflow:hidden;transform:rotate(2deg);box-shadow:0 30px 60px -20px #00000040}.edu-photo-frame:hover{transform:rotate(0)scale(1.02);box-shadow:0 40px 80px -20px #0000004d}.edu-photo-frame:before{content:"";z-index:1;pointer-events:none;background:linear-gradient(135deg,#e8b40026 0%,#0000 60%);position:absolute;inset:0}.edu-photo{width:100%;display:block}.edu-photo-caption{font-family:var(--font-mono);color:var(--ink-2);letter-spacing:.02em;margin-top:18px;font-size:13px}.edu-item{padding:0 0 38px 40px;position:relative}.edu-item:last-child{padding-bottom:0}.edu-item:before{content:"";background:var(--bg);border:3px solid var(--accent);border-radius:50%;width:16px;height:16px;position:absolute;top:4px;left:-29px}.edu-period{font-family:var(--font-mono);color:var(--accent-deep);letter-spacing:.04em;font-size:12px}.edu-item h3{font-family:var(--font-display);letter-spacing:-.01em;margin:6px 0 2px;font-size:clamp(19px,2.2vw,24px);font-weight:600}.edu-item h4{color:var(--ink-2);margin-bottom:10px;font-size:14.5px;font-weight:500}.edu-item p{color:var(--ink-2);max-width:60ch;font-size:15px}.certs{text-align:center;margin-top:54px}.certs .lab{font-family:var(--font-mono);letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);margin-bottom:24px;font-size:12px;display:block}.cert-card{max-width:700px;transition:transform .4s var(--ease);align-items:center;gap:36px;margin:0 auto;display:flex}.cert-card:hover{transform:translateY(-4px)}.cert-badge-img{flex-shrink:0;width:160px;height:160px}.cert-info{text-align:left;flex-direction:column;gap:8px;display:flex}.cert-name{font-family:var(--font-display);color:var(--ink);font-size:clamp(32px,4.5vw,52px);font-weight:700;line-height:1.1}.cert-issuer{color:var(--ink-2);font-size:18px}.cert-link{font-family:var(--font-mono);letter-spacing:.04em;color:var(--accent-deep);transition:gap .3s var(--ease);align-items:center;gap:8px;margin-top:10px;font-size:14px;font-weight:600;display:inline-flex}.cert-card:hover .cert-link{gap:12px}.lightbox{z-index:10000;cursor:zoom-out;background:#000000f2;justify-content:center;align-items:center;padding:40px;animation:.3s lightboxFadeIn;display:flex;position:fixed;inset:0}@keyframes lightboxFadeIn{0%{opacity:0}to{opacity:1}}.lightbox img{object-fit:contain;cursor:default;border-radius:12px;max-width:100%;max-height:100%;animation:.3s cubic-bezier(.34,1.56,.64,1) lightboxZoomIn;box-shadow:0 30px 80px -20px #000c}@keyframes lightboxZoomIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.lightbox-close{color:#fff;cursor:pointer;width:48px;height:48px;transition:all .3s var(--ease);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1a;border:2px solid #ffffff4d;border-radius:50%;place-items:center;display:grid;position:absolute;top:24px;right:24px}.lightbox-close:hover{background:var(--accent);border-color:var(--accent);color:var(--ink);transform:scale(1.1)}.contact{background:var(--black);color:#fff}.contact-grid{grid-template-columns:1.2fr .8fr;align-items:center;gap:clamp(36px,6vw,90px);display:grid}.contact h2{font-family:var(--font-display);letter-spacing:-.03em;font-size:clamp(44px,7.5vw,104px);font-weight:700;line-height:.92}.contact h2 .y{color:var(--accent)}.contact .lead{color:#ffffffa6;max-width:44ch;margin:26px 0 36px;font-size:18px}.contact-list{flex-direction:column;gap:4px;display:flex}.contact-link{font-family:var(--font-display);transition:padding .4s var(--ease), color .3s;border-top:1px solid #ffffff24;justify-content:space-between;align-items:center;gap:16px;padding:20px 0;font-size:clamp(18px,2.4vw,26px);font-weight:500;display:flex}.contact-list .contact-link:last-child{border-bottom:1px solid #ffffff24}.contact-link:hover{color:var(--accent);padding-left:14px}.contact-link .k{font-family:var(--font-mono);letter-spacing:.1em;color:#ffffff73;text-transform:uppercase;font-size:12px}.contact-link .v{align-items:center;gap:14px;display:flex}.footer{background:var(--black);color:#ffffff8c;border-top:1px solid #ffffff1a;padding:40px 0}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;font-size:13.5px;display:flex}.footer .logo{color:#fff;font-size:18px}.footer-socials{font-family:var(--font-mono);letter-spacing:.06em;gap:22px;font-size:12px;display:flex}.footer-socials a:hover{color:var(--accent)}.modal-ov{z-index:200;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);opacity:0;animation:ovin .35s var(--ease) forwards;background:#0a09078c;justify-content:center;align-items:flex-start;padding:clamp(16px,5vh,60px) 18px;display:flex;position:fixed;inset:0;overflow-y:auto}@keyframes ovin{to{opacity:1}}.modal{background:var(--surface);opacity:0;width:min(960px,100%);animation:modin .5s 50ms var(--ease) forwards;border-radius:22px;position:relative;overflow:hidden;transform:translateY(24px)scale(.98);box-shadow:0 40px 100px -30px #0009}@keyframes modin{to{opacity:1;transform:none}}.modal-media{aspect-ratio:16/9;background:#1d1c18;width:100%;position:relative}.modal-close{z-index:5;color:#fff;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);width:42px;height:42px;transition:background .25s, transform .3s var(--ease);background:#141310b3;border-radius:50%;place-items:center;display:grid;position:absolute;top:16px;right:16px}.modal-close:hover{background:var(--accent);color:var(--ink);transform:rotate(90deg)}.modal-body{padding:clamp(26px,4vw,46px)}.modal-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:18px;margin-bottom:8px;display:flex}.modal-kicker{font-family:var(--font-mono);letter-spacing:.12em;color:var(--accent-deep);text-transform:uppercase;font-size:12px}.modal h2{font-family:var(--font-display);letter-spacing:-.025em;margin:8px 0 6px;font-size:clamp(30px,4.5vw,52px);font-weight:700;line-height:.98}.modal .modal-period{font-family:var(--font-mono);color:var(--ink-2);font-size:12.5px}.modal-role{background:var(--accent);color:var(--ink);white-space:nowrap;border-radius:100px;align-items:center;gap:8px;padding:8px 15px;font-size:13px;font-weight:600;display:inline-flex}.modal-lead{color:var(--ink);max-width:64ch;margin:22px 0 28px;font-size:17.5px;line-height:1.55}.modal-section-label{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);align-items:center;gap:10px;margin-bottom:14px;font-size:12px;display:flex}.modal-section-label:before{content:"";background:var(--ink);width:18px;height:1px}.modal-hl{gap:12px;margin-bottom:30px;list-style:none;display:grid}.modal-hl li{color:var(--ink);gap:13px;font-size:15.5px;display:flex}.modal-hl li .b{background:var(--accent);width:20px;height:20px;color:var(--ink);font-family:var(--font-mono);border-radius:6px;flex:none;place-items:center;margin-top:1px;font-size:11px;font-weight:700;display:grid}.modal-gallery{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:30px;display:grid}.modal-gallery .gph{aspect-ratio:4/3;border-radius:12px;position:relative;overflow:hidden}.modal-gallery .gph.has-image{cursor:zoom-in;transition:transform .3s var(--ease), box-shadow .3s var(--ease)}.modal-gallery .gph.has-image:hover{transform:scale(1.03);box-shadow:0 10px 30px -10px #0000004d}.modal-gallery .gph.has-image.is-video{cursor:default}.modal-gallery .gph.has-image.is-video:hover{transform:none}.modal-gallery .gph.has-image img{object-fit:cover;border-radius:inherit;width:100%;height:100%}.project-media{border-radius:inherit;width:100%;height:100%;position:relative;overflow:hidden}.project-media img,.project-media video{display:block}.media-play-overlay{cursor:pointer;background:#0000004d;place-items:center;transition:background .2s;display:grid;position:absolute;inset:0}.media-play-overlay:hover{background:#0006}.modal-tags{flex-wrap:wrap;gap:8px;margin-bottom:30px;display:flex}.modal-tags .tag{border-color:var(--line-strong);color:var(--ink-2)}.modal-actions{flex-wrap:wrap;gap:14px;display:flex}.reveal{opacity:0;transition:opacity .9s var(--ease), transform .9s var(--ease);transform:translateY(30px)}.reveal.in{opacity:1;transform:none}.reveal.d1{transition-delay:80ms}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}.reveal-x{opacity:0;transition:opacity .9s var(--ease), transform .9s var(--ease);transform:translate(-40px)}.reveal-x.in{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){.reveal,.reveal-x{opacity:1!important;transform:none!important}.marquee-track{animation:none}.hproj-panel{transition:none}}@media (width<=980px){.nav-links{display:none}.nav-burger{display:flex}.hero-grid{grid-template-columns:1fr;gap:40px;min-height:0}.hero-visual{order:-1}.hero-photo-wrap{width:min(78%,360px);margin:0 auto}.hero-scrollcue{display:none}.about-inner{grid-template-columns:1fr}.skills-grid{grid-template-columns:1fr 1fr}.contact-grid,.edu-grid{grid-template-columns:1fr}.edu-photo-wrap{max-width:400px;margin-top:40px;position:static}.edu-photo-frame{transform:rotate(1deg)}.hproj-carousel-inner{padding:0 clamp(20px,5vw,40px);position:relative}.hproj-slide-container{min-height:auto;position:relative;overflow:visible}.hproj-panel{opacity:1;pointer-events:auto;flex-direction:column;gap:20px;display:flex;position:relative;inset:auto;transform:none}.hproj-panel.prev,.hproj-panel.next{display:none}.hproj-media{aspect-ratio:4/3;border-radius:18px;width:100%;position:relative;overflow:hidden}.hproj-info{flex-direction:column;gap:8px;display:flex}.hproj-name{font-size:clamp(28px,8vw,42px)}.hproj-tagline{margin-bottom:12px;font-size:15px}.hproj-tags{gap:6px;margin-bottom:20px}.hproj-ghostnum{display:none}.hproj-nav{z-index:10;background:var(--accent);width:48px;height:48px;color:var(--ink);-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;border-radius:50%;place-items:center;display:grid;position:absolute;top:90px;box-shadow:0 4px 14px #00000040}.hproj-nav.disabled{color:#fff6;background:#ffffff26}.hproj-nav-prev{left:10px}.hproj-nav-next{right:10px}.hproj-nav svg{width:24px;height:24px}.hproj-dots{margin-top:30px}.section-head{flex-direction:column;align-items:flex-start}}@media (width<=560px){.skills-grid{grid-template-columns:1fr}.xp-row{grid-template-columns:1fr;gap:14px}.xp-period{text-align:left}.modal-gallery{grid-template-columns:1fr}.hero-badge{width:92px;height:92px;font-size:11px}.hproj-nav{width:40px;height:40px;top:70px}.hproj-nav-prev{left:4px}.hproj-nav-next{right:4px}.hproj-name{font-size:26px}}.mobile-menu{z-index:90;background:var(--bg);transition:transform .5s var(--ease);flex-direction:column;justify-content:center;gap:8px;padding:40px;display:flex;position:fixed;inset:0;transform:translateY(-100%)}.mobile-menu.open{transform:none}.mobile-menu a{font-family:var(--font-display);padding:8px 0;font-size:34px;font-weight:600}.mobile-menu a .mn{font-family:var(--font-mono);color:var(--accent-deep);margin-right:12px;font-size:13px}.mm-close{font-family:var(--font-mono);font-size:14px;position:absolute;top:24px;right:24px}.mobile-lang{gap:16px;margin-top:30px;display:flex}.mobile-lang button{font-family:var(--font-mono);border:1.5px solid var(--line-strong);border-radius:100px;padding:10px 20px;font-size:16px}.mobile-lang button.active{background:var(--ink);color:#fff;border-color:var(--ink)}
