:root{--font-sans: "Manrope", system-ui, -apple-system, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, "SF Mono", monospace}:root{--orange-100: #fb631b;--orange-200: #f4793f;--orange-300: #f79a6f;--orange-400: #f9bc9f;--orange-500: #fcddcf;--black: #181818;--grey-1000: #101010;--grey-800: #434343;--grey-700: #5c5b59;--grey-600: #858483;--grey-500: #adadac;--grey-400: #d6d6d6;--grey-300: #e5e5e5;--grey-200: #eeeeee;--grey-100: #f6f6f6;--off-white: #f9f8f4;--sand-300: #e0ddd6;--sand-500: #f5f4f1;--white: #ffffff;--blue-100: #8fb6cc;--blue-300: #bcd3e0;--blue-500: #e9f0f5;--success-100: #69be78;--error-100: #e14942;--accent: var(--orange-100);--accent-hover: var(--orange-200);--accent-tint: var(--orange-500);--text-strong: var(--black);--text-body: var(--black);--text-muted: var(--grey-600);--text-faint: var(--grey-500);--text-on-accent: var(--white);--surface-page: var(--white);--surface-panel: var(--off-white);--surface-sand: var(--sand-500);--surface-keycap: var(--grey-200);--surface-chip: var(--grey-100);--surface-dark: var(--black);--rule: var(--grey-300);--rule-strong: var(--grey-400);--border-input: var(--grey-300);--ink: var(--black);--muted: var(--grey-600);--panel: var(--off-white);--keycap: var(--grey-200)}:root{--font-sans: "Manrope", system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace;--text-hero-size: 40px;--text-hero-lh: 1.1;--text-title-lg-size: 28px;--text-title-lg-lh: 1.142;--text-title-md-size: 26px;--text-title-md-lh: 1.23;--text-title-sm-size: 20px;--text-title-sm-lh: 1.4;--text-title-xs-size: 18px;--text-title-xs-lh: 1.33;--text-body-md-size: 14px;--text-body-md-lh: 1.43;--text-body-sm-size: 13px;--text-body-sm-lh: 1.23;--text-label-size: 12px;--text-label-lh: 1.2;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--tracking-tight: -.02em;--tracking-label: .05em;--tracking-btn: .04em}:root{--radius-xs: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 16px;--radius-btn: 7px;--radius-pill: 999px;--space-1: 4px;--space-2: 6px;--space-3: 8px;--space-4: 12px;--space-5: 16px;--space-6: 24px;--space-7: 32px;--space-8: 48px;--space-9: 64px;--space-10: 80px;--rule-w: 1px;--border: 1px solid var(--rule);--content-max: 1136px;--rail-inset: 48px;--shadow-card: 0 10px 30px rgba(20, 30, 70, .25);--shadow-soft: 0 1px 2px rgba(24, 24, 24, .06);--ease: cubic-bezier(.4, 0, .2, 1);--dur: .15s;--transition: .15s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased}body{font-family:var(--font-sans);color:var(--text-body);background:var(--surface-page);line-height:1.5}.mono{font-family:var(--font-mono)}.muted{color:var(--text-muted)}.ds-stage{padding:32px;background:var(--surface-page);min-height:100%}.ds-stage--panel{background:var(--surface-panel)}.t-hero{font-size:var(--text-hero-size);line-height:var(--text-hero-lh);font-weight:var(--weight-medium);letter-spacing:var(--tracking-tight)}.t-title-lg{font-size:var(--text-title-lg-size);line-height:var(--text-title-lg-lh);font-weight:var(--weight-medium);letter-spacing:var(--tracking-tight)}.t-title-md{font-size:var(--text-title-md-size);line-height:var(--text-title-md-lh);font-weight:var(--weight-medium);letter-spacing:var(--tracking-tight)}.t-title-sm{font-size:var(--text-title-sm-size);line-height:var(--text-title-sm-lh);font-weight:var(--weight-medium);letter-spacing:var(--tracking-tight)}.t-title-xs{font-size:var(--text-title-xs-size);line-height:var(--text-title-xs-lh);font-weight:var(--weight-medium)}.t-body-md{font-size:var(--text-body-md-size);line-height:var(--text-body-md-lh);font-weight:var(--weight-regular)}.t-body-sm{font-size:var(--text-body-sm-size);line-height:var(--text-body-sm-lh);font-weight:var(--weight-regular)}.t-label{font-family:var(--font-mono);font-size:var(--text-label-size);text-transform:uppercase;letter-spacing:var(--tracking-label);color:var(--text-muted)}.key{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 4px;margin-left:8px;font-family:var(--font-mono);font-size:11px;font-weight:var(--weight-medium);background:var(--surface-keycap);border:1px solid var(--rule);border-radius:var(--radius-sm);color:var(--text-body)}.key-combo{display:inline-flex;align-items:center;gap:6px;margin-left:8px}.key-combo .key{margin:0}.key-combo .then{font-family:var(--font-mono);font-size:11px;color:var(--text-muted)}.btn{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:12px;font-weight:var(--weight-medium);letter-spacing:var(--tracking-btn);text-transform:uppercase;text-decoration:none;padding:9px 14px;border-radius:var(--radius-btn);border:1px solid var(--rule);color:var(--text-body);background:var(--white);cursor:pointer;transition:background var(--transition),border-color var(--dur) var(--ease)}.btn:hover{background:var(--surface-panel)}.btn-dark{background:var(--surface-dark);color:#fff;border-color:var(--surface-dark)}.btn-dark .key{background:#333;color:#fff;border-color:#444}.btn-dark:hover{background:var(--grey-1000)}.btn-accent{background:var(--accent);color:var(--text-on-accent);border-color:var(--accent)}.btn-accent .key{background:#fff3;color:#fff;border-color:#ffffff4d}.btn-accent:hover{background:var(--accent-hover)}.chip{font-family:var(--font-mono);font-size:13px;background:var(--surface-chip);border:1px solid var(--rule);border-radius:var(--radius-md);padding:3px 8px}.frame{position:relative;max-width:calc(var(--content-max) + var(--rail-inset) * 2);margin:0 auto;padding:0 var(--rail-inset)}.frame:before,.frame:after{content:"";position:absolute;top:0;bottom:0;width:1px;background:var(--rule);z-index:1}.frame:before{left:var(--rail-inset)}.frame:after{right:var(--rail-inset)}.hm-toggle{display:inline-flex;gap:4px;background:var(--surface-dark);color:#fff;border-radius:var(--radius-md);padding:5px;font-family:var(--font-mono);font-size:12px;letter-spacing:var(--tracking-btn)}.hm-toggle span{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:5px}.hm-toggle .on{background:#fff;color:var(--black)}.hm-toggle .dot{width:8px;height:8px;border-radius:50%;border:1.5px solid currentColor}.hm-toggle .on .dot{background:currentColor}:root{--banner-bg: #e9ecf6;--banner-ink: #2b3653;--logo-grey: #b3b1aa}.announce{background:var(--banner-bg);font-size:13px;text-align:center;padding:9px 16px;color:var(--banner-ink)}.announce a{color:inherit;text-decoration:underline;text-underline-offset:2px}nav{border-bottom:1px solid var(--rule)}.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px;position:relative;z-index:2}.wordmark{font-family:var(--font-sans);font-weight:700;font-size:22px;letter-spacing:-.02em;text-decoration:none;color:var(--ink);display:inline-flex}.wordmark-logo{display:block;height:40px;width:auto}.wordmark-logo--footer{height:56px}.frame:before,.frame:after{display:none}.nav-links{display:flex;gap:28px;font-size:14px;font-weight:500}.nav-links a{color:var(--ink);text-decoration:none;opacity:.85}.nav-links a:hover{opacity:1}.nav-actions{display:flex;gap:10px;align-items:center}.logos{padding:44px 0;border-bottom:1px solid var(--rule);text-align:center;position:relative;z-index:2}.logos .cap{font-family:var(--font-mono);font-size:12px;color:var(--muted);margin-bottom:22px;text-transform:uppercase;letter-spacing:.06em}.logo-row{display:flex;flex-wrap:wrap;justify-content:center;gap:40px}.logo-row span{font-weight:700;font-size:19px;color:var(--logo-grey);letter-spacing:-.01em}.metrics{padding:72px 0;border-bottom:1px solid var(--rule);position:relative;z-index:2}.metrics .label{font-family:var(--font-mono);font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.metrics h2{font-size:26px;font-weight:500;letter-spacing:-.02em;margin-bottom:28px}.metrics table{width:100%;border-collapse:collapse;font-size:14px}.metrics th,.metrics td{text-align:left;padding:14px 12px;border-bottom:1px solid var(--rule)}.metrics th{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);font-weight:500}.metrics td.num{font-family:var(--font-mono);font-weight:500}.metrics td .bar{display:inline-block;height:8px;background:var(--accent);border-radius:2px;vertical-align:middle}@media(max-width:640px){.metrics thead{display:none}.metrics table,.metrics tbody,.metrics tr,.metrics td{display:block;width:100%}.metrics tr{padding:12px 0;border-bottom:1px solid var(--rule)}.metrics tr:last-child{border-bottom:none}.metrics td{border:none;padding:3px 0}.metrics td:before{content:attr(data-label);display:inline-block;min-width:96px;font-family:var(--font-mono);font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}.metrics td:first-child{font-size:16px;font-weight:600;padding-bottom:4px}.metrics td:first-child:before{display:none}.metrics td .bar{max-width:100%}}footer{padding:64px 0 40px;position:relative;z-index:2}.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px}.foot-grid .wordmark{margin-bottom:12px;display:block}.foot-grid .tagline{font-size:14px;color:var(--muted);max-width:260px}.foot-col h4{font-family:var(--font-mono);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:14px}.foot-col a{display:block;font-size:14px;color:var(--ink);text-decoration:none;margin-bottom:9px;opacity:.85}.foot-col a:hover{opacity:1}.foot-bottom{display:flex;justify-content:space-between;margin-top:48px;padding-top:20px;border-top:1px solid var(--rule);font-family:var(--font-mono);font-size:12px;color:var(--muted)}.hero{border-bottom:1px solid var(--rule);padding:120px 0 80px;position:relative;z-index:2}.hero .overline{font-family:var(--font-mono);font-size:13px;letter-spacing:.04em;color:var(--muted);margin-bottom:20px}.hero h1{font-weight:500;font-size:40px;line-height:1.1;letter-spacing:-.02em;max-width:760px}.hero .sub{font-weight:500;font-size:28px;line-height:1.142;letter-spacing:-.02em;color:var(--muted);margin-top:8px;max-width:760px}.hero .sub .accent{color:var(--accent)}.hero-cta{display:flex;gap:12px;margin-top:36px}.showcase{padding:56px 0;border-bottom:1px solid var(--rule);position:relative;z-index:2}.feature{padding:72px 0;border-bottom:1px solid var(--rule);position:relative;z-index:2}.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.feature .label{font-family:var(--font-mono);font-size:12px;color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:14px}.feature h2{font-size:28px;font-weight:500;letter-spacing:-.02em;line-height:1.142}.feature p{color:var(--muted);font-size:16px;margin-top:14px;max-width:460px}.feature .links{margin-top:22px;display:flex;gap:10px}.feature-visual{border:1px solid var(--rule);border-radius:12px;background:var(--panel);min-height:280px;display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:13px;color:var(--logo-grey)}.feature.rev .feature-visual{order:-1}.projects-section{padding:72px 0;border-bottom:1px solid var(--rule);position:relative;z-index:2}.projects-label{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.projects-heading{font-size:32px;font-weight:500;letter-spacing:-.02em;margin-bottom:40px}.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}.project-card{border:1px solid var(--rule);border-radius:10px;padding:24px;background:var(--white);transition:background .15s}.project-card:hover{background:var(--panel)}.project-card__overline{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:10px;min-height:1em}.project-card__featured-tag{color:var(--accent)}.project-card__title{font-size:18px;font-weight:500;letter-spacing:-.01em;margin-bottom:8px}.project-card__title a{color:var(--ink);text-decoration:none}.project-card__title a:hover{text-decoration:underline;text-underline-offset:3px}.project-card__summary{font-size:14px;line-height:1.5;margin-bottom:14px}.project-card__stack{font-size:12px;color:var(--muted);letter-spacing:.02em}.project-page{padding:72px 0 96px;position:relative;z-index:2}.project-header{max-width:720px;padding-bottom:40px;border-bottom:1px solid var(--rule);margin-bottom:32px}.project-overline{font-size:13px;letter-spacing:.04em;color:var(--muted);margin-bottom:16px}.project-title{font-size:36px;font-weight:500;letter-spacing:-.02em;line-height:1.12;margin-bottom:16px}.project-summary{font-size:17px;line-height:1.55;color:var(--muted);max-width:620px}.project-meta{display:flex;flex-wrap:wrap;gap:32px;padding-bottom:40px;border-bottom:1px solid var(--rule);margin-bottom:48px}.project-meta__group{display:flex;flex-direction:column;gap:10px}.project-meta__label{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}.project-tags{display:flex;flex-wrap:wrap;gap:8px;list-style:none}.project-tag{font-size:12px;letter-spacing:.02em;color:var(--ink);padding:4px 10px;border:1px solid var(--rule);border-radius:4px;background:var(--panel)}.project-detail{max-width:680px;font-size:16px;line-height:1.7;font-family:var(--font-sans);color:var(--ink);margin-bottom:56px}.project-detail p{margin-bottom:1.25em}.project-detail p:last-child{margin-bottom:0}.project-detail h2{font-size:22px;font-weight:500;letter-spacing:-.01em;line-height:1.3;margin-top:2em;margin-bottom:.6em}.project-detail h3{font-size:18px;font-weight:500;letter-spacing:-.01em;line-height:1.35;margin-top:1.75em;margin-bottom:.5em}.project-detail ul,.project-detail ol{padding-left:1.4em;margin-bottom:1.25em}.project-detail li{margin-bottom:.35em}.project-detail code{font-family:var(--font-mono);font-size:.875em;background:var(--panel);border:1px solid var(--rule);border-radius:3px;padding:2px 5px}.project-detail pre{font-family:var(--font-mono);font-size:13px;background:var(--panel);border:1px solid var(--rule);border-radius:6px;padding:20px;overflow-x:auto;margin-bottom:1.5em}.project-detail pre code{background:none;border:none;padding:0;font-size:inherit}.project-back{border-top:1px solid var(--rule);padding-top:28px;max-width:680px}.project-back__link{font-size:13px;letter-spacing:.02em;color:var(--muted);text-decoration:none;transition:color .15s}.project-back__link:hover{color:var(--ink)}.stack-page{padding:72px 0 96px;position:relative;z-index:2}.stack-header{max-width:720px;padding-bottom:40px;border-bottom:1px solid var(--rule);margin-bottom:48px}.stack-overline{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:16px}.stack-title{font-size:36px;font-weight:500;letter-spacing:-.02em;line-height:1.12}.stack-groups{display:flex;flex-direction:column;gap:0}.stack-group{display:grid;grid-template-columns:200px 1fr;gap:24px;align-items:start;padding:28px 0;border-bottom:1px solid var(--rule)}.stack-group__label{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);padding-top:5px}.stack-group__items{display:flex;flex-wrap:wrap;gap:8px;list-style:none}.stack-item{font-family:var(--font-mono);font-size:13px;color:var(--ink);padding:5px 12px;border:1px solid var(--rule);border-radius:4px;background:var(--panel);letter-spacing:.01em}.stack-back{border-top:1px solid var(--rule);padding-top:28px;margin-top:48px}.stack-back__link{font-size:13px;letter-spacing:.02em;color:var(--muted);text-decoration:none;transition:color .15s}.stack-back__link:hover{color:var(--ink)}.notes-page{padding:72px 0 96px;position:relative;z-index:2}.notes-overline{font-size:12px;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:16px}.notes-page h1{font-size:36px;font-weight:500;letter-spacing:-.02em;line-height:1.12;margin-bottom:40px}.notes-list{display:flex;flex-direction:column}.notes-list .note-card+.note-card{border-top:1px solid var(--rule)}.note-card{padding:28px 0}.note-card__date{font-size:12px;color:var(--muted);letter-spacing:.04em;margin-bottom:8px}.note-card__title{font-size:20px;font-weight:500;letter-spacing:-.01em;margin-bottom:8px}.note-card__title a{color:var(--ink);text-decoration:none}.note-card__title a:hover{text-decoration:underline;text-underline-offset:3px}.note-card__desc{font-size:15px;line-height:1.55;margin-bottom:10px}.note-card__tags{font-size:12px;color:var(--muted);letter-spacing:.03em;margin-bottom:0}@media(max-width:760px){:root{--rail-inset: 20px}.nav-links{display:none}.foot-grid{grid-template-columns:1fr 1fr}.hero{padding:72px 0 56px}.hero h1{font-size:38px}.hero .sub{font-size:22px}.feature-grid{grid-template-columns:1fr;gap:28px}.feature.rev .feature-visual{order:0}.projects-grid{grid-template-columns:1fr}.project-title{font-size:28px}.project-page{padding:48px 0 72px}.project-meta{gap:20px}.stack-title{font-size:28px}.stack-page{padding:48px 0 72px}.stack-group{grid-template-columns:1fr;gap:12px}}
