:root{--c-surface: #f9f9f9;--c-surface-bright: #ffffff;--c-surface-warm: #fdf8f8;--c-surface-muted: #f1edec;--c-surface-container: #eeeeee;--c-surface-container-high: #e8e8e8;--c-on-surface: #1b1b1b;--c-on-surface-variant: #4c4546;--c-primary: #000000;--c-on-primary: #ffffff;--c-outline: #7e7576;--c-outline-variant: #cfc4c5;--c-glass-fill: rgba(255, 255, 255, .45);--c-glass-border: rgba(255, 255, 255, .3);--c-accent-glow: rgba(110, 142, 251, .12);--f-display: "Playfair Display", serif;--f-headline: "Archivo Narrow", sans-serif;--f-body: "DM Sans", sans-serif;--f-mono: "Geist Mono", monospace;--sp-section: 160px;--sp-margin-desktop: 80px;--sp-margin-mobile: 24px;--sp-gutter: 24px;--hero-bg-start: #fdf8f8;--hero-bg-end: #f1edec;--c-muted-1: rgba(0,0,0,.04);--c-muted-2: rgba(0,0,0,.1);--c-muted-3: rgba(0,0,0,.15);--loader-bg: var(--c-primary);--loader-text: var(--c-on-primary);--loader-line: rgba(255,255,255,.1);--loader-fill: rgba(255,255,255,.5);--footer-bg: var(--c-primary);--footer-color: var(--c-on-primary);--footer-color-rgb: 255,255,255;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--orb-start: rgba(255,255,255,.9);--orb-end: rgba(255,255,255,.08);--orb-shadow-inset: inset -15px -15px 40px rgba(0,0,0,.04);--orb-shadow-outset: 15px 15px 40px rgba(255,255,255,.7)}:root[data-theme=dark]{--c-surface: #0b0b0c;--c-surface-bright: #0f0f10;--c-surface-warm: #0b0b0c;--c-surface-muted: #151516;--c-surface-container: #141415;--c-surface-container-high: #1b1b1d;--c-on-surface: #e9e9ea;--c-on-surface-variant: #bfb9ba;--c-primary: #ffffff;--c-on-primary: #0b0b0c;--c-outline: rgba(255,255,255,.12);--c-outline-variant: rgba(255,255,255,.06);--c-glass-fill: rgba(255,255,255,.03);--c-glass-border: rgba(255,255,255,.06);--c-accent-glow: rgba(110,142,251,.06);--hero-bg-start: #070708;--hero-bg-end: #0f0f10;--c-muted-1: rgba(255,255,255,.04);--c-muted-2: rgba(255,255,255,.08);--c-muted-3: rgba(255,255,255,.15);--loader-bg: var(--c-surface);--loader-text: var(--c-on-surface);--loader-line: rgba(255,255,255,.06);--loader-fill: rgba(255,255,255,.12);--footer-bg: var(--c-surface);--footer-color: var(--c-on-surface);--footer-color-rgb: 233,233,234;--orb-start: rgba(0,0,0,.28);--orb-end: rgba(0,0,0,.6);--orb-shadow-inset: inset -8px -8px 30px rgba(0,0,0,.5);--orb-shadow-outset: 10px 10px 30px rgba(0,0,0,.45)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--f-body);background:var(--c-surface);color:var(--c-on-surface);overflow-x:hidden;cursor:none}a{color:inherit;text-decoration:none}img,svg{display:block;max-width:100%}ul{list-style:none}button{cursor:none;border:none;background:none;font-family:inherit}::selection{background:var(--c-primary);color:var(--c-on-primary)}#cursor-outer{position:fixed;width:40px;height:40px;border:1.5px solid var(--c-outline);border-radius:50%;pointer-events:none;z-index:9999;top:0;left:0;transform:translate(-50%,-50%);transition:width .4s var(--ease-out-expo),height .4s var(--ease-out-expo),background .3s ease,border-color .3s ease;mix-blend-mode:multiply}#cursor-dot{position:fixed;width:6px;height:6px;background:var(--c-primary);border-radius:50%;pointer-events:none;z-index:9999;top:0;left:0;transform:translate(-50%,-50%)}body.cursor-hover #cursor-outer{width:70px;height:70px;background:var(--c-glass-fill);border-color:var(--c-outline)}body.cursor-active #cursor-outer{width:20px;height:20px}body.cursor-project #cursor-outer{width:90px;height:90px;background:var(--c-primary);border-color:var(--c-primary)}:root[data-theme=dark] #cursor-outer{mix-blend-mode:normal;background:transparent;border-color:var(--c-outline)}:root[data-theme=dark] body.cursor-hover #cursor-outer{background:#ffffff08}:root[data-theme=dark] #preview-card{box-shadow:0 60px 80px -30px #0009}:root[data-theme=dark] .preview-mockup-inner{box-shadow:0 8px 24px #0009}:root[data-theme=dark] .skill-node-card{background:var(--c-surface-container-high);border:1px solid var(--c-glass-border)}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#00000026;border-radius:99px}.container{max-width:1440px;margin:0 auto}.px-desktop{padding-left:var(--sp-margin-desktop);padding-right:var(--sp-margin-desktop)}.px-mobile{padding-left:var(--sp-margin-mobile);padding-right:var(--sp-margin-mobile)}.section-pad{padding-top:var(--sp-section);padding-bottom:var(--sp-section)}.label-caps{font-family:var(--f-mono);font-size:11px;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--c-on-surface-variant)}.display-xl{font-family:var(--f-display);font-size:clamp(64px,10vw,120px);font-weight:700;line-height:1;letter-spacing:-.03em;color:var(--c-primary)}.display-lg{font-family:var(--f-display);font-size:clamp(48px,7vw,96px);font-weight:700;line-height:1;letter-spacing:-.03em;color:var(--c-primary)}.headline{font-family:var(--f-headline);font-size:clamp(28px,4vw,48px);font-weight:600;line-height:1.15;letter-spacing:-.02em}.body-lg{font-family:var(--f-body);font-size:17px;font-weight:300;line-height:1.7;color:var(--c-on-surface-variant);letter-spacing:-.005em}.signature{font-family:var(--f-display);font-style:italic;font-weight:400}.glass{background:var(--c-glass-fill);backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);border:1px solid var(--c-glass-border)}.orb{border-radius:50%;background:radial-gradient(circle at 40% 40%,#ffffffe6,#ffffff1a);box-shadow:inset -15px -15px 40px #0000000a,15px 15px 40px #ffffffb3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.reveal{opacity:0;transform:translateY(40px)}.reveal-left{opacity:0;transform:translate(-40px)}.reveal-scale{opacity:0;transform:scale(.92)}.bg-float-layer{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;pointer-events:none}.float-orb{position:absolute;border-radius:50%;animation:floatOrb var(--dur, 10s) ease-in-out infinite var(--delay, 0s);background:radial-gradient(circle at 40% 40%,var(--orb-start),var(--orb-end));box-shadow:var(--orb-shadow-inset),var(--orb-shadow-outset);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}@keyframes floatOrb{0%,to{transform:translate(0) rotate(0)}33%{transform:translate(15px,-20px) rotate(3deg)}66%{transform:translate(-10px,10px) rotate(-2deg)}}#nav{position:fixed;top:28px;left:50%;transform:translate(-50%);width:calc(100% - 48px);max-width:1400px;z-index:100;opacity:0}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-radius:999px;background:linear-gradient(180deg,#ffffff0a,#ffffff05);backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);border:1px solid var(--c-glass-border);box-shadow:0 8px 30px #00000014}.nav-logo{font-family:var(--f-display);font-style:italic;font-size:20px;font-weight:400;letter-spacing:-.01em;color:var(--c-primary)}.nav-links{display:flex;gap:40px;align-items:center}.nav-menu-toggle{display:none;width:44px;height:44px;align-items:center;justify-content:center;border-radius:50%;background:#ffffff0a;border:1px solid var(--c-glass-border);color:var(--c-primary)}.nav-mobile-panel{display:none}.nav-link{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-on-surface-variant);transition:color .3s ease;position:relative}.nav-link:after{content:"";position:absolute;bottom:-2px;left:0;width:0;height:.5px;background:var(--c-primary);transition:width .4s var(--ease-out-expo)}.nav-link:hover{color:var(--c-primary)}.nav-link:hover:after{width:100%}.nav-link.active{color:var(--c-primary)}.nav-link.active:after{width:100%}.nav-cta{display:flex;align-items:center;gap:8px;background:#ffffff0a;border:1px solid var(--c-glass-border);padding:10px 24px;border-radius:999px;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-primary);transition:all .3s var(--ease-out-expo)}.nav-controls{display:flex;align-items:center;gap:12px}#theme-toggle{width:44px;height:44px;display:inline-grid;place-items:center;border-radius:10px;background:var(--c-glass-fill);border:1px solid var(--c-glass-border);z-index:10050;font-size:16px;cursor:pointer;-webkit-appearance:none;transition:transform .18s ease,background .18s ease}#theme-toggle:hover{transform:translateY(-3px)}.material-symbols-outlined{color:var(--c-on-surface-variant)!important}.nav-cta:hover{background:var(--c-primary);color:var(--c-on-primary);border-color:var(--c-primary);transform:scale(1.03)}#hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow:hidden;background:radial-gradient(ellipse at 50% 60%,var(--hero-bg-start) 0%,var(--hero-bg-end) 100%)}.hero-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(0,0,0,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.04) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.4) 0%,transparent 70%);mask-image:radial-gradient(ellipse at center,rgba(0,0,0,.4) 0%,transparent 70%);pointer-events:none}.hero-content{position:relative;z-index:10;text-align:center;max-width:1100px;padding:100px 24px 0}.hero-eyebrow{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:40px;opacity:0}.hero-eyebrow-line{width:40px;height:1px;background:var(--c-outline-variant)}.hero-title{font-family:var(--f-display);font-size:clamp(56px,10vw,128px);font-weight:700;line-height:.95;letter-spacing:-.04em;color:var(--c-primary);text-transform:uppercase;margin-bottom:40px;overflow:hidden}.hero-title em{font-style:italic;font-weight:400;text-transform:none}.hero-title .word{display:inline-block;overflow:hidden}.hero-title .char{display:inline-block;transform:translateY(110%)}.hero-sub{max-width:480px;margin:0 auto 48px;opacity:0}.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;opacity:0}.btn-primary{display:inline-flex;align-items:center;gap:10px;background:var(--c-primary);color:var(--c-on-primary);padding:16px 40px;border-radius:4px;font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;transition:all .3s var(--ease-out-expo);position:relative;overflow:hidden}.btn-primary:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffff14;transform:translate(-100%);transition:transform .4s var(--ease-out-expo)}.btn-primary:hover:before{transform:translate(0)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px #00000026}.btn-ghost{display:inline-flex;align-items:center;gap:10px;background:var(--c-glass-fill);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--c-primary);padding:16px 40px;border-radius:4px;border:1px solid var(--c-glass-border);font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;transition:all .3s var(--ease-out-expo)}.btn-ghost:hover{background:#ffffff1f;transform:translateY(-2px)}.scroll-indicator{position:absolute;bottom:48px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;opacity:0}.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,transparent,var(--c-outline-variant));animation:scrollPulse 2s ease-in-out infinite}@keyframes scrollPulse{0%,to{opacity:.3;transform:scaleY(1)}50%{opacity:1;transform:scaleY(.7)}}.hero-stat{position:absolute;background:var(--c-glass-fill);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--c-glass-border);border-radius:16px;padding:20px 24px;opacity:0;pointer-events:none}.hero-stat--left{left:6%;top:40%}.hero-stat--right{right:6%;top:55%}.hero-stat-number{font-family:var(--f-display);font-size:36px;font-weight:700;color:var(--c-primary);line-height:1;margin-bottom:4px}.hero-stat-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-on-surface-variant)}.marquee-strip{overflow:hidden;border-top:1px solid var(--c-outline-variant);border-bottom:1px solid var(--c-outline-variant);padding:20px 0;background:var(--c-primary)}.marquee-track{display:flex;gap:0;animation:marqueeScroll 25s linear infinite;white-space:nowrap}.marquee-track:hover{animation-play-state:paused}@keyframes marqueeScroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.marquee-item{display:inline-flex;align-items:center;gap:32px;padding:0 40px;font-family:var(--f-mono);font-size:11px;letter-spacing:.15em;text-transform:uppercase;color:var(--c-on-primary);flex-shrink:0}.marquee-dot{width:4px;height:4px;border-radius:50%;background:var(--c-on-primary);opacity:.3}#about{position:relative;background:var(--c-surface);overflow:hidden}.about-grid{display:grid;grid-template-columns:7fr 5fr;gap:80px;align-items:start}.about-image-wrap{position:relative;height:700px;border-radius:24px;overflow:hidden;background:var(--c-surface-container-high)}.about-image-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;filter:grayscale(1);transition:filter .8s ease}.about-image{width:100%;height:100%;object-fit:cover;border-radius:24px}.about-image-wrap:hover .about-image-placeholder{filter:grayscale(0)}.about-image-overlay{position:absolute;bottom:0;left:0;right:0;padding:40px;background:linear-gradient(to top,var(--c-surface) 0%,transparent 100%)}.about-quote{font-family:var(--f-display);font-style:italic;font-size:20px;line-height:1.5;color:var(--c-primary)}.about-sticky-side{position:sticky;top:120px;display:flex;flex-direction:column;gap:48px}.about-section-tag{display:flex;flex-direction:column;gap:16px}.about-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}.badge{padding:8px 20px;border:1px solid var(--c-outline-variant);border-radius:999px;font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--c-on-surface-variant);background:var(--c-glass-fill);transition:all .3s ease}.badge:hover{background:var(--c-primary);color:var(--c-on-primary);border-color:var(--c-primary)}.about-stats{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--c-outline-variant);border:1px solid var(--c-outline-variant);border-radius:16px;overflow:hidden}.stat-cell{background:var(--c-surface-bright);padding:28px 24px;display:flex;flex-direction:column;gap:4px}.stat-num{font-family:var(--f-display);font-size:40px;font-weight:700;color:var(--c-primary);line-height:1}.stat-label{font-family:var(--f-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--c-on-surface-variant)}.about-text-block{border-top:1px solid var(--c-outline-variant);padding-top:32px}.about-text-block h4{font-family:var(--f-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--c-primary);margin-bottom:16px}#projects{background:var(--c-surface-bright);position:relative;overflow:visible}.projects-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:64px}.project-filters{display:flex;gap:32px;border-bottom:1px solid var(--c-outline-variant);padding-bottom:20px;margin-bottom:0;overflow-x:auto}.project-filter-btn{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-on-surface-variant);padding-bottom:20px;position:relative;white-space:nowrap;transition:color .3s ease}.project-filter-btn:after{content:"";position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--c-primary);transition:width .4s var(--ease-out-expo)}.project-filter-btn.active,.project-filter-btn:hover{color:var(--c-primary)}.project-filter-btn.active:after,.project-filter-btn:hover:after{width:100%}.project-list{margin-top:0}.project-row{display:flex;align-items:center;padding:28px 0;border-bottom:1px solid var(--c-outline-variant);cursor:none;position:relative;transition:background .3s ease;gap:24px}.project-row:before{content:"";position:absolute;left:-80px;right:-80px;top:0;bottom:0;background:transparent;transition:background .3s ease;z-index:0}.project-row:hover:before,.project-row.active:before{background:var(--c-surface-container)}.project-row>*{position:relative;z-index:1}.project-num{font-family:var(--f-mono);font-size:12px;color:var(--c-on-surface-variant);width:48px;flex-shrink:0;transition:color .3s}.project-row:hover .project-num,.project-row.active .project-num,.project-row:hover .project-number,.project-row.active .project-number{color:var(--c-primary)}.project-icon{width:56px;height:56px;border-radius:12px;background:var(--c-surface-container);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .4s var(--ease-out-expo)}.project-row:hover .project-icon,.project-row.active .project-icon{transform:scale(1.1) rotate(-3deg)}.project-info{flex:1}.project-title{font-family:var(--f-headline);font-size:28px;font-weight:600;color:var(--c-primary);line-height:1.1;margin-bottom:4px}.project-sub{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-on-surface-variant)}.project-tech-tags{display:flex;gap:8px;flex-shrink:0}.tech-tag{padding:6px 14px;border-radius:999px;background:var(--c-surface-container);font-family:var(--f-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--c-on-surface-variant);opacity:0;transition:opacity .3s,background .3s}.project-row:hover .tech-tag,.project-row.active .tech-tag{opacity:1}.project-arrow{width:44px;height:44px;border-radius:50%;border:1px solid var(--c-outline-variant);color:inherit;text-decoration:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;position:relative;z-index:2;transition:all .3s var(--ease-out-expo)}.project-row:hover .project-arrow,.project-row.active .project-arrow{background:var(--c-primary);border-color:var(--c-primary);color:var(--c-on-primary);transform:rotate(-45deg)}#preview-card{position:fixed;width:380px;aspect-ratio:16 / 9;border-radius:24px;overflow:hidden;pointer-events:none;z-index:60;opacity:0;transform:translate(-50%,-50%) scale(.85) rotate(-5deg);transition:opacity .5s var(--ease-out-expo),transform .5s var(--ease-out-expo);background:var(--c-surface-bright);-webkit-backdrop-filter:blur(30px);backdrop-filter:blur(30px);border:1px solid var(--c-glass-border);box-shadow:0 80px 100px -40px #0000001f}#preview-card.show{opacity:1;transform:translate(-50%,-50%) scale(1) rotate(0)}.preview-content{width:100%;height:100%;padding:0;display:flex;align-items:stretch}.preview-mockup{flex:1;width:100%;aspect-ratio:auto;min-height:100%;background:var(--c-surface-container-high);border-radius:0;border:0;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;transition:background .5s ease}.preview-mockup-inner{width:100%;height:100%;background:var(--c-surface-bright);border-radius:0;box-shadow:none;display:flex;flex-direction:column;overflow:hidden}.preview-mock-body{flex:1;display:flex;align-items:center;justify-content:center}.project-hover-target{display:flex;align-items:center;gap:24px;flex:1;min-width:0}#experience{background:var(--c-surface);position:relative;overflow:hidden}.experience-inner{position:relative}.timeline-axis{position:absolute;left:50%;top:0;bottom:0;width:1px;background:var(--c-surface-container-high);transform:translate(-50%)}.timeline-progress-line{position:absolute;top:0;left:0;width:100%;background:var(--c-primary);transition:height .1s linear;box-shadow:0 0 20px #0000000f;height:0}.exp-items{display:flex;flex-direction:column;gap:96px;position:relative}.exp-item{display:grid;grid-template-columns:1fr 40px 1fr;align-items:center;gap:0}.exp-card-side{display:flex}.exp-card-side--left{justify-content:flex-end;padding-right:60px}.exp-card-side--right{justify-content:flex-start;padding-left:60px}.exp-center{display:flex;justify-content:center;align-items:center}.exp-dot{width:14px;height:14px;border-radius:50%;background:var(--c-surface-bright);border:2px solid var(--c-outline-variant);transition:all .5s var(--ease-out-expo);position:relative;z-index:10}.exp-dot.active{border-color:var(--c-primary);background:var(--c-primary);box-shadow:0 0 0 6px #0000000f;transform:scale(1.2)}.exp-card{background:var(--c-glass-fill);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--c-glass-border);border-radius:24px;padding:40px;max-width:480px;width:100%;transition:all .5s var(--ease-out-expo)}.exp-card:hover{transform:translateY(-6px);box-shadow:0 40px 60px #0000000f}.exp-era{font-family:var(--f-mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--c-on-surface-variant);margin-bottom:12px;display:block}.exp-title{font-family:var(--f-display);font-size:clamp(22px,3vw,32px);font-weight:700;color:var(--c-primary);margin-bottom:12px;line-height:1.1}.exp-org{display:flex;align-items:center;gap:12px;margin-bottom:20px}.exp-org-line{width:24px;height:1px;background:var(--c-outline-variant)}.exp-org-name{font-family:var(--f-display);font-style:italic;font-size:16px;color:var(--c-on-surface-variant)}.exp-body{font-size:15px;line-height:1.7;color:var(--c-on-surface-variant)}.exp-year{font-family:var(--f-display);font-style:italic;font-size:clamp(48px,5vw,72px);color:var(--c-muted-1);line-height:1;white-space:nowrap}#skills{background:var(--c-surface-warm);position:relative;overflow:hidden}.skills-grid{display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:center}.skills-left{display:flex;flex-direction:column;gap:40px}.skills-categories{display:flex;flex-direction:column;gap:20px;margin-top:8px}.skill-cat{display:flex;align-items:center;gap:20px;padding:20px 0;border-bottom:1px solid var(--c-outline-variant);cursor:default}.skill-cat-num{font-family:var(--f-display);font-style:italic;font-size:28px;color:var(--c-muted-1);line-height:1;transition:color .3s;width:32px;flex-shrink:0}.skill-cat:hover .skill-cat-num{color:var(--c-muted-2)}.skill-cat-info{display:flex;flex-direction:column;gap:4px}.skill-cat-title{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--c-primary)}.skill-cat-desc{font-size:13px;color:var(--c-on-surface-variant)}.skills-right{position:relative;height:600px;display:flex;align-items:center;justify-content:center}.orbit-wrap{position:relative;width:520px;height:520px}.orbit-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:120px;height:120px;border-radius:50%;background:var(--c-glass-fill);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--c-glass-border);display:flex;align-items:center;justify-content:center;z-index:10;box-shadow:0 0 40px #0000000f}.orbit-ring{position:absolute;top:50%;left:50%;border-radius:50%;border:1px solid var(--c-outline-variant);transform:translate(-50%,-50%);animation:orbitSpin var(--spin-dur, 30s) linear infinite var(--spin-dir, normal)}.orbit-ring--1{width:220px;height:220px;--spin-dur: 20s}.orbit-ring--2{width:360px;height:360px;--spin-dur: 30s;--spin-dir: reverse}.orbit-ring--3{width:480px;height:480px;--spin-dur: 45s}@keyframes orbitSpin{0%{transform:translate(-50%,-50%) rotate(0)}to{transform:translate(-50%,-50%) rotate(360deg)}}#contact{background:var(--c-surface);position:relative;overflow:hidden}.contact-grid{display:grid;grid-template-columns:7fr 5fr;gap:80px;align-items:start}.contact-heading{font-family:var(--f-display);font-size:clamp(52px,8vw,100px);font-weight:700;line-height:.92;letter-spacing:-.04em;color:var(--c-primary);margin-bottom:48px}.contact-heading em{font-style:italic;font-weight:400}.contact-links{display:flex;flex-wrap:wrap;gap:12px;margin-top:40px}.contact-link-btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;background:var(--c-glass-fill);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--c-glass-border);border-radius:8px;font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-primary);transition:all .3s var(--ease-out-expo);position:relative;overflow:hidden}.contact-link-btn:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:var(--c-primary);transform:translateY(100%);transition:transform .4s var(--ease-out-expo)}.contact-link-btn span{position:relative;z-index:1}.contact-link-btn:hover:before{transform:translateY(0)}.contact-link-btn:hover{color:var(--c-on-primary)}.contact-form-wrap{background:var(--c-glass-fill);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--c-glass-border);border-radius:32px;padding:48px;box-shadow:0 40px 80px #0000000a}.form-field{position:relative;margin-bottom:36px}.form-input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--c-outline-variant);padding:16px 0;font-family:var(--f-body);font-size:16px;color:var(--c-on-surface);outline:none;transition:border-color .3s ease;-moz-appearance:none;appearance:none;-webkit-appearance:none;border-radius:0;box-shadow:none}.form-input:focus{border-color:var(--c-primary)}.form-input::placeholder{color:transparent}.form-label{position:absolute;left:0;top:16px;font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--c-on-surface-variant);transition:all .3s var(--ease-out-expo);pointer-events:none}.form-input:focus~.form-label,.form-input:not(:placeholder-shown)~.form-label{top:-8px;font-size:9px;color:var(--c-primary)}textarea.form-input{resize:none;min-height:100px}.btn-submit{width:100%;background:var(--c-primary);color:var(--c-on-primary);padding:20px;border-radius:12px;font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;transition:all .3s var(--ease-out-expo);position:relative;overflow:hidden}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 20px 40px #00000026}footer{background:var(--footer-bg);color:var(--footer-color);padding:60px var(--sp-margin-desktop)}.footer-inner{max-width:1440px;margin:0 auto;display:flex;flex-direction:column;gap:48px}.footer-top{display:flex;justify-content:space-between;align-items:center}.footer-logo{font-family:var(--f-display);font-style:italic;font-size:28px;color:var(--footer-color)}.footer-nav-links{display:flex;gap:40px}.footer-link{font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(var(--footer-color-rgb, 255,255,255),.4);transition:color .3s;display:flex;align-items:center;gap:6px}.footer-link:hover{color:var(--footer-color)}.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid rgba(var(--footer-color-rgb),.08);padding-top:32px}.footer-copy{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(var(--footer-color-rgb),.2)}.footer-policy-links{display:flex;gap:32px}.footer-policy{font-family:var(--f-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:rgba(var(--footer-color-rgb),.2);transition:color .3s}.footer-policy:hover{color:rgba(var(--footer-color-rgb),.5)}.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:80px}.section-index{font-family:var(--f-mono);font-size:12px;color:#0003;margin-bottom:8px}.section-desc{max-width:380px;font-size:16px;line-height:1.65;color:var(--c-on-surface-variant)}@media (max-width: 900px){:root{--sp-margin-desktop: 24px}.about-grid,.skills-grid,.contact-grid{grid-template-columns:1fr}.about-sticky-side{position:static}.hero-stat{display:none}.exp-item{grid-template-columns:1fr}.timeline-axis{display:none}.exp-card-side--left,.exp-card-side--right{padding:0;justify-content:center}.exp-center,.nav-links,.nav-controls .nav-cta{display:none}.nav-menu-toggle{display:inline-grid}#nav{width:calc(100% - 24px);top:12px}.nav-inner{padding:14px 18px;border-radius:28px}.nav-mobile-panel{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding:0 18px;max-height:0;opacity:0;overflow:hidden;pointer-events:none;transform:translateY(-8px);transition:max-height .35s var(--ease-out-expo),opacity .25s ease,transform .25s ease}.nav-mobile-panel.open{max-height:320px;opacity:1;pointer-events:auto;transform:translateY(0)}.nav-mobile-link,.nav-mobile-cta{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-radius:18px;background:#ffffffb3;border:1px solid var(--c-glass-border);font-family:var(--f-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-primary)}.orbit-wrap{width:340px;height:340px}.orbit-ring--3{width:320px;height:320px}.orbit-ring--2{width:240px;height:240px}.orbit-ring--1{width:150px;height:150px}.section-header,.projects-header{flex-direction:column;align-items:flex-start;gap:24px}footer{padding:40px 24px}}@media (prefers-color-scheme: dark){:root{--loader-bg: #0b0b0c;--loader-text: #e9e9ea;--loader-line: rgba(255,255,255,.06);--loader-fill: rgba(255,255,255,.12);--footer-bg: #0b0b0c;--footer-color: #e9e9ea;--footer-color-rgb: 233,233,234}}#loader{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:9000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px}.loader-text{font-family:var(--f-display);font-size:24px;color:var(--loader-text);overflow:hidden}.loader-count{font-family:var(--f-mono);font-size:72px;font-weight:300;color:var(--loader-text);letter-spacing:-.03em;line-height:1}.loader-line{width:200px;height:1px;background:var(--loader-line);position:relative;overflow:hidden}.loader-line-fill{position:absolute;left:0;top:0;height:100%;background:var(--loader-fill);width:0;transition:width .05s linear}
