.theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--color-text-secondary);border:1px solid var(--color-border);background:transparent;transition:all .25s ease;font-size:1.125rem;cursor:pointer}.theme-toggle:hover{color:var(--color-text-primary);border-color:var(--color-text-tertiary);background:var(--color-surface-elevated)}.nav{position:fixed;top:0;left:0;right:0;z-index:1001;transition:background-color .25s ease,box-shadow .25s ease,backdrop-filter .25s ease,-webkit-backdrop-filter .25s ease}.nav-scrolled{background-color:var(--color-bg-glass);backdrop-filter:blur(16px) saturate(1.8);-webkit-backdrop-filter:blur(16px) saturate(1.8);box-shadow:var(--shadow-nav);border-bottom:1px solid var(--color-border-subtle)}.nav-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}@media(min-width:1024px){.nav-inner{padding:0 32px}}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:60px}.nav-logo{display:flex;align-items:center;text-decoration:none;position:relative}.nav-logo img{height:28px;filter:var(--invert);opacity:.8;transition:opacity .25s ease}.nav-logo img:hover{opacity:1}.nav-menu{display:none}@media(min-width:768px){.nav-menu{display:flex;align-items:center;gap:4px}}.nav-link{font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;letter-spacing:-.02em;color:var(--color-text-secondary);padding:8px 16px;border-radius:8px;border:1px solid transparent;transition:color .15s ease,background-color .15s ease,border-color .15s ease}.nav-link:hover{color:var(--color-text-primary);background:var(--color-glass-hover);border-color:var(--color-border-subtle)}.nav-actions{display:flex;align-items:center;gap:8px;position:relative}.nav-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:var(--color-text-secondary);border:1px solid var(--color-border);font-size:1.125rem;transition:all .25s ease}.nav-icon:hover{color:var(--color-text-primary);border-color:var(--color-text-tertiary);background:var(--color-surface-elevated)}.nav-burger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:8px;border-radius:8px;border:1px solid var(--color-border);transition:all .25s ease}@media(min-width:768px){.nav-burger{display:none}}.nav-burger span{display:block;width:100%;height:2px;background:var(--color-text-secondary);border-radius:1px;transition:transform .25s ease}.nav-burger:hover{border-color:var(--color-text-tertiary)}.nav-burger-open span:first-child{transform:rotate(45deg) translate(2px,3px)}.nav-burger-open span:last-child{transform:rotate(-45deg) translate(2px,-3px)}.nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;background:var(--color-bg-glass-solid);backdrop-filter:blur(32px) saturate(1.8);-webkit-backdrop-filter:blur(32px) saturate(1.8);animation:fade-in .2s ease}.nav-overlay-link{font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;letter-spacing:-.02em;font-size:1.5rem;color:var(--color-text-secondary);padding:8px 24px;border-radius:8px;transition:color .15s ease}.nav-overlay-link:hover{color:var(--color-text-primary)}.btn{display:inline-flex;align-items:center;gap:8px;padding:16px 24px;height:40px;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.875rem;font-weight:500;line-height:1;border-radius:9999px;transition:all .25s ease;white-space:nowrap;text-decoration:none;cursor:pointer}.btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.btn-default{color:var(--color-text-primary);border:1px solid var(--color-text-tertiary);background:transparent}.btn-default:hover{border-color:var(--color-text-secondary);background:var(--color-surface-elevated)}.btn-primary{color:#fff;background:var(--gradient-accent);border:none;padding:16px 25px;height:40px}.btn-primary:hover{opacity:.9}.btn-ghost{color:var(--color-text-secondary);border:none;background:transparent;padding:8px 16px}.btn-ghost:hover{color:var(--color-text-primary);background:var(--color-surface-elevated)}.btn-icon{width:36px;height:36px;padding:0;justify-content:center;border-radius:8px;color:var(--color-text-secondary);border:1px solid var(--color-border);background:transparent}.btn-icon:hover{color:var(--color-text-primary);border-color:var(--color-text-tertiary);background:var(--color-surface-elevated)}.social-links{display:flex;gap:8px}.social-link{display:flex;align-items:center;gap:8px;padding:8px;color:var(--color-text-tertiary);border-radius:8px;font-size:1.125rem;transition:all .25s ease;text-decoration:none}.social-link:hover{color:var(--color-text-primary);background:var(--color-surface-elevated)}.social-link span{font-size:.875rem;color:var(--color-text-secondary)}.hero-blueprint{position:absolute;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:hidden;pointer-events:none}.hbp-paper{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,color-mix(in srgb,var(--color-accent) 18%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--color-accent) 18%,transparent) 1px,transparent 1px);background-size:20px 20px;opacity:.12}.hbp-paper-major{background-size:100px 100px;background-image:linear-gradient(to right,color-mix(in srgb,var(--color-accent) 35%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--color-accent) 35%,transparent) 1px,transparent 1px);opacity:.2}.hbp-spotlights{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(to right,color-mix(in srgb,var(--color-accent) 55%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--color-accent) 55%,transparent) 1px,transparent 1px),linear-gradient(to right,color-mix(in srgb,var(--color-accent) 30%,transparent) 1px,transparent 1px),linear-gradient(to bottom,color-mix(in srgb,var(--color-accent) 30%,transparent) 1px,transparent 1px);background-size:100px 100px,100px 100px,20px 20px,20px 20px;opacity:.55;-webkit-mask-image:radial-gradient(circle at 52% 40%,black 180px,transparent 380px),radial-gradient(circle at 72% 22%,black 100px,transparent 240px),radial-gradient(circle at 27% 52%,black 130px,transparent 280px),radial-gradient(circle at 8% 23%,black 150px,transparent 300px),radial-gradient(circle at 98% 44%,black 130px,transparent 260px),radial-gradient(circle at 7% 85%,black 150px,transparent 300px);mask-image:radial-gradient(circle at 52% 40%,black 180px,transparent 380px),radial-gradient(circle at 72% 22%,black 100px,transparent 240px),radial-gradient(circle at 27% 52%,black 130px,transparent 280px),radial-gradient(circle at 8% 23%,black 150px,transparent 300px),radial-gradient(circle at 98% 44%,black 130px,transparent 260px),radial-gradient(circle at 7% 85%,black 150px,transparent 300px)}.hbp-svg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;transform:translateY(25px);color:var(--color-accent);opacity:.88}.hbp-stroke{fill:none;stroke:currentColor;stroke-width:1.25;vector-effect:non-scaling-stroke}.hbp-stroke-thin{stroke-width:.75;opacity:.8}.hbp-stroke-dashed{stroke-dasharray:6 4;opacity:.55}.hbp-stroke-dash-dot{stroke-dasharray:12 3 2 3;opacity:.45}.hbp-frame{stroke-width:1;opacity:.55}.hbp-draw{stroke-dasharray:2000;stroke-dashoffset:2000;animation:hbp-draw-in 2.8s ease-out forwards}@keyframes hbp-draw-in{to{stroke-dashoffset:0}}.hbp-gear{animation:hbp-rotate 60s linear infinite}.hbp-gear:nth-of-type(2){animation-duration:30s;animation-direction:reverse}.hbp-gear:nth-of-type(3){animation-duration:45s}@keyframes hbp-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.hbp-dim-bg{fill:var(--color-bg);opacity:.9;stroke:none}.hbp-mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:11px;fill:var(--color-accent);letter-spacing:.02em}.hbp-mono-sm{font-size:9px;fill:color-mix(in srgb,var(--color-accent) 80%,var(--color-text-tertiary));opacity:.9}.hbp-anno-lead{stroke-dasharray:3 2;opacity:.55;animation:hbp-pulse 4s ease-in-out infinite}.hbp-anno-dot{fill:var(--color-accent);stroke:none}@keyframes hbp-pulse{0%,to{opacity:.35}50%{opacity:.75}}.hbp-panel-bg{fill:color-mix(in srgb,var(--color-bg) 85%,transparent);stroke:color-mix(in srgb,var(--color-accent) 55%,transparent);stroke-width:1;opacity:.98}.hbp-panel-sep{stroke:color-mix(in srgb,var(--color-accent) 30%,transparent);stroke-width:1;stroke-dasharray:3 2;vector-effect:non-scaling-stroke}.hbp-panel-hdr{font-family:JetBrains Mono,Fira Code,monospace;font-size:9px;letter-spacing:.1em;text-transform:uppercase;fill:color-mix(in srgb,var(--color-accent) 80%,var(--color-text-tertiary))}.hbp-panel-hdr-right{fill:var(--color-accent);opacity:.85}.hbp-panel-gutter{font-family:JetBrains Mono,Fira Code,monospace;font-size:10px;fill:color-mix(in srgb,var(--color-accent) 45%,var(--color-text-tertiary));opacity:.55}.hbp-panel-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:10px;fill:var(--color-text-secondary)}.hbp-panel-ftr{font-family:JetBrains Mono,Fira Code,monospace;font-size:9px;letter-spacing:.08em;fill:color-mix(in srgb,var(--color-accent) 75%,var(--color-text-tertiary));text-transform:uppercase}.hbp-tok-k{fill:var(--color-accent);font-weight:600}.hbp-tok-f{fill:color-mix(in srgb,var(--color-accent) 80%,#fff)}.hbp-tok-v{fill:var(--color-text-primary)}.hbp-tok-c{fill:color-mix(in srgb,var(--color-accent) 55%,var(--color-text-tertiary));font-style:italic}.hbp-tok-s{fill:color-mix(in srgb,var(--color-accent) 60%,#e0d5ff)}.hbp-tok-n{fill:color-mix(in srgb,var(--color-accent) 55%,#60efff)}.hbp-tok-p{fill:var(--color-text-tertiary)}.hbp-vignette{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 50% 50%,transparent 45%,color-mix(in srgb,var(--color-bg) 75%,transparent) 100%)}.hero-blueprint~.hero-tron{display:none}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:flex-end;gap:32px;position:relative;padding-top:60px;padding-bottom:96px;overflow:hidden}@media(min-width:1024px){.hero{padding-bottom:160px}}.hero-tron{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none}.hero-tron canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%}.hero-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}@media(min-width:1024px){.hero-inner{padding:0 32px}}.hero-inner{max-width:900px;position:relative;z-index:1;text-align:center;margin-bottom:auto;padding-top:32vh}@media(min-width:640px){.hero-inner{padding-top:38vh}}@media(min-width:768px){.hero-inner{padding-top:50vh}}@media(min-width:1024px){.hero-inner{padding-top:38vh}}.hero-title{font-family:Anton,sans-serif;font-size:clamp(3.5rem,12vw,8.5rem);font-weight:400;line-height:.92;letter-spacing:-.04em;color:var(--color-text-primary);margin-bottom:32px;text-transform:uppercase}.hero-title-bold:first-child{display:block}.hero-title-outline{-webkit-text-stroke:2px var(--color-accent);color:transparent;font-style:italic}.hero-subtitle{font-family:JetBrains Mono,Fira Code,monospace;font-size:1rem;line-height:1.75;letter-spacing:-.01em;color:var(--color-text-secondary);max-width:560px;margin-left:auto;margin-right:auto;margin-bottom:32px}@media(min-width:768px){.hero-subtitle{font-size:1.125rem}}.hero-actions{display:flex;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}.hero-stats{display:flex;justify-content:center;gap:48px;position:relative;z-index:1;padding:0 24px}@media(min-width:640px){.hero-stats{gap:96px}}.hero-stat{display:flex;flex-direction:column;align-items:center;gap:4px}.hero-stat-value{font-family:JetBrains Mono,Fira Code,monospace;font-size:1rem;font-weight:700;color:var(--color-text-tertiary);line-height:1}@media(min-width:640px){.hero-stat-value{font-size:1.125rem}}.hero-stat-label{font-family:JetBrains Mono,Fira Code,monospace;font-size:.65rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;opacity:.7}@media(min-width:640px){.hero-stat-label{font-size:.75rem}}.section{opacity:0;transition:opacity .7s ease}.section.revealed{opacity:1}.section-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}@media(min-width:1024px){.section-inner{padding:0 32px}}.section-header{margin-bottom:24px}@media(min-width:768px){.section-header{margin-bottom:48px}}.section-label{display:block;color:var(--color-accent);font-size:.875rem;margin-bottom:8px}.section-title{font-family:Inter,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:2.25rem;font-weight:600;line-height:1.1;letter-spacing:-.02em;text-transform:uppercase;color:var(--color-text-primary)}@media(min-width:768px){.section-title{font-size:3rem}}@media(min-width:1024px){.section-title{font-size:3.75rem}}.section-title-star{display:inline-flex;align-items:center;vertical-align:middle;color:var(--color-accent);padding:0 .15em;line-height:1;position:relative;top:-.05em}.badge{display:inline-flex;align-items:center;padding:2px 8px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;font-weight:500;letter-spacing:.02em;border-radius:4px;text-transform:uppercase}.badge-default{color:var(--color-text-secondary);border:1px solid var(--color-border)}.badge-accent{color:#fff;background:color-mix(in srgb,var(--color-accent) 75%,transparent);border:1px solid color-mix(in srgb,var(--color-accent) 75%,transparent)}.badge-tech{color:var(--color-accent-secondary);background:var(--color-accent-glow);border:1px solid var(--color-accent-secondary)}.showcase{display:grid;gap:24px;align-items:center;padding:24px 0;opacity:0;transition:opacity .7s ease}@media(min-width:768px){.showcase{gap:48px;padding:48px 0}}.showcase.revealed{opacity:1}.showcase:not(:last-child){border-bottom:1px solid var(--color-border-subtle)}@media(min-width:1024px){.showcase{grid-template-columns:3fr 2fr;gap:64px}}.showcase-reverse{background:var(--color-surface-elevated);border-radius:12px;padding:24px}@media(min-width:768px){.showcase-reverse{padding:48px}}@media(min-width:1024px){.showcase-reverse{background:none;border-radius:0;padding:48px 0;grid-template-columns:2fr 3fr}.showcase-reverse .showcase-image{order:2}.showcase-reverse .showcase-content{order:1}}.showcase-image{border-radius:12px;overflow:hidden;border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer}.showcase-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;aspect-ratio:4/3}.showcase-image:hover img{transform:scale(1.03)}.showcase-content{display:flex;flex-direction:column;gap:16px}.showcase-meta{display:flex;align-items:center;gap:8px}.showcase-year{font-size:.75rem;color:var(--color-text-tertiary)}.showcase-title{font-family:Inter,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.25rem;font-weight:600;line-height:1.25}@media(min-width:768px){.showcase-title{font-size:1.5rem}}.showcase-title{color:var(--color-text-primary)}.showcase-title a{color:inherit;text-decoration:none;transition:color .15s ease}.showcase-title a:hover{color:var(--color-accent)}.showcase-desc{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;line-height:1.75;color:var(--color-text-secondary)}.showcase-tech{display:flex;flex-wrap:wrap;gap:4px}.showcase-highlights{display:flex;flex-direction:column;gap:4px;padding-left:24px;color:var(--color-text-secondary);font-size:.875rem}.showcase-highlights li{list-style:disc}.showcase-highlights li::marker{color:var(--color-accent)}.showcase-actions{display:flex;gap:8px;margin-top:8px}.project-card{cursor:pointer;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);overflow:hidden;transition:box-shadow .25s ease,border-color .25s ease;display:flex;flex-direction:column;height:100%}.project-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card-hover)}.project-card:hover .project-card-image img{transform:scale(1.05)}.project-card-image{position:relative;overflow:hidden;aspect-ratio:16/10;background:var(--color-surface-elevated)}.project-card-image img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.project-card-category{position:absolute;top:8px;right:8px}.project-card-body{padding:16px;display:flex;flex-direction:column;gap:8px;flex:1}.project-card-head{display:flex;align-items:center;justify-content:space-between;gap:8px}.project-card-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary)}.project-card-year{font-size:.75rem;color:var(--color-text-tertiary);flex-shrink:0}.project-card-desc{font-size:.875rem;color:var(--color-text-secondary);line-height:1.75;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.project-card-tech{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto;padding-top:8px}.react-slideshow-container{display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;position:relative}.react-slideshow-container .nav{z-index:10;position:absolute;cursor:pointer}.react-slideshow-container .nav:first-of-type{left:0}.react-slideshow-container .nav:last-of-type{right:0}.react-slideshow-container .default-nav{height:30px;background:#fff9;width:30px;border:0;text-align:center;color:#fff;border-radius:50%;display:-webkit-box;display:-ms-flexbox;display:flex;-webkit-box-align:center;-ms-flex-align:center;align-items:center;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center}.react-slideshow-container .default-nav:hover,.react-slideshow-container .default-nav:focus{background:#fff;color:#666;outline:0}.react-slideshow-container .default-nav.disabled:hover{cursor:not-allowed}.react-slideshow-container .default-nav:first-of-type{margin-right:-30px;border-right:0;border-top:0}.react-slideshow-container .default-nav:last-of-type{margin-left:-30px}.react-slideshow-container+ul.indicators{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;margin-top:20px}.react-slideshow-container+ul.indicators li{display:inline-block;position:relative;width:7px;height:7px;padding:5px;margin:0}.react-slideshow-container+ul.indicators .each-slideshow-indicator{border:0;opacity:.25;cursor:pointer;background:transparent;color:transparent}.react-slideshow-container+ul.indicators .each-slideshow-indicator:before{position:absolute;top:0;left:0;width:7px;height:7px;border-radius:50%;content:"";background:#000;text-align:center}.react-slideshow-container+ul.indicators .each-slideshow-indicator:hover,.react-slideshow-container+ul.indicators .each-slideshow-indicator.active{opacity:.75;outline:0}.react-slideshow-fadezoom-wrapper{width:100%;overflow:hidden}.react-slideshow-fadezoom-wrapper .react-slideshow-fadezoom-images-wrap{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap}.react-slideshow-fadezoom-wrapper .react-slideshow-fadezoom-images-wrap>div{position:relative;opacity:0}.react-slideshow-wrapper .react-slideshow-fade-images-wrap>div[aria-hidden=true]{display:none}.react-slideshow-wrapper.slide{width:100%;overflow:hidden}.react-slideshow-wrapper .images-wrap.horizontal{display:-webkit-box;display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;width:auto}.react-slideshow-wrapper .images-wrap>div[aria-hidden=true]{display:none}.popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:10000;background:var(--overlay-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto;display:flex;align-items:flex-start;justify-content:center;padding:32px 16px;animation:fade-in .2s ease}.popup{position:relative;width:100%;max-width:960px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;overflow:hidden;box-shadow:var(--shadow-popup);margin:auto 0}.popup-close{position:absolute;top:16px;right:16px;z-index:10;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:9999px;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:1.125rem;transition:all .15s ease;cursor:pointer}.popup-close:hover{color:var(--color-text-primary);border-color:var(--color-text-tertiary)}.popup-media{position:relative;width:100%;background:var(--color-surface-elevated)}.popup-media .react-slideshow-container{position:relative}.popup-media .react-slideshow-container .nav{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:36px;height:36px;margin:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:9999px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.8}.popup-media .react-slideshow-container .nav:hover{opacity:1}.popup-media .react-slideshow-container .nav[data-type=prev]{left:16px;right:auto}.popup-media .react-slideshow-container .nav[data-type=next]{right:16px;left:auto}.popup-slide{display:flex;align-items:center;justify-content:center;background:var(--color-surface-elevated)}.popup-slide img{width:100%;max-height:450px;object-fit:contain}.popup-body{padding:32px}@media(min-width:768px){.popup-body{padding:48px}}.popup-columns{display:flex;flex-direction:column;gap:32px}@media(min-width:768px){.popup-columns{flex-direction:row;gap:48px}}.popup-left{flex:1.5;display:flex;flex-direction:column;gap:16px;min-width:0}.popup-title{font-family:Inter,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.875rem;font-weight:700;line-height:1.1;letter-spacing:-.02em}@media(min-width:768px){.popup-title{font-size:2.25rem}}.popup-title{color:var(--color-text-primary)}.popup-meta{display:flex;align-items:center;gap:8px}.popup-year{font-size:.75rem;color:var(--color-text-tertiary)}.popup-desc{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;line-height:1.75;color:var(--color-text-secondary);white-space:pre-line}.popup-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.popup-right{flex:1;display:flex;flex-direction:column;gap:24px;min-width:0}@media(min-width:768px){.popup-right{border-left:1px solid var(--color-border-subtle);padding-left:48px}}.popup-section{display:flex;flex-direction:column;gap:8px}.popup-section-label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em}.popup-tech{display:flex;flex-wrap:wrap;gap:4px}.popup-highlights{display:flex;flex-direction:column;gap:4px;padding-left:16px;font-size:.875rem;color:var(--color-text-secondary)}.popup-highlights li{list-style:disc}.popup-highlights li::marker{color:var(--color-accent)}.project-grid{display:grid;gap:24px;grid-template-columns:1fr}@media(min-width:640px){.project-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1024px){.project-grid{grid-template-columns:repeat(3,1fr)}}.skill-card{display:flex;flex-direction:column;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);text-decoration:none;color:inherit;overflow:hidden;transition:all .25s ease}.skill-card:hover{border-color:var(--color-accent);box-shadow:0 0 30px var(--color-accent-glow)}.skill-card:hover .skill-visual-code .code-line{opacity:1}.skill-card:hover .skill-visual-design .design-frame{transform:scale(1.05)}.skill-card:hover .cube{animation-play-state:running}.skill-card-body{padding:24px}.skill-card-number{font-size:.75rem;color:var(--color-text-tertiary);display:block;margin-bottom:8px}.skill-card-title{font-size:1.125rem;font-weight:600;color:var(--color-text-primary);margin-bottom:8px}.skill-card-desc{font-size:.875rem;color:var(--color-text-secondary);line-height:1.75}.skill-visual{height:180px;display:flex;align-items:center;justify-content:center;background:var(--color-surface-elevated);border-bottom:1px solid var(--color-border-subtle);overflow:hidden}.skill-visual-code{flex-direction:column;align-items:flex-start;padding:24px 32px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;gap:4px}.code-line{opacity:.5;transition:opacity .4s ease;white-space:nowrap}.code-indent{padding-left:24px}.code-kw{color:var(--color-accent)}.code-fn{color:var(--color-accent-secondary)}.skill-visual-design{padding:32px}.design-frame{width:100%;max-width:200px;display:flex;flex-direction:column;gap:6px;transition:transform .25s ease}.design-nav{height:8px;border-radius:4px;background:var(--color-border)}.design-hero{height:40px;border-radius:4px;background:var(--gradient-card-hover);border:1px solid var(--color-border)}.design-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.design-card{height:50px;border-radius:4px;border:1px solid var(--color-border);background:var(--color-surface);transition:border-color .25s ease}.skill-card:hover .design-card{border-color:var(--color-accent)}.skill-card:hover .design-card:nth-child(2){transition-delay:80ms}.skill-card:hover .design-card:nth-child(3){transition-delay:.16s}.cube-scene{width:80px;height:80px;perspective:300px}.cube{width:100%;height:100%;position:relative;transform-style:preserve-3d;animation:cube-spin 8s linear infinite;animation-play-state:paused}.cube-face{position:absolute;width:80px;height:80px;border:1px solid var(--color-accent);background:var(--color-accent-glow);opacity:.6}.cube-front{transform:translateZ(40px)}.cube-back{transform:rotateY(180deg) translateZ(40px)}.cube-right{transform:rotateY(90deg) translateZ(40px)}.cube-left{transform:rotateY(-90deg) translateZ(40px)}.cube-top{transform:rotateX(90deg) translateZ(40px)}.cube-bottom{transform:rotateX(-90deg) translateZ(40px)}@keyframes cube-spin{0%{transform:rotateX(-20deg) rotateY(0)}to{transform:rotateX(-20deg) rotateY(360deg)}}@media(max-width:767px){.code-line{opacity:1}.design-card{border-color:var(--color-accent)}.cube{animation-play-state:running}}.footer{border-top:1px solid var(--color-border);padding:48px 0 16px}.footer-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}@media(min-width:1024px){.footer-inner{padding:0 32px}}.footer-grid{display:grid;gap:32px;margin-bottom:32px}@media(min-width:768px){.footer-grid{grid-template-columns:1fr auto;align-items:start}}.footer-brand-block{display:flex;flex-direction:column;gap:8px}.footer-logo{height:28px;width:auto;align-self:flex-start;filter:var(--invert);opacity:.8}.footer-tagline{font-size:.875rem;color:var(--color-text-secondary);line-height:1.75;max-width:460px}.footer-nav-group{display:flex;gap:48px}.footer-column{min-width:120px}.footer-column-title{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.footer-links{display:flex;flex-direction:column;gap:4px}.footer-links button,.footer-links a{display:inline-flex;align-items:center;gap:4px;font-size:.875rem;color:var(--color-text-secondary);text-align:left;text-decoration:none;transition:color .15s ease}.footer-links button:hover,.footer-links a:hover{color:var(--color-text-primary)}.footer-link-icon{font-size:1rem;flex-shrink:0}.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:16px;border-top:1px solid var(--color-border-subtle)}.footer-copy{font-size:.75rem;color:var(--color-text-tertiary)}.footer-back-top{font-family:JetBrains Mono,Fira Code,monospace;font-size:.75rem;color:var(--color-text-tertiary);transition:color .15s ease}.footer-back-top:hover{color:var(--color-accent)}.skills-grid{display:grid;gap:24px;grid-template-columns:1fr}@media(min-width:768px){.skills-grid{grid-template-columns:repeat(3,1fr)}}.contact-inner{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}@media(min-width:1024px){.contact-inner{padding:0 32px}}.contact-inner{text-align:center;border-top:1px solid var(--color-border);padding-top:64px;padding-bottom:64px}@media(min-width:768px){.contact-inner{padding-top:96px;padding-bottom:96px}}.contact-label{display:block;color:var(--color-accent);font-size:.875rem;margin-bottom:8px}.contact-heading{font-family:Inter,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1.875rem;font-weight:700;line-height:1.1;letter-spacing:-.02em}@media(min-width:768px){.contact-heading{font-size:2.25rem}}.contact-heading{color:var(--color-text-primary);margin-bottom:8px}.contact-text{font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;color:var(--color-text-secondary);margin-bottom:24px}.about-layout{display:grid;gap:48px;align-items:center}@media(min-width:768px){.about-layout{grid-template-columns:2fr 1fr}}.about-text{display:flex;flex-direction:column;gap:16px}.about-text p{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;line-height:1.75;color:var(--color-text-secondary)}.about-meta{display:flex;align-items:center;gap:16px;margin-top:8px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;letter-spacing:-.02em;color:var(--color-text-secondary)}.about-divider{width:1px;height:14px;background:var(--color-border)}.about-image{border-radius:12px;overflow:hidden;border:1px solid var(--color-border)}.about-image img{width:100%;aspect-ratio:3/4;object-fit:cover}.theme-dark{--color-bg: #0a0a0a;--color-surface: #111111;--color-surface-elevated: #191919;--color-border: #222222;--color-border-subtle: #1a1a1a;--color-text-primary: #fafafa;--color-text-secondary: #888888;--color-text-tertiary: #555555;--color-accent: #7c6aef;--color-accent-secondary: #a78bfa;--color-accent-glow: rgba(124, 106, 239, .15);--gradient-accent: linear-gradient(135deg, #7c6aef, #a78bfa);--gradient-bg: radial-gradient(ellipse at 50% 0%, rgba(124, 106, 239, .18) 0%, rgba(124, 106, 239, .04) 40%, transparent 70%);--gradient-card-hover: linear-gradient(135deg, rgba(124, 106, 239, .06) 0%, transparent 100%);--shadow-card: 0 0 0 1px var(--color-border);--shadow-card-hover: 0 0 0 1px var(--color-accent), 0 8px 25px -5px rgba(0, 0, 0, .3);--shadow-popup: 0 25px 50px -12px rgba(0, 0, 0, .5);--shadow-nav: 0 1px 0 0 var(--color-border);--color-bg-glass: rgba(10, 10, 10, .75);--color-bg-glass-solid: rgba(10, 10, 10, .92);--color-glass-hover: rgba(255, 255, 255, .06);--invert: invert(100%);--overlay-bg: rgba(0, 0, 0, .7);color-scheme:dark}.theme-light{--color-bg: #fafafa;--color-surface: #ffffff;--color-surface-elevated: #ececec;--color-border: #e5e5e5;--color-border-subtle: #eeeeee;--color-text-primary: #0a0a0a;--color-text-secondary: #666666;--color-text-tertiary: #999999;--color-accent: #6d5ace;--color-accent-secondary: #8b6fdb;--color-accent-glow: rgba(109, 90, 206, .1);--gradient-accent: linear-gradient(135deg, #6d5ace, #8b6fdb);--gradient-bg: radial-gradient(ellipse at 50% 0%, rgba(109, 90, 206, .12) 0%, rgba(109, 90, 206, .03) 40%, transparent 70%);--gradient-card-hover: linear-gradient(135deg, rgba(109, 90, 206, .04) 0%, transparent 100%);--shadow-card: 0 0 0 1px var(--color-border);--shadow-card-hover: 0 0 0 1px var(--color-accent), 0 8px 25px -5px rgba(0, 0, 0, .08);--shadow-popup: 0 25px 50px -12px rgba(0, 0, 0, .15);--shadow-nav: 0 1px 0 0 var(--color-border);--color-bg-glass: rgba(250, 250, 250, .75);--color-bg-glass-solid: rgba(250, 250, 250, .92);--color-glass-hover: rgba(0, 0, 0, .05);--invert: invert(0%);--overlay-bg: rgba(255, 255, 255, .7);color-scheme:light}.reveal{opacity:0;transition:opacity .6s ease}.revealed{opacity:1}.stagger-children .reveal:nth-child(1){transition-delay:80ms}.stagger-children .reveal:nth-child(2){transition-delay:.16s}.stagger-children .reveal:nth-child(3){transition-delay:.24s}.stagger-children .reveal:nth-child(4){transition-delay:.32s}.stagger-children .reveal:nth-child(5){transition-delay:.4s}.stagger-children .reveal:nth-child(6){transition-delay:.48s}.stagger-children .reveal:nth-child(7){transition-delay:.56s}.stagger-children .reveal:nth-child(8){transition-delay:.64s}.stagger-children .reveal:nth-child(9){transition-delay:.72s}.stagger-children .reveal:nth-child(10){transition-delay:.8s}.stagger-children .reveal:nth-child(11){transition-delay:.88s}.stagger-children .reveal:nth-child(12){transition-delay:.96s}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes pulse-glow{0%,to{opacity:.4}50%{opacity:.8}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:1rem;line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg);overflow-x:hidden}a{color:inherit;text-decoration:none}button{font:inherit;color:inherit;cursor:pointer;border:none;background:none}img{display:block;max-width:100%;height:auto}ul,ol{list-style:none}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:9999px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}::selection{background:color-mix(in srgb,var(--color-accent) 80%,transparent);color:#fff}#root{min-height:100vh;position:relative}#root:before{content:"";position:fixed;top:0;left:0;right:0;height:60vh;background:var(--gradient-bg);pointer-events:none;z-index:-1}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.mono{font-family:JetBrains Mono,Fira Code,monospace}.accent{color:var(--color-accent)}main{display:flex;flex-direction:column;gap:64px}@media(min-width:1024px){main{gap:96px}}
