@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap");:root{--bg:#0d0c0b;--bg-1:#131210;--bg-2:#1a1815;--bg-3:#211e1a;--line:rgba(236,232,224,0.09);--line-2:rgba(236,232,224,0.16);--text:#ece8e0;--text-dim:#a39c90;--text-mute:#6e685e;--accent:#4f8cff;--accent-2:#7fa9ff;--accent-rgb:79,140,255;--grad:linear-gradient(100deg,#4f8cff,#7c8bff 25%,#9b6cff 50%,#b594ff 70%,#4f8cff);--accent-dim:rgba(var(--accent-rgb),0.14);--accent-line:rgba(var(--accent-rgb),0.35);--font-sans:"Space Grotesk",system-ui,sans-serif;--font-mono:"JetBrains Mono",ui-monospace,monospace;--maxw:1240px;--ease:cubic-bezier(0.22,1,0.36,1)}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg);color:var(--text);font-family:var(--font-sans);font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}body:before{background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(circle at 50% 35%,#000 0,transparent 78%);-webkit-mask-image:radial-gradient(circle at 50% 35%,#000 0,transparent 78%);opacity:.5}body:after,body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0}body:after{background:radial-gradient(120% 80% at 50% -10%,rgba(var(--accent-rgb),.1),transparent 60%)}::selection{background:var(--accent);color:#0d0c0b}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.progress{height:2px;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2));z-index:200;box-shadow:0 0 12px rgba(var(--accent-rgb),.6)}.glow,.progress{position:fixed;top:0;left:0}.glow{width:480px;height:480px;border-radius:50%;background:radial-gradient(circle,rgba(var(--accent-rgb),.1),transparent 65%);transform:translate(-50%,-50%);pointer-events:none;z-index:1;transition:opacity .4s;opacity:0}.nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:20px clamp(20px,5vw,56px);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(var(--bg),rgba(13,12,11,0));transition:background .3s,border-color .3s;border-bottom:1px solid transparent}.nav.scrolled{background:rgba(13,12,11,.82);border-bottom:1px solid var(--line)}.nav .brand{font-family:var(--font-mono);font-weight:600;font-size:15px;letter-spacing:.04em;display:flex;align-items:center;gap:10px}.nav .brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 10px var(--accent);animation:pulse 2.4s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.35}}.nav-links{display:flex;gap:6px;align-items:center}.nav-links a{font-family:var(--font-mono);font-size:13px;color:var(--text-mute);padding:8px 14px;border-radius:8px;letter-spacing:.02em;transition:color .2s,background .2s;position:relative}.nav-links a .idx{color:var(--accent);opacity:.6;margin-right:6px}.nav-links a:hover{color:var(--text)}.nav-links a.active{color:var(--text);background:var(--bg-2)}.nav-links a.active .idx{opacity:1}.nav-cta{font-family:var(--font-mono);font-size:13px;color:#fff!important;background:var(--grad);background-size:200% 100%;background-position:0 50%;padding:9px 16px!important;border-radius:8px;font-weight:600;transition:transform .2s,box-shadow .2s,background-position .55s var(--ease)}.nav-cta:hover{transform:translateY(-1px);background-position:100% 50%;box-shadow:0 8px 24px rgba(124,108,255,.5)}.nav-toggle{display:none}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,56px)}.wrap,section{position:relative;z-index:2}.eyebrow{font-family:var(--font-mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:10px;margin-bottom:22px}.eyebrow:before{content:"";width:26px;height:1px;background:var(--accent);display:inline-block}h2.section-title{font-size:clamp(34px,5vw,60px);font-weight:600;letter-spacing:-.02em;line-height:1.04;text-wrap:balance}.section-head{margin-bottom:64px;max-width:760px}.section-head p{color:var(--text-dim);margin-top:18px;font-size:19px;max-width:580px}[data-reveal]{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease),transform .9s var(--ease)}[data-reveal].in{opacity:1;transform:none}[data-reveal-delay="1"]{transition-delay:.08s}[data-reveal-delay="2"]{transition-delay:.16s}[data-reveal-delay="3"]{transition-delay:.24s}[data-reveal-delay="4"]{transition-delay:.32s}[data-reveal-delay="5"]{transition-delay:.4s}.hero{min-height:100vh;display:flex;padding:120px 0 80px}.hero,.hero-grid{align-items:center}.hero-grid{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);grid-gap:clamp(36px,5vw,68px);gap:clamp(36px,5vw,68px);width:100%}.hero-grid>div{min-width:0}.hero .avail{font-family:var(--font-mono);font-size:13px;color:var(--text-dim);display:inline-flex;align-items:center;gap:9px;padding:7px 13px;border:1px solid var(--line-2);border-radius:100px;margin-bottom:28px}.hero .avail .led{width:7px;height:7px;border-radius:50%;background:#3ddc7e;box-shadow:0 0 8px #3ddc7e;animation:pulse 2s infinite}.hero h1{font-size:clamp(46px,8.5vw,104px);font-weight:600;line-height:.96;letter-spacing:-.03em}.hero h1 .accent{color:var(--accent)}.hero h1 .grad{background:var(--grad);background-size:280% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 26px rgba(124,139,255,.28));animation:gradFlow 6s linear infinite}@keyframes gradFlow{to{background-position:280% 50%}}.hero .role-line{font-family:var(--font-mono);font-size:clamp(15px,2.2vw,23px);color:var(--text-dim);margin-top:26px;min-height:2.9em;line-height:1.45;overflow-wrap:anywhere;max-width:100%}.hero .role-line .prompt{color:var(--accent);margin-right:6px}.hero .role-line .typed{color:var(--text)}.hero .role-line .caret{display:inline-block;width:9px;height:1.05em;background:var(--accent);transform:translateY(3px);margin-left:3px;animation:blink 1s steps(1) infinite}@keyframes blink{50%{opacity:0}}.hero .lead{color:var(--text-dim);font-size:19px;max-width:480px;margin-top:30px}.hero .cta-row{display:flex;gap:14px;margin-top:38px;flex-wrap:wrap}.btn{font-family:var(--font-mono);font-size:14px;padding:14px 24px;border-radius:10px;display:inline-flex;align-items:center;gap:10px;cursor:pointer;transition:all .2s var(--ease);border:1px solid var(--line-2);color:var(--text);background:transparent}.btn .arrow{transition:transform .2s}.btn:hover .arrow{transform:translateX(4px)}.btn.primary{background:var(--grad);background-size:200% 100%;background-position:0 50%;color:#fff;border:none;font-weight:600;transition:background-position .55s var(--ease),transform .2s var(--ease),box-shadow .25s var(--ease)}.btn.primary:hover{background-position:100% 50%;transform:translateY(-2px);box-shadow:0 16px 40px -14px rgba(124,108,255,.7)}.btn.ghost:hover{border-color:var(--accent-line);background:var(--accent-dim)}.terminal{background:linear-gradient(180deg,var(--bg-2),var(--bg-1));border:1px solid var(--line-2);border-radius:14px;overflow:hidden;box-shadow:0 30px 80px -30px rgba(0,0,0,.8),inset 0 1px 0 rgba(255,255,255,.03);font-family:var(--font-mono);font-size:13.5px}.terminal .bar{display:flex;align-items:center;gap:8px;padding:13px 16px;border-bottom:1px solid var(--line)}.terminal .bar .b{width:11px;height:11px;border-radius:50%;background:var(--bg-3)}.terminal .bar .b:first-child{background:#ff5f57}.terminal .bar .b:nth-child(2){background:#febc2e}.terminal .bar .b:nth-child(3){background:#28c840}.terminal .bar .title{margin-left:8px;color:var(--text-mute);font-size:12px}.terminal .body{padding:20px;line-height:1.85}.terminal .cmt{color:var(--text-mute)}.terminal .k{color:var(--accent)}.terminal .s{color:#7fd3a0}.terminal .v{color:var(--text)}.terminal .p{color:#7aa2f7}.terminal .ln{opacity:0;transform:translateY(8px);transition:all .5s var(--ease)}.terminal .ln.in{opacity:1;transform:none}.about{padding:120px 0}.about-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:72px;gap:72px;align-items:center}.about .photo{position:relative;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;background:linear-gradient(135deg,rgba(var(--accent-rgb),.1),transparent 60%),repeating-linear-gradient(45deg,var(--bg-2) 0 12px,var(--bg-1) 12px 24px);aspect-ratio:4/5}.about .photo img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(.2) contrast(1.02)}.about .photo .frame-tag{position:absolute;bottom:14px;left:14px;font-family:var(--font-mono);font-size:12px;color:var(--text);background:rgba(13,12,11,.7);border:1px solid var(--line-2);padding:6px 11px;border-radius:8px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.about p.body{color:var(--text-dim);font-size:20px;line-height:1.7}.about p.body strong{color:var(--text);font-weight:500}.about p.body+p.body{margin-top:22px}.about .sig{font-family:var(--font-mono);font-size:13px;color:var(--text-mute);margin-top:30px}.stats{display:grid;grid-template-columns:repeat(5,1fr);grid-gap:0;gap:0;margin-top:88px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.stat{padding:34px 22px;border-left:1px solid var(--line)}.stat:first-child{border-left:none}.stat .num{font-size:clamp(34px,4vw,52px);font-weight:600;letter-spacing:-.02em;line-height:1}.stat .num .suffix{color:var(--accent)}.stat .lbl{font-family:var(--font-mono);font-size:12.5px;color:var(--text-mute);margin-top:12px;letter-spacing:.02em}.skills{padding:120px 0}.skills-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px}.skill-card{border:1px solid var(--line);border-radius:14px;padding:28px;background:var(--bg-1);transition:border-color .3s,transform .3s,background .3s}.skill-card:hover{border-color:var(--accent-line);transform:translateY(-4px);background:var(--bg-2)}.skill-card .ico{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;background:var(--accent-dim);color:var(--accent);font-family:var(--font-mono);font-size:18px;font-weight:600;margin-bottom:20px;border:1px solid var(--accent-line)}.skill-card h3{font-size:20px;font-weight:600;margin-bottom:8px}.skill-card p{color:var(--text-mute);font-size:14.5px;font-family:var(--font-mono)}.skill-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}.skill-tags span{font-family:var(--font-mono);font-size:12px;color:var(--text-dim);border:1px solid var(--line-2);padding:5px 10px;border-radius:7px}.marquee{margin-top:64px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;padding:26px 0;--gap:64px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}.marquee .track{display:flex;gap:var(--gap);width:max-content;animation:scrollx 28s linear infinite}.marquee:hover .track{animation-play-state:paused}.marquee .item{font-family:var(--font-mono);font-size:17px;color:var(--text-mute);display:flex;gap:var(--gap);align-items:center;white-space:nowrap}.marquee .item:after{content:"◦";color:var(--accent)}@keyframes scrollx{to{transform:translateX(calc(-50% - var(--gap)/2))}}.work{position:relative}.work-sticky{position:-webkit-sticky;position:sticky;top:0;height:100vh;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-start}.work-head{position:relative;flex:0 0 auto;padding:clamp(92px,13vh,116px) clamp(20px,5vw,56px) 0;pointer-events:none}.work-head .row{display:flex;justify-content:space-between;align-items:flex-end;max-width:var(--maxw);margin:0 auto}.work-progress{font-family:var(--font-mono);font-size:13px;color:var(--text-mute)}.work-progress b{color:var(--accent)}.work-track{display:flex;gap:28px;padding:0 clamp(20px,5vw,56px);will-change:transform;align-items:center;margin:auto 0}.pcard{flex:0 0 clamp(320px,42vw,560px);border:1px solid var(--line-2);border-radius:16px;overflow:hidden;background:var(--bg-1);transition:border-color .3s}.pcard:hover{border-color:color-mix(in srgb,var(--theme) 45%,var(--line-2))}.pcard .pcard-visual{position:relative;aspect-ratio:16/11;display:grid;place-items:center;overflow:hidden;border-bottom:1px solid var(--line);background:radial-gradient(78% 70% at 50% 42%,color-mix(in srgb,var(--theme) 20%,transparent),transparent 72%),linear-gradient(180deg,var(--bg-2),var(--bg-1))}.pcard .pcard-visual .pattern{position:absolute;inset:0;pointer-events:none;background-image:radial-gradient(color-mix(in srgb,var(--theme) 26%,transparent) 1px,transparent 1.4px);background-size:17px 17px;-webkit-mask-image:radial-gradient(62% 60% at 50% 44%,#000,transparent 78%);mask-image:radial-gradient(62% 60% at 50% 44%,#000,transparent 78%);opacity:.4;transition:opacity .5s var(--ease)}.pcard .pcard-visual .glow{position:absolute;top:42%;left:50%;width:230px;height:230px;border-radius:50%;transform:translate(-50%,-50%);pointer-events:none;background:radial-gradient(circle,color-mix(in srgb,var(--theme) 60%,transparent),transparent 62%);filter:blur(34px);opacity:.5;transition:opacity .5s var(--ease),transform .6s var(--ease)}.pcard .pcard-visual .icon{position:relative;z-index:2;width:118px;height:118px;border-radius:26px;display:grid;place-items:center;color:color-mix(in srgb,var(--theme) 72%,#ffffff 28%);background:linear-gradient(160deg,color-mix(in srgb,var(--theme) 16%,transparent),color-mix(in srgb,var(--theme) 4%,transparent));border:1px solid color-mix(in srgb,var(--theme) 34%,transparent);box-shadow:0 18px 50px -16px color-mix(in srgb,var(--theme) 60%,transparent),inset 0 1px 0 rgba(255,255,255,.08);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s var(--ease)}.pcard .pcard-visual .icon svg{width:60px;height:60px}.pcard .pcard-visual .ring{position:absolute;z-index:1;width:172px;height:172px;border-radius:50%;border:1px solid color-mix(in srgb,var(--theme) 22%,transparent);pointer-events:none;transition:transform .6s var(--ease),opacity .5s}.pcard:hover .pcard-visual .icon{transform:translateY(-4px) scale(1.05);border-color:color-mix(in srgb,var(--theme) 55%,transparent);box-shadow:0 24px 60px -14px color-mix(in srgb,var(--theme) 75%,transparent),inset 0 1px 0 rgba(255,255,255,.1)}.pcard:hover .pcard-visual .glow{opacity:.78}.pcard:hover .pcard-visual .pattern{opacity:.55}.pcard:hover .pcard-visual .ring{transform:scale(1.08)}.pcard .pcard-visual .num{top:16px;left:16px;font-size:12px;color:var(--text-dim);letter-spacing:.04em}.pcard .pcard-visual .badge,.pcard .pcard-visual .num{position:absolute;z-index:3;font-family:var(--font-mono)}.pcard .pcard-visual .badge{top:14px;right:14px;font-size:11px;letter-spacing:.03em;color:color-mix(in srgb,var(--theme) 80%,#ffffff 20%);background:color-mix(in srgb,var(--theme) 13%,transparent);border:1px solid color-mix(in srgb,var(--theme) 32%,transparent);padding:5px 11px;border-radius:100px}.pcard .meta{padding:24px 26px 26px}.pcard .meta .top{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.pcard .meta h3{font-size:26px;font-weight:600;letter-spacing:-.01em}.pcard .meta .client{font-family:var(--font-mono);font-size:12.5px;color:var(--text-mute)}.pcard .meta .desc{color:var(--text-dim);font-size:15.5px;margin-top:12px}.pcard .meta .stack{display:flex;flex-wrap:wrap;gap:7px;margin-top:18px}.pcard .meta .stack span{font-family:var(--font-mono);font-size:11.5px;color:var(--text-dim);border:1px solid var(--line);padding:4px 9px;border-radius:6px}.pcard .meta .link{display:inline-flex;align-items:center;gap:8px;margin-top:22px;font-family:var(--font-mono);font-size:13px;color:color-mix(in srgb,var(--theme) 78%,#ffffff 22%);transition:gap .2s}.pcard .meta .link:hover{gap:13px}.work-hint{font-family:var(--font-mono);font-size:12px;color:var(--text-mute);display:flex;align-items:center;gap:8px}.work-end{flex:0 0 360px;display:flex;flex-direction:column;justify-content:center;gap:18px;padding-left:20px}.work-end h3{font-size:30px;font-weight:600;max-width:280px}.exp{padding:120px 0}.exp-wrap{position:relative;max-width:840px;margin:0 auto}.exp-line{position:absolute;left:7px;top:6px;bottom:6px;width:2px;background:var(--line-2)}.exp-line .fill{position:absolute;top:0;left:0;width:100%;height:0;background:linear-gradient(var(--accent),var(--accent-2));box-shadow:0 0 12px rgba(var(--accent-rgb),.5)}.exp-item{position:relative;padding:0 0 54px 48px}.exp-item:last-child{padding-bottom:0}.exp-item .node{position:absolute;left:0;top:4px;width:16px;height:16px;border-radius:50%;background:var(--bg);border:2px solid var(--line-2);transition:all .4s var(--ease)}.exp-item.lit .node{border-color:var(--accent);background:var(--accent);box-shadow:0 0 0 5px var(--accent-dim),0 0 16px rgba(var(--accent-rgb),.6)}.exp-item .when{font-family:var(--font-mono);font-size:13px;color:var(--accent);margin-bottom:7px}.exp-item h3{font-size:23px;font-weight:600}.exp-item .org{color:var(--text-dim);font-size:16px;margin-top:4px}.exp-item.current h3:after{content:"NOW";font-family:var(--font-mono);font-size:10px;vertical-align:middle;margin-left:12px;color:var(--accent);border:1px solid var(--accent-line);background:var(--accent-dim);padding:3px 7px;border-radius:6px;letter-spacing:.08em}.writing{padding:120px 0}.posts{display:grid;grid-gap:0;gap:0;border-top:1px solid var(--line)}.post{display:grid;grid-template-columns:120px 1fr auto;grid-gap:30px;gap:30px;align-items:center;padding:30px 6px;border-bottom:1px solid var(--line);transition:padding .3s var(--ease),background .3s}.post:hover{padding-left:22px;background:linear-gradient(90deg,var(--accent-dim),transparent 60%)}.post .cat{font-family:var(--font-mono);font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.08em}.post h3{font-size:23px;font-weight:500;transition:color .2s}.post:hover h3{color:var(--accent)}.post .date{font-family:var(--font-mono);font-size:13px;color:var(--text-mute);white-space:nowrap}.github{padding:120px 0}.gh-panel{border:1px solid var(--line-2);border-radius:18px;overflow:hidden;background:linear-gradient(180deg,var(--bg-1),var(--bg));padding:48px clamp(28px,4vw,56px)}.gh-top{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:24px}.gh-top h3{font-size:30px;font-weight:600}.gh-top h3 span{color:var(--accent);font-family:var(--font-mono)}.gh-top p{color:var(--text-dim);margin-top:10px;max-width:420px}.gh-grid{display:grid;grid-template-columns:repeat(auto-fill,13px);grid-gap:5px;gap:5px;margin-top:40px;justify-content:start}.gh-cell{width:13px;height:13px;border-radius:3px;background:var(--bg-3)}.gh-legend{display:flex;align-items:center;gap:10px;font-family:var(--font-mono);font-size:12px;color:var(--text-mute);margin-top:20px}.gh-legend .scale{display:flex;gap:4px}.gh-legend .scale i{width:12px;height:12px;border-radius:3px;display:block}.contact{padding:130px 0 0}.contact-grid{display:grid;grid-template-columns:1fr 1.05fr;grid-gap:clamp(36px,6vw,90px);gap:clamp(36px,6vw,90px);align-items:start;max-width:var(--maxw);margin:0 auto}.contact-form,.contact-intro{min-width:0}.contact-intro h2{font-size:clamp(40px,5.4vw,76px);font-weight:600;letter-spacing:-.03em;line-height:.98;font-style:normal}.contact-intro h2 .accent{background:var(--grad);background-size:280% 100%;-webkit-background-clip:text;background-clip:text;color:transparent;-webkit-text-fill-color:transparent;filter:drop-shadow(0 4px 22px rgba(124,139,255,.3));animation:gradFlow 6s linear infinite}.contact-lead{color:var(--text-dim);font-size:18px;max-width:440px;margin-top:26px}.contact-cards{display:flex;flex-direction:column;gap:12px;margin-top:44px}.cc{display:flex;align-items:center;gap:16px;padding:16px 18px;border:1px solid var(--line);border-radius:14px;background:var(--bg-1);transition:border-color .22s var(--ease),background .22s var(--ease),transform .22s var(--ease)}.cc:hover{border-color:var(--accent-line);background:var(--bg-2);transform:translateY(-2px)}.cc-ico{flex:none;width:44px;height:44px;border-radius:11px;display:grid;place-items:center;background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent-line)}.cc-ico svg{width:20px;height:20px}.cc-txt{display:flex;flex-direction:column;gap:3px;min-width:0}.cc-lbl{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mute)}.cc-val{font-size:15.5px;color:var(--text);font-style:normal;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.contact-form{border:1px solid var(--line-2);border-radius:20px;background:var(--bg-1);padding:clamp(26px,3vw,40px);gap:22px;box-shadow:0 30px 80px -40px rgba(0,0,0,.7)}.contact-form,.field{display:flex;flex-direction:column}.field{gap:10px}.field label{font-family:var(--font-mono);font-size:13px;letter-spacing:.02em;color:var(--text-dim)}.contact-form input,.contact-form textarea{width:100%;font-family:var(--font-sans);font-size:16px;color:var(--text);background:var(--bg);border:1px solid var(--line-2);border-radius:12px;padding:15px 16px;transition:border-color .2s,box-shadow .2s,background .2s;resize:vertical}.contact-form textarea{min-height:140px;line-height:1.55}.contact-form input::placeholder,.contact-form textarea::placeholder{color:var(--text-mute)}.contact-form input:focus,.contact-form textarea:focus{outline:none;border-color:var(--accent);background:var(--bg-1);box-shadow:0 0 0 4px var(--accent-dim)}.contact-form input:user-invalid,.contact-form textarea:user-invalid{border-color:rgba(255,90,90,.6)}.btn.primary.form-submit{justify-content:center;gap:11px;padding:17px 24px;font-size:15px;margin-top:2px;color:#fff;border:none;font-weight:600;background:var(--grad);background-size:200% 100%;background-position:0 50%;box-shadow:0 18px 44px -16px rgba(124,108,255,.7);transition:background-position .5s var(--ease),transform .2s var(--ease),box-shadow .25s var(--ease)}.btn.primary.form-submit:hover{background-position:100% 50%;transform:translateY(-2px);box-shadow:0 22px 50px -16px rgba(124,108,255,.85)}.form-submit .send-ico{width:18px;height:18px;flex:none}.btn.primary.form-submit:disabled{opacity:.6;cursor:progress}.form-note{text-align:center;font-family:var(--font-mono);font-size:13px;color:var(--text-mute);overflow-wrap:anywhere}.form-note a{color:var(--accent)}.form-note a:hover{text-decoration:underline}.form-note.is-ok{color:#3ddc7e}.form-note.is-err{color:#ff6b6b}.contact .meta-row{display:flex;gap:28px;margin-top:40px;flex-wrap:wrap;font-family:var(--font-mono);font-size:13px;color:var(--text-mute)}.contact .meta-row .led{width:7px;height:7px;border-radius:50%;background:#3ddc7e;box-shadow:0 0 8px #3ddc7e;display:inline-block;margin-right:8px}@media (max-width:900px){.contact-grid{grid-template-columns:1fr;gap:48px}}footer{margin-top:120px;border-top:1px solid var(--line);padding:34px clamp(20px,5vw,56px);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;font-family:var(--font-mono);font-size:12.5px;color:var(--text-mute);position:relative;z-index:2}footer a:hover{color:var(--accent)}.theme-fab{position:fixed;right:22px;bottom:22px;z-index:300}.theme-fab-btn{width:50px;height:50px;border-radius:50%;cursor:pointer;display:grid;place-items:center;color:var(--accent);background:var(--bg-1);border:1px solid var(--accent-line);box-shadow:0 10px 30px -8px rgba(0,0,0,.6),0 0 0 4px var(--accent-dim);transition:transform .25s var(--ease),box-shadow .25s var(--ease)}.theme-fab-btn:hover{transform:translateY(-2px) rotate(-8deg)}.theme-fab-btn svg{width:22px;height:22px}.theme-pop{position:absolute;right:0;bottom:64px;width:228px;background:var(--bg-1);border:1px solid var(--line-2);border-radius:16px;padding:16px;box-shadow:0 24px 60px -20px rgba(0,0,0,.75);opacity:0;transform:translateY(8px) scale(.96);transform-origin:bottom right;pointer-events:none;transition:opacity .2s var(--ease),transform .2s var(--ease)}.theme-fab.open .theme-pop{opacity:1;transform:none;pointer-events:auto}.theme-pop-head{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-mute);margin-bottom:14px}.swatches{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px}.swatch{aspect-ratio:1;border-radius:10px;cursor:pointer;position:relative;border:2px solid transparent;transition:transform .18s var(--ease),border-color .18s var(--ease);background:var(--sw);box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.swatch:hover{transform:scale(1.08)}.swatch.active{border-color:var(--text)}.swatch.active:after{content:"";position:absolute;inset:0;margin:auto;width:7px;height:7px;border-radius:50%;background:#0d0c0b;box-shadow:0 0 0 2px rgba(255,255,255,.6)}@media (max-width:680px){.theme-fab{right:14px;bottom:14px}}@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:44px}.hero .terminal{order:2}.about-grid{grid-template-columns:1fr;gap:40px}.about .photo{max-width:380px}.skills-grid{grid-template-columns:1fr 1fr}.stats{grid-template-columns:repeat(3,1fr)}.stat:nth-child(4){border-left:none}.stat{border-top:1px solid var(--line)}.stats{border-top:none}}@media (max-width:680px){body{font-size:16px}.nav-links{display:flex;flex-direction:column;position:absolute;top:calc(100% + 8px);right:16px;left:16px;background:var(--bg-1);border:1px solid var(--line-2);border-radius:14px;padding:12px;gap:4px;opacity:0;visibility:hidden;transform:translateY(-10px) scale(.98);transform-origin:top right;pointer-events:none;box-shadow:0 24px 50px -24px rgba(0,0,0,.8);transition:opacity .28s var(--ease),transform .3s var(--ease),visibility .3s var(--ease)}.nav-links.open{opacity:1;visibility:visible;transform:none;pointer-events:auto}.nav-links a{opacity:0;transform:translateY(6px);transition:opacity .25s var(--ease),transform .25s var(--ease),color .2s,background .2s}.nav-links.open a{opacity:1;transform:none}.nav-links.open a:first-child{transition-delay:.04s}.nav-links.open a:nth-child(2){transition-delay:.08s}.nav-links.open a:nth-child(3){transition-delay:.12s}.nav-links.open a:nth-child(4){transition-delay:.16s}.nav-links.open a:nth-child(5){transition-delay:.2s}.nav-toggle{display:inline-flex;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:44px;height:40px;color:var(--text);background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;cursor:pointer;transition:border-color .2s,background .2s}.nav-toggle:hover{border-color:var(--accent-line)}.nav-toggle span{display:block;width:20px;height:2px;border-radius:2px;background:currentColor;transition:transform .3s var(--ease),opacity .2s var(--ease)}.nav:has(.nav-links.open) .nav-toggle span:first-child{transform:translateY(7px) rotate(45deg)}.nav:has(.nav-links.open) .nav-toggle span:nth-child(2){opacity:0}.nav:has(.nav-links.open) .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.skills-grid{grid-template-columns:1fr}.stats{grid-template-columns:1fr 1fr}.stat:nth-child(odd){border-left:none}.post{grid-template-columns:1fr;gap:8px;padding:22px 6px}.post .date{order:-1}.work-sticky{height:auto;padding:100px 0 60px}.work-track{flex-direction:column;transform:none!important}.pcard{flex:1 1 auto;width:100%}.work-head{position:relative;padding:0 clamp(20px,5vw,56px) 40px}.work-end{flex:1 1 auto;padding-left:0}}@media (prefers-reduced-motion:reduce){*{animation-duration:1ms!important;transition-duration:1ms!important;scroll-behavior:auto}[data-reveal]{opacity:1;transform:none}}@media (min-width:681px) and (max-height:820px){.work-head{padding-top:84px}.pcard .pcard-visual{aspect-ratio:16/9}.pcard .pcard-visual .icon{width:104px;height:104px;border-radius:23px}.pcard .pcard-visual .icon svg{width:52px;height:52px}.pcard .meta{padding:20px 22px 22px}.pcard .meta h3{font-size:23px}.pcard .meta .desc{font-size:14.5px;margin-top:9px}.pcard .meta .stack{margin-top:13px}.pcard .meta .link{margin-top:15px}}@media (min-width:681px) and (max-height:680px){.work-head{padding-top:74px}.work-head .section-title{font-size:30px}.pcard{flex-basis:clamp(300px,40vw,480px)}.pcard .pcard-visual{aspect-ratio:16/8}.pcard .pcard-visual .icon{width:90px;height:90px;border-radius:20px}.pcard .pcard-visual .icon svg{width:46px;height:46px}.pcard .pcard-visual .ring{width:140px;height:140px}.pcard .meta{padding:16px 20px 18px}.pcard .meta .desc{display:none}.pcard .meta .stack{margin-top:10px}.pcard .meta .link{margin-top:12px}}