@import"https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=DM+Sans:wght@400;500;700&display=swap";:root{--c-green: #00E5A0;--c-green-bright: #E8FFF5;--c-green-deep: #0D8060;--c-green-dim: #1A3A2E;--c-bg: #0D0F14;--c-bg-deeper: #0A0C10;--c-surface: #101418;--c-surface-2: #141820;--c-border: #1A2A22;--c-text: #F0F0F0;--c-text-soft: #C0C0C0;--c-text-muted: #9A9A9A;--c-muted: #4A6E60;--c-dim: #2A3A30;--c-cream: #F4F1EA;--c-cream-border: #D8D2C2;--c-ink: #1A1A1A;--c-ink-soft: #6A6A6A;--fg-1: var(--c-text);--fg-2: var(--c-text-soft);--fg-3: var(--c-text-muted);--fg-mute: var(--c-muted);--bg-page: var(--c-bg);--bg-card: var(--c-surface);--bg-raised: var(--c-surface-2);--bg-well: var(--c-bg-deeper);--border: var(--c-border);--border-strong: var(--c-green-dim);--accent: var(--c-green);--accent-soft: var(--c-green-dim);--accent-deep: var(--c-green-deep);--font-mono: "DM Mono", "Courier New", ui-monospace, monospace;--font-body: "DM Sans", system-ui, -apple-system, "Segoe UI", sans-serif;--fs-h1: clamp(2rem, 5vw, 3.5rem);--fs-h2: clamp(1.5rem, 3vw, 2.25rem);--fs-h3: 1.25rem;--fs-body: 1rem;--fs-body-lg: 1.05rem;--fs-small: .875rem;--fs-cap: .8rem;--fs-label: .75rem;--lh-tight: 1.1;--lh-snug: 1.3;--lh-body: 1.7;--tr-label-tight: .1em;--tr-label: .18em;--tr-label-wide: .3em;--tr-wordmark: .4em;--sp-1: 8px;--sp-2: 16px;--sp-3: 24px;--sp-4: 32px;--sp-5: 48px;--sp-6: 64px;--sp-7: 96px;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--bw: 1px;--shadow-glow-green: 0 0 24px rgba(0, 229, 160, .35);--shadow-glow-soft: 0 0 12px rgba(0, 229, 160, .18);--shadow-lift: 0 2px 0 rgba(0, 0, 0, .4);--ease-out: cubic-bezier(.22, 1, .36, 1);--t-fast: .12s;--t-med: .2s;--t-slow: .32s}body{font-family:var(--font-body);font-size:var(--fs-body);line-height:var(--lh-body);color:var(--fg-2);background:var(--bg-page);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}h1,.h1{font-family:var(--font-mono);font-size:var(--fs-h1);font-weight:700;line-height:var(--lh-tight);letter-spacing:.02em;color:var(--fg-1)}h2,.h2{font-family:var(--font-mono);font-size:var(--fs-h2);font-weight:700;line-height:var(--lh-tight);letter-spacing:.01em;color:var(--fg-1)}h3,.h3{font-family:var(--font-mono);font-size:var(--fs-h3);font-weight:700;line-height:var(--lh-snug);color:var(--fg-1)}p,.body{font-family:var(--font-body);font-size:var(--fs-body);line-height:var(--lh-body);color:var(--fg-2)}.body-lg{font-size:var(--fs-body-lg);line-height:var(--lh-body)}small,.caption{font-family:var(--font-body);font-size:var(--fs-cap);color:var(--fg-3);line-height:1.5}.label,.eyebrow{font-family:var(--font-mono);font-size:var(--fs-label);font-weight:400;letter-spacing:var(--tr-label);text-transform:uppercase;color:var(--c-muted)}.label--accent{color:var(--c-green)}.wordmark{font-family:var(--font-mono);font-weight:700;letter-spacing:var(--tr-wordmark);text-transform:uppercase;color:var(--fg-1)}code,.mono{font-family:var(--font-mono);font-size:.95em}a{color:var(--c-green);text-decoration:none;transition:color var(--t-fast) var(--ease-out)}a:hover{color:var(--c-green-bright)}::selection{background:var(--c-green);color:var(--c-bg)}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--c-bg);color:var(--c-text-soft);font-family:var(--font-body);min-height:100vh;-webkit-font-smoothing:antialiased}img{display:block;max-width:100%}.container{max-width:1180px;margin:0 auto;padding:0 32px}@media(max-width:640px){.container{padding:0 16px}}.eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--c-muted);display:inline-flex;align-items:center;gap:10px}.eyebrow .num{color:var(--c-green)}.eyebrow .slash{color:var(--c-dim)}.section-head{display:flex;align-items:end;justify-content:space-between;margin-bottom:32px;gap:24px}.section-head h2{font-family:var(--font-mono);font-weight:700;font-size:clamp(1.75rem,3vw,2.25rem);color:var(--c-text);margin:12px 0 0;letter-spacing:.01em}.section-head p{font-size:14px;color:var(--c-text-muted);max-width:320px;margin:0}@media(max-width:640px){.section-head{flex-direction:column;align-items:start}.section-head p{max-width:100%}}.btn{font-family:var(--font-mono);font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;padding:12px 20px;border-radius:8px;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:8px;transition:all var(--t-fast) var(--ease-out);text-decoration:none;white-space:nowrap}.btn:focus-visible{outline:2px solid var(--c-green);outline-offset:2px}.btn-primary{background:var(--c-green);color:var(--c-bg)}.btn-primary:hover{box-shadow:0 0 16px #00e5a066;transform:translateY(-1px)}.btn-primary:active{background:var(--c-green-deep);color:var(--c-green-bright);transform:translateY(0);box-shadow:none}.btn-outline{background:transparent;color:var(--c-green);border-color:var(--c-green-dim)}.btn-outline:hover{background:#00e5a00f;border-color:var(--c-green)}.btn-ghost{background:transparent;color:var(--c-text-soft)}.btn-ghost:hover{color:var(--c-green)}.nav{position:sticky;top:0;z-index:50;background:#0d0f14b8;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border)}.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 32px;max-width:1180px;margin:0 auto}.nav-brand{display:flex;align-items:center;gap:12px;cursor:pointer;background:none;border:0;color:inherit;padding:0;text-decoration:none}.nav-brand img{height:36px}.nav-brand .wm{font-family:var(--font-mono);font-weight:700;font-size:14px;letter-spacing:.4em;color:var(--c-text);padding-left:.4em;min-width:10.5em;display:inline-block}.nav-links{display:flex;align-items:center;gap:4px}.nav-link{font-family:var(--font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-text-muted);background:none;border:0;cursor:pointer;padding:8px 14px;border-radius:6px;transition:color var(--t-fast) var(--ease-out);text-decoration:none}.nav-link:hover{color:var(--c-text)}.nav-link.active{color:var(--c-green)}.nav-hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;background:none;border:0;cursor:pointer;padding:8px;border-radius:6px;color:var(--c-text);margin-left:auto}.nav-hamburger span{display:block;width:22px;height:2px;background:currentColor;border-radius:2px;transition:transform .25s ease,opacity .25s ease}.nav-open .nav-hamburger span:nth-child(1){transform:translateY(7px) rotate(45deg)}.nav-open .nav-hamburger span:nth-child(2){opacity:0;transform:scaleX(0)}.nav-open .nav-hamburger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media(max-width:640px){.nav-inner{padding:14px 16px}.nav-hamburger{display:flex}.nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:4px;background:#0d0f14f5;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--c-border);padding:8px 16px 16px}.nav-open .nav-links{display:flex}.nav-link{padding:12px 16px;font-size:13px}.nav-links .btn-outline{margin-left:0!important;margin-top:8px;text-align:center}}.hero{position:relative;padding:96px 0 80px;overflow:hidden}.hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,#1A2A22 1px,transparent 1px);background-size:22px 22px;mask-image:radial-gradient(ellipse 60% 60% at 30% 40%,black,transparent 75%);-webkit-mask-image:radial-gradient(ellipse 60% 60% at 30% 40%,black,transparent 75%);opacity:.7;pointer-events:none}.hero-inner{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:48px;align-items:center}.hero-tags{display:flex;gap:8px;margin-bottom:24px}.hero h1{font-family:var(--font-mono);font-weight:700;font-size:clamp(2.25rem,5vw,3.5rem);line-height:1.05;color:var(--c-text);margin:0 0 24px;letter-spacing:.01em;max-width:740px}.hero h1 .gr{color:var(--c-green)}.hero p.sub{font-size:16px;line-height:1.7;color:var(--c-text-soft);max-width:560px;margin:0 0 36px}.hero-cta{display:flex;gap:12px;margin-bottom:56px;flex-wrap:wrap;align-items:center}.hero-socials{display:flex;gap:10px;align-items:center}.social-btn{display:flex;align-items:center;justify-content:center;width:46px;height:46px;border:1px solid var(--c-border);color:var(--c-muted);transition:border-color .2s,color .2s;flex-shrink:0}.social-btn:hover{border-color:var(--c-green);color:var(--c-green)}.hero-stats{display:flex;gap:48px}.hero-stat .n{font-family:var(--font-mono);font-weight:700;font-size:28px;color:var(--c-text)}.hero-stat .l{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);margin-top:4px}.hero-decor{position:relative;height:360px}@media(max-width:960px){.hero-inner{grid-template-columns:1fr}.hero-decor{display:none}}.chip{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;border-radius:4px;border:1px solid transparent;display:inline-block}.chip-brand{color:var(--c-green);background:#00e5a00f;border-color:var(--c-green-dim)}.chip-tech{color:var(--c-text-soft);background:var(--c-surface-2);border-color:var(--c-border)}.section{padding:80px 0}.section.alt{background:var(--c-bg-deeper)}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.project-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:18px;cursor:pointer;transition:all var(--t-med) var(--ease-out);display:flex;flex-direction:column}.project-card:hover{border-color:var(--c-green-dim);transform:translateY(-2px)}.project-card[hidden]{display:none}.project-thumb{height:200px;border-radius:8px;background:linear-gradient(140deg,#141820,#0a0c10);border:1px solid var(--c-border);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;margin-bottom:16px}.project-thumb:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,42,34,.6) 1px,transparent 1px);background-size:14px 14px;pointer-events:none}.project-thumb svg{position:relative;opacity:.6}.project-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.status{font-family:var(--font-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;display:inline-flex;align-items:center;gap:6px}.status.complete{color:var(--c-green)}.status.progress{color:var(--c-text-muted)}.project-title{font-family:var(--font-mono);font-weight:700;font-size:16px;color:var(--c-text);margin:4px 0 6px;letter-spacing:.01em}.project-desc{font-size:13px;color:var(--c-text-muted);margin:0 0 14px;line-height:1.6;flex:1}.project-stack{display:flex;flex-wrap:wrap;gap:4px}.tech-mini{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--c-text-soft);padding:2px 7px;border-radius:4px;background:var(--c-surface-2);border:1px solid var(--c-border)}.carousel{overflow:hidden}.carousel-track{display:flex;gap:20px;will-change:transform}.carousel-card{flex-shrink:0}.carousel-nav{display:flex;gap:8px;align-items:center}.carousel-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text-muted);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--t-fast) var(--ease-out)}.carousel-btn:hover{border-color:var(--c-green-dim);color:var(--c-green)}.carousel-dots{display:flex;gap:6px;justify-content:center;margin-top:20px}.carousel-dot{width:6px;height:6px;border-radius:50%;border:none;background:var(--c-border);cursor:pointer;padding:0;transition:background var(--t-fast) var(--ease-out)}.carousel-dot.active{background:var(--c-green)}@media(max-width:640px){.carousel-nav{display:none}}.projects-cta{margin-top:40px;text-align:center}.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}.filter-btn{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;padding:6px 12px;border-radius:4px;border:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text-muted);cursor:pointer;transition:all var(--t-fast) var(--ease-out)}.filter-btn:hover{border-color:var(--c-green-dim);color:var(--c-text)}.filter-btn.active{border-color:var(--c-green-dim);background:#00e5a00f;color:var(--c-green)}.about{display:grid;grid-template-columns:1.6fr 1fr;gap:64px;align-items:start}.about h2{font-family:var(--font-mono);font-weight:700;font-size:clamp(1.75rem,3vw,2.25rem);color:var(--c-text);margin:12px 0 24px}.about h2 .gr{color:var(--c-green)}.about p{font-size:15px;line-height:1.75;color:var(--c-text-soft);margin:0 0 16px;max-width:580px}.skills{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.about-aside{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:28px;display:flex;flex-direction:column;align-items:center;gap:18px}.badge{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--c-muted)}.badge .gr{color:var(--c-green)}.contact-callout{margin-top:32px;padding-top:28px;border-top:1px solid var(--c-border)}.contact-label{display:flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-green);margin-bottom:10px}@media(max-width:860px){.about{grid-template-columns:1fr}}.subscribe{background:var(--c-surface);border:1px solid var(--c-border);border-radius:12px;padding:56px 48px;position:relative;overflow:hidden;max-width:720px;margin:0 auto;text-align:center}.subscribe:before,.subscribe:after{content:"";position:absolute;top:50%;height:1px;background:var(--c-green-dim);width:30%;z-index:0}.subscribe:before{left:0}.subscribe:after{right:0}.subscribe .dot{position:absolute;top:50%;width:6px;height:6px;border-radius:50%;background:var(--c-green);transform:translateY(-50%);box-shadow:0 0 8px #00e5a099;z-index:0}.subscribe .dot.l{left:30%;transform:translate(-50%,-50%)}.subscribe .dot.r{right:30%;transform:translate(50%,-50%)}.subscribe>*{position:relative;z-index:1}.subscribe h2{font-family:var(--font-mono);font-weight:700;font-size:28px;color:var(--c-text);margin:0 0 12px}.subscribe p{font-size:14px;color:var(--c-text-muted);margin:0 0 24px}.subscribe-form{display:flex;gap:8px;max-width:460px;margin:0 auto}.subscribe-form[hidden]{display:none}.subscribe-form input{flex:1;background:var(--c-bg);border:1px solid var(--c-border);border-radius:8px;padding:12px 14px;color:var(--c-text);font-family:var(--font-body);font-size:14px;outline:none;transition:border-color var(--t-fast) var(--ease-out)}.subscribe-form input:focus{border-color:var(--c-green-dim)}.subscribe-form input::placeholder{color:var(--c-muted)}.subscribe .subscribe-hint{font-size:14px;color:var(--c-text-muted);margin-top:16px}@media(max-width:640px){.subscribe{padding:40px 24px}.subscribe:before,.subscribe:after,.subscribe .dot{display:none}.subscribe-form{flex-direction:column}.subscribe-form .btn{width:100%;justify-content:center}.subscribe .subscribe-hint{margin-top:40px}}.subscribe-done{color:var(--c-green);font-family:var(--font-mono);letter-spacing:.16em;text-transform:uppercase;font-size:12px;margin:0}.subscribe-error{color:var(--c-text-muted);font-family:var(--font-mono);font-size:12px;margin:8px 0 0}.footer{background:var(--c-bg-deeper);border-top:1px solid var(--c-border);padding:56px 0 32px;margin-top:80px}.footer-inner{display:flex;justify-content:space-between;gap:32px;align-items:start;flex-wrap:wrap}.footer-brand{display:flex;flex-direction:column;gap:8px}.footer-brand .wm{font-family:var(--font-mono);font-weight:700;font-size:14px;letter-spacing:.4em;color:var(--c-text)}.footer-brand .tg{font-family:var(--font-mono);font-size:10px;letter-spacing:.28em;text-transform:uppercase;color:var(--c-muted)}.footer-cols{display:flex;gap:56px}.footer-col{min-width:0}.footer-col h4{font-family:var(--font-mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--c-muted);margin:0 0 14px}.footer-col a{display:block;color:var(--c-text-soft);font-size:14px;text-decoration:none;margin-bottom:8px;transition:color var(--t-fast);cursor:pointer;overflow-wrap:break-word}.footer-col a:hover{color:var(--c-green)}.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--c-border);display:flex;justify-content:space-between;font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);gap:16px;flex-wrap:wrap}@media(max-width:640px){.footer-cols{flex-wrap:wrap;gap:24px}.footer-col{flex:1 1 40%}.footer-bottom{flex-direction:column;gap:8px}}.page-head{padding:80px 0 32px}.page-head h1{font-family:var(--font-mono);font-weight:700;font-size:clamp(2rem,4vw,3rem);color:var(--c-text);margin:12px 0 16px;letter-spacing:.01em}.page-head p{font-size:16px;color:var(--c-text-muted);max-width:540px}.post-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--c-border)}.post-row{display:grid;grid-template-columns:120px 1fr 80px;gap:32px;align-items:start;padding:28px 0;border-bottom:1px solid var(--c-border);cursor:pointer;transition:background var(--t-fast) var(--ease-out);text-decoration:none;color:inherit}.post-row:hover{background:#00e5a005}.post-row:hover .post-title{color:var(--c-green)}.post-cat{display:flex;flex-direction:column;gap:6px}.post-date{font-family:var(--font-mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted)}.post-title{font-family:var(--font-mono);font-weight:700;font-size:18px;color:var(--c-text);margin:0 0 6px;transition:color var(--t-fast)}.post-excerpt{font-size:14px;color:var(--c-text-muted);margin:0;line-height:1.6;max-width:620px}.post-readmore{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-text-muted);text-align:right;align-self:center}.post-row:hover .post-readmore{color:var(--c-green)}@media(max-width:640px){.post-row{grid-template-columns:1fr;gap:10px}.post-readmore{text-align:left}}.article{max-width:720px;margin:0 auto;padding:56px 32px 96px}.article .back{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-muted);background:none;border:0;padding:0;cursor:pointer;margin-bottom:32px;text-decoration:none;display:inline-block}.article .back:hover{color:var(--c-green)}.article-meta{display:flex;gap:16px;align-items:center;margin-bottom:16px;font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-muted);flex-wrap:wrap}.article-meta .gr{color:var(--c-green)}.article h1{font-family:var(--font-mono);font-weight:700;font-size:clamp(2rem,4vw,2.75rem);color:var(--c-text);margin:0 0 16px;line-height:1.1;letter-spacing:.01em}.article .lede{font-size:18px;line-height:1.65;color:var(--c-text);margin:0 0 32px}.article .hero-img{height:280px;border-radius:12px;background:linear-gradient(140deg,#141820,#0a0c10);border:1px solid var(--c-border);margin:24px 0 40px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.article .hero-img:after{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,rgba(26,42,34,.5) 1px,transparent 1px);background-size:18px 18px}.article .hero-img svg{position:relative}.article p{font-size:16px;line-height:1.75;color:var(--c-text-soft);margin:0 0 18px}.article h2{font-family:var(--font-mono);font-weight:700;font-size:22px;color:var(--c-text);margin:40px 0 16px}.article pre{background:var(--c-bg-deeper);border:1px solid var(--c-border);border-left:2px solid var(--c-green-dim);border-radius:8px;padding:16px 18px;font-family:var(--font-mono);font-size:13px;color:var(--c-text-soft);overflow-x:auto;margin:16px 0;line-height:1.55}.article hr{border:none;position:relative;margin:48px 0;height:1px;background:linear-gradient(to right,var(--c-border) calc(50% - 12px),transparent calc(50% - 12px),transparent calc(50% + 12px),var(--c-border) calc(50% + 12px))}.article hr:after{content:"";position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:var(--c-green);box-shadow:0 0 6px #00e5a080}
