:root{--bg:#04090d;--bg-2:#080f14;--surface:#0c1419;--surface-2:#151d22;--line:#252f36;--line-soft:#192227;--ink:#f5f5f5;--ink-2:#b8bfc3;--muted:#80878c;--faint:#474e53;--accent:#20d9ce;--accent-2:#00bfaf;--accent-ink:#050f15;--accent-glow:#20d9ce59;--grain-op:.045;--shadow:0 24px 60px -24px #000000b3;--particle:128,240,226;--font-display:"Space Grotesk",system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,monospace;--font-serif:"Instrument Serif",Georgia,serif;--maxw:1180px;--gutter:clamp(20px,5vw,80px);--r:14px;--r-lg:22px}@supports (color:lab(0% 0 0)){:root{--bg:lab(2.23228% -.955366 -2.10725);--bg-2:lab(4.07533% -1.6517 -3.57026);--surface:lab(5.7431% -2.11667 -4.42811);--surface-2:lab(10.1326% -2.78234 -4.8876);--line:lab(18.8391% -3.18049 -5.5181);--line-soft:lab(12.4537% -2.80581 -4.89657);--ink:lab(96.52% -.0000298023 .0000119209);--ink-2:lab(76.8272% -1.88127 -3.11954);--muted:lab(55.9517% -2.23836 -3.7331);--faint:lab(32.7505% -2.21221 -3.71978);--accent:lab(78.3717% -46.135 -7.34671);--accent-2:lab(69.3224% -52.2772 -5.23559);--accent-ink:lab(3.71648% -1.8399 -4.33106);--accent-glow:lab(78.3717% -46.135 -7.34671/.35);--shadow:0 24px 60px -24px lab(0% 0 0/.7)}}html[data-theme=light]{--bg:#eff5f5;--bg-2:#e7eeef;--surface:#fcfefe;--surface-2:#dfe8e9;--line:#c2cdcd;--line-soft:#d4dddd;--ink:#0c1317;--ink-2:#272f34;--muted:#52595e;--faint:#80878c;--accent:#008d8d;--accent-2:#007a77;--accent-ink:#fcfcfc;--accent-glow:#008d8d38;--grain-op:.03;--shadow:0 24px 60px -28px #2b4c5f47;--particle:14,130,122}@supports (color:lab(0% 0 0)){html[data-theme=light]{--bg:lab(95.9999% -1.89981 -.79807);--bg-2:lab(93.6998% -2.53275 -1.06348);--surface:lab(99.44% -.633419 -.266325);--surface-2:lab(91.3997% -3.16545 -1.32856);--line:lab(81.5596% -3.79789 -1.59286);--line-soft:lab(87.3397% -3.16539 -1.32844);--ink:lab(5.28882% -1.78097 -3.63748);--ink-2:lab(18.8326% -2.51988 -4.31124);--muted:lab(37.3908% -2.2193 -3.72331);--faint:lab(55.9517% -2.23836 -3.7331);--accent:lab(52.5436% -39.292 -11.7155);--accent-2:lab(45.7504% -43.7424 -10.223);--accent-ink:lab(98.84% .0000298023 -.0000119209);--accent-glow:lab(52.5436% -39.292 -11.7155/.22);--shadow:0 24px 60px -28px lab(30.4692% -7.98236 -15.0479/.28)}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}body{background-color:var(--bg);color:var(--ink);font-family:var(--font-display);cursor:none;font-size:17px;line-height:1.6;overflow-x:hidden}@media (pointer:coarse){body{cursor:auto}}::selection{background:var(--accent);color:var(--accent-ink)}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}.scroll-bar{z-index:300;background:var(--accent);width:0;height:2px;box-shadow:0 0 14px var(--accent-glow),0 0 4px var(--accent);transition:width 80ms linear;position:fixed;top:0;left:0}.cursor-aura{pointer-events:none;z-index:0;background:radial-gradient(circle,var(--accent-glow),transparent 62%);filter:blur(46px);opacity:.55;mix-blend-mode:screen;border-radius:50%;width:520px;height:520px;transition:opacity .5s;position:fixed;top:0;left:0;transform:translate(-50%,-50%)}html[data-theme=light] .cursor-aura{mix-blend-mode:multiply;opacity:.4}@media (pointer:coarse){.cursor-aura{display:none}}.grain{z-index:1;pointer-events:none;opacity:var(--grain-op);mix-blend-mode:overlay;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}.ambient{pointer-events:none;z-index:0;background:radial-gradient(circle,var(--accent-glow),transparent 65%);filter:blur(40px);opacity:.6;border-radius:50%;width:60vw;max-width:760px;height:60vw;max-height:760px;position:fixed;top:-18vw;right:-12vw}.cursor,.cursor-dot{z-index:9999;pointer-events:none;mix-blend-mode:difference;border-radius:50%;position:fixed;top:0;left:0}.cursor{border:1.5px solid #fff;width:38px;height:38px;transition:width .25s,height .25s,background .25s,opacity .25s;transform:translate(-50%,-50%)}.cursor-dot{background:#fff;width:5px;height:5px;transform:translate(-50%,-50%)}.cursor.hover{background:#fff;width:64px;height:64px}.cursor.hide{opacity:0}@media (pointer:coarse){.cursor,.cursor-dot{display:none}}.wrap{width:100%;max-width:var(--maxw);padding:0 var(--gutter);z-index:2;margin:0 auto;position:relative}section{position:relative}.eyebrow{font-family:var(--font-mono);letter-spacing:.22em;text-transform:uppercase;color:var(--accent);align-items:center;gap:14px;font-size:12.5px;display:inline-flex}.eyebrow .idx{color:var(--faint)}.eyebrow:before{content:"";background:var(--accent);width:34px;height:1px;display:inline-block}.sec-head{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:24px;margin-bottom:56px;display:flex}.sec-title{letter-spacing:-.03em;font-size:clamp(34px,6vw,68px);font-weight:600;line-height:.98}.sec-title em{font-family:var(--font-serif);color:var(--accent);font-style:italic;font-weight:400}.reveal{opacity:0;transition:opacity .9s cubic-bezier(.16,.84,.3,1),transform .9s cubic-bezier(.16,.84,.3,1);transform:translateY(34px)}.reveal.in{opacity:1;transform:none}.reveal[data-d="1"]{transition-delay:80ms}.reveal[data-d="2"]{transition-delay:.16s}.reveal[data-d="3"]{transition-delay:.24s}.reveal[data-d="4"]{transition-delay:.32s}@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}.nav{z-index:100;background-color:#0000;border-bottom:1px solid #0000;transition:background .4s,border-color .4s,-webkit-backdrop-filter .4s,backdrop-filter .4s;position:fixed;top:0;left:0;right:0}.nav.scrolled{background-color:color-mix(in oklch,var(--bg)72%,transparent);-webkit-backdrop-filter:blur(16px)saturate(1.4);backdrop-filter:blur(16px)saturate(1.4);border-color:var(--line-soft)}.nav-inner{max-width:var(--maxw);padding:0 var(--gutter);justify-content:space-between;align-items:center;height:76px;margin:0 auto;display:flex}.brand{font-family:var(--font-mono);letter-spacing:.04em;align-items:center;gap:9px;font-size:15px;font-weight:700;display:flex}.brand .sq{background:var(--accent);width:11px;height:11px;box-shadow:0 0 14px var(--accent-glow);animation:2.6s ease-in-out infinite pulseSq}@keyframes pulseSq{0%,to{transform:rotate(0)scale(1)}50%{transform:rotate(45deg)scale(.82)}}.nav-links{align-items:center;gap:22px;display:flex}.nav-links a{font-family:var(--font-mono);letter-spacing:.06em;color:var(--muted);text-transform:uppercase;font-size:12.5px;transition:color .25s;position:relative}.nav-links a:after{content:"";background:var(--accent);width:0;height:1px;transition:width .3s;position:absolute;bottom:-5px;left:0}.nav-links a:hover{color:var(--ink)}.nav-links a:hover:after{width:100%}.nav-links a.active{color:var(--ink)}.nav-links a.active:after{width:100%}.nav-right{align-items:center;gap:14px;display:flex}.theme-btn{border:1px solid var(--line);width:42px;height:42px;color:var(--ink);background:0 0;border-radius:50%;place-items:center;transition:border-color .25s,transform .25s;display:grid}.theme-btn:hover{border-color:var(--accent);transform:rotate(35deg)}.menu-btn{color:var(--ink);background:0 0;border:none;display:none}@media (max-width:1120px){.nav-links{display:none}.menu-btn{place-items:center;display:grid}}.hero{flex-direction:column;justify-content:center;min-height:100svh;padding-top:76px;display:flex;position:relative;overflow:hidden}#hero-canvas{z-index:1;width:100%;height:100%;position:absolute;inset:0}.hero-inner{z-index:3;width:100%;position:relative}.hero-top{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:clamp(30px,8vh,90px);display:flex}.status{font-family:var(--font-mono);letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);background:color-mix(in oklch,var(--surface)50%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:100px;align-items:center;gap:11px;padding:9px 16px;font-size:12.5px;display:inline-flex}.status .dot{width:8px;height:8px;position:relative}.status .dot:before,.status .dot:after{content:"";background:var(--accent);border-radius:50%;position:absolute;inset:0}.status .dot:after{animation:1.8s cubic-bezier(0,0,.2,1) infinite ping}@keyframes ping{75%,to{opacity:0;transform:scale(2.6)}}.hero-meta{font-family:var(--font-mono);letter-spacing:.08em;color:var(--faint);text-align:right;text-transform:uppercase;font-size:12px;line-height:1.9}.hero-stage{position:relative}.hero-fallback{letter-spacing:-.04em;font-size:clamp(56px,13.5vw,200px);font-weight:700;line-height:.86}.hero-canvas-wrap{width:100%;height:clamp(220px,38vh,420px);position:relative}.hero-hint{font-family:var(--font-mono);letter-spacing:.1em;color:var(--faint);text-transform:uppercase;align-items:center;gap:8px;font-size:11px;display:flex;position:absolute;bottom:6px;right:0}.hero-hint .blink{background:var(--accent);border-radius:50%;width:7px;height:7px;animation:1.4s step-end infinite blink}@keyframes blink{50%{opacity:.15}}.hero-bottom{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:40px;margin-top:clamp(28px,6vh,66px);display:flex}.hero-sub{max-width:440px;color:var(--ink-2);font-size:18px;line-height:1.6}.hero-sub b{color:var(--ink);font-weight:600}.hero-sub .ser{font-family:var(--font-serif);color:var(--accent);font-size:1.15em;font-style:italic}.hero-cta{flex-wrap:wrap;gap:14px;display:flex}.btn{font-family:var(--font-mono);letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--line);color:var(--ink);will-change:transform;background:0 0;border-radius:100px;align-items:center;gap:10px;padding:16px 26px;font-size:13px;transition:background .3s,color .3s,border-color .3s,transform .2s;display:inline-flex;position:relative}.btn .ic{transition:transform .3s}.btn-primary{background:var(--accent);color:var(--accent-ink);border-color:var(--accent);box-shadow:0 8px 30px -10px var(--accent-glow)}.btn-primary:hover{transform:translateY(-2px)}.btn-primary:hover .ic{transform:translate(2px,2px)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost:hover .ic{transform:translate(2px,-2px)}.scroll-cue{z-index:3;font-family:var(--font-mono);letter-spacing:.2em;text-transform:uppercase;color:var(--muted);flex-direction:column;align-items:center;gap:8px;font-size:11px;display:flex;position:absolute;bottom:26px;left:50%;transform:translate(-50%)}.scroll-cue .rail{background:linear-gradient(var(--accent),transparent);width:1px;height:42px;position:relative;overflow:hidden}.scroll-cue .rail:after{content:"";background:var(--ink);width:1px;height:10px;animation:1.8s ease-in-out infinite railrun;position:absolute;top:-10px;left:0}@keyframes railrun{0%{top:-10px}to{top:42px}}.block{padding:clamp(90px,14vh,150px) 0}.block.alt{background:var(--bg-2)}.about-grid{grid-template-columns:1.4fr 1fr;align-items:start;gap:clamp(36px,6vw,80px);display:grid}@media (max-width:880px){.about-grid{grid-template-columns:1fr}}.about-lead{letter-spacing:-.02em;font-size:clamp(22px,3vw,31px);font-weight:500;line-height:1.4}.about-lead b{color:var(--accent);font-weight:600}.about-lead .ser{font-family:var(--font-serif);font-style:italic;font-weight:400}.about-facts{border-top:1px solid var(--line-soft);gap:0;margin-top:40px;display:grid}.fact{border-bottom:1px solid var(--line-soft);grid-template-columns:28px 1fr auto;align-items:center;gap:18px;padding:20px 4px;transition:padding-left .3s,color .3s;display:grid}.fact:hover{padding-left:16px}.fact .k{font-family:var(--font-mono);color:var(--faint);font-size:11px}.fact .lbl{color:var(--muted);font-size:14px;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase}.fact .v{text-align:right;font-size:16px;font-weight:600}.fact:hover .v{color:var(--accent)}.whoami{border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow);background:#02060a;background:lab(1.56791% -.736393 -1.68948);overflow:hidden}html[data-theme=light] .whoami{background:#080e12;background:lab(3.71536% -1.38281 -2.90609)}.whoami-bar{background:#070e13;background:lab(3.71611% -1.54437 -3.3687);border-bottom:1px solid #1d252b;border-bottom:1px solid lab(14.1945% -2.82097 -4.90251);align-items:center;gap:8px;padding:13px 16px;display:flex}.whoami-bar .dots{gap:7px;display:flex}.whoami-bar .dots i{border-radius:50%;width:11px;height:11px;display:inline-block}.whoami-bar .t{font-family:var(--font-mono);color:#7b8185;color:lab(53.6268% -1.87159 -3.11426);margin-left:6px;font-size:11.5px}.whoami-body{font-family:var(--font-mono);color:#cbd2d7;color:lab(83.7873% -1.88327 -3.12065);min-height:318px;padding:22px 22px 26px;font-size:13.5px;line-height:1.85}.whoami-cmd{color:var(--accent)}.whoami-cmd .muted{color:#5e6468;color:lab(42.0264% -1.86379 -3.11012)}.wo{white-space:pre-wrap;word-break:break-word}.wo .key{color:#4db4cc;color:lab(68.1666% -25.7782 -21.2649)}.wo .str{color:#7cd591;color:lab(78.4684% -38.941 25.3387)}.wo .num{color:#e4b750;color:lab(77.0141% 9.01151 56.9378)}.wo .bool{color:#f47b74;color:lab(66.0576% 46.9408 26.6951)}.wo .punc{color:#6c7377;color:lab(47.8266% -1.86804 -3.11236)}.whoami-cur{background:var(--accent);vertical-align:-2px;width:8px;height:1.05em;margin-left:2px;animation:1s step-end infinite blink;display:inline-block}.whoami-cur.gone{display:none}.whoami-cap{font-family:var(--font-mono);color:var(--faint);letter-spacing:.06em;justify-content:space-between;margin-top:14px;font-size:11.5px;display:flex}.whoami-cap .ok{color:var(--accent)}.timeline{margin-top:10px;position:relative}.tl-row{border-top:1px solid var(--line-soft);grid-template-columns:120px 1fr;gap:clamp(20px,4vw,54px);padding:30px 0;transition:background .4s;display:grid;position:relative}.tl-row:last-child{border-bottom:1px solid var(--line-soft)}.tl-row:hover{background:color-mix(in oklch,var(--accent)5%,transparent)}.tl-year{font-family:var(--font-mono);letter-spacing:.04em;color:var(--accent);padding-top:4px;font-size:14px;font-weight:700}.tl-year .tag{color:var(--faint);letter-spacing:.14em;text-transform:uppercase;margin-top:6px;font-size:10px;font-weight:500;display:block}.tl-main{align-items:flex-start;gap:20px;display:flex}.tl-num{font-family:var(--font-mono);color:var(--faint);min-width:30px;padding-top:6px;font-size:12px}.tl-body h3{letter-spacing:-.02em;margin-bottom:8px;font-size:clamp(20px,2.6vw,28px);font-weight:600}.tl-body p{color:var(--muted);max-width:560px;font-size:16px}.tl-row.future h3{color:var(--accent)}.tl-row.future .tl-main:after{content:"→"}.marquee{border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);margin-bottom:60px;padding:22px 0;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000);mask-image:linear-gradient(90deg,#0000,#000 8% 92%,#0000)}.marquee-track{gap:56px;width:max-content;animation:26s linear infinite marq;display:flex}.marquee:hover .marquee-track{animation-play-state:paused}@keyframes marq{to{transform:translate(-50%)}}.marquee-item{font-family:var(--font-display);letter-spacing:-.02em;color:var(--faint);align-items:center;gap:56px;font-size:clamp(26px,4vw,46px);font-weight:600;transition:color .3s;display:inline-flex}.marquee-item:after{content:"✦";color:var(--accent);font-size:.5em}.marquee-item:hover{color:var(--ink)}.skills-grid{border:1px solid var(--line-soft);border-radius:var(--r-lg);grid-template-columns:repeat(3,1fr);gap:0;display:grid;overflow:hidden}@media (max-width:820px){.skills-grid{grid-template-columns:1fr 1fr}}@media (max-width:540px){.skills-grid{grid-template-columns:1fr}}.skill{border-right:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);padding:34px 30px;transition:background-color .4s;position:relative;overflow:hidden}.skill:before{content:attr(data-n);font-family:var(--font-mono);color:var(--faint);font-size:12px;position:absolute;top:18px;right:22px}.skill:hover{background-color:var(--surface)}.skill .ic{background:color-mix(in oklch,var(--accent)14%,transparent);width:44px;height:44px;color:var(--accent);border-radius:12px;place-items:center;margin-bottom:22px;transition:background .3s,color .3s,transform .3s;display:grid}.skill:hover .ic{background:var(--accent);color:var(--accent-ink);transform:translateY(-3px)}.skill h3{margin-bottom:6px;font-size:20px;font-weight:600}.skill p{color:var(--muted);font-size:14.5px}.proj-list{gap:26px;display:grid}.tilt{transform-style:preserve-3d;will-change:transform;transition:transform .15s ease-out}.proj{border:1px solid var(--line);border-radius:var(--r-lg);background-color:var(--surface);transition:border-color .4s,box-shadow .4s;position:relative;overflow:hidden}.proj:hover{border-color:color-mix(in oklch,var(--accent)55%,var(--line));box-shadow:var(--shadow)}.proj.feat{grid-template-columns:1.1fr 1fr;display:grid}@media (max-width:820px){.proj.feat{grid-template-columns:1fr}}.proj-media{background:repeating-linear-gradient(135deg,var(--surface-2)0 16px,var(--bg-2)16px 32px);border-right:1px solid var(--line);min-height:280px;position:relative;overflow:hidden}.proj-media .ph{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);justify-content:center;align-items:center;gap:10px;font-size:12px;display:flex;position:absolute;inset:0}.proj-media:after{content:"";background:linear-gradient(120deg,transparent 55%,color-mix(in oklch,var(--surface)65%,transparent));pointer-events:none;position:absolute;inset:0}.proj-media .glow{background:radial-gradient(circle,var(--accent-glow),transparent 70%);filter:blur(30px);border-radius:50%;width:200px;height:200px;position:absolute;top:-40px;right:-40px}.proj-art{z-index:1;text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:13px;padding:24px;transition:transform .6s cubic-bezier(.16,.84,.3,1);display:flex;position:absolute;inset:0}.proj:hover .proj-art{transform:scale(1.03)}.proj-art .pa-ic{width:52px;height:52px;color:var(--accent);opacity:.92}.proj-art .pa-name{font-family:var(--font-mono);letter-spacing:.02em;color:var(--ink);font-size:clamp(22px,2.8vw,32px);font-weight:700}.proj-art .pa-name b{color:var(--accent);font-weight:700}.proj-art .pa-name.serif{font-family:var(--font-serif);letter-spacing:0;font-size:clamp(27px,3.2vw,40px);font-style:italic;font-weight:400}.proj-art .pa-tag{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-size:11.5px}.proj-art.jc .pa-ic{color:#e4a0bf;color:lab(73.277% 29.4253 -5.61684)}.proj-body{flex-direction:column;gap:16px;padding:clamp(26px,3vw,44px);display:flex}.proj-top{justify-content:space-between;align-items:center;gap:16px;display:flex}.proj-kicker{font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-size:11px}.proj h3{letter-spacing:-.025em;font-size:clamp(24px,3vw,36px);font-weight:600;line-height:1.02}.proj p{color:var(--muted);font-size:15.5px;line-height:1.65}.proj-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-top:auto;padding-top:12px;display:flex}.status-chip{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--ink-2);border:1px solid var(--line);border-radius:100px;align-items:center;gap:8px;padding:7px 13px;font-size:11px;display:inline-flex}.status-chip .d{border-radius:50%;width:7px;height:7px}.status-chip.online .d{background:var(--accent);box-shadow:0 0 8px var(--accent-glow)}.status-chip.dev .d{background:#f3ba25;background:lab(79.3101% 12.3229 74.8349)}.proj-links{gap:18px;display:flex}.proj-links a{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;color:var(--ink-2);align-items:center;gap:6px;font-size:12px;transition:color .25s;display:inline-flex}.proj-links a:hover{color:var(--accent)}.proj-sub{grid-template-columns:1fr 1fr;gap:26px;display:grid}@media (max-width:720px){.proj-sub{grid-template-columns:1fr}}.proj.mini{flex-direction:column;display:flex}.proj.mini .proj-body{min-height:230px}.proj .arrow{border:1px solid var(--line);width:42px;height:42px;color:var(--ink-2);border-radius:50%;flex-shrink:0;place-items:center;transition:background .3s,color .3s,transform .3s;display:grid}.proj:hover .arrow{background:var(--accent);color:var(--accent-ink);transform:rotate(45deg)}.term-wrap{border-radius:var(--r-lg);border:1px solid var(--line);box-shadow:var(--shadow);background:#02060a;background:lab(1.56791% -.736393 -1.68948);overflow:hidden}html[data-theme=light] .term-wrap{background:#080e12;background:lab(3.71536% -1.38281 -2.90609)}.term-bar{background:#070e13;background:lab(3.71611% -1.54437 -3.3687);border-bottom:1px solid #1d252b;border-bottom:1px solid lab(14.1945% -2.82097 -4.90251);align-items:center;gap:8px;padding:14px 18px;display:flex}.term-bar .dots{gap:8px;display:flex}.term-bar .dots i{border-radius:50%;width:12px;height:12px;display:inline-block}.term-bar .t{font-family:var(--font-mono);color:#7b8185;color:lab(53.6268% -1.87159 -3.11426);margin-left:8px;font-size:12px}.term-body{height:360px;font-family:var(--font-mono);cursor:text;color:#cbd2d7;color:lab(83.7873% -1.88327 -3.12065);padding:20px 22px;font-size:13.5px;line-height:1.7;overflow-y:auto}.term-body::-webkit-scrollbar{width:8px}.term-body::-webkit-scrollbar-thumb{background:#262f35;background:lab(18.836% -2.8536 -4.91588);border-radius:8px}.term-line{white-space:pre-wrap;word-break:break-word}.term-line.in{color:var(--accent)}.term-line.err{color:#f66d67;color:lab(63.526% 53.3685 30.8739)}.term-input-row{color:var(--accent);align-items:center;display:flex}.term-input-row span{margin-right:9px}.term-input-row input{color:#dee6ea;color:lab(90.7474% -1.885 -3.12164);font-family:var(--font-mono);caret-color:var(--accent);background:0 0;border:none;outline:none;flex:1;font-size:13.5px}.term-hint{text-align:center;font-family:var(--font-mono);color:var(--muted);margin-top:18px;font-size:12px}.term-hint b{color:var(--accent)}.cert-bignum{align-items:baseline;gap:18px;margin-bottom:40px;display:flex}.cert-bignum .n{letter-spacing:-.05em;font-size:clamp(60px,12vw,150px);font-weight:700;line-height:.8}.cert-bignum .n em{font-family:var(--font-serif);color:var(--accent);font-style:italic;font-weight:400}.cert-bignum .meta{font-family:var(--font-mono);color:var(--muted);max-width:280px;font-size:13px;line-height:1.7}.cert-filters{flex-wrap:wrap;gap:10px;margin-bottom:34px;display:flex}.chip{font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--line);color:var(--muted);background:0 0;border-radius:100px;padding:9px 16px;font-size:12px;transition:all .25s}.chip:hover{color:var(--ink);border-color:var(--ink-2)}.chip.active{background:var(--accent);color:var(--accent-ink);border-color:var(--accent)}.cert-grid{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (max-width:720px){.cert-grid{grid-template-columns:1fr}}.cert{border:1px solid var(--line-soft);border-radius:var(--r);background-color:var(--surface);flex-direction:column;gap:16px;padding:24px;transition:border-color .3s,transform .3s;display:flex}.cert:hover{border-color:color-mix(in oklch,var(--accent)50%,var(--line));transform:translateY(-3px)}.cert-top{justify-content:space-between;align-items:center;display:flex}.cert-top .ic{background:color-mix(in oklch,var(--accent)14%,transparent);width:38px;height:38px;color:var(--accent);border-radius:10px;place-items:center;display:grid}.cat{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;border-radius:100px;padding:5px 10px;font-size:10.5px}.cat.programming{background:color-mix(in oklch,var(--accent)16%,transparent);color:var(--accent)}.cat.data{color:#60aaf3;color:lab(67.0489% -7.13784 -44.1464);background:#3a84ca2e;background:lab(53.0444% -5.47877 -43.8836/.18)}.cat.soft-skills{color:#4ebe7d;color:lab(69.3433% -44.5479 22.9571);background:#3aa85b29;background:lab(61.285% -45.3286 29.93/.16)}.cat.other{color:#ddb049;color:lab(74.6863% 9.14198 57.3365);background:#e0af3b29;background:lab(74.6768% 10.2723 63.231/.16)}.cert h3{font-size:16.5px;font-weight:600;line-height:1.3}.cert-meta{font-family:var(--font-mono);color:var(--muted);gap:16px;font-size:12px;display:flex}.cert-skills{flex-wrap:wrap;gap:7px;margin-top:auto;display:flex}.cert-skills span{font-family:var(--font-mono);color:var(--ink-2);border:1px solid var(--line-soft);border-radius:6px;padding:4px 9px;font-size:10.5px}.cert a.cred{font-family:var(--font-mono);color:var(--accent);align-items:center;gap:6px;font-size:12px;display:inline-flex}.cert-more{text-align:center;margin-top:34px}.cert-repo{border:1px solid var(--line-soft);border-radius:var(--r);text-align:center;font-family:var(--font-mono);color:var(--muted);margin-top:34px;padding:22px;font-size:13px}.cert-repo a{color:var(--accent)}.contact{padding:clamp(100px,16vh,180px) 0;position:relative}.contact-big{letter-spacing:-.04em;margin-bottom:40px;font-size:clamp(44px,10vw,132px);font-weight:700;line-height:.92}.contact-big em{font-family:var(--font-serif);color:var(--accent);font-style:italic;font-weight:400}.contact-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:40px;display:flex}.contact-links{flex:1;gap:0;min-width:300px;display:grid}.clink{border-top:1px solid var(--line-soft);justify-content:space-between;align-items:center;gap:20px;padding:22px 4px;transition:padding .3s,color .3s;display:flex}.clink:last-child{border-bottom:1px solid var(--line-soft)}.clink:hover{padding-left:14px;padding-right:14px}.clink .l{font-family:var(--font-mono);color:var(--faint);text-transform:uppercase;letter-spacing:.1em;font-size:12px}.clink .v{font-size:clamp(18px,2.4vw,26px);font-weight:500}.clink:hover .v{color:var(--accent)}.clink .ar{color:var(--muted);transition:transform .3s,color .3s}.clink:hover .ar{color:var(--accent);transform:translate(4px,-4px)}.footer{border-top:1px solid var(--line-soft);padding:50px 0 60px}.footer-inner{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;display:flex}.footer .copy{font-family:var(--font-mono);color:var(--faint);letter-spacing:.04em;font-size:12px}.footer .copy b{color:var(--ink-2)}.to-top{font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em;color:var(--muted);align-items:center;gap:8px;font-size:12px;transition:color .25s;display:flex}.to-top:hover{color:var(--accent)}.drawer{z-index:200;background:var(--bg);padding:100px var(--gutter)40px;visibility:hidden;flex-direction:column;transition:transform .5s cubic-bezier(.7,0,.2,1),visibility .5s;display:flex;position:fixed;inset:0;overflow-y:auto;transform:translateY(-100%)}.drawer.open{visibility:visible;transform:none}.drawer a{letter-spacing:-.02em;border-bottom:1px solid var(--line-soft);padding:14px 0;font-size:34px;font-weight:600}.drawer .close{top:26px;right:var(--gutter);color:var(--ink);background:0 0;border:none;position:absolute}@media (max-width:600px){body{font-size:16px}.hero-meta{display:none}.proj.feat{grid-template-columns:1fr}}.icon-btn{border:1px solid var(--line);width:42px;height:42px;color:var(--ink);background:0 0;border-radius:50%;place-items:center;transition:border-color .25s,color .25s,background-color .25s;display:grid}.icon-btn:hover{border-color:var(--accent);color:var(--accent)}.icon-btn[data-on=true]{border-color:var(--accent);color:var(--accent-ink);background-color:var(--accent)}.kbd-hint{font-family:var(--font-mono);letter-spacing:.04em;font-size:11px}@media (max-width:600px){.cmdk-trigger{display:none}}.lang-btn{border:1px solid var(--line);height:42px;color:var(--muted);font-family:var(--font-mono);letter-spacing:.06em;background:0 0;border-radius:100px;align-items:center;gap:5px;padding:0 14px;font-size:12px;transition:border-color .25s;display:inline-flex}.lang-btn:hover{border-color:var(--accent)}.lang-btn .lg{transition:color .25s}.lang-btn .lg.on{color:var(--accent)}.lang-btn .sep{color:var(--faint)}.greeting{color:var(--accent);text-transform:none;letter-spacing:.04em}.boot{z-index:500;background:var(--bg);justify-content:center;align-items:center;transition:opacity .7s,visibility .7s;display:flex;position:fixed;inset:0}.boot.done{opacity:0;visibility:hidden;pointer-events:none}.boot-inner{width:min(620px,86vw)}.boot-log{font-family:var(--font-mono);color:var(--ink-2);white-space:pre-wrap;min-height:320px;margin:0;font-size:clamp(12px,1.5vw,14.5px);line-height:1.85}.boot-log .ok{color:var(--accent)}.boot-log .dim{color:var(--faint)}.boot-log .cur{background:var(--accent);vertical-align:-2px;width:9px;height:1.05em;animation:1s step-end infinite blink;display:inline-block}.boot-skip{border:1px solid var(--line);color:var(--muted);font-family:var(--font-mono);letter-spacing:.08em;background:0 0;border-radius:100px;margin-top:22px;padding:8px 14px;font-size:11.5px;transition:color .25s,border-color .25s}.boot-skip:hover{color:var(--accent);border-color:var(--accent)}.cmdk{z-index:450;background:color-mix(in oklch,var(--bg)55%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);opacity:0;visibility:hidden;justify-content:center;align-items:flex-start;padding-top:14vh;transition:opacity .25s,visibility .25s;display:flex;position:fixed;inset:0}.cmdk.open{opacity:1;visibility:visible}.cmdk-panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);width:min(560px,92vw);box-shadow:var(--shadow);transition:transform .28s cubic-bezier(.16,.84,.3,1);overflow:hidden;transform:translateY(-12px)scale(.98)}.cmdk.open .cmdk-panel{transform:none}.cmdk-input-row{border-bottom:1px solid var(--line-soft);align-items:center;gap:12px;padding:18px 20px;display:flex}.cmdk-prompt{font-family:var(--font-mono);color:var(--accent);font-size:16px}.cmdk-input-row input{color:var(--ink);font-family:var(--font-display);background:0 0;border:none;outline:none;flex:1;font-size:17px}.cmdk-input-row input::placeholder{color:var(--faint)}.cmdk kbd,.cmdk-foot kbd{font-family:var(--font-mono);color:var(--muted);border:1px solid var(--line);background:var(--bg-2);border-radius:5px;padding:2px 6px;font-size:10.5px}.cmdk-list{max-height:46vh;margin:0;padding:8px;list-style:none;overflow-y:auto}.cmdk-item{cursor:pointer;border-radius:10px;align-items:center;gap:14px;padding:13px 14px;transition:background-color .15s;display:flex}.cmdk-item .ci-ic{background:color-mix(in oklch,var(--accent)14%,transparent);width:30px;height:30px;color:var(--accent);font-family:var(--font-mono);border-radius:8px;flex-shrink:0;place-items:center;font-size:13px;display:grid}.cmdk-item .ci-label{font-size:15px;font-weight:500}.cmdk-item .ci-kind{font-family:var(--font-mono);letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-left:auto;font-size:10.5px}.cmdk-item.active,.cmdk-item:hover{background:color-mix(in oklch,var(--accent)12%,transparent)}.cmdk-empty{text-align:center;font-family:var(--font-mono);color:var(--faint);padding:26px;font-size:13px}.cmdk-foot{border-top:1px solid var(--line-soft);font-family:var(--font-mono);color:var(--muted);gap:18px;padding:12px 18px;font-size:11px;display:flex}.cmdk-foot span{align-items:center;gap:6px;display:inline-flex}.reveal-cine{opacity:0;filter:blur(6px);transition:opacity 1s cubic-bezier(.16,.84,.3,1),transform 1s cubic-bezier(.16,.84,.3,1),filter 1s;transform:translateY(48px)scale(.965)}.reveal-cine.in{opacity:1;filter:none;transform:none}@media (prefers-reduced-motion:reduce){.reveal-cine{opacity:1;filter:none;transform:none}}:where(a,button,input,[tabindex],[data-magnetic]):focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:8px}:where(a,button,input,[tabindex]):focus:not(:focus-visible){outline:none}section[id],[id=top]{scroll-margin-top:96px}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}.marquee-track{animation:none!important;transform:none!important}.ambient,.cursor-aura{opacity:0!important}.grain,.scroll-cue,.hero-hint .blink{display:none}}::view-transition-old(root){mix-blend-mode:normal;animation:none}::view-transition-new(root){mix-blend-mode:normal;animation:none}::view-transition-new(root){z-index:1}::view-transition-old(root){z-index:0}
