:root{--font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", ui-monospace, SFMono-Regular, "SF Mono", Menlo, monospace;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--space-32: 8rem;--radius-xs: 8px;--radius-sm: 12px;--radius-md: 16px;--radius-lg: 22px;--radius-xl: 30px;--radius-pill: 999px;--container: 1180px;--ease-out: cubic-bezier(.16, 1, .3, 1);--ease-in-out: cubic-bezier(.65, 0, .35, 1);--bg: #fafafb;--bg-muted: #f3f4f7;--surface: #ffffff;--surface-2: #f7f8fa;--text: #0c0d10;--text-soft: #585c66;--text-faint: #898d97;--line: #e7e8ec;--line-strong: #d6d8de;--accent: #2f5bff;--accent-2: #7c3aed;--accent-contrast: #ffffff;--accent-tint: rgba(47, 91, 255, .08);--accent-tint-strong: rgba(47, 91, 255, .14);--grad: linear-gradient(120deg, var(--accent), var(--accent-2));--grad-text: linear-gradient(120deg, #2f5bff 0%, #7c3aed 70%, #2f5bff 100%);--shadow-sm: 0 1px 2px rgba(12, 13, 16, .04), 0 2px 8px rgba(12, 13, 16, .04);--shadow-md: 0 4px 12px rgba(12, 13, 16, .06), 0 12px 32px rgba(12, 13, 16, .07);--shadow-lg: 0 8px 24px rgba(12, 13, 16, .08), 0 24px 60px rgba(12, 13, 16, .1);--shadow-accent: 0 8px 30px rgba(47, 91, 255, .28);--grid-line: rgba(12, 13, 16, .045);--spotlight: rgba(47, 91, 255, .1);color-scheme:light}:root[data-theme=dark]{--bg: #08090c;--bg-muted: #0c0e13;--surface: #101218;--surface-2: #14161e;--text: #f4f5f7;--text-soft: #a2a7b2;--text-faint: #6b6f7a;--line: #1e2129;--line-strong: #2a2e38;--accent: #6d8bff;--accent-2: #a78bfa;--accent-contrast: #07080b;--accent-tint: rgba(109, 139, 255, .1);--accent-tint-strong: rgba(109, 139, 255, .18);--grad: linear-gradient(120deg, var(--accent), var(--accent-2));--grad-text: linear-gradient(120deg, #8aa0ff 0%, #c4b1ff 70%, #8aa0ff 100%);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3), 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4), 0 12px 32px rgba(0, 0, 0, .45);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5), 0 24px 60px rgba(0, 0, 0, .6);--shadow-accent: 0 8px 36px rgba(109, 139, 255, .35);--grid-line: rgba(255, 255, 255, .04);--spotlight: rgba(109, 139, 255, .16);color-scheme:dark}*,*:before,*:after{box-sizing:border-box}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{margin:0;font-family:var(--font-body);color:var(--text);background:var(--bg);min-height:100vh;line-height:1.65;font-size:16px;letter-spacing:-.011em;overflow-x:hidden;transition:background-color .4s var(--ease-out),color .4s var(--ease-out)}h1,h2,h3,h4{margin:0;font-family:var(--font-display);font-weight:800;letter-spacing:-.03em;line-height:1.05}p{margin:0}a{color:inherit;text-decoration:none}ul,ol{margin:0;padding:0;list-style:none}img{max-width:100%;display:block}::selection{background:var(--accent);color:var(--accent-contrast)}::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:999px;border:3px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--text-faint)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}.skip-link{position:fixed;top:-100px;left:var(--space-4);z-index:200;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:var(--space-3) var(--space-4);box-shadow:var(--shadow-md);font-weight:600;transition:top .2s var(--ease-out)}.skip-link:focus{top:var(--space-4)}.container{width:min(var(--container),calc(100% - 2 * var(--space-5)));margin-inline:auto}.section{position:relative;padding:clamp(4.5rem,11vw,8rem) 0}.section-muted{background:var(--bg-muted);border-block:1px solid var(--line)}.section-head{margin-bottom:clamp(2.5rem,6vw,4rem);max-width:60ch}.eyebrow{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:.78rem;font-weight:500;letter-spacing:.04em;color:var(--accent);margin-bottom:var(--space-4)}.eyebrow:before{content:"";width:26px;height:1px;background:var(--accent);opacity:.6}.section-head h2{font-size:clamp(2rem,5.5vw,3.2rem);letter-spacing:-.04em}.section-head .section-sub{margin-top:var(--space-4);color:var(--text-soft);font-size:clamp(1rem,2.2vw,1.12rem);max-width:56ch}.text-grad{background:var(--grad-text);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.scroll-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:100;background:transparent;pointer-events:none}.scroll-progress-bar{height:100%;width:100%;transform:scaleX(var(--progress, 0));transform-origin:0 50%;background:var(--grad)}.site-header{position:sticky;top:0;z-index:60;padding:var(--space-4) 0;transition:padding .35s var(--ease-out)}.site-header.is-scrolled{padding:var(--space-3) 0}.nav-shell{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-2) var(--space-2) var(--space-2) var(--space-4);border-radius:var(--radius-pill);border:1px solid transparent;transition:background .35s var(--ease-out),border-color .35s var(--ease-out),box-shadow .35s var(--ease-out)}.site-header.is-scrolled .nav-shell{background:color-mix(in srgb,var(--surface) 72%,transparent);backdrop-filter:saturate(180%) blur(16px);-webkit-backdrop-filter:saturate(180%) blur(16px);border-color:var(--line);box-shadow:var(--shadow-md)}.brand{display:inline-flex;align-items:center;gap:var(--space-3);font-weight:700;letter-spacing:-.02em;flex-shrink:0}.brand-mark{display:grid;place-items:center;width:34px;height:34px;border-radius:10px;background:var(--grad);color:#fff;font-family:var(--font-display);font-weight:800;font-size:.92rem;letter-spacing:-.04em;box-shadow:var(--shadow-accent)}.brand-name{font-size:.98rem}.nav-list{display:flex;align-items:center;gap:2px;margin-inline:auto;overflow-x:auto;scrollbar-width:none;max-width:100%}.nav-list::-webkit-scrollbar{display:none}.nav-list a{display:inline-flex;align-items:center;border-radius:var(--radius-pill);padding:.5rem .95rem;font-size:.9rem;font-weight:500;color:var(--text-soft);white-space:nowrap;transition:color .2s var(--ease-out),background .2s var(--ease-out)}.nav-list a:hover{color:var(--text);background:var(--accent-tint)}.nav-list .nav-active{color:var(--text);background:var(--accent-tint-strong)}.nav-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.theme-toggle{display:inline-grid;place-items:center;width:40px;height:40px;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--surface);color:var(--text);cursor:pointer;font:inherit;transition:transform .2s var(--ease-out),border-color .2s var(--ease-out),background .2s var(--ease-out)}.theme-toggle svg{width:18px;height:18px}.theme-toggle:hover{transform:translateY(-1px);border-color:var(--line-strong);background:var(--surface-2)}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);border-radius:var(--radius-pill);border:1px solid transparent;padding:.78rem 1.35rem;min-height:46px;font-family:var(--font-body);font-weight:600;font-size:.94rem;letter-spacing:-.01em;cursor:pointer;white-space:nowrap;transition:transform .25s var(--ease-out),box-shadow .25s var(--ease-out),background .25s var(--ease-out),border-color .25s var(--ease-out),color .25s var(--ease-out)}.btn svg{width:17px;height:17px}.btn:hover{transform:translateY(-2px)}.btn:active{transform:translateY(0)}.btn-primary{background:var(--accent);color:var(--accent-contrast);box-shadow:var(--shadow-accent)}.btn-primary:hover{box-shadow:0 12px 40px color-mix(in srgb,var(--accent) 45%,transparent)}.btn-primary .arrow{transition:transform .25s var(--ease-out)}.btn-primary:hover .arrow{transform:translate(3px)}.btn-secondary{background:var(--surface);border-color:var(--line);color:var(--text);box-shadow:var(--shadow-sm)}.btn-secondary:hover{border-color:var(--line-strong);background:var(--surface-2)}.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}.btn-ghost:hover{border-color:var(--line-strong);background:var(--accent-tint)}.hero{position:relative;padding-top:clamp(2rem,6vw,4rem);padding-bottom:clamp(3rem,8vw,6rem);overflow:clip}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;overflow:hidden}.hero-grid-overlay{position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background-image:linear-gradient(to right,var(--grid-line) 1px,transparent 1px),linear-gradient(to bottom,var(--grid-line) 1px,transparent 1px);background-size:56px 56px;mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 10%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 0%,#000 10%,transparent 75%)}.hero-aurora{position:absolute;border-radius:50%;filter:blur(80px);opacity:.55}.hero-aurora-a{width:38rem;height:38rem;top:-16rem;right:-10rem;background:radial-gradient(circle,var(--accent),transparent 70%);animation:drift 22s var(--ease-in-out) infinite}.hero-aurora-b{width:26rem;height:26rem;bottom:-12rem;left:-8rem;background:radial-gradient(circle,var(--accent-2),transparent 70%);opacity:.4;animation:drift 26s var(--ease-in-out) infinite reverse}.hero-inner{position:relative;z-index:1;display:grid;gap:clamp(2.5rem,5vw,4rem);align-items:center}.hero-name{font-size:clamp(2.9rem,9vw,5.6rem);letter-spacing:-.045em;line-height:.98}.hero-roles{margin-top:var(--space-5);font-family:var(--font-mono);font-size:clamp(.92rem,2.3vw,1.08rem);font-weight:500;color:var(--text-soft);letter-spacing:-.01em}.hero-roles .sep{color:var(--accent);margin:0 .55rem}.hero-lead{margin-top:var(--space-6);max-width:50ch;font-size:clamp(1.05rem,2.4vw,1.25rem);color:var(--text-soft);line-height:1.6}.hero-actions{margin-top:var(--space-8);display:flex;flex-wrap:wrap;gap:var(--space-3)}.hero-stats{margin:clamp(2.5rem,5vw,3.5rem) 0 0;display:flex;flex-wrap:wrap;align-items:stretch}.stat{display:flex;flex-direction:column;align-items:flex-start;padding-right:clamp(1.25rem,4vw,2.25rem)}.stat+.stat{padding-left:clamp(1.25rem,4vw,2.25rem);border-left:1px solid var(--line)}.stat-value{margin:0;display:flex;align-items:baseline;gap:.06em;font-family:var(--font-display);font-weight:800;font-size:clamp(1.7rem,4vw,2.15rem);letter-spacing:-.04em;line-height:1.1}.stat-value .accent{color:var(--accent)}.stat-label{margin-top:var(--space-2);font-family:var(--font-mono);font-size:.74rem;color:var(--text-faint);letter-spacing:.01em;line-height:1.4;max-width:15ch}.hero-card{position:relative;border-radius:var(--radius-xl);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-lg);padding:var(--space-3);overflow:hidden;max-width:380px;width:100%;justify-self:end}.hero-card-photo{position:relative;border-radius:calc(var(--radius-xl) - 8px);overflow:hidden;aspect-ratio:4 / 5;background:var(--surface-2)}.hero-card-photo img{width:100%;height:100%;object-fit:cover}.hero-card-photo:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to top,rgba(8,9,12,.78) 0%,transparent 45%)}.hero-card-caption{position:absolute;left:var(--space-5);right:var(--space-5);bottom:var(--space-5);z-index:1;color:#fff}.hero-card-caption .loc{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.78rem;opacity:.85}.hero-card-caption .loc svg{width:13px;height:13px}.hero-card-meta{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-4) var(--space-3) var(--space-2)}.hero-card-meta span{font-family:var(--font-mono);font-size:.72rem;font-weight:500;color:var(--text-soft);padding:.32rem .6rem;border-radius:var(--radius-pill);background:var(--surface-2);border:1px solid var(--line)}.marquee{position:relative;border-block:1px solid var(--line);background:var(--bg-muted);padding:var(--space-5) 0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}.marquee-track{display:flex;width:max-content;gap:var(--space-10);animation:scroll-x 38s linear infinite}.marquee:hover .marquee-track{animation-play-state:paused}.marquee-item{display:inline-flex;align-items:center;gap:var(--space-3);font-family:var(--font-mono);font-size:.95rem;font-weight:500;color:var(--text-soft);white-space:nowrap}.marquee-item:before{content:"";width:5px;height:5px;border-radius:50%;background:var(--accent);opacity:.7}.project-toolbar{display:flex;flex-wrap:wrap;gap:var(--space-4);align-items:center;justify-content:space-between;margin-bottom:var(--space-8)}.search-field{position:relative;flex:1 1 240px;max-width:320px}.search-field svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-faint);pointer-events:none}.search-field input{width:100%;min-height:46px;border:1px solid var(--line);border-radius:var(--radius-pill);background:var(--surface);color:var(--text);padding:0 var(--space-4) 0 2.7rem;font:inherit;font-size:.92rem;transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out)}.search-field input::placeholder{color:var(--text-faint)}.search-field input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-tint)}.filter-wrap{display:flex;flex-wrap:wrap;gap:var(--space-2)}.chip{min-height:38px;border-radius:var(--radius-pill);border:1px solid var(--line);padding:0 var(--space-4);background:var(--surface);color:var(--text-soft);font:inherit;font-size:.83rem;font-weight:500;cursor:pointer;transition:background .18s var(--ease-out),border-color .18s var(--ease-out),color .18s var(--ease-out)}.chip:hover{color:var(--text);border-color:var(--line-strong)}.chip-active{background:var(--text);border-color:var(--text);color:var(--bg)}.project-grid{display:grid;gap:var(--space-5);grid-template-columns:1fr}.project-card{position:relative;display:flex;flex-direction:column;gap:var(--space-4);padding:clamp(1.5rem,3vw,2.1rem);border-radius:var(--radius-lg);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);overflow:hidden;transition:transform .35s var(--ease-out),box-shadow .35s var(--ease-out),border-color .35s var(--ease-out)}.project-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;opacity:0;background:radial-gradient(420px circle at var(--mx, 50%) var(--my, 50%),var(--spotlight),transparent 60%);transition:opacity .35s var(--ease-out);pointer-events:none}.project-card:hover{transform:translateY(-4px);border-color:var(--line-strong);box-shadow:var(--shadow-lg)}.project-card:hover:before{opacity:1}.project-top{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4)}.project-index{font-family:var(--font-mono);font-size:.8rem;color:var(--text-faint);letter-spacing:.02em}.project-featured-badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:.7rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--accent);padding:.28rem .6rem;border-radius:var(--radius-pill);border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);background:var(--accent-tint)}.project-card h3{font-size:clamp(1.3rem,2.6vw,1.65rem);letter-spacing:-.03em}.project-card p{color:var(--text-soft);font-size:.98rem;line-height:1.6;max-width:60ch}.project-card.is-featured{background:linear-gradient(180deg,var(--surface),var(--surface));border-color:var(--line-strong)}.tag-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.tag-list li{font-family:var(--font-mono);font-size:.74rem;font-weight:500;color:var(--text-soft);padding:.3rem .65rem;border-radius:var(--radius-xs);background:var(--surface-2);border:1px solid var(--line)}.project-footer{margin-top:auto;padding-top:var(--space-2)}.project-link{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:600;font-size:.92rem;color:var(--text);transition:gap .25s var(--ease-out),color .25s var(--ease-out)}.project-link svg{width:16px;height:16px;transition:transform .25s var(--ease-out)}.project-card:hover .project-link{color:var(--accent)}.project-card:hover .project-link svg{transform:translate(3px,-3px)}.project-empty{padding:var(--space-12);text-align:center;color:var(--text-faint);font-family:var(--font-mono);border:1px dashed var(--line-strong);border-radius:var(--radius-lg)}.about-layout{display:grid;gap:clamp(2rem,5vw,3.5rem);align-items:start}.about-lead{font-size:clamp(1.2rem,2.8vw,1.6rem);line-height:1.5;letter-spacing:-.02em;color:var(--text);font-weight:500;max-width:24ch}.about-body p{color:var(--text-soft);font-size:1.05rem;line-height:1.7;max-width:62ch}.about-body p+p{margin-top:var(--space-4)}.about-highlights{margin-top:var(--space-8);display:grid;gap:var(--space-4)}.about-highlights article{display:flex;gap:var(--space-4);padding:var(--space-5);border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);transition:transform .3s var(--ease-out),border-color .3s var(--ease-out)}.about-highlights article:hover{transform:translateY(-3px);border-color:var(--line-strong)}.about-icon{flex-shrink:0;width:42px;height:42px;border-radius:var(--radius-sm);display:grid;place-items:center;background:var(--accent-tint);color:var(--accent)}.about-icon svg{width:20px;height:20px}.about-highlights h3{font-size:1.05rem;margin-bottom:var(--space-2)}.about-highlights p{color:var(--text-soft);font-size:.93rem;line-height:1.55}.skills-grid{display:grid;gap:var(--space-4);grid-template-columns:1fr}.skills-grid article{padding:var(--space-6);border-radius:var(--radius-md);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow-sm);transition:border-color .3s var(--ease-out)}.skills-grid article:hover{border-color:var(--line-strong)}.skills-grid h3{display:flex;align-items:center;gap:var(--space-3);font-size:1.05rem;margin-bottom:var(--space-4)}.skills-grid h3 .num{font-family:var(--font-mono);font-size:.78rem;font-weight:500;color:var(--accent)}.badge-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.badge-list li{font-family:var(--font-mono);font-size:.8rem;font-weight:500;color:var(--text-soft);padding:.4rem .7rem;border-radius:var(--radius-xs);background:var(--surface-2);border:1px solid var(--line);transition:color .2s var(--ease-out),border-color .2s var(--ease-out),background .2s var(--ease-out)}.badge-list li:hover{color:var(--text);border-color:var(--accent);background:var(--accent-tint)}.timeline{position:relative;display:grid;gap:0;padding-left:var(--space-8)}.timeline:before{content:"";position:absolute;left:7px;top:8px;bottom:8px;width:2px;background:linear-gradient(to bottom,var(--accent),var(--line) 60%)}.timeline-item{position:relative;padding:0 0 var(--space-10)}.timeline-item:last-child{padding-bottom:0}.timeline-item:before{content:"";position:absolute;left:calc(-1 * var(--space-8) + 1px);top:6px;width:16px;height:16px;border-radius:50%;background:var(--bg-muted);border:3px solid var(--accent);box-shadow:0 0 0 5px var(--bg-muted)}.timeline-period{font-family:var(--font-mono);font-size:.78rem;font-weight:500;color:var(--accent);letter-spacing:.01em;margin-bottom:var(--space-2)}.timeline-item h3{font-size:clamp(1.15rem,2.4vw,1.4rem);letter-spacing:-.02em;margin-bottom:var(--space-3)}.timeline-item p{color:var(--text-soft);max-width:64ch;line-height:1.65}.contact-section .container{text-align:center}.contact-headline{font-size:clamp(2.2rem,7vw,4rem);letter-spacing:-.04em;line-height:1.02;max-width:16ch;margin:0 auto}.contact-sub{margin:var(--space-6) auto 0;max-width:48ch;color:var(--text-soft);font-size:clamp(1.02rem,2.3vw,1.18rem)}.contact-actions{margin-top:var(--space-8);display:flex;flex-wrap:wrap;gap:var(--space-3);justify-content:center}.contact-socials{margin-top:var(--space-10);display:flex;flex-wrap:wrap;gap:var(--space-5);justify-content:center}.contact-socials a{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-mono);font-size:.88rem;color:var(--text-soft);transition:color .2s var(--ease-out)}.contact-socials a:hover{color:var(--accent)}.contact-socials svg{width:17px;height:17px}.toast{position:fixed;left:50%;bottom:var(--space-6);transform:translate(-50%,12px);z-index:120;border-radius:var(--radius-pill);background:var(--text);color:var(--bg);font-weight:600;font-size:.88rem;padding:var(--space-3) var(--space-5);box-shadow:var(--shadow-lg);opacity:0;pointer-events:none;transition:opacity .25s var(--ease-out),transform .25s var(--ease-out)}.toast-visible{opacity:1;transform:translate(-50%)}.site-footer{border-top:1px solid var(--line);background:var(--bg-muted)}.footer-wrap{padding:clamp(2.5rem,5vw,3.5rem) 0;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--space-5)}.footer-brand{display:flex;align-items:center;gap:var(--space-3);font-weight:700}.footer-meta{color:var(--text-faint);font-size:.86rem;font-family:var(--font-mono)}.footer-top{display:inline-flex;align-items:center;gap:var(--space-2);font-size:.88rem;font-weight:600;color:var(--text-soft);transition:color .2s var(--ease-out)}.footer-top:hover{color:var(--accent)}.footer-top svg{width:15px;height:15px}.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease-out),transform .8s var(--ease-out)}.reveal-visible{opacity:1;transform:none}@keyframes drift{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(20px,30px,0) scale(1.08)}}@keyframes scroll-x{to{transform:translate(calc(-50% - var(--space-10) / 2))}}a:focus-visible,button:focus-visible,input:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:var(--radius-xs)}@media (min-width: 720px){.project-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.project-card.is-featured{grid-column:1 / -1}.skills-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.about-highlights{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 940px){.hero-inner{grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr)}.about-layout{grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr)}.about-highlights{grid-template-columns:1fr}}@media (max-width: 939px){.hero-card{justify-self:start;max-width:340px}}@media (max-width: 620px){.brand-name{display:none}.nav-list a{padding:.5rem .7rem;font-size:.85rem}.hero-stats{grid-template-columns:repeat(3,auto);gap:var(--space-5)}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}}
