:root{color-scheme:light dark;--navy: #1e3a8a;--emerald: #10b981;--bg: #f4f7fb;--bg-soft: #eaf1fa;--header-bg: rgba(244, 247, 251, .72);--panel: rgba(255, 255, 255, .85);--panel-strong: #ffffff;--card-a: #ffffff;--card-b: #eef3fb;--card-border: rgba(30, 58, 138, .18);--ink: #15233c;--muted: #51617a;--line: rgba(30, 58, 138, .16);--chip-ink: #16307a;--link: #047857;--accent-a: #1e3a8a;--accent-b: #059669;--accent-soft-a: rgba(30, 58, 138, .16);--accent-soft-b: rgba(5, 150, 105, .16);--blob-a: rgba(30, 58, 138, .12);--blob-b: rgba(5, 150, 105, .12);--noise: rgba(20, 40, 80, .06);--glow: 0 16px 40px rgba(30, 58, 138, .18);--radius: 18px}@media (prefers-color-scheme: dark){:root{--bg: #0a1322;--bg-soft: #0d1a2e;--header-bg: rgba(10, 19, 34, .7);--panel: rgba(20, 32, 52, .8);--panel-strong: #11203a;--card-a: rgba(20, 32, 52, .95);--card-b: rgba(12, 22, 38, .95);--card-border: rgba(59, 111, 212, .32);--ink: #e8edf4;--muted: #9fb0c6;--line: rgba(120, 160, 210, .2);--chip-ink: #eaf0ff;--link: #5eead4;--accent-a: #3b6fd4;--accent-b: #10b981;--accent-soft-a: rgba(59, 111, 212, .5);--accent-soft-b: rgba(16, 185, 129, .42);--blob-a: rgba(59, 111, 212, .3);--blob-b: rgba(16, 185, 129, .22);--noise: rgba(255, 255, 255, .26);--glow: 0 16px 42px rgba(16, 185, 129, .22)}}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:Space Grotesk,sans-serif;color:var(--ink);background:radial-gradient(circle at 18% 12%,var(--blob-a),transparent 33%),radial-gradient(circle at 78% 22%,var(--blob-b),transparent 30%),var(--bg);background-attachment:fixed;min-height:100vh;line-height:1.6;overflow-x:hidden}.noise{position:fixed;inset:0;pointer-events:none;opacity:.2;background-image:radial-gradient(var(--noise) .35px,transparent .35px);background-size:4px 4px}.site-header{position:sticky;top:0;z-index:10;backdrop-filter:blur(12px);background:var(--header-bg);border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;padding:1rem clamp(1rem,3vw,3rem)}.brand{display:inline-flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--ink);font-family:Sora,sans-serif;font-weight:600;letter-spacing:.01em}.brand img{width:36px;height:36px;border-radius:10px}nav{display:flex;gap:clamp(.75rem,2vw,1.5rem);flex-wrap:wrap;justify-content:flex-end;align-items:center}nav a{color:var(--muted);text-decoration:none;font-weight:500;transition:color .25s ease}nav a:hover,nav a:focus-visible{color:var(--ink)}.lang-pill{padding:.2rem .65rem;border-radius:999px;border:1px solid var(--line);font-size:.78rem;font-weight:600;letter-spacing:.06em;color:var(--link)!important;transition:background .2s ease,border-color .2s ease!important}.lang-pill:hover,.lang-pill:focus-visible{background:var(--accent-soft-b);border-color:var(--accent-b);color:var(--link)!important}main{max-width:1100px;margin:0 auto;padding:clamp(1.25rem,4vw,3rem);display:grid;gap:clamp(2.5rem,6vw,5rem)}.eyebrow{width:fit-content;padding:.28rem .65rem;border-radius:999px;font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--chip-ink);background:linear-gradient(120deg,var(--accent-soft-a),var(--accent-soft-b))}h1,h2{font-family:Sora,sans-serif;line-height:1.1}h1{font-size:clamp(2rem,6vw,4.1rem);max-width:18ch}h1 span{background:linear-gradient(90deg,var(--accent-a),var(--accent-b));-webkit-background-clip:text;background-clip:text;color:transparent}h2{font-size:clamp(1.45rem,4vw,2.15rem)}.hero-copy{font-size:clamp(1rem,2.2vw,1.2rem);max-width:55ch;color:var(--muted)}.post-date{font-size:.85rem;color:var(--muted)}.about,.apps-section,.contact{background:linear-gradient(160deg,var(--card-a),var(--card-b));border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 10px 30px #02080f2e;padding:clamp(1.2rem,3vw,2rem)}.about,.contact{display:grid;gap:.75rem}.section-head{margin-bottom:1.2rem}.section-head p,.about p,.contact p{color:var(--muted);max-width:65ch}.app-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.app-card{border:1px solid var(--card-border);border-radius:14px;background:linear-gradient(145deg,var(--card-a),var(--card-b));color:inherit;padding:1rem;display:grid;gap:.6rem;text-decoration:none;transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease}.app-card:hover,.app-card:focus-within,.app-card:focus-visible{transform:translateY(-4px);box-shadow:var(--glow);border-color:var(--accent-b)}.app-card:focus-visible{outline:3px solid var(--accent-b);outline-offset:3px}.app-tag{display:inline-flex;align-items:center;width:fit-content;max-width:100%;min-height:1.65rem;font-size:.75rem;line-height:1;text-transform:uppercase;letter-spacing:.09em;color:var(--chip-ink);background:linear-gradient(100deg,var(--accent-soft-a),var(--accent-soft-b));border-radius:999px;padding:.35rem .65rem}.app-title{font-size:1.15rem;font-family:Sora,sans-serif}.app-card p{color:var(--muted)}.app-links{display:flex;gap:.8rem}.app-links a{text-decoration:none;font-weight:600;color:var(--link);transition:color .2s ease}.app-links a:hover,.app-links a:focus-visible{color:var(--ink)}.contact-links{display:flex;gap:.8rem;flex-wrap:wrap}.contact-links a{text-decoration:none;font-weight:600;color:var(--link);border-bottom:1px dashed var(--line);transition:color .2s ease}.contact-links a:hover,.contact-links a:focus-visible{color:var(--ink)}.prose{color:var(--muted);max-width:72ch;line-height:1.85;font-size:1.05rem}.prose h2{font-size:clamp(1.2rem,3vw,1.6rem);color:var(--ink);margin-top:2rem;margin-bottom:.6rem}.prose h3{font-family:Sora,sans-serif;font-size:1.1rem;color:var(--ink);margin-top:1.5rem;margin-bottom:.4rem}.prose p{margin-bottom:1.1rem}.prose ul,.prose ol{padding-left:1.4rem;margin-bottom:1.1rem}.prose li{margin-bottom:.4rem}.prose strong{color:var(--ink);font-weight:600}.prose a{color:var(--link);text-decoration:underline;text-underline-offset:3px}.prose a:hover{color:var(--ink)}.prose code{font-size:.9em;background:var(--accent-soft-a);border:1px solid var(--card-border);border-radius:4px;padding:.15em .4em;color:var(--ink)}.prose pre{background:#0b1626;border:1px solid var(--line);border-radius:10px;padding:1rem 1.2rem;overflow-x:auto;margin-bottom:1.4rem}.prose pre code{background:none;border:none;padding:0;font-size:.9rem;color:#d6e2f2}.back-link a{color:var(--muted);text-decoration:none;font-weight:500;font-size:.95rem;transition:color .2s ease}.back-link a:hover{color:var(--ink)}footer{text-align:center;padding:2rem 1rem 2.2rem;color:var(--muted)}.reveal{opacity:0;transform:translateY(24px);animation:reveal .7s ease forwards}.reveal:nth-of-type(2){animation-delay:.1s}.reveal:nth-of-type(3){animation-delay:.18s}.reveal:nth-of-type(4){animation-delay:.26s}@keyframes reveal{to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion: reduce){.reveal{animation:none;opacity:1;transform:none}}@media (max-width: 640px){nav{gap:.55rem .9rem;font-size:.95rem}.site-header{align-items:flex-start;flex-direction:column;gap:.7rem}.brand span{font-size:.95rem}}
