@font-face{font-family:Cinzel Variable;font-style:normal;font-display:swap;font-weight:400 900;src:url(/assets/cinzel-latin-ext-wght-normal-CG36JvV6.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Cinzel Variable;font-style:normal;font-display:swap;font-weight:400 900;src:url(/assets/cinzel-latin-wght-normal-DMUuCU8H.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Grotesk Variable;font-style:normal;font-display:swap;font-weight:300 700;src:url(/assets/space-grotesk-vietnamese-wght-normal-D0rl6rjA.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Grotesk Variable;font-style:normal;font-display:swap;font-weight:300 700;src:url(/assets/space-grotesk-latin-ext-wght-normal-D9tNdqV9.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Grotesk Variable;font-style:normal;font-display:swap;font-weight:300 700;src:url(/assets/space-grotesk-latin-wght-normal-BhU9QXUp.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-mono-vietnamese-400-normal-BNOj0Qhp.woff2)format("woff2"),url(/assets/space-mono-vietnamese-400-normal-B0PMp_xB.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-mono-latin-ext-400-normal-DTLbW2xa.woff2)format("woff2"),url(/assets/space-mono-latin-ext-400-normal-D4cJI_B-.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Mono;font-style:normal;font-display:swap;font-weight:400;src:url(/assets/space-mono-latin-400-normal-Rg4St2Dn.woff2)format("woff2"),url(/assets/space-mono-latin-400-normal-_3DlpgIW.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Space Mono;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-mono-vietnamese-700-normal-DWQgDHuA.woff2)format("woff2"),url(/assets/space-mono-vietnamese-700-normal-D-KrLuLr.woff)format("woff");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Space Mono;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-mono-latin-ext-700-normal-B2s3bDs2.woff2)format("woff2"),url(/assets/space-mono-latin-ext-700-normal-B_E7P90g.woff)format("woff");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Space Mono;font-style:normal;font-display:swap;font-weight:700;src:url(/assets/space-mono-latin-700-normal-mWgeinG7.woff2)format("woff2"),url(/assets/space-mono-latin-700-normal-D7A851RN.woff)format("woff");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}html:has(.portfolio){--void:#06060c;--void-2:#0a0a14;--bg:#0b0c16;--panel:#171828b3;--panel-2:#202134cc;--line:#bab2e624;--line-soft:#bab2e614;--cream:#ece3cb;--cream-dim:#c8bd9d;--gold:#d8c290;--text:#c5c6d6;--text-dim:#9a9cb0;--text-faint:#5b5d72;--violet:#b277ff;--violet-2:#8a5cff;--violet-deep:#5a36b8;--aqua:#6fd6ff;--display:"Cinzel Variable", "Times New Roman", serif;--sans:"Space Grotesk Variable", system-ui, sans-serif;--mono:"Space Mono", "SFMono-Regular", monospace;--ease:cubic-bezier(.22, 1, .36, 1);--slow:cubic-bezier(.7, 0, .2, 1);--maxw:1320px;background:var(--void)}html:has(.portfolio) body{background:var(--void)}.portfolio{z-index:0;font-family:var(--sans);color:var(--text);background:var(--void);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;min-height:100vh;position:relative;overflow-x:hidden}.portfolio .stars-canvas{z-index:0;pointer-events:none;position:fixed;inset:0}.portfolio .cosmic-veil{z-index:0;pointer-events:none;background:radial-gradient(120% 90% at 50% -10%, #7850c833, transparent 55%), radial-gradient(90% 70% at 85% 110%, #506ec81f, transparent 60%), linear-gradient(180deg, var(--void) 0%, var(--bg) 40%, var(--void-2) 100%);position:fixed;inset:0}.portfolio .grain{z-index:1;pointer-events:none;opacity:.045;mix-blend-mode:screen;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");position:fixed;inset:0}.portfolio .portfolio-content{z-index:2;position:relative}.portfolio ::selection{color:#fff;background:#b277ff52}html:has(.portfolio) ::-webkit-scrollbar{width:10px}html:has(.portfolio) ::-webkit-scrollbar-track{background:var(--void)}html:has(.portfolio) ::-webkit-scrollbar-thumb{background:#b277ff40;border-radius:10px}html:has(.portfolio) ::-webkit-scrollbar-thumb:hover{background:#b277ff73}.portfolio .kicker{font-family:var(--mono);letter-spacing:.42em;text-transform:uppercase;color:var(--violet);font-size:.72rem}.portfolio .mono{font-family:var(--mono)}.portfolio .display{font-family:var(--display);color:var(--cream);line-height:.96}.portfolio .eyebrow-line{font-family:var(--mono);letter-spacing:.3em;text-transform:uppercase;color:var(--text-dim);align-items:center;gap:.85rem;font-size:.7rem;display:inline-flex}.portfolio .eyebrow-line:before{content:"";background:linear-gradient(90deg, transparent, var(--violet));width:38px;height:1px}.portfolio .shell{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.5rem,5vw,5rem)}.portfolio .page{padding:7rem 0 4rem}.portfolio .section-home{display:block}.portfolio .page-head{margin-bottom:4rem}.portfolio .page-index{font-family:var(--mono);letter-spacing:.3em;color:var(--text-faint);text-transform:uppercase;font-size:.72rem}.portfolio .page-title{font-family:var(--display);color:var(--cream);letter-spacing:.01em;margin:.6rem 0 0;font-size:clamp(2.8rem,8vw,6.5rem);font-weight:600;line-height:.95}.portfolio .page-sub{color:var(--text-dim);max-width:46ch;margin-top:1.4rem;font-size:1.02rem;line-height:1.7}.portfolio .nav{z-index:60;transition:background .5s var(--ease), backdrop-filter .5s var(--ease), padding .4s var(--ease), border-color .5s;border-bottom:1px solid #0000;justify-content:space-between;align-items:center;padding:1.4rem clamp(1.5rem,5vw,5rem);display:flex;position:fixed;top:0;left:0;right:0}.portfolio .nav.scrolled{-webkit-backdrop-filter:blur(18px)saturate(140%);backdrop-filter:blur(18px)saturate(140%);border-bottom:1px solid var(--line-soft);background:#08080eb8;padding-top:1rem;padding-bottom:1rem}.portfolio .brand{cursor:pointer;background:0 0;border:0;align-items:center;gap:.8rem;display:flex}.portfolio .brand-mark{width:38px;height:38px;box-shadow:0 0 0 1px var(--line), 0 8px 30px #7846dc59;transition:transform .5s var(--ease), box-shadow .5s;border-radius:9px;flex-shrink:0;overflow:hidden}.portfolio .brand:hover .brand-mark{transform:translateY(-2px)rotate(-4deg);box-shadow:0 0 0 1px #b277ff80,0 10px 36px #8c5aff80}.portfolio .brand-mark img{width:100%;height:100%;display:block}.portfolio .brand-name{font-family:var(--mono);letter-spacing:.28em;color:var(--text);text-transform:uppercase;text-align:left;font-size:.72rem;line-height:1.3}.portfolio .brand-name b{color:var(--cream);font-weight:700}.portfolio .brand-name span{color:var(--text-faint);letter-spacing:.34em;font-size:.6rem;display:block}.portfolio .nav-links{align-items:center;gap:.3rem;display:flex}.portfolio .nav-link{cursor:pointer;font-family:var(--mono);letter-spacing:.16em;text-transform:uppercase;color:var(--text-dim);transition:color .35s var(--ease);background:0 0;border:0;border-radius:6px;padding:.55rem .95rem;font-size:.74rem;position:relative}.portfolio .nav-link:hover{color:var(--cream)}.portfolio .nav-link .dot{opacity:0;color:var(--violet);margin-right:.4rem;transition:opacity .35s}.portfolio .nav-link.active{color:var(--cream)}.portfolio .nav-link.active .dot{opacity:1}.portfolio .nav-link.active:after{content:"";background:linear-gradient(90deg, var(--violet), transparent);height:1px;position:absolute;bottom:.3rem;left:.95rem;right:.95rem}.portfolio .nav-cta{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--cream);border:1px solid var(--line);background:var(--panel);cursor:pointer;transition:all .4s var(--ease);border-radius:100px;padding:.6rem 1.2rem;font-size:.72rem}.portfolio .nav-cta:hover{background:#b277ff1f;border-color:#b277ff99;box-shadow:0 0 30px #b277ff40}.portfolio .nav-toggle{border:1px solid var(--line);color:var(--cream);cursor:pointer;background:0 0;border-radius:10px;width:42px;height:42px;font-size:1.1rem;display:none}.portfolio .btn{font-family:var(--mono);letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .45s var(--ease);border:1px solid #0000;border-radius:100px;align-items:center;gap:.7rem;padding:1rem 1.7rem;font-size:.78rem;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.portfolio .btn .arr{transition:transform .45s var(--ease)}.portfolio .btn:hover .arr{transform:translate(4px)}.portfolio .btn-primary{background:var(--cream);color:#15101f;box-shadow:0 10px 40px #b277ff40}.portfolio .btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 50px #b277ff73}.portfolio .btn-ghost{color:var(--cream);border-color:var(--line);background:0 0}.portfolio .btn-ghost:hover{background:#b277ff14;border-color:#b277ff99;transform:translateY(-2px)}@keyframes pf-reveal{0%{opacity:0;transform:translateY(18px)}to{opacity:1}}@keyframes pf-fade{0%{opacity:0}to{opacity:1}}.portfolio [data-reveal]{opacity:0}.portfolio [data-reveal].in{animation:pf-reveal .7s var(--ease) forwards}.portfolio .hero-name .hero-line.in{animation-name:pf-fade}@media (prefers-reduced-motion:reduce){.portfolio [data-reveal]{opacity:1!important;animation:none!important}}.portfolio .panel{background:var(--panel);border:1px solid var(--line-soft);transition:border-color .5s var(--ease), background .5s var(--ease), transform .5s var(--ease), box-shadow .5s;border-radius:18px}.portfolio .panel:hover{border-color:var(--line);background:var(--panel-2)}.portfolio .tag{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--cream-dim);border:1px solid var(--line-soft);background:#ffffff05;border-radius:100px;padding:.35rem .7rem;font-size:.66rem;transition:all .35s}.portfolio .panel:hover .tag,.portfolio .proj:hover .tag{border-color:var(--line)}.portfolio .link-out{font-family:var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--violet);transition:gap .35s var(--ease), color .35s;align-items:center;gap:.45rem;font-size:.72rem;text-decoration:none;display:inline-flex}.portfolio .link-out:hover{color:var(--cream);gap:.75rem}.portfolio .divider{background:var(--line-soft);border:0;height:1px}.portfolio .glow-text{text-shadow:0 0 40px #b277ff66}.portfolio .hero{flex-direction:column;justify-content:center;min-height:100vh;padding-top:6rem;display:flex;position:relative;overflow:hidden}.portfolio .hero-inner{z-index:3;width:100%;position:relative}.portfolio .hero-top{margin-bottom:2.2rem}.portfolio .hero-name{flex-direction:column;display:flex}.portfolio .hero-line{letter-spacing:.02em;color:var(--cream);font-size:clamp(4rem,17vw,15rem);font-weight:700;line-height:.86}.portfolio .hero-line.glow-text{color:#0000;-webkit-text-stroke:1.5px var(--cream-dim)}@supports not (-webkit-text-stroke:1px red){.portfolio .hero-line.glow-text{color:var(--cream)}}.portfolio .hero-grid{grid-template-columns:1fr auto;align-items:end;gap:2.5rem;max-width:1000px;margin-top:2.6rem;display:grid}.portfolio .hero-summary{max-width:44ch;color:var(--text);font-size:1.08rem;line-height:1.75}.portfolio .hero-actions{flex-wrap:wrap;gap:.9rem;display:flex}.portfolio .portal{aspect-ratio:1;z-index:1;pointer-events:none;will-change:transform;width:min(46vw,640px);position:absolute;top:46%;left:64%}.portfolio .portal-ring{border:1px solid #b277ff2e;border-radius:50%;position:absolute;inset:0}.portfolio .portal-ring.r1{animation:60s linear infinite pf-spin}.portfolio .portal-ring.r2{border-style:dashed;border-color:#b496ff24;animation:90s linear infinite reverse pf-spin;inset:12%}.portfolio .portal-ring.r3{border-color:#ece7d21f;animation:45s linear infinite pf-spin;inset:26%}.portfolio .portal-core{filter:blur(6px);animation:pf-pulse 7s var(--slow) infinite;background:radial-gradient(circle,#ece1be8c,#b277ff66 38%,#5a36b82e 62%,#0000 72%);border-radius:50%;position:absolute;inset:30%}@keyframes pf-spin{to{transform:rotate(360deg)}}@keyframes pf-pulse{0%,to{opacity:.8;transform:scale(.92)}50%{opacity:1;transform:scale(1.06)}}.portfolio .hero-footer{z-index:3;border-top:1px solid var(--line-soft);flex-wrap:wrap;align-items:center;gap:2.5rem;margin-top:4.5rem;padding-top:1.6rem;display:flex;position:relative}.portfolio .hf-item{letter-spacing:.18em;color:var(--text-dim);align-items:center;gap:.5rem;font-size:.72rem;display:inline-flex}.portfolio .hf-item i{color:var(--violet);font-size:.6rem;font-style:normal}.portfolio .hf-mid{color:var(--text-faint)}.portfolio .scroll-cue{cursor:pointer;color:var(--cream);background:0 0;border:0;align-items:center;gap:.7rem;margin-left:auto;display:inline-flex}.portfolio .scroll-cue .mono{letter-spacing:.3em;font-size:.72rem}.portfolio .cue-line{background:var(--cream-dim);width:46px;height:1px;position:relative;overflow:hidden}.portfolio .cue-line:after{content:"";background:var(--violet);animation:pf-cue 2.4s var(--ease) infinite;position:absolute;inset:0;transform:translate(-100%)}@keyframes pf-cue{0%{transform:translate(-100%)}50%{transform:translate(0)}to{transform:translate(100%)}}.portfolio .marquee{z-index:3;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);background:#08081066;padding:2.2rem 0;position:relative;overflow:hidden}.portfolio .marquee-track{width:max-content;animation:38s linear infinite pf-marquee;display:flex}.portfolio .marquee-group{display:flex}.portfolio .marquee-word{color:#0000;-webkit-text-stroke:1px #c8bd9d59;white-space:nowrap;align-items:center;padding:0 1.4rem;font-size:clamp(2rem,5vw,3.4rem);display:inline-flex}.portfolio .marquee-star{color:var(--violet);-webkit-text-stroke:0;margin-left:2.2rem;font-size:1rem;font-style:normal}@keyframes pf-marquee{to{transform:translate(-50%)}}.portfolio .timeline{flex-direction:column;gap:1.4rem;display:flex}.portfolio .exp{grid-template-columns:36px 1fr;gap:1.4rem;display:grid}.portfolio .exp-rail{flex-direction:column;align-items:center;padding-top:2rem;display:flex}.portfolio .exp-node{background:var(--void);border:1px solid var(--violet);border-radius:50%;flex-shrink:0;width:13px;height:13px;box-shadow:0 0 0 4px #b277ff1a}.portfolio .exp-node.live{background:var(--violet);animation:2.4s ease-in-out infinite pf-livePulse;box-shadow:0 0 0 4px #b277ff33,0 0 24px #b277ffcc}@keyframes pf-livePulse{0%,to{box-shadow:0 0 0 4px #b277ff2e,0 0 18px #b277ff99}50%{box-shadow:0 0 0 7px #b277ff0d,0 0 30px #b277ffe6}}.portfolio .exp-line{background:linear-gradient(180deg, var(--line), transparent);flex:1;width:1px;margin-top:.6rem}.portfolio .exp-body{padding:2rem 2.2rem}.portfolio .exp-head{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1.5rem;margin-bottom:1.4rem;display:flex}.portfolio .exp-company{font-family:var(--display);color:var(--cream);align-items:center;gap:.9rem;font-size:1.85rem;font-weight:600;display:flex}.portfolio .badge-live{font-family:var(--mono);letter-spacing:.2em;color:var(--violet);border:1px solid #b277ff66;border-radius:100px;align-items:center;gap:.4rem;padding:.2rem .55rem;font-size:.6rem;display:inline-flex}.portfolio .badge-live i{background:var(--violet);width:5px;height:5px;box-shadow:0 0 8px var(--violet);border-radius:50%}.portfolio .exp-role{color:var(--text-dim);letter-spacing:.02em;margin-top:.35rem;font-size:.95rem}.portfolio .exp-meta{text-align:right;flex-direction:column;align-items:flex-end;gap:.35rem;display:flex}.portfolio .exp-meta .mono{letter-spacing:.08em;color:var(--cream-dim);font-size:.72rem}.portfolio .exp-meta .dim{color:var(--text-faint)}.portfolio .exp-list{flex-direction:column;gap:.85rem;margin:0;padding:0;list-style:none;display:flex}.portfolio .exp-list li{color:var(--text);gap:.8rem;font-size:.97rem;line-height:1.6;display:flex}.portfolio .li-mark{color:var(--violet);flex-shrink:0}.portfolio .exp-link{margin-top:1.5rem}.portfolio .skills-grid{grid-template-columns:repeat(2,1fr);gap:1.4rem;display:grid}.portfolio .skill-card{padding:2rem 2.1rem}.portfolio .skill-head{border-bottom:1px solid var(--line-soft);align-items:baseline;gap:1rem;margin-bottom:1.6rem;padding-bottom:1.2rem;display:flex}.portfolio .skill-code{letter-spacing:.2em;color:var(--violet);border:1px solid #b277ff4d;border-radius:6px;padding:.25rem .5rem;font-size:.66rem}.portfolio .skill-title{font-family:var(--display);color:var(--cream);font-size:1.55rem;font-weight:600}.portfolio .skill-items{flex-wrap:wrap;gap:.6rem;display:flex}.portfolio .skill-chip{color:var(--text);border:1px solid var(--line-soft);transition:all .35s var(--ease);cursor:default;background:#ffffff06;border-radius:10px;padding:.55rem 1rem;font-size:.9rem}.portfolio .skill-chip:hover{color:var(--cream);background:#b277ff14;border-color:#b277ff80;transform:translateY(-2px);box-shadow:0 8px 24px #b277ff26}.portfolio .proj-list{flex-direction:column;gap:1.4rem;display:flex}.portfolio .proj{grid-template-columns:56px 1fr 220px;align-items:center;gap:2rem;padding:2.4rem;display:grid}.portfolio .proj-index{color:var(--text-faint);letter-spacing:.1em;align-self:flex-start;padding-top:.4rem;font-size:.8rem}.portfolio .proj-kind{letter-spacing:.18em;color:var(--violet);text-transform:uppercase;font-size:.68rem}.portfolio .proj-title{font-family:var(--display);color:var(--cream);margin:.5rem 0 0;font-size:clamp(1.8rem,3.2vw,2.6rem);font-weight:600}.portfolio .proj-summary{color:var(--text-dim);max-width:60ch;margin:1rem 0 1.3rem;font-size:.98rem;line-height:1.7}.portfolio .proj-tags{flex-wrap:wrap;gap:.5rem;display:flex}.portfolio .proj-links{gap:1.4rem;margin-top:1.3rem;display:flex}.portfolio .proj-visual{justify-content:center;align-items:center;height:160px;display:flex;position:relative}.portfolio .proj-glyph{color:#0000;-webkit-text-stroke:1px #c8bd9d66;font-size:6rem;line-height:1}.portfolio .proj-logo{opacity:.9;filter:drop-shadow(0 0 20px #00b6f366);z-index:2;width:84px;height:auto;position:relative}.portfolio .proj-orbit{border:1px solid var(--line-soft);border-radius:50%;width:150px;height:150px;position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%)}.portfolio .proj:hover .proj-orbit{border-color:#b277ff59;animation:18s linear infinite pf-spin}.portfolio .proj:hover{transform:translateY(-3px);box-shadow:0 24px 60px #0006}.portfolio .proj:hover .proj-glyph{-webkit-text-stroke-color:#b277ffb3}.portfolio .contrib-list{border-top:1px solid var(--line-soft);flex-direction:column;display:flex}.portfolio .contrib-row{border-bottom:1px solid var(--line-soft);transition:padding .45s var(--ease), background .45s var(--ease);grid-template-columns:48px 1fr auto 28px;align-items:center;gap:1.6rem;padding:1.6rem .4rem;text-decoration:none;display:grid}.portfolio .contrib-row:hover{background:var(--panel);padding-left:1.4rem;padding-right:1.4rem}.portfolio .contrib-row-index{color:var(--text-faint);letter-spacing:.1em;font-size:.72rem}.portfolio .contrib-row-name{font-family:var(--display);color:var(--cream);font-size:clamp(1.5rem,2.6vw,2.1rem);font-weight:600}.portfolio .contrib-row-org{letter-spacing:.2em;text-transform:uppercase;color:var(--violet);font-size:.7rem}.portfolio .contrib-arrow{color:var(--text-faint);text-align:right;transition:transform .4s var(--ease), color .4s}.portfolio .contrib-row:hover .contrib-arrow{color:var(--cream);transform:translate(4px,-4px)}.portfolio .about-grid{grid-template-columns:1.25fr 1fr;align-items:center;gap:3.5rem;display:grid}.portfolio .about-lead{font-family:var(--display);color:var(--cream);font-size:clamp(1.6rem,2.8vw,2.3rem);font-weight:500;line-height:1.42}.portfolio .about-body{color:var(--text);max-width:56ch;margin-top:1.6rem;font-size:1.05rem;line-height:1.85}.portfolio .edu{padding:2.2rem}.portfolio .edu-school{font-family:var(--display);color:var(--cream);margin:1rem 0 .4rem;font-size:1.9rem;font-weight:600}.portfolio .edu-area{color:var(--text-dim);font-size:.95rem}.portfolio .edu-meta{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);letter-spacing:.06em;color:var(--cream-dim);justify-content:space-between;margin:1.2rem 0;padding:.9rem 0;font-size:.74rem;display:flex}.portfolio .edu-grade{color:var(--violet)}.portfolio .edu-list{flex-direction:column;gap:.85rem;margin-top:1.4rem;padding:0;list-style:none;display:flex}.portfolio .edu-list li{color:var(--text);gap:.7rem;font-size:.92rem;line-height:1.6;display:flex}.portfolio .contact-head{grid-template-columns:1.05fr 1fr;align-items:center;gap:3.5rem;margin-bottom:3rem;display:grid}.portfolio .contact-note{font-family:var(--display);color:var(--cream);max-width:20ch;font-size:clamp(1.6rem,2.8vw,2.3rem);font-weight:500;line-height:1.42}.portfolio .contact-grid{grid-template-columns:repeat(3,1fr);gap:1.2rem;display:grid}.portfolio .contact-card{flex-direction:column;gap:.7rem;padding:1.8rem;display:flex}.portfolio .cc-label{letter-spacing:.2em;color:var(--violet);text-transform:uppercase;font-size:.66rem}.portfolio .cc-value{color:var(--cream);word-break:break-word;font-size:1.05rem}.portfolio .cc-actions{justify-content:space-between;align-items:center;margin-top:auto;padding-top:1rem;display:flex}.portfolio .cc-copy{cursor:pointer;letter-spacing:.14em;color:var(--text-faint);font-size:.66rem;font-family:var(--mono);background:0 0;border:0;transition:color .3s}.portfolio .cc-copy:hover{color:var(--cream)}.portfolio .contact-links{flex-direction:column;display:flex}.portfolio .connect-row{border-top:1px solid var(--line-soft);transition:padding .4s var(--ease);grid-template-columns:30px 1fr auto 24px;align-items:center;gap:1.3rem;padding:1.5rem .5rem;text-decoration:none;display:grid}.portfolio .connect-row:last-child{border-bottom:1px solid var(--line-soft)}.portfolio .connect-row:hover{padding-left:1.5rem}.portfolio .connect-icon{color:var(--cream-dim);transition:color .4s var(--ease);display:inline-flex}.portfolio .connect-row:hover .connect-icon{color:var(--violet)}.portfolio .connect-name{font-family:var(--display);color:var(--cream);font-size:1.6rem}.portfolio .connect-handle{color:var(--text-dim);font-size:.85rem}.portfolio .connect-arrow{color:var(--text-faint);text-align:right;transition:transform .4s var(--ease), color .4s}.portfolio .connect-row:hover .connect-arrow{color:var(--violet);transform:translate(4px,-4px)}.portfolio .footer{z-index:3;border-top:1px solid var(--line-soft);margin-top:4rem;padding:5rem 0 2.5rem;position:relative}.portfolio .footer-top{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;display:flex}.portfolio .footer-cta{color:var(--cream);cursor:pointer;font-size:clamp(2rem,4.5vw,3.4rem);font-weight:600;line-height:1.05;transition:color .4s}.portfolio .footer-cta:hover{color:var(--violet)}.portfolio .footer-bottom{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1.5rem;display:flex}.portfolio .footer-meta{letter-spacing:.14em;color:var(--text-faint);font-size:.7rem}.portfolio .footer-links{gap:1.6rem;display:flex}@media (width<=980px){.portfolio .nav-links{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);border:1px solid var(--line);background:#08080ef2;border-radius:16px;flex-direction:column;align-items:stretch;gap:.2rem;padding:1rem;display:none;position:fixed;top:72px;left:1rem;right:1rem}.portfolio .nav-links[data-open=true]{display:flex}.portfolio .nav-toggle{display:block}.portfolio .nav-cta{display:none}.portfolio .skills-grid,.portfolio .about-grid,.portfolio .contact-head{grid-template-columns:1fr}.portfolio .about-grid{gap:2.5rem}.portfolio .contact-head{gap:2rem}.portfolio .proj{grid-template-columns:1fr;gap:1.2rem}.portfolio .proj-visual{justify-self:start;height:120px}.portfolio .proj-index{display:none}.portfolio .contact-grid,.portfolio .hero-grid{grid-template-columns:1fr}.portfolio .portal{opacity:.6;left:78%}}@media (width<=560px){.portfolio .exp{grid-template-columns:1fr}.portfolio .exp-rail{display:none}.portfolio .exp-body{padding:1.6rem}.portfolio .exp-head{flex-direction:column}.portfolio .exp-meta{text-align:left;align-items:flex-start}.portfolio .hero-footer{gap:1.2rem}.portfolio .scroll-cue{width:100%;margin-left:0}.portfolio .page{padding:4.5rem 0 2.5rem}.portfolio .page-head{margin-bottom:2.5rem}.portfolio .hero-line{font-size:clamp(2.75rem,15vw,5rem)}.portfolio .contrib-row{grid-template-columns:1fr auto;gap:.25rem 1rem;padding:1.3rem .4rem}.portfolio .contrib-row-index{display:none}.portfolio .contrib-row-name{grid-area:1/1}.portfolio .contrib-row-org{grid-area:2/1}.portfolio .contrib-arrow{grid-area:1/2/3;align-self:center}.portfolio .connect-row{grid-template-columns:30px 1fr auto;gap:.2rem .9rem}.portfolio .connect-icon{grid-area:1/1/3;align-self:center}.portfolio .connect-name{grid-area:1/2}.portfolio .connect-handle{overflow-wrap:anywhere;grid-area:2/2;font-size:.78rem}.portfolio .connect-arrow{grid-area:1/3/3;align-self:center}}
