:root{--color-background:#fdfbf5;--color-background-soft:#f9f7f0;--color-background-mute:#f5f2e8;--color-primary:#024aae;--color-primary-dark:#023c8e;--color-primary-rgb:2,74,174;--color-secondary:#2791db;--color-secondary-dark:#1a7ebd;--color-text:#1e293b;--color-text-light:#64748b;--color-border:#efeadb;--color-border-hover:#e6e0cb;--color-heading:#0f172a;--color-danger:#ec0021;--color-warning:#ffaa15;--color-success:#10b981;--color-info:#2791db}html.dark{--color-background:#0f172a;--color-background-soft:#1e293b;--color-background-mute:#334155;--color-primary:#2791db;--color-primary-dark:#4aa6e3;--color-primary-rgb:39,145,219;--color-secondary:#94a3b8;--color-secondary-dark:#64748b;--color-text:#f8fafc;--color-text-light:#cbd5e0;--color-border:#334155;--color-border-hover:#475569;--color-heading:#f1f5f9;--color-danger:#f55873;--color-warning:#ffcc66;--color-success:#34d399;--color-info:#60a5fa}html.theme-blue{--color-background:#f0f9ff;--color-background-soft:#e0f2fe;--color-background-mute:#bae6fd;--color-primary:#0284c7;--color-primary-dark:#0369a1;--color-primary-rgb:2,132,199;--color-secondary:#38bdf8;--color-secondary-dark:#0ea5e9;--color-border:#e0f2fe;--color-border-hover:#bae6fd;--color-text:#075985;--color-text-light:#0369a1;--color-heading:#0c4a6e}html.theme-blue.dark{--color-background:#082f49;--color-background-soft:#0c4a6e;--color-background-mute:#0e7490;--color-primary:#38bdf8;--color-primary-dark:#7dd3fc;--color-primary-rgb:56,189,248;--color-secondary:#0ea5e9;--color-secondary-dark:#0284c7;--color-border:#0c4a6e;--color-border-hover:#0e7490;--color-text:#f8fafc;--color-text-light:#cbd5e0;--color-heading:#f1f5f9}html.theme-green{--color-background:#f0fdf4;--color-background-soft:#dcfce7;--color-background-mute:#bbf7d0;--color-primary:#15803d;--color-primary-dark:#166534;--color-primary-rgb:21,128,61;--color-secondary:#4ade80;--color-secondary-dark:#22c55e;--color-border:#dcfce7;--color-border-hover:#bbf7d0;--color-text:#166534;--color-text-light:#15803d;--color-heading:#14532d}html.theme-green.dark{--color-background:#14532d;--color-background-soft:#166534;--color-background-mute:#15803d;--color-primary:#4ade80;--color-primary-dark:#86efac;--color-primary-rgb:74,222,128;--color-secondary:#22c55e;--color-secondary-dark:#16a34a;--color-border:#166534;--color-border-hover:#15803d;--color-text:#f8fafc;--color-text-light:#cbd5e0;--color-heading:#f1f5f9}html.theme-purple{--color-background:#faf5ff;--color-background-soft:#f3e8ff;--color-background-mute:#e9d5ff;--color-primary:#7e22ce;--color-primary-dark:#6b21a8;--color-primary-rgb:126,34,206;--color-secondary:#c084fc;--color-secondary-dark:#a855f7;--color-border:#f3e8ff;--color-border-hover:#e9d5ff;--color-text:#6b21a8;--color-text-light:#7e22ce;--color-heading:#581c87}html.theme-purple.dark{--color-background:#181288;--color-background-soft:#251db8;--color-background-mute:#312af0;--color-primary:#6f6cfb;--color-primary-dark:#8986fc;--color-primary-rgb:111,108,251;--color-secondary:#423ff9;--color-secondary-dark:#615dfa;--color-border:#251db8;--color-border-hover:#312af0;--color-text:#f8fafc;--color-text-light:#cbd5e0;--color-heading:#f1f5f9}html.theme-warm{--color-background:#fff7ed;--color-background-soft:#ffedd5;--color-background-mute:#fed7aa;--color-primary:#c2410c;--color-primary-dark:#9a3412;--color-primary-rgb:194,65,12;--color-secondary:#fb923c;--color-secondary-dark:#f97316;--color-border:#ffedd5;--color-border-hover:#fed7aa;--color-text:#9a3412;--color-text-light:#c2410c;--color-heading:#7c2d12}html.theme-warm.dark{--color-background:#7c2d12;--color-background-soft:#9a3412;--color-background-mute:#c2410c;--color-primary:#fb923c;--color-primary-dark:#fdba74;--color-primary-rgb:251,146,60;--color-secondary:#f97316;--color-secondary-dark:#ea580c;--color-border:#9a3412;--color-border-hover:#c2410c;--color-text:#f8fafc;--color-text-light:#cbd5e0;--color-heading:#f1f5f9}html.theme-teal{--color-background:#f0fdfa;--color-background-soft:#ccfbf1;--color-background-mute:#99f6e4;--color-primary:#0d9488;--color-primary-dark:#0f766e;--color-primary-rgb:13,148,136;--color-secondary:#5eead4;--color-secondary-dark:#2dd4bf;--color-border:#ccfbf1;--color-border-hover:#99f6e4;--color-text:#115e59;--color-text-light:#0f766e;--color-heading:#134e4a}html.theme-teal.dark{--color-background:#134e4a;--color-background-soft:#115e59;--color-background-mute:#0f766e;--color-primary:#5eead4;--color-primary-dark:#99f6e4;--color-primary-rgb:94,234,212;--color-secondary:#2dd4bf;--color-secondary-dark:#14b8a6;--color-border:#115e59;--color-border-hover:#0f766e;--color-text:#f8fafc;--color-text-light:#cbd5e0;--color-heading:#f1f5f9}:root{--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;--font-mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;--container:1120px;--container-narrow:720px;--radius-sm:8px;--radius:14px;--radius-lg:22px;--radius-pill:999px;--shadow-sm:0 1px 2px rgba(15,23,42,0.06),0 1px 3px rgba(15,23,42,0.07);--shadow:0 6px 20px -6px rgba(15,23,42,0.12);--shadow-lg:0 22px 48px -14px rgba(15,23,42,0.25);--header-h:64px;--ease:cubic-bezier(0.22,1,0.36,1)}html.dark{--shadow-sm:0 1px 2px rgba(0,0,0,0.4);--shadow:0 8px 24px -6px rgba(0,0,0,0.55);--shadow-lg:0 26px 56px -16px rgba(0,0,0,0.7)}*,:after,:before{box-sizing:border-box}*{margin:0}html{color-scheme:light dark;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{background-color:var(--color-background);color:var(--color-text);font-family:var(--font-sans);font-size:1rem;line-height:1.65;min-height:100dvh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;transition:background-color .3s,color .3s}main{flex:1 1 auto;width:100%}img{max-width:100%;height:auto;display:block}::selection{background:rgba(var(--color-primary-rgb),.22)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:4px}h1,h2,h3,h4{color:var(--color-heading);line-height:1.15;font-weight:750;letter-spacing:-.02em}a{color:var(--color-primary);text-decoration:none;transition:color .18s var(--ease)}a:hover{color:var(--color-primary-dark)}.container{padding-inline:1.5rem}.container,.page{width:100%;max-width:var(--container);margin-inline:auto}.page{padding:3.5rem 1.5rem 5rem}.page-narrow{max-width:var(--container-narrow)}.eyebrow{display:inline-block;font-family:var(--font-mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.6rem}.page-header{margin-bottom:2.5rem}.page-title{font-size:clamp(2rem,1.4rem + 2.4vw,2.9rem);margin-bottom:.5rem}.page-subtitle{color:var(--color-text-light);font-size:1.1rem;max-width:60ch}.site-header{position:-webkit-sticky;position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--color-background) 80%,transparent);-webkit-backdrop-filter:saturate(180%) blur(12px);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--color-border)}.site-header-inner{height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:1rem}.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:800;letter-spacing:-.02em;font-size:1.05rem}.brand,.brand:hover{color:var(--color-heading)}.brand-mark{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;font-size:.85rem;font-weight:800;letter-spacing:0;box-shadow:var(--shadow-sm)}.nav{display:flex;align-items:center;gap:.35rem}.nav-link{position:relative;padding:.45rem .7rem;border-radius:var(--radius-sm);color:var(--color-text-light);font-weight:550;font-size:.95rem;transition:color .18s var(--ease),background .18s var(--ease)}.nav-link:hover{color:var(--color-heading);background:var(--color-background-mute)}.nav-link.active{color:var(--color-primary)}.nav-link.active:after{content:"";position:absolute;left:.7rem;right:.7rem;bottom:.15rem;height:2px;border-radius:2px;background:var(--color-primary)}.header-actions{display:flex;align-items:center;gap:.75rem}.nav-toggle{display:none}.theme-switcher{display:flex;align-items:center;gap:.5rem}.theme-select{-moz-appearance:none;appearance:none;-webkit-appearance:none;background:var(--color-background-soft);color:var(--color-text);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.4rem 1.8rem .4rem .7rem;font-size:.85rem;font-family:inherit;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .6rem center;text-transform:capitalize;transition:border-color .18s var(--ease)}.theme-select:hover{border-color:var(--color-border-hover)}.icon-btn{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-background-soft);color:var(--color-text);cursor:pointer;font-size:1rem;transition:border-color .18s var(--ease),background .18s var(--ease),transform .18s var(--ease)}.icon-btn:hover{border-color:var(--color-border-hover);background:var(--color-background-mute)}.icon-btn:active{transform:scale(.94)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.7rem 1.3rem;border-radius:var(--radius-sm);font-weight:600;font-size:.95rem;border:1px solid transparent;cursor:pointer;transition:transform .18s var(--ease),background .18s var(--ease),border-color .18s var(--ease),box-shadow .18s var(--ease),color .18s var(--ease)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--color-primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--color-primary-dark);color:#fff;box-shadow:var(--shadow);transform:translateY(-1px)}.btn-outline{background:transparent;color:var(--color-heading);border-color:var(--color-border-hover)}.btn-outline:hover{border-color:var(--color-primary);color:var(--color-primary);transform:translateY(-1px)}.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--color-border);background:radial-gradient(60% 120% at 15% 0,rgba(var(--color-primary-rgb),.16),transparent 60%),radial-gradient(50% 110% at 100% 10%,rgba(var(--color-primary-rgb),.1),transparent 55%),linear-gradient(180deg,var(--color-background-soft),var(--color-background))}.hero:before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--color-border) 1px,transparent 1px),linear-gradient(90deg,var(--color-border) 1px,transparent 1px);background-size:56px 56px;-webkit-mask-image:radial-gradient(70% 70% at 50% 30%,#000 0,transparent 75%);mask-image:radial-gradient(70% 70% at 50% 30%,#000 0,transparent 75%);opacity:.5;pointer-events:none}.hero-inner{position:relative;max-width:var(--container);margin-inline:auto;padding:clamp(4rem,3rem + 6vw,7.5rem) 1.5rem clamp(3.5rem,2.5rem + 5vw,6rem)}.hero-eyebrow{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-mono);font-size:.8rem;letter-spacing:.04em;color:var(--color-text-light);background:var(--color-background);border:1px solid var(--color-border);padding:.35rem .8rem;border-radius:var(--radius-pill);box-shadow:var(--shadow-sm)}.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--color-success);box-shadow:0 0 0 3px rgba(16,185,129,.2)}.hero h1{font-size:clamp(2.6rem,1.6rem + 4.6vw,4.6rem);margin:1.2rem 0 0;line-height:1.05}.hero h1 .accent{background:linear-gradient(120deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;background-clip:text;color:transparent}.hero-lead{margin-top:1.3rem;font-size:clamp(1.05rem,.95rem + .6vw,1.3rem);color:var(--color-text-light);max-width:54ch}.hero-actions{flex-wrap:wrap;gap:.8rem}.hero-actions,.hero-social{margin-top:2rem;display:flex}.hero-social{gap:1.2rem;font-size:.9rem}.hero-social,.hero-social a{color:var(--color-text-light)}.hero-social a:hover{color:var(--color-primary)}.section{max-width:var(--container);margin-inline:auto;padding:4rem 1.5rem}.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1.8rem}.section-title{font-size:clamp(1.5rem,1.2rem + 1.2vw,2rem)}.section-link{font-weight:600;font-size:.95rem;white-space:nowrap}.section-link:after{content:" \2192"}.grid{display:grid;grid-gap:1.4rem;gap:1.4rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.card{display:flex;flex-direction:column;background:var(--color-background-soft);border:1px solid var(--color-border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s var(--ease),border-color .2s var(--ease)}.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-border-hover)}.card-cover{display:block;aspect-ratio:16/9;overflow:hidden;background:var(--color-background-mute)}.card-cover img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}.card:hover .card-cover img{transform:scale(1.04)}.card-cover-mono{display:grid;place-items:center;width:100%;height:100%;color:rgba(255,255,255,.92);font-family:var(--font-mono);font-weight:700;font-size:2.4rem;letter-spacing:.05em;text-shadow:0 2px 10px rgba(0,0,0,.25)}.card-body{display:flex;flex-direction:column;flex:1 1;padding:1.4rem}.card-eyebrow{font-family:var(--font-mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-primary);margin-bottom:.6rem}.card-title{font-size:1.2rem;font-weight:700;letter-spacing:-.01em;line-height:1.25}.card-title a{color:var(--color-heading)}.card-title a:hover{color:var(--color-primary)}.card-excerpt{margin-top:.6rem;color:var(--color-text-light);font-size:.95rem;flex:1 1}.card-meta{align-items:center;gap:.75rem;flex-wrap:wrap;font-size:.82rem;color:var(--color-text-light)}.card-links,.card-meta{margin-top:1.1rem;display:flex}.card-links{gap:1rem;font-size:.9rem;font-weight:600}.tags{display:flex;flex-wrap:wrap;gap:.45rem}.tag{font-family:var(--font-mono);font-size:.74rem;padding:.2rem .6rem;border-radius:var(--radius-pill);background:var(--color-background-mute);color:var(--color-text-light);border:1px solid var(--color-border);transition:color .18s var(--ease),border-color .18s var(--ease)}a.tag:hover{color:var(--color-primary);border-color:var(--color-primary)}.random-photo{width:100%;height:auto;border-radius:var(--radius);border:1px solid var(--color-border);box-shadow:var(--shadow);object-fit:cover}.media-frame{max-width:var(--container);margin:0 auto;padding:0 1.5rem}.article-header{margin-bottom:2rem}.article-title{font-size:clamp(2rem,1.5rem + 2.4vw,3rem);margin-bottom:.7rem}.dek{font-size:1.2rem;line-height:1.5;margin-bottom:1.2rem}.article-meta,.dek{color:var(--color-text-light)}.article-meta{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;font-size:.85rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.article-figure{margin:1.8rem 0}.prose{font-size:1.06rem;line-height:1.75;color:var(--color-text)}.prose>*+*{margin-top:1.15rem}.prose h2{font-size:1.6rem;margin-top:2.6rem}.prose h3{font-size:1.3rem;margin-top:2rem}.prose a{text-decoration:underline;text-underline-offset:3px;-webkit-text-decoration-color:rgba(var(--color-primary-rgb),.4);text-decoration-color:rgba(var(--color-primary-rgb),.4)}.prose a:hover{-webkit-text-decoration-color:var(--color-primary);text-decoration-color:var(--color-primary)}.prose ol,.prose ul{padding-left:1.4rem}.prose li+li{margin-top:.4rem}.prose blockquote{border-left:3px solid var(--color-primary);padding:.4rem 0 .4rem 1.2rem;color:var(--color-text-light);font-style:italic}.prose code{font-family:var(--font-mono);font-size:.88em;background:var(--color-background-mute);padding:.15em .4em;border-radius:6px}.prose pre{background:#0b1220;color:#e2e8f0;border:1px solid var(--color-border);border-radius:var(--radius);padding:1.1rem 1.3rem;overflow-x:auto;font-size:.9rem;line-height:1.6}.prose pre code{background:none;padding:0;font-size:inherit;color:inherit}.prose img{border-radius:var(--radius);border:1px solid var(--color-border)}.prose hr{border:none;border-top:1px solid var(--color-border);margin:2.4rem 0}.prose table{width:100%;border-collapse:collapse;font-size:.95rem}.prose td,.prose th{border:1px solid var(--color-border);padding:.55rem .8rem;text-align:left}.prose th{background:var(--color-background-mute)}.article-tags{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.resume{display:flex;flex-direction:column;gap:2.2rem}.resume-section h2{font-size:1.3rem;margin-bottom:1rem;padding-bottom:.5rem}.resume-job,.resume-section h2{border-bottom:1px solid var(--color-border)}.resume-job{padding:1.2rem 0}.resume-job:last-child{border-bottom:none}.resume-job-head{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;align-items:baseline}.resume-role{font-weight:700;color:var(--color-heading)}.resume-dates{font-family:var(--font-mono);font-size:.82rem;color:var(--color-text-light)}.resume-company{color:var(--color-primary);font-weight:600;margin-top:.15rem}.resume-job ul{margin-top:.7rem;padding-left:1.3rem}.resume-empty,.resume-job ul{color:var(--color-text-light)}.form{display:flex;flex-direction:column;gap:1rem;max-width:560px}.form input,.form textarea{width:100%;font-family:inherit;font-size:1rem;color:var(--color-text);background:var(--color-background-soft);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:.8rem 1rem;transition:border-color .18s var(--ease),box-shadow .18s var(--ease)}.form input::placeholder,.form textarea::placeholder{color:var(--color-text-light)}.form input:focus,.form textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.18)}.form textarea{min-height:160px;resize:vertical}.form-status{font-size:.95rem}.form-status.ok{color:var(--color-success)}.form-status.error{color:var(--color-danger)}.comments-section{margin-top:3rem;padding-top:2rem;border-top:1px solid var(--color-border)}.comments-title{font-size:1.4rem;margin-bottom:1.4rem}.comments{list-style:none;padding:0;margin:0 0 2.5rem;display:flex;flex-direction:column;gap:1rem}.comment{background:var(--color-background-soft);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.1rem 1.3rem}.comment-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:.4rem}.comment-author{font-weight:700;color:var(--color-heading)}.comment-date{font-family:var(--font-mono);font-size:.78rem;color:var(--color-text-light)}.comment-body{color:var(--color-text);white-space:pre-wrap;word-break:break-word}.comments-empty{color:var(--color-text-light);margin-bottom:2rem}.comment-form{background:var(--color-background-soft);border:1px solid var(--color-border);border-radius:var(--radius);padding:1.5rem;max-width:none}.comment-form-title{font-size:1.1rem;margin-bottom:.4rem}.site-footer{margin-top:auto;background:var(--color-background-soft);border-top:1px solid var(--color-border)}.site-footer-inner{max-width:var(--container);margin-inline:auto;padding:3rem 1.5rem 2rem;display:flex;flex-wrap:wrap;align-items:flex-start;gap:2.5rem 3.5rem}.footer-brand{flex:0 1 420px;max-width:420px}.footer-cols{display:flex;flex-wrap:wrap;gap:2rem 3.5rem;margin-left:auto}.footer-col{min-width:140px}.footer-brand .brand{margin-bottom:.8rem}.footer-tagline{color:var(--color-text-light);font-size:.95rem;max-width:38ch}.footer-col h3{font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-light);margin-bottom:.9rem}.footer-col ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.55rem}.footer-col a{color:var(--color-text);font-size:.95rem}.footer-col a:hover{color:var(--color-primary)}.footer-bottom{border-top:1px solid var(--color-border);text-align:center;padding:1.2rem 1.5rem;color:var(--color-text-light);font-size:.85rem}.notfound{min-height:60vh;display:grid;place-content:center;text-align:center;grid-gap:1rem;gap:1rem;padding:2rem}.notfound h1{font-size:clamp(2.5rem,2rem + 4vw,5rem)}.skip-link{position:absolute;left:-9999px;top:0;background:var(--color-primary);color:#fff;padding:.6rem 1rem;border-radius:0 0 var(--radius-sm) 0;z-index:200}.skip-link:focus{left:0;color:#fff}@media (max-width:760px){.nav-toggle{display:inline-grid}.nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:.15rem;padding:.6rem;background:var(--color-background);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow)}.nav.open{display:flex}.nav-link{padding:.7rem .85rem;font-size:1rem;border-radius:var(--radius-sm)}.nav-link.active{background:var(--color-background-mute)}.brand span.brand-name,.nav-link.active:after{display:none}.section-head{flex-direction:column;align-items:flex-start}.theme-select{display:none}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}