:root{
  --canvas:#f7f7f4;
  --canvas-soft:#fafaf7;
  --surface-card:#ffffff;
  --surface-strong:#e6e5e0;
  --hairline:#e6e5e0;
  --hairline-soft:#efeee8;
  --hairline-strong:#cfcdc4;
  --ink:#26251e;
  --body:#5a5852;
  --muted:#807d72;
  --muted-soft:#a09c92;
  --primary:#f54e00;
  --primary-active:#d04200;
  --on-primary:#ffffff;
  --t-thinking:#dfa88f;
  --t-grep:#9fc9a2;
  --t-read:#9fbbe0;
  --t-edit:#c0a8dd;
  --t-done:#c08532;
  --success:#1f8a65;
  --error:#cf2d56;
  --r-xs:4px;--r-sm:6px;--r-md:8px;--r-lg:12px;--r-xl:16px;--r-pill:9999px;
  --s-xxs:4px;--s-xs:8px;--s-sm:12px;--s-base:16px;--s-md:20px;--s-lg:24px;--s-xl:32px;--s-xxl:48px;--s-section:80px;
  --font-sans:"Inter",system-ui,"Helvetica Neue",Helvetica,Arial,sans-serif;
  --font-mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --maxw:1200px;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--canvas);
  color:var(--body);
  font-family:var(--font-sans);
  font-size:16px;
  line-height:1.5;
  letter-spacing:-0.15px;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--ink);text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--s-lg)}

h1,h2,h3{color:var(--ink);font-weight:400;margin:0}
h1{font-size:72px;line-height:1.1;letter-spacing:-2.16px}
h2{font-size:36px;line-height:1.2;letter-spacing:-0.72px}
h3{font-size:26px;line-height:1.25;letter-spacing:-0.325px}
h4{color:var(--ink);font-weight:600}
p{margin:0 0 var(--s-base)}

.label-eyebrow{
  font-size:11px;font-weight:600;line-height:1.4;letter-spacing:0.88px;
  text-transform:uppercase;color:var(--muted);margin-bottom:var(--s-sm);display:block;
}

/* Top nav */
.topnav{background:var(--canvas);border-bottom:1px solid var(--hairline)}
.topnav-inner{height:64px;display:flex;align-items:center;justify-content:space-between}
.wordmark{font-size:18px;font-weight:600;letter-spacing:-0.3px;color:var(--ink)}
a.wordmark:hover{text-decoration:none}
.nav-menu ul{display:flex;gap:var(--s-lg);list-style:none;margin:0;padding:0}
.nav-menu a{font-size:14px;font-weight:500;color:var(--body)}
.nav-menu a.active{color:var(--ink)}
.nav-menu a:hover{color:var(--ink);text-decoration:none}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav-toggle span{width:22px;height:2px;background:var(--ink);display:block}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-sans);font-size:14px;font-weight:500;line-height:1;cursor:pointer;border:1px solid transparent;border-radius:var(--r-md);padding:10px 18px;height:40px;transition:background .15s ease}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--primary);color:var(--on-primary)}
.btn-primary:hover{background:var(--primary-active);color:var(--on-primary)}
.btn-secondary{background:var(--surface-card);color:var(--ink);border-color:var(--hairline-strong)}
.btn-download{background:var(--ink);color:var(--canvas);padding:12px 20px;height:44px}
.btn-download:hover{background:#000;color:var(--canvas)}
.btn-text{background:none;color:var(--ink);padding:10px 4px;height:40px}
.btn-text:hover{text-decoration:underline}

/* Hero */
.hero{background:var(--canvas);padding:var(--s-section) 0}
.hero h1{max-width:14ch}
.hero-sub{font-size:16px;color:var(--body);max-width:60ch;margin-top:var(--s-md)}
.hero-actions{display:flex;gap:var(--s-base);flex-wrap:wrap;margin-top:var(--s-xl)}

/* IDE-mockup card adapted: reference card */
.ref-card{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);margin-top:var(--s-xxl);overflow:hidden}
.ref-card-bar{display:flex;align-items:center;gap:var(--s-xs);padding:var(--s-sm) var(--s-base);border-bottom:1px solid var(--hairline);background:var(--canvas-soft)}
.ref-dot{width:10px;height:10px;border-radius:var(--r-pill);background:var(--hairline-strong)}
.ref-card-body{display:grid;grid-template-columns:1fr 1.3fr;gap:0}
.ref-pane{background:var(--canvas-soft);padding:var(--s-base);font-family:var(--font-mono);font-size:13px;line-height:1.5;color:var(--body)}
.ref-pane.code{border-right:1px solid var(--hairline)}
.ref-pane .ck{color:var(--ink)}
.ref-pane figure{margin:0}
.ref-pane figcaption{font-size:13px;color:var(--muted);padding-top:var(--s-xs);font-family:var(--font-sans)}

/* Sections */
.section{padding:var(--s-section) 0}
.section-tight{padding:var(--s-xxl) 0}
.section-head{max-width:60ch;margin-bottom:var(--s-xl)}
.section-head p{color:var(--body);margin-top:var(--s-sm)}

/* Cards grid */
.grid{display:grid;gap:var(--s-lg)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:var(--s-lg)}
.card h3{font-size:22px;line-height:1.3;letter-spacing:-0.11px;margin-bottom:var(--s-sm)}
.card p{font-size:16px;color:var(--body);margin:0}
.card .label-eyebrow{color:var(--muted)}

/* Badge pill */
.badge{display:inline-block;background:var(--surface-strong);color:var(--ink);font-size:11px;font-weight:600;letter-spacing:0.88px;text-transform:uppercase;border-radius:var(--r-pill);padding:4px 10px}

/* Article media */
.article-hero{padding:var(--s-xxl) 0 var(--s-lg)}
.article-meta{display:flex;gap:var(--s-base);flex-wrap:wrap;align-items:center;color:var(--muted);font-size:13px;margin-top:var(--s-base)}
.article-figure{margin:var(--s-xl) 0}
.article-figure img{border:1px solid var(--hairline);border-radius:var(--r-lg);width:100%;object-fit:cover}
.article-figure figcaption{font-size:13px;color:var(--muted);margin-top:var(--s-xs)}
.prose{max-width:74ch}
.prose h2{font-size:36px;margin:var(--s-xxl) 0 var(--s-base)}
.prose h3{font-size:26px;margin:var(--s-xl) 0 var(--s-sm)}
.prose p{color:var(--body);margin:0 0 var(--s-base)}
.prose ul,.prose ol{color:var(--body);padding-left:var(--s-md);margin:0 0 var(--s-base)}
.prose li{margin-bottom:var(--s-xs)}
.prose a{color:var(--ink);text-decoration:underline}

/* Callout adapted from code-block */
.callout{background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:var(--s-md);margin:var(--s-lg) 0}
.callout .label-eyebrow{margin-bottom:var(--s-xs)}
.callout p{margin:0;color:var(--body)}
.spec{font-family:var(--font-mono);font-size:13px;background:var(--canvas-soft);border:1px solid var(--hairline);border-radius:var(--r-md);padding:var(--s-base);margin:var(--s-base) 0;color:var(--ink);white-space:pre-wrap}

/* Step rows adapted from timeline pills (scoped, neutral usage as content stages) */
.steps{list-style:none;margin:var(--s-base) 0;padding:0;display:grid;gap:var(--s-sm)}
.steps li{display:flex;gap:var(--s-sm);align-items:flex-start;background:var(--surface-card);border:1px solid var(--hairline);border-radius:var(--r-lg);padding:var(--s-base)}
.step-pill{flex:0 0 auto;font-size:11px;font-weight:600;letter-spacing:0.88px;text-transform:uppercase;border-radius:var(--r-pill);padding:4px 10px;color:var(--ink)}
.step-pill.s1{background:var(--t-read)}
.step-pill.s2{background:var(--t-grep)}
.step-pill.s3{background:var(--t-edit)}
.step-pill.s4{background:var(--t-done);color:var(--on-primary)}
.step-body{color:var(--body)}
.step-body strong{color:var(--ink);font-weight:600}

/* Internal link band */
.related{border-top:1px solid var(--hairline);padding-top:var(--s-xl);margin-top:var(--s-xxl)}

/* Contact / form */
.contact-band{background:var(--canvas);border-top:1px solid var(--hairline)}
.form-wrap{max-width:560px}
.form-row{margin-bottom:var(--s-base)}
.form-row label{display:block;font-size:14px;font-weight:600;color:var(--ink);margin-bottom:var(--s-xxs)}
.text-input{width:100%;background:var(--surface-card);color:var(--ink);border:1px solid var(--hairline-strong);border-radius:var(--r-md);padding:12px 16px;height:44px;font-family:var(--font-sans);font-size:16px}
textarea.text-input{height:auto;min-height:120px;resize:vertical}
.text-input:focus{outline:2px solid var(--ink);outline-offset:1px;border-color:var(--ink)}
.field-error{color:var(--error);font-size:13px;margin-top:var(--s-xxs);display:none}
.form-row.invalid .field-error{display:block}
.form-row.invalid .text-input{border-color:var(--error)}
.form-status{display:none;border-radius:var(--r-md);padding:var(--s-base);margin-top:var(--s-base);font-size:14px}
.form-status.show{display:block}
.form-status.success{background:var(--canvas-soft);border:1px solid var(--success);color:var(--success)}
.btn[disabled]{opacity:.6;cursor:not-allowed}

/* CTA band */
.cta-band{background:var(--canvas);border-top:1px solid var(--hairline);padding:96px 0;text-align:center}
.cta-band h2{margin:0 auto var(--s-base);max-width:18ch}
.cta-band p{max-width:54ch;margin:0 auto}

/* Footer */
.footer{background:var(--canvas);border-top:1px solid var(--hairline);color:var(--body);padding:var(--s-xxl) 0 var(--s-lg)}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:var(--s-lg)}
.footer-col ul{list-style:none;margin:0;padding:0;display:grid;gap:var(--s-xs)}
.footer-head{font-size:11px;font-weight:600;letter-spacing:0.88px;text-transform:uppercase;color:var(--muted);margin:0 0 var(--s-sm)}
.footer-link{font-size:14px;color:var(--body)}
.footer-link:hover{color:var(--ink)}
.footer-note{font-size:14px;color:var(--muted);max-width:40ch}
.footer-base{border-top:1px solid var(--hairline);margin-top:var(--s-xl);padding-top:var(--s-base)}
.footer-disclaimer{font-size:13px;color:var(--muted-soft);max-width:90ch}
.footer-copy{font-size:13px;color:var(--muted);margin:0}

/* Cookie banner */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;background:var(--surface-card);border-top:1px solid var(--hairline-strong);z-index:50}
.cookie-banner[hidden]{display:none}
.cookie-inner{display:flex;gap:var(--s-base);align-items:center;justify-content:space-between;padding:var(--s-base) var(--s-lg);flex-wrap:wrap}
.cookie-text{font-size:14px;color:var(--body);margin:0;max-width:70ch}
.cookie-actions{display:flex;gap:var(--s-sm)}

/* Responsive */
@media (max-width:1024px){
  h1{font-size:56px;letter-spacing:-1.6px}
  .grid-3{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:repeat(3,1fr)}
}
@media (max-width:768px){
  .nav-toggle{display:flex}
  .nav-menu{display:none;position:absolute;left:0;right:0;top:64px;background:var(--canvas);border-bottom:1px solid var(--hairline);padding:var(--s-base) var(--s-lg)}
  .nav-menu.open{display:block}
  .nav-menu ul{flex-direction:column;gap:var(--s-base)}
  .topnav-inner{position:relative}
}
@media (max-width:640px){
  h1{font-size:32px;letter-spacing:-0.8px}
  h2{font-size:28px;letter-spacing:-0.5px}
  .hero{padding:var(--s-xxl) 0}
  .section{padding:var(--s-xxl) 0}
  .grid-3,.grid-2{grid-template-columns:1fr}
  .ref-card-body{grid-template-columns:1fr}
  .ref-pane.code{border-right:0;border-bottom:1px solid var(--hairline)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .cta-band{padding:var(--s-xxl) 0}
}
