@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2c55a0e60120577a-s.2a48534a.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/9c72aa0f40e4eef8-s.18a48cbc.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/ad66f9afd8947f86-s.7a40eb73.woff2)format("woff2");unicode-range:U+1F??}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/5476f68d60460930-s.c995e352.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/2bbe8d2671613f1f-s.76dcb0b2.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/1bffadaabf893a1e-s.7cd81963.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter;font-style:normal;font-weight:100 900;font-display:swap;src:url(../media/83afe278b6a6bb3c-s.p.3a6ba036.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter Fallback;src:local(Arial);ascent-override:90.44%;descent-override:22.52%;line-gap-override:0.0%;size-adjust:107.12%}.inter_fd091ad6-module__giF-bG__className{font-family:Inter,Inter Fallback;font-style:normal}.inter_fd091ad6-module__giF-bG__variable{--font-sans:"Inter","Inter Fallback"}
@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/13bf9871fe164e7f-s.f2220059.woff2)format("woff2");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/cc545e633e20c56d-s.f6f1950f.woff2)format("woff2");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/71b036adf157cdcf-s.bd5f4d11.woff2)format("woff2");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/89b21bb081cb7469-s.51c18f09.woff2)format("woff2");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/3fe682a82f50d426-s.23358719.woff2)format("woff2");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:100 800;font-display:swap;src:url(../media/70bc3e132a0a741e-s.p.15008bfb.woff2)format("woff2");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:JetBrains Mono Fallback;src:local(Arial);ascent-override:75.79%;descent-override:22.29%;line-gap-override:0.0%;size-adjust:134.59%}.jetbrains_mono_6104e6b7-module__s6uLTa__className{font-family:JetBrains Mono,JetBrains Mono Fallback;font-style:normal}.jetbrains_mono_6104e6b7-module__s6uLTa__variable{--font-mono:"JetBrains Mono","JetBrains Mono Fallback"}
:root{--nav-h:64px;--bg:#070b12;--bg-2:#0d1421;--bg-3:#111c2e;--bg-4:#192538;--accent:#00c8f0;--accent-mid:#00a8cc;--accent-dim:#00c8f014;--accent-ring:#00c8f047;--accent-text:#00c8f0;--green:#22c55e;--green-dim:#22c55e1a;--amber:#f59e0b;--amber-dim:#f59e0b1a;--warn:#f59e0b;--danger:#f87171;--info:#60a5fa;--success:#22c55e;--tx-1:#e8edf5;--tx-2:#8b9ab5;--tx-3:#56657e;--tx-4:#2a3550;--bd:#ffffff12;--bd-2:#ffffff1f;--bd-s:#00c8f038;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"SFMono-Regular","JetBrains Mono","Fira Code",Consolas,monospace;--r-xs:2px;--r-sm:4px;--r:6px;--r-lg:8px;--r-xl:12px;--ease:cubic-bezier(.16,1,.3,1);--t:.16s ease;--t-s:.32s var(--ease);--shadow:0 4px 24px #0009;--shadow-lg:0 16px 48px #000c;--glow:0 0 32px #00c8f01f;--color-accent:var(--accent);--color-text-secondary:var(--tx-2);--color-text-tertiary:var(--tx-3);--space-xs:6px;--space-sm:12px;--space-md:20px;--space-lg:32px;--space-xl:48px;--font-code:var(--font-mono);--nav-height:var(--nav-h)}[data-theme=light]{--bg:#f0f4fa;--bg-2:#fff;--bg-3:#f6f9fd;--bg-4:#eaeef8;--accent:#0284c7;--accent-mid:#0369a1;--accent-dim:#0284c714;--accent-ring:#0284c73d;--accent-text:#0284c7;--green:#16a34a;--green-dim:#16a34a14;--warn:#d97706;--danger:#dc2626;--tx-1:#0c1220;--tx-2:#3d5068;--tx-3:#7a8fa6;--tx-4:#c0cedf;--bd:#00000014;--bd-2:#00000024;--bd-s:#0284c73d;--shadow:0 2px 12px #00000014;--shadow-lg:0 8px 32px #0000001f;--glow:none}@keyframes caret{0%,to{opacity:1}50%{opacity:0}}@keyframes ping-dot{0%,70%{opacity:.9;transform:scale(1)}to{opacity:0;transform:scale(2.2)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes glitch-a{0%{clip-path:inset(38% 0 54%);transform:translate(-3px)}25%{clip-path:inset(75% 0 8%);transform:translate(3px)}50%{clip-path:inset(44% 0 18%);transform:translate(-2px)}75%{clip-path:inset(20% 0 58%);transform:translate(2px)}to{clip-path:inset(52% 0 34%);transform:translate(0)}}@keyframes glitch-b{0%{clip-path:inset(20% 0 58%);transform:translate(3px)}25%{clip-path:inset(52% 0 12%);transform:translate(-3px)}50%{clip-path:inset(60% 0 32%);transform:translate(2px)}75%{clip-path:inset(36% 0 52%);transform:translate(-2px)}to{clip-path:inset(40% 0 16%);transform:translate(0)}}@keyframes fadeUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}html,body{max-width:100vw;overflow-x:hidden}body{background:var(--bg);color:var(--tx-1);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.65;transition:background .22s,color .22s}a{color:inherit;text-decoration:none}img{max-width:100%;display:block}button{cursor:pointer;font:inherit;color:inherit;background:0 0;border:none}::selection{background:var(--accent-dim);color:var(--accent)}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--bd-2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--accent)}.container{max-width:1160px;margin:0 auto;padding:0 32px}@media (max-width:640px){.container{padding:0 20px}}.glitch{display:inline-block;position:relative}.glitch:before,.glitch:after{content:attr(data-text);pointer-events:none;display:none;position:absolute;inset:0}.btn{border-radius:var(--r);letter-spacing:.01em;transition:all var(--t);white-space:nowrap;cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:10px 22px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent);color:#070b12;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-mid);border-color:var(--accent-mid);transform:translateY(-1px)}.btn-ghost{color:var(--tx-1);border-color:var(--bd-2);background:0 0}.btn-ghost:hover{border-color:var(--accent-ring);color:var(--accent);background:var(--accent-dim);transform:translateY(-1px)}.btn-secondary{background:var(--bg-3);color:var(--tx-2);border-color:var(--bd)}.btn-secondary:hover{color:var(--tx-1);border-color:var(--bd-2)}.btn-icon{border-radius:var(--r);border:1px solid var(--bd);width:38px;height:38px;color:var(--tx-2);transition:all var(--t);justify-content:center;align-items:center;display:flex}.btn-icon:hover{color:var(--accent);border-color:var(--bd-s);background:var(--accent-dim)}.navbar{z-index:1000;height:var(--nav-h);-webkit-backdrop-filter:blur(24px);background:#03050af5;border-bottom:1px solid #00c8f02e;position:fixed;inset:0 0 auto}[data-theme=light] .navbar{background:#fffffff7;border-bottom-color:#0284c733}.navbar-inner{justify-content:space-between;align-items:center;max-width:1160px;height:100%;margin:0 auto;padding:0 32px;display:flex}@media (max-width:640px){.navbar-inner{padding:0 20px}}.navbar-logo{font-family:var(--font-mono);color:var(--tx-1);letter-spacing:-.01em;align-items:center;gap:10px;font-size:1rem;font-weight:700;display:flex}.navbar-logo-icon{border-radius:var(--r);background:var(--accent);color:#070b12;width:30px;height:30px;font-family:var(--font-mono);letter-spacing:0;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:800;display:flex}.navbar-links{align-items:center;gap:2px;list-style:none;display:flex}.navbar-link{border-radius:var(--r);color:var(--tx-2);transition:color var(--t),background var(--t);align-items:center;gap:5px;padding:6px 13px;font-size:.875rem;font-weight:500;display:flex}.navbar-link:hover{color:var(--tx-1);background:var(--bg-3)}.navbar-link.active{color:var(--accent);background:var(--accent-dim)}.navbar-actions{align-items:center;gap:8px;display:flex}.theme-toggle,.mobile-toggle{border-radius:var(--r);width:34px;height:34px;color:var(--tx-2);border:1px solid var(--bd);transition:all var(--t);justify-content:center;align-items:center;display:flex}.theme-toggle:hover,.mobile-toggle:hover{color:var(--accent);border-color:var(--bd-s);background:var(--accent-dim)}.mobile-toggle{display:none}@media (max-width:760px){.navbar-links{display:none}.mobile-toggle{display:flex}.navbar-links.open{top:var(--nav-h);background:var(--bg-2);border-bottom:1px solid var(--bd);z-index:999;flex-direction:column;align-items:stretch;gap:2px;padding:12px 16px 18px;display:flex;position:fixed;left:0;right:0}.navbar-links.open .navbar-link{padding:11px 14px;font-size:.95rem}}.hero{min-height:100vh;padding:calc(var(--nav-h) + 64px)32px 80px;align-items:center;display:flex;position:relative;overflow:hidden}.hero-grid-bg{pointer-events:none;background-image:radial-gradient(circle,#00c8f01f 1px,#0000 1px);background-size:44px 44px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(80% 70% at 50% 40%,#000 10%,#0000 100%);mask-image:radial-gradient(80% 70% at 50% 40%,#000 10%,#0000 100%)}.hero-grid-bg:after{content:"";pointer-events:none;background:radial-gradient(circle,#00c8f00f 0%,#0000 70%);width:600px;height:600px;position:absolute;top:-100px;right:-100px}.hero-grid{z-index:1;grid-template-columns:1fr 420px;align-items:center;gap:72px;width:100%;max-width:1160px;margin:0 auto;display:grid;position:relative}@media (max-width:1000px){.hero-grid{grid-template-columns:1fr;gap:48px}.hero{padding:calc(var(--nav-h) + 40px)20px 60px}}.hero-status{background:var(--green-dim);font-family:var(--font-mono);letter-spacing:.08em;color:var(--green);border:1px solid #22c55e38;border-radius:100px;align-items:center;gap:8px;width:fit-content;margin-bottom:24px;padding:5px 14px 5px 10px;font-size:.72rem;display:inline-flex}.hero-status-dot{background:var(--green);border-radius:50%;width:7px;height:7px;position:relative}.hero-status-dot:after{content:"";background:var(--green);opacity:.3;border-radius:50%;animation:2s ease-out infinite ping-dot;position:absolute;inset:-2px}.hero-name{letter-spacing:-.04em;color:var(--tx-1);margin-bottom:16px;font-size:clamp(2.8rem,7vw,5rem);font-weight:800;line-height:1.04}.hero-name-accent{color:var(--accent)}.hero-title{font-family:var(--font-mono);color:var(--tx-2);margin-bottom:20px;font-size:clamp(.9rem,1.8vw,1.05rem);line-height:1.5}.hero-title-sep{color:var(--tx-4);margin:0 6px}.hero-bio{color:var(--tx-2);max-width:520px;margin-bottom:36px;font-size:1.05rem;line-height:1.8}.hero-ctas{flex-wrap:wrap;gap:10px;margin-bottom:48px;display:flex}.hero-stats{border-top:1px solid var(--bd);align-items:center;padding-top:20px;display:flex}.hero-stat{flex-direction:column;gap:3px;padding:0 28px;display:flex}.hero-stat:first-child{padding-left:0}.hero-stat-num{font-family:var(--font-mono);color:var(--accent);font-size:1.6rem;font-weight:800;line-height:1}.hero-stat-lbl{color:var(--tx-3);letter-spacing:.08em;text-transform:uppercase;font-size:.7rem}.hero-stat-sep{background:var(--bd);flex-shrink:0;width:1px;height:36px}.hero-terminal{flex-direction:column;gap:12px;display:flex}.terminal{border:1px solid var(--bd-2);border-radius:var(--r-lg);font-family:var(--font-mono);box-shadow:var(--shadow),var(--glow);background:#030608;overflow:hidden}[data-theme=light] .terminal{background:#0f1520;border-color:#0000004d}.terminal-chrome{background:#ffffff08;border-bottom:1px solid #ffffff0f;align-items:center;gap:6px;padding:11px 16px;display:flex}.terminal-dot{border-radius:50%;width:10px;height:10px}.terminal-dot--r{background:#ff5f56}.terminal-dot--y{background:#ffbd2e}.terminal-dot--g{background:#27c93f}.terminal-name{color:#ffffff40;letter-spacing:.05em;align-items:center;gap:5px;margin-left:8px;font-size:.7rem;display:flex}.terminal-body{flex-direction:column;gap:8px;min-height:190px;padding:18px 20px 24px;display:flex}.terminal-line{gap:10px;font-size:.82rem;line-height:1.5;display:flex}.terminal-prompt{color:var(--tx-3);-webkit-user-select:none;user-select:none;flex-shrink:0}.terminal-prompt--cmd{color:var(--accent)}.terminal-out{color:#e8edf573}.terminal-out--ok{color:var(--green)}.terminal-caret{background:var(--accent);vertical-align:text-bottom;width:7px;height:.9em;animation:1s step-end infinite caret;display:inline-block}.hero-quick-links{gap:10px;display:flex}.hero-quick-link{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r);color:var(--tx-2);transition:all var(--t);flex:1;justify-content:center;align-items:center;gap:7px;padding:11px 14px;font-size:.84rem;font-weight:500;display:flex}.hero-quick-link:hover{color:var(--accent);border-color:var(--bd-s);background:var(--accent-dim)}.section{padding:104px 0;position:relative;overflow:hidden}.section>.container{z-index:1;position:relative}main>.section:nth-child(2n){background:var(--bg-2)}main>.section:nth-child(odd){background:var(--bg)}[data-theme=light] main>.section:nth-child(2n){background:var(--bg-3)}[data-theme=light] main>.section:nth-child(odd){background:var(--bg-2)}.section-label{font-family:var(--font-mono);color:var(--accent);letter-spacing:.16em;text-transform:uppercase;align-items:center;gap:12px;margin-bottom:12px;font-size:.7rem;font-weight:700;display:flex}.section-label:before{content:"";background:var(--accent);flex-shrink:0;width:20px;height:1px;display:inline-block}.section-title{letter-spacing:-.035em;color:var(--tx-1);font-size:clamp(2rem,4.5vw,3rem);font-weight:800;line-height:1.1}.section-subtitle{font-family:var(--font-mono);color:var(--tx-3);letter-spacing:.04em;margin-top:10px;font-size:.82rem}.section-divider{background:var(--accent);border-radius:0;width:40px;height:3px;margin:24px 0 40px}.about-grid{grid-template-columns:1.1fr 1fr;align-items:start;gap:72px;display:grid}@media (max-width:760px){.about-grid{grid-template-columns:1fr;gap:40px}}.about-quote{font-family:var(--font-mono);color:var(--accent);border-left:3px solid var(--accent);background:var(--accent-dim);border-radius:0 var(--r)var(--r)0;margin-bottom:24px;padding:16px 20px;font-size:.9rem;line-height:1.7}.about-text{color:var(--tx-2);margin-bottom:32px;font-size:1rem;line-height:1.85}.about-stats{grid-template-columns:1fr 1fr;gap:12px;display:grid}.about-stat-card{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r);transition:border-color var(--t),background var(--t);padding:20px}.about-stat-card:hover{border-color:var(--bd-s);background:var(--bg-4)}.about-stat-num{font-family:var(--font-mono);color:var(--accent);margin-bottom:4px;font-size:2rem;font-weight:800;line-height:1}.about-stat-lbl{color:var(--tx-3);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.about-stat-value{font-family:var(--font-mono);color:var(--accent);margin-bottom:4px;font-size:2rem;font-weight:800;line-height:1}.about-stat-label{color:var(--tx-3);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem}.about-philosophy-title{font-family:var(--font-mono);letter-spacing:.12em;text-transform:uppercase;color:var(--tx-3);align-items:center;gap:8px;margin-bottom:16px;font-size:.68rem;display:flex}.about-philosophy-title span{color:var(--accent)}.about-philosophy{list-style:none}.about-philosophy li{color:var(--tx-2);border-bottom:1px solid var(--bd);align-items:flex-start;gap:12px;padding:13px 0;font-size:.93rem;line-height:1.55;display:flex}.about-philosophy li:last-child{border-bottom:none}.about-philosophy li:before{content:"//";color:var(--accent);font-family:var(--font-mono);opacity:.7;flex-shrink:0;margin-top:2px;font-size:.76rem}.stack-categories{flex-wrap:wrap;gap:6px;margin-bottom:28px;display:flex}.stack-category-btn{border-radius:var(--r);font-family:var(--font-mono);letter-spacing:.04em;color:var(--tx-2);border:1px solid var(--bd);cursor:pointer;transition:all var(--t);background:0 0;align-items:center;gap:7px;padding:6px 14px;font-size:.76rem;font-weight:600;display:inline-flex}.stack-category-btn:hover{color:var(--tx-1);background:var(--bg-3);border-color:var(--bd-2)}.stack-category-btn.active{color:var(--accent);background:var(--accent-dim);border-color:var(--bd-s)}.stack-filter-btn{border-radius:var(--r);font-family:var(--font-mono);letter-spacing:.04em;color:var(--tx-2);border:1px solid var(--bd);cursor:pointer;transition:all var(--t);background:0 0;align-items:center;gap:7px;padding:6px 14px;font-size:.76rem;font-weight:600;display:inline-flex}.stack-filter-btn:hover{color:var(--tx-1);background:var(--bg-3);border-color:var(--bd-2)}.stack-filter-btn.active{color:var(--accent);background:var(--accent-dim);border-color:var(--bd-s)}.stack-filters{flex-wrap:wrap;gap:6px;margin-bottom:28px;display:flex}.stack-cat-dot{border-radius:50%;flex-shrink:0;width:7px;height:7px}.stack-grid,.stack-chips{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;display:grid}.skill-chip{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);transition:border-color var(--t),background var(--t);border-left:2px solid #0000;padding:14px 16px}.skill-chip:hover{border-color:var(--bd-2);border-left-color:var(--accent);background:var(--bg-3)}.skill-chip-top{align-items:center;gap:9px;margin-bottom:9px;display:flex}.skill-chip-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.skill-chip-name{color:var(--tx-1);text-overflow:ellipsis;white-space:nowrap;flex:1;font-size:.875rem;font-weight:600;overflow:hidden}.skill-chip-pct{font-family:var(--font-mono);color:var(--tx-3);font-size:.7rem}.skill-chip-track{background:var(--bd);border-radius:0;height:2px;overflow:hidden}.skill-chip-fill{border-radius:0;height:100%}.projects-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.project-card{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);cursor:pointer;transition:border-color var(--t),transform var(--t-s);flex-direction:column;display:flex;overflow:hidden}.project-card:hover{border-color:var(--bd-s);transform:translateY(-2px)}.project-image{background:var(--bg-3);flex-shrink:0;height:180px;position:relative;overflow:hidden}.project-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--t-s)}.project-card:hover .project-image img{transform:scale(1.03)}.project-image-placeholder{background:linear-gradient(135deg,var(--bg-3),var(--bg-4));flex-direction:column;justify-content:center;align-items:center;gap:10px;width:100%;height:100%;display:flex}.project-image-placeholder>svg{color:var(--accent);opacity:.3}.project-image-placeholder>span{font-family:var(--font-mono);color:var(--tx-3);letter-spacing:.06em;text-align:center;padding:0 12px;font-size:.72rem}.project-image-placeholder-icon{color:var(--accent);opacity:.35}.project-image-placeholder-label{font-family:var(--font-mono);color:var(--tx-3);letter-spacing:.1em;font-size:.65rem}.project-body{flex-direction:column;flex:1;padding:20px;display:flex}.project-header{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:8px;display:flex}.project-card:has(.project-featured-badge){border-top:2px solid var(--accent)}.project-featured-badge{background:var(--accent-dim);border:1px solid var(--bd-s);border-radius:var(--r-xs);font-family:var(--font-mono);color:var(--accent);letter-spacing:.08em;flex-shrink:0;align-items:center;gap:4px;padding:2px 8px;font-size:.62rem;font-weight:700;display:inline-flex}.project-name{color:var(--tx-1);margin-bottom:8px;font-size:1.05rem;font-weight:700;line-height:1.3}.project-desc{color:var(--tx-2);flex:1;margin-bottom:16px;font-size:.9rem;line-height:1.7}.project-tags{flex-wrap:wrap;gap:5px;margin-bottom:18px;display:flex}.project-tag{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r-xs);font-family:var(--font-mono);color:var(--tx-3);padding:2px 9px;font-size:.7rem}.project-links{gap:8px;margin-top:auto;display:flex}.project-link{border-radius:var(--r);color:var(--tx-2);border:1px solid var(--bd);transition:all var(--t);background:0 0;align-items:center;gap:5px;padding:6px 12px;font-size:.8rem;font-weight:500;display:inline-flex}.project-link:hover,.project-link--details{color:var(--accent);border-color:var(--bd-s);background:var(--accent-dim)}.project-link--details:hover{background:#00c8f026}.modal-overlay{z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b8;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-2);border:1px solid var(--bd-2);border-radius:var(--r-lg);width:100%;max-width:680px;max-height:90vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{border-bottom:1px solid var(--bd);justify-content:space-between;align-items:flex-start;gap:16px;padding:28px 28px 20px;display:flex}.modal-title{color:var(--tx-1);letter-spacing:-.025em;font-size:1.4rem;font-weight:800;line-height:1.25}.modal-close{border-radius:var(--r);background:var(--bg-3);border:1px solid var(--bd);width:32px;height:32px;color:var(--tx-2);cursor:pointer;transition:all var(--t);flex-shrink:0;justify-content:center;align-items:center;display:flex}.modal-close:hover{color:var(--danger);background:#f8717112;border-color:#f871714d}.modal-body{flex-direction:column;gap:22px;padding:24px 28px;display:flex}.modal-section{flex-direction:column;gap:10px;display:flex}.modal-section-title{font-family:var(--font-mono);color:var(--accent);letter-spacing:.14em;text-transform:uppercase;font-size:.68rem;font-weight:700}.modal-desc{color:var(--tx-2);font-size:.95rem;line-height:1.8}.modal-arch{color:var(--tx-2);font-size:.9rem;line-height:1.75}.modal-features{flex-direction:column;list-style:none;display:flex}.modal-features li{color:var(--tx-2);border-bottom:1px solid var(--bd);align-items:flex-start;gap:10px;padding:8px 0;font-size:.9rem;display:flex}.modal-features li:last-child{border-bottom:none}.modal-features li:before{content:"→";color:var(--accent);font-family:var(--font-mono);flex-shrink:0;margin-top:2px;font-size:.8rem}.modal-tech{flex-wrap:wrap;gap:5px;display:flex}.modal-actions{border-top:1px solid var(--bd);gap:10px;padding:20px 28px;display:flex}.modal-links{gap:10px;display:flex}.tag{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r-xs);font-family:var(--font-mono);color:var(--tx-3);white-space:nowrap;padding:2px 9px;font-size:.7rem}.arch-card-content{flex:1}.timeline{padding-left:28px;position:relative}.timeline:before{content:"";background:linear-gradient(to bottom,var(--accent),transparent);width:1px;position:absolute;top:8px;bottom:8px;left:0}.timeline-item{margin-bottom:40px;position:relative}.timeline-item:last-child{margin-bottom:0}.timeline-dot{background:var(--bg);border:2px solid var(--accent);border-radius:50%;flex-shrink:0;width:10px;height:10px;position:absolute;top:6px;left:-32px}.timeline-content{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);transition:border-color var(--t);padding:22px 24px}.timeline-content:hover{border-color:var(--bd-2)}.timeline-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:4px;display:flex}.timeline-role{color:var(--tx-1);font-size:1.05rem;font-weight:700;line-height:1.3}.timeline-company{color:var(--accent);margin-bottom:6px;font-size:.92rem;font-weight:600}.timeline-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.timeline-date{font-family:var(--font-mono);color:var(--tx-3);font-size:.76rem}.timeline-live{font-family:var(--font-mono);color:var(--green);letter-spacing:.06em;align-items:center;gap:5px;font-size:.68rem;font-weight:700;display:inline-flex}.timeline-live:before{content:"";background:var(--green);border-radius:50%;flex-shrink:0;width:5px;height:5px;display:inline-block}.timeline-duration{font-family:var(--font-mono);color:var(--tx-3);background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r-xs);padding:2px 8px;font-size:.7rem}.timeline-desc{color:var(--tx-2);margin:12px 0;font-size:.9rem;line-height:1.75}.timeline-bullets{margin:10px 0;list-style:none}.timeline-bullet-item{color:var(--tx-2);border-bottom:1px solid var(--bd);align-items:flex-start;gap:10px;padding:5px 0;font-size:.875rem;line-height:1.55;display:flex}.timeline-bullet-item:last-child{border-bottom:none}.timeline-bullet-item:before{content:"—";color:var(--accent);font-family:var(--font-mono);flex-shrink:0;margin-top:2px;font-size:.76rem}.timeline-technologies{flex-wrap:wrap;gap:5px;margin-top:12px;display:flex}.timeline-tech-chip{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r-xs);font-family:var(--font-mono);color:var(--tx-3);padding:2px 9px;font-size:.7rem}.education-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.education-card{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);transition:border-color var(--t),background var(--t);border-left:2px solid #0000;gap:18px;padding:22px;display:flex}.education-card:hover{border-left-color:var(--accent);border-color:var(--bd-2);background:var(--bg-3)}.education-icon{border-radius:var(--r);background:var(--accent-dim);border:1px solid var(--bd-s);width:40px;height:40px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.education-degree{color:var(--tx-1);margin-bottom:3px;font-size:.95rem;font-weight:700}.education-institute{color:var(--accent);margin-bottom:4px;font-size:.875rem;font-weight:500}.education-year{font-family:var(--font-mono);color:var(--tx-3);margin-bottom:4px;font-size:.76rem}.education-field{color:var(--tx-3);font-size:.82rem}.cert-link{color:var(--accent);transition:opacity var(--t);align-items:center;gap:4px;margin-top:6px;font-size:.8rem;display:inline-flex}.cert-link:hover{opacity:.75}.contact-grid{grid-template-columns:1fr 1.3fr;align-items:start;gap:64px;display:grid}@media (max-width:760px){.contact-grid{grid-template-columns:1fr;gap:40px}}.contact-info-list{flex-direction:column;gap:14px;list-style:none;display:flex}.contact-info-item{align-items:flex-start;gap:16px;display:flex}.contact-info-icon{border-radius:var(--r);background:var(--accent-dim);border:1px solid var(--bd-s);width:40px;height:40px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.contact-info-label{font-family:var(--font-mono);color:var(--tx-3);letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px;font-size:.68rem}.contact-info-value{color:var(--tx-1);font-size:.95rem;font-weight:500}.contact-info-value a{color:var(--accent)}.contact-info-value a:hover{opacity:.75}.contact-form{flex-direction:column;gap:16px;display:flex}.contact-form-group{flex-direction:column;gap:6px;display:flex}.contact-form-label{font-family:var(--font-mono);color:var(--tx-3);letter-spacing:.08em;text-transform:uppercase;font-size:.72rem}.contact-form-input,.contact-form-textarea{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);width:100%;color:var(--tx-1);font-size:.9rem;font-family:var(--font-sans);transition:border-color var(--t),background var(--t);outline:none;padding:11px 14px}.contact-form-input::placeholder,.contact-form-textarea::placeholder{color:var(--tx-4)}.contact-form-input:focus,.contact-form-textarea:focus{border-color:var(--bd-s);background:var(--bg-3)}.contact-form-textarea{resize:vertical;min-height:140px}.contact-form-submit{align-self:flex-start;margin-top:4px}.footer{background:#030508;border-top:1px solid #00c8f02e}[data-theme=light] .footer{background:#0f1520}[data-theme=light] .footer,[data-theme=light] .footer-tagline,[data-theme=light] .footer-bottom,[data-theme=light] .footer-link-group h4,[data-theme=light] .footer-link-group a{color:#8b9ab5}[data-theme=light] .footer-logo{color:#e8edf5}[data-theme=light] .footer-link-group a:hover{color:var(--accent)}.footer-inner{grid-template-columns:auto 1fr auto;align-items:start;gap:48px;max-width:1160px;margin:0 auto;padding:56px 32px 28px;display:grid}@media (max-width:760px){.footer-inner{grid-template-columns:1fr;gap:32px;padding:40px 20px 24px}}.footer-logo{font-family:var(--font-mono);color:var(--tx-1);align-items:center;gap:10px;margin-bottom:12px;font-size:1rem;font-weight:700;display:flex}.footer-tagline{color:var(--tx-3);max-width:240px;font-size:.875rem;line-height:1.6}.footer-links{gap:48px;display:flex}@media (max-width:480px){.footer-links{gap:32px}}.footer-link-group{flex-direction:column;gap:10px;display:flex}.footer-link-group h4{font-family:var(--font-mono);color:var(--tx-3);text-transform:uppercase;letter-spacing:.12em;margin-bottom:4px;font-size:.68rem;font-weight:700}.footer-link-group a{color:var(--tx-2);transition:color var(--t);font-size:.9rem}.footer-link-group a:hover{color:var(--accent)}.footer-social{flex-direction:column;align-items:flex-end;gap:10px;display:flex}.footer-bottom{border-top:1px solid var(--bd);font-family:var(--font-mono);color:var(--tx-3);grid-column:1/-1;justify-content:space-between;align-items:center;padding-top:24px;font-size:.72rem;display:flex}.footer-built{color:var(--accent)}.blog-listing{padding-bottom:100px}.blog-hero-header{background:var(--bg-2);border-bottom:1px solid var(--bd);padding:calc(var(--nav-h) + 64px)0 56px}.blog-page-title{letter-spacing:-.04em;color:var(--tx-1);margin:12px 0 14px;font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800}.blog-page-subtitle{color:var(--tx-2);max-width:560px;font-size:1.05rem;line-height:1.75}.blog-featured-card{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r-lg);transition:border-color var(--t);grid-template-columns:1fr 1.2fr;gap:0;margin:48px 0 36px;display:grid;overflow:hidden}.blog-featured-card:hover{border-color:var(--bd-s)}@media (max-width:760px){.blog-featured-card{grid-template-columns:1fr}}.blog-featured-image{background:var(--bg-3);min-height:300px;overflow:hidden}.blog-featured-image img{object-fit:cover;width:100%;height:100%}.blog-featured-body{flex-direction:column;justify-content:center;padding:36px;display:flex}.blog-featured-badge{background:var(--amber-dim);border-radius:var(--r-xs);font-family:var(--font-mono);color:var(--amber);letter-spacing:.1em;border:1px solid #f59e0b40;align-items:center;gap:4px;width:fit-content;margin-bottom:14px;padding:3px 10px;font-size:.65rem;font-weight:700;display:inline-flex}.blog-featured-title{color:var(--tx-1);letter-spacing:-.025em;margin-bottom:12px;font-size:clamp(1.3rem,2.5vw,1.7rem);font-weight:800;line-height:1.25}.blog-featured-excerpt{color:var(--tx-2);margin-bottom:20px;font-size:.95rem;line-height:1.75}.blog-featured-meta{flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:18px;display:flex}.blog-featured-read{color:var(--accent);align-items:center;gap:6px;font-size:.875rem;font-weight:600;display:inline-flex}.blog-filters{flex-direction:column;gap:14px;margin-bottom:32px;display:flex}.blog-search-wrap{max-width:420px;position:relative}.blog-search-icon{color:var(--tx-3);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.blog-search{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);width:100%;color:var(--tx-1);font-size:.9rem;font-family:var(--font-sans);transition:border-color var(--t);outline:none;padding:10px 14px 10px 38px}.blog-search::placeholder{color:var(--tx-4)}.blog-search:focus{border-color:var(--bd-s)}.blog-tag-filters{flex-wrap:wrap;gap:6px;display:flex}.blog-tag-filter-btn{border-radius:var(--r-xs);font-family:var(--font-mono);color:var(--tx-2);border:1px solid var(--bd);cursor:pointer;transition:all var(--t);letter-spacing:.03em;background:0 0;padding:5px 13px;font-size:.74rem;font-weight:600}.blog-tag-filter-btn:hover{color:var(--tx-1);background:var(--bg-3);border-color:var(--bd-2)}.blog-tag-filter-btn.active{color:var(--accent);background:var(--accent-dim);border-color:var(--bd-s)}.blog-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;display:grid}.blog-card{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);transition:border-color var(--t),transform var(--t-s);flex-direction:column;display:flex;overflow:hidden}.blog-card:hover{border-color:var(--bd-s);transform:translateY(-2px)}.blog-card-image{background:var(--bg-3);flex-shrink:0;height:180px;overflow:hidden}.blog-card-image img{object-fit:cover;width:100%;height:100%;transition:transform var(--t-s)}.blog-card:hover .blog-card-image img{transform:scale(1.03)}.blog-card-image--placeholder{background:linear-gradient(135deg,var(--bg-3),var(--bg-4));justify-content:center;align-items:center;display:flex}.blog-card-placeholder-icon{font-family:var(--font-mono);color:var(--accent);opacity:.3;font-size:1.5rem;font-weight:700}.blog-card-body{flex-direction:column;flex:1;padding:20px;display:flex}.blog-card-tags{flex-wrap:wrap;gap:5px;margin-bottom:11px;display:flex}.tag-pill{border-radius:var(--r-xs);font-family:var(--font-mono);letter-spacing:.04em;background:color-mix(in srgb,var(--tag-color,var(--accent))12%,transparent);border:1px solid color-mix(in srgb,var(--tag-color,var(--accent))30%,transparent);color:var(--tag-color,var(--accent));padding:2px 9px;font-size:.68rem;font-weight:700}.blog-card-title{color:var(--tx-1);letter-spacing:-.01em;margin-bottom:8px;font-size:1.02rem;font-weight:700;line-height:1.35}.blog-card-excerpt{color:var(--tx-2);flex:1;margin-bottom:16px;font-size:.875rem;line-height:1.7}.blog-card-meta{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.blog-card-meta-item{font-family:var(--font-mono);color:var(--tx-3);align-items:center;gap:4px;font-size:.72rem;display:flex}.blog-empty{text-align:center;color:var(--tx-3);flex-direction:column;align-items:center;gap:14px;padding:80px 0;display:flex}.reading-progress{top:var(--nav-h);background:var(--accent);z-index:999;height:2px;box-shadow:0 0 8px var(--accent);transition:width .1s linear;position:fixed;left:0}.blog-post{padding-top:calc(var(--nav-h) + 48px);padding-bottom:100px}@media (max-width:640px){.blog-post{padding-top:calc(var(--nav-h) + 28px);padding-bottom:60px}}.blog-post-back{color:var(--tx-3);transition:color var(--t);align-items:center;gap:6px;margin-bottom:40px;font-size:.875rem;display:inline-flex}.blog-post-back:hover{color:var(--accent)}.blog-post-cover{border-radius:var(--r);border:1px solid var(--bd);max-height:480px;margin-bottom:40px;overflow:hidden}.blog-post-cover img{object-fit:cover;width:100%;height:100%;display:block}.blog-post-header{max-width:760px;margin:0 auto 40px}.blog-post-tags{flex-wrap:wrap;gap:6px;margin-bottom:18px;display:flex}.blog-post-title{color:var(--tx-1);letter-spacing:-.035em;margin-bottom:16px;font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;line-height:1.18}.blog-post-excerpt{color:var(--tx-2);margin-bottom:20px;font-size:1.1rem;line-height:1.75}.blog-post-meta{border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);flex-wrap:wrap;align-items:center;gap:18px;margin-top:20px;padding:18px 0;display:flex}.blog-post-meta-item{font-family:var(--font-mono);color:var(--tx-3);align-items:center;gap:5px;font-size:.76rem;display:flex}.blog-post-divider{background:var(--bd);height:1px;margin:32px 0}.blog-content{flex-direction:column;gap:20px;max-width:760px;margin:0 auto;display:flex}.blog-cover{border-radius:var(--r);border:1px solid var(--bd);margin-bottom:40px;overflow:hidden}.blog-cover img{width:100%;height:auto}.block-paragraph{color:var(--tx-2);font-size:1.02rem;line-height:1.85}.block-h2{color:var(--tx-1);letter-spacing:-.025em;border-top:1px solid var(--bd);margin-top:12px;padding-top:12px;font-size:1.6rem;font-weight:800}.block-h3{color:var(--tx-1);letter-spacing:-.015em;font-size:1.2rem;font-weight:700}.block-code-wrap{position:relative}.block-code-lang{background:var(--bg-4);border:1px solid var(--bd);border-radius:var(--r)var(--r)0 0;font-family:var(--font-mono);color:var(--tx-3);text-transform:uppercase;letter-spacing:.08em;border-bottom:none;justify-content:space-between;align-items:center;padding:8px 16px;font-size:.72rem;display:flex}.block-code-copy{cursor:pointer;color:var(--tx-3);font-size:.72rem;font-family:var(--font-mono);transition:color var(--t);background:0 0;border:none;align-items:center;gap:5px;padding:0;display:flex}.block-code-copy:hover{color:var(--accent)}.block-code{border:1px solid var(--bd);border-radius:0 0 var(--r)var(--r);font-family:var(--font-mono);color:#e6edf3;background:#030608;padding:20px;font-size:.875rem;line-height:1.65;overflow-x:auto}.block-code-wrap .block-code-lang+.block-code{border-top-left-radius:0;border-top-right-radius:0}.block-code .block-code{background:0 0;border:none;border-radius:0;padding:0}.block-code-caption{font-family:var(--font-mono);color:var(--tx-3);text-align:center;margin-top:6px;font-size:.72rem}.block-callout{border-radius:var(--r);border-left:3px solid;padding:16px 20px;font-size:.9rem;line-height:1.7}.block-callout--info{color:#93c5fd;background:#60a5fa14;border-color:#60a5fa}.block-callout--warning{color:#fcd34d;background:#fbbf2414;border-color:#fbbf24}.block-callout--success{color:#86efac;background:#22c55e14;border-color:#22c55e}.block-callout--error{color:#fca5a5;background:#f8717114;border-color:#f87171}.block-list{flex-direction:column;gap:6px;padding-left:0;list-style:none;display:flex}.block-list li{color:var(--tx-2);align-items:flex-start;gap:10px;font-size:.97rem;line-height:1.65;display:flex}.block-list li:before{content:"→";color:var(--accent);font-family:var(--font-mono);flex-shrink:0;margin-top:3px;font-size:.8rem}.block-list--ordered{counter-reset:list-counter}.block-list--ordered li:before{content:counter(list-counter,decimal-leading-zero)".";counter-increment:list-counter;color:var(--accent);font-family:var(--font-mono);margin-top:3px;font-size:.75rem}.block-quote{border-left:3px solid var(--accent);background:var(--bg-3);border-radius:0 var(--r)var(--r)0;padding:20px 24px}.block-quote-text{color:var(--tx-1);margin-bottom:8px;font-size:1.05rem;font-style:italic;line-height:1.7}.block-quote-attr{font-family:var(--font-mono);color:var(--tx-3);font-size:.76rem}.block-image{border-radius:var(--r);overflow:hidden}.block-image img{width:100%}.block-image-caption{font-family:var(--font-mono);color:var(--tx-3);text-align:center;margin-top:8px;font-size:.72rem}.block-table-wrap{overflow-x:auto}.block-table{border-collapse:collapse;width:100%;font-size:.88rem}.block-table th{text-align:left;font-family:var(--font-mono);color:var(--tx-3);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--bd-2);background:var(--bg-3);padding:10px 14px;font-size:.72rem}.block-table td{color:var(--tx-2);border-bottom:1px solid var(--bd);vertical-align:top;padding:11px 14px}.block-table tr:last-child td{border-bottom:none}.block-table tr:hover td{background:var(--bg-3)}.block-table-caption{font-family:var(--font-mono);color:var(--tx-3);text-align:center;margin-top:8px;font-size:.72rem}.block-divider{background:var(--bd);height:1px;margin:8px 0}.block-tags{flex-wrap:wrap;gap:6px;display:flex}.block-video-wrap{border-radius:var(--r);border:1px solid var(--bd);overflow:hidden}.block-video-wrap video{width:100%;display:block}.action-bar{border-top:1px solid var(--bd);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-top:40px;padding:20px 0;display:flex}.action-bar-left,.action-bar-right{align-items:center;gap:10px;display:flex}.action-btn{border-radius:var(--r);border:1px solid var(--bd);color:var(--tx-2);cursor:pointer;transition:all var(--t);background:0 0;align-items:center;gap:6px;padding:7px 14px;font-size:.84rem;display:inline-flex}.action-btn:hover{color:var(--accent);border-color:var(--bd-s);background:var(--accent-dim)}.action-btn.liked{color:var(--danger);background:#f8717112;border-color:#f871714d}.related-posts{margin-top:64px}.related-posts-title{font-family:var(--font-mono);color:var(--accent);letter-spacing:.16em;text-transform:uppercase;align-items:center;gap:12px;margin-bottom:20px;font-size:.7rem;font-weight:700;display:flex}.related-posts-title:before{content:"";background:var(--accent);flex-shrink:0;width:20px;height:1px;display:inline-block}.related-posts-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;display:grid}.newsletter-banner{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);text-align:center;margin-top:40px;padding:32px}.newsletter-banner h3{color:var(--tx-1);margin-bottom:6px;font-size:1.15rem;font-weight:700}.newsletter-banner p{color:var(--tx-2);margin-bottom:18px;font-size:.9rem}.newsletter-form{gap:8px;max-width:420px;margin:0 auto;display:flex}.newsletter-input{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r);color:var(--tx-1);font-size:.9rem;font-family:var(--font-sans);outline:none;flex:1;padding:10px 14px}.newsletter-input:focus{border-color:var(--bd-s)}.newsletter-input::placeholder{color:var(--tx-4)}.skeleton{background:linear-gradient(90deg,var(--bg-3)25%,var(--bg-4)50%,var(--bg-3)75%);border-radius:var(--r);background-size:200% 100%;animation:1.6s infinite shimmer}.skeleton-heading{width:40%;height:28px;margin-bottom:12px}.skeleton-text{width:90%;height:14px;margin-bottom:8px}.skeleton-card{width:100%;height:180px}.empty-placeholder{text-align:center;color:var(--tx-3);font-family:var(--font-mono);padding:64px 0;font-size:.875rem}.arch-layout{grid-template-columns:380px 1fr;align-items:start;gap:40px;margin-bottom:40px;display:grid}@media (max-width:900px){.arch-layout{grid-template-columns:1fr}}.arch-stack{flex-direction:column;display:flex}.arch-stack-item{flex-direction:column;align-items:center;display:flex}.arch-layer{background:var(--bg-3);border:1px solid var(--bd);border-left:3px solid var(--layer-color,var(--accent));border-radius:var(--r);width:100%;transition:background var(--t),border-color var(--t);align-items:center;gap:14px;padding:14px 18px;display:flex}.arch-layer:hover{background:var(--bg-4)}.arch-layer--highlight{background:var(--accent-dim);border-color:var(--bd-s);border-left-color:var(--accent)}.arch-layer-icon{border-radius:var(--r);background:color-mix(in srgb,var(--layer-color,var(--accent))12%,transparent);border:1px solid color-mix(in srgb,var(--layer-color,var(--accent))28%,transparent);width:36px;height:36px;color:var(--layer-color,var(--accent));flex-shrink:0;justify-content:center;align-items:center;display:flex}.arch-layer-label{font-family:var(--font-mono);color:var(--tx-1);letter-spacing:.04em;margin-bottom:2px;font-size:.78rem;font-weight:700}.arch-layer-sublabel{font-family:var(--font-mono);color:var(--tx-3);letter-spacing:.02em;font-size:.66rem}@keyframes flow-pulse{0%,to{opacity:.3;transform:scaleX(1)}50%{opacity:1;transform:scaleX(1.1)}}@keyframes flow-drop{0%{opacity:0;top:0}15%{opacity:1}85%{opacity:1}to{opacity:0;top:100%}}.arch-connector{background:linear-gradient(to bottom,var(--accent),#00c8f033);flex-shrink:0;width:1px;height:28px;position:relative}.arch-connector:after{content:"";background:var(--accent);width:6px;height:6px;box-shadow:0 0 6px var(--accent);border-radius:50%;animation:2.4s ease-in-out infinite flow-drop;position:absolute;top:0;left:50%;transform:translate(-50%)}.arch-endpoints{background:var(--bg-3);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden}.arch-endpoints-header{background:var(--bg-4);border-bottom:1px solid var(--bd);justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.arch-endpoints-label{font-family:var(--font-mono);color:var(--accent);letter-spacing:.14em;font-size:.68rem;font-weight:700}.arch-endpoints-count{font-family:var(--font-mono);color:var(--tx-3);font-size:.68rem}.arch-endpoints-list{flex-direction:column;display:flex}.arch-endpoint{border-bottom:1px solid var(--bd);transition:background var(--t);flex-wrap:wrap;align-items:center;gap:10px;padding:10px 18px;display:flex}.arch-endpoint:last-child{border-bottom:none}.arch-endpoint:hover{background:var(--bg-4)}.arch-method{font-family:var(--font-mono);letter-spacing:.06em;border-radius:var(--r-xs);text-align:center;flex-shrink:0;min-width:44px;padding:2px 7px;font-size:.65rem;font-weight:800}.arch-method--get{color:#22c55e;background:#22c55e1f;border:1px solid #22c55e40}.arch-method--post{color:#f59e0b;background:#f59e0b1f;border:1px solid #f59e0b40}.arch-path{font-family:var(--font-mono);color:var(--tx-1);flex:1;min-width:0;font-size:.78rem}.arch-ep-desc{color:var(--tx-3);white-space:nowrap;font-size:.78rem}.arch-ep-tag{font-family:var(--font-mono);border-radius:var(--r-xs);background:var(--accent-dim);color:var(--accent);border:1px solid var(--bd-s);letter-spacing:.06em;flex-shrink:0;padding:1px 6px;font-size:.6rem;font-weight:700}.arch-principles{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;display:grid}.arch-principle{background:var(--bg-2);border:1px solid var(--bd);border-radius:var(--r);transition:border-color var(--t),background var(--t),transform var(--t-s);border-left:2px solid #0000;align-items:flex-start;gap:16px;padding:20px;display:flex}.arch-principle:hover{border-left-color:var(--accent);border-color:var(--bd-2);background:var(--bg-3)}.arch-principle-icon{border-radius:var(--r);background:var(--accent-dim);border:1px solid var(--bd-s);width:36px;height:36px;color:var(--accent);flex-shrink:0;justify-content:center;align-items:center;display:flex}.arch-principle-title{color:var(--tx-1);margin-bottom:5px;font-size:.9rem;font-weight:700}.arch-principle-desc{color:var(--tx-2);font-size:.83rem;line-height:1.65}
