/* ATIL Brand Guidelines — Components & Section-Specific
   ====================================================== */

/* ——— Hero ——— */
.hero{
  padding:120px 0 100px;
  position:relative;
}
.hero-meta{
  display:flex;align-items:center;gap:18px;
  margin-bottom:40px;
}
.hero-meta .v{
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--grey-500);
}
.hero-meta .live-dot{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-mono);font-size:11px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--red);
}
.hero-meta .live-dot::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--red);
  animation:pulse 1.6s var(--ease-out) infinite;
}
.hero h1.display{margin:0;color:var(--ink)}
.hero h1.display .red{color:var(--red);font-style:italic;font-family:var(--font-serif);font-weight:400}
.hero .lede{margin-top:32px;font-size:22px;line-height:1.4;max-width:52ch;color:var(--ink)}
.hero-foot{
  margin-top:64px;
  display:grid;grid-template-columns:repeat(4,1fr);
  border-top:1px solid var(--line);
  padding-top:24px;gap:24px;
}
.hero-foot .col .k{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500);margin-bottom:6px}
.hero-foot .col .v{font-family:var(--font-display);font-weight:500;font-size:28px;letter-spacing:-.025em;color:var(--ink)}
.hero-foot .col .v .red{color:var(--red)}

/* ——— Manifesto block (full-bleed red) ——— */
.manifesto{
  background:var(--red);color:#fff;
  border-radius:var(--r-4);
  padding:80px 64px;
  margin:48px 0;
  position:relative;overflow:hidden;
}
.manifesto::before{
  content:"";position:absolute;inset:24px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:var(--r-3);pointer-events:none;
}
.manifesto .kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:24px}
.manifesto .quote{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(32px, 3.6vw, 52px);
  line-height:1.08;letter-spacing:-.025em;
  color:#fff;
  max-width:24ch;
  margin:0;
}
.manifesto .quote em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:#fff}

/* ——— Principles ——— */
.principles{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden}
.principle{background:#fff;padding:32px;display:grid;grid-template-columns:48px 1fr;gap:18px}
.principle .num{font-family:var(--font-mono);font-size:11px;color:var(--red);letter-spacing:.1em;padding-top:5px}
.principle h3{margin-bottom:10px}
.principle p{margin:0;font-size:14.5px}

/* ——— Logo: hero specimen ——— */
.logo-stage{
  background:#fff;border:1px solid var(--line);
  border-radius:var(--r-4);
  padding:80px;
  display:flex;align-items:center;justify-content:center;
  min-height:320px;
  position:relative;overflow:hidden;
}
.logo-stage.dark{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.logo-stage.red{background:var(--red);color:#fff;border-color:var(--red)}
.logo-stage.paper-2{background:var(--paper-2);color:var(--ink);border-color:transparent}
.logo-stage .label{
  position:absolute;top:18px;left:22px;
  font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);
}
.logo-stage.dark .label{color:var(--grey-300)}
.logo-stage.red .label{color:rgba(255,255,255,.7)}
.logo-stage .corner{
  position:absolute;top:18px;right:22px;
  font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);
}
.logo-stage.dark .corner,.logo-stage.red .corner{color:rgba(255,255,255,.55)}

/* ——— Lockup family ——— */
.lockups{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:14px}
.lockup{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:28px;display:flex;align-items:center;justify-content:center;
  min-height:140px;position:relative;
}
.lockup .lbl{position:absolute;bottom:14px;left:18px;font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500)}

/* ——— Construction grid ——— */
.construction{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-4);
  padding:64px;position:relative;
  display:flex;align-items:center;justify-content:center;
  min-height:520px;
}
.construction .grid-bg{
  position:absolute;inset:0;
  background-image:
    linear-gradient(0deg,rgba(10,15,31,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(10,15,31,.06) 1px,transparent 1px);
  background-size:32px 32px;
  pointer-events:none;
}
.construction .blueprint{position:relative;width:480px;height:480px}
.construction .blueprint .blueprint-overlay{position:absolute;inset:0;width:100%;height:100%}
.construction .blueprint .blueprint-mark{position:absolute;inset:0;width:100%;height:100%;object-fit:contain}

/* ——— Sizing rail ——— */
.sizing{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:32px;display:flex;align-items:flex-end;gap:48px;flex-wrap:wrap;
}
.sizing .step{display:flex;flex-direction:column;align-items:center;gap:10px}
.sizing .step .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey-500)}

/* ——— Misuse ——— */
.misuse{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.misuse .item{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:28px 20px 56px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-height:200px;position:relative;
}
.misuse .item .demo{
  width:88px;height:88px;
  display:flex;align-items:center;justify-content:center;
  color:var(--red);
}
.misuse .item .demo svg{width:100%;height:100%}
.misuse .item .x{
  position:absolute;top:14px;right:16px;
  font-family:var(--font-mono);font-size:13px;color:var(--ink);
  font-weight:600;
}
.misuse .item .lbl{
  position:absolute;bottom:18px;left:0;right:0;
  text-align:center;
  font-family:var(--font-mono);font-size:10.5px;
  letter-spacing:.1em;text-transform:uppercase;color:var(--grey-700);
}
.misuse .item.busy{background:var(--paper-2)}
.misuse .item.busy::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(circle at 20% 30%, rgba(126,91,255,.4), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(255,122,31,.45), transparent 45%);
  border-radius:inherit;
}
.misuse .item.busy .demo,.misuse .item.busy .lbl,.misuse .item.busy .x{position:relative;z-index:1}

/* ——— Color swatches ——— */
.swatches{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.sw{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  overflow:hidden;display:flex;flex-direction:column;
}
.sw .chip{
  height:200px;padding:16px;
  display:flex;flex-direction:column;justify-content:space-between;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;
}
.sw .chip .top{display:flex;justify-content:space-between;align-items:flex-start}
.sw .chip .bot{font-size:24px;font-family:var(--font-display);font-weight:500;letter-spacing:-.02em}
.sw .meta{padding:18px;display:flex;flex-direction:column;gap:6px}
.sw .meta .name{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.01em}
.sw .meta .role{font-size:13.5px;color:var(--grey-700);line-height:1.45}
.sw .meta .codes{
  display:grid;grid-template-columns:repeat(2,1fr);gap:4px 12px;
  margin-top:8px;
  font-family:var(--font-mono);font-size:10.5px;
  color:var(--grey-500);letter-spacing:.04em;
}
.sw .meta .codes b{color:var(--ink);font-weight:500;display:inline-block;min-width:38px}

/* ——— Greyscale ramp ——— */
.greys{
  display:grid;grid-template-columns:repeat(8,1fr);
  border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden;
}
.greys .seg{
  height:120px;padding:14px;
  display:flex;flex-direction:column;justify-content:space-between;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;
}
.greys .seg .b{font-size:18px;font-family:var(--font-display);font-weight:500;letter-spacing:-.02em}

/* ——— Ratio bars ——— */
.ratios{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ratio-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);padding:22px;
}
.ratio-card .head{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:14px;
}
.ratio-card .bar{
  height:14px;border-radius:var(--r-pill);overflow:hidden;
  display:flex;background:var(--paper-2);
  margin-bottom:10px;
}
.ratio-card .bar span{display:block;height:100%}
.ratio-card .legend{
  font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--grey-500);line-height:1.7;
}
.ratio-card .legend i{display:inline-block;width:9px;height:9px;border-radius:2px;margin-right:6px;vertical-align:-1px}

/* ——— Contrast pairs ——— */
.pairs{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pair{
  display:flex;align-items:center;gap:14px;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:14px 18px;justify-content:space-between;
}
.pair .demo{
  padding:8px 14px;border-radius:var(--r-2);
  font-family:var(--font-display);font-weight:600;font-size:14px;
}
.pair .label{font-family:var(--font-mono);font-size:11px;color:var(--grey-500);letter-spacing:.04em}
.pair .stat{font-family:var(--font-mono);font-size:12px;font-weight:500}
.pair .stat .ok{color:#0c7a36}
.pair .stat .warn{color:#a16a00}
.pair .stat .fail{color:#b32820}

/* ——— Type spec rows ——— */
.type-spec{
  display:grid;grid-template-columns:240px 1fr;gap:48px;
  padding:36px 0;border-bottom:1px solid var(--line);
}
.type-spec:last-child{border:none}
.type-spec .meta{font-family:var(--font-mono);font-size:11.5px;line-height:1.85;color:var(--grey-500)}
.type-spec .meta strong{display:block;font-family:var(--font-display);font-size:20px;font-weight:600;letter-spacing:-.015em;color:var(--ink);margin-bottom:8px;text-transform:none;letter-spacing:-.015em}
.type-spec .meta .row{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding:6px 0;margin-top:0}
.type-spec .meta .row:first-of-type{border-top:none;margin-top:6px}
.type-spec .meta .row b{color:var(--ink);font-weight:500}
.type-spec .sample-display{font-family:var(--font-display);font-size:96px;line-height:.95;letter-spacing:-.045em;font-weight:500;color:var(--ink)}
.type-spec .sample-display em{font-family:var(--font-serif);font-style:italic;font-weight:400;color:var(--red)}
.type-spec .sample-h{font-family:var(--font-display);font-size:48px;line-height:1.02;letter-spacing:-.025em;font-weight:600;color:var(--ink)}
.type-spec .sample-body{font-family:var(--font-body);font-size:18px;line-height:1.55;color:var(--grey-700);max-width:54ch}
.type-spec .sample-mono{font-family:var(--font-mono);font-size:13.5px;line-height:1.85;color:var(--ink)}
.type-spec .sample-mono .k{color:var(--grey-500)}
.type-spec .sample-mono .v{color:var(--red)}

/* ——— Type at work — context grid ——— */
.context-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.ctx{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:24px;min-height:240px;
  display:flex;flex-direction:column;justify-content:space-between;gap:14px;
  position:relative;overflow:hidden;
}
.ctx.ink{background:var(--ink);color:var(--paper)}
.ctx.red{background:var(--red);color:#fff}
.ctx .lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500)}
.ctx.ink .lbl{color:var(--grey-300)}
.ctx.red .lbl{color:rgba(255,255,255,.7)}

/* ——— Type scale table ——— */
.scale-table{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden;
}
.scale-row{
  display:grid;grid-template-columns:110px 110px 90px 1fr;gap:18px;
  align-items:baseline;padding:16px 24px;
  border-top:1px solid var(--line);
  font-family:var(--font-mono);font-size:11.5px;color:var(--grey-500);
}
.scale-row:first-child{border-top:none}
.scale-row .lbl{color:var(--ink);font-weight:500}
.scale-row .demo{font-family:var(--font-display);color:var(--ink);font-weight:500;letter-spacing:-.025em}
.scale-row .demo.body{font-family:var(--font-body);font-weight:400;letter-spacing:0}
.scale-row .demo.mono{font-family:var(--font-mono);font-weight:500;letter-spacing:.06em;text-transform:uppercase}

/* ——— Spacing scale ——— */
.spacing-rail{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:32px;display:flex;flex-direction:column;gap:14px;
}
.spacing-row{
  display:grid;grid-template-columns:60px 80px 1fr;gap:24px;
  align-items:center;
  font-family:var(--font-mono);font-size:11.5px;color:var(--grey-500);
}
.spacing-row .name{color:var(--ink);font-weight:500}
.spacing-row .px{font-family:var(--font-mono);font-size:11px;color:var(--grey-500)}
.spacing-row .vis{height:14px;background:var(--paper-2);border-radius:2px;position:relative}
.spacing-row .vis::before{
  content:"";position:absolute;left:0;top:0;height:100%;
  background:var(--red);border-radius:2px;
}

/* ——— Radius rail ——— */
.radius-rail{display:flex;gap:14px;flex-wrap:wrap}
.radius-rail .r{
  background:var(--ink);width:88px;height:88px;
  display:flex;align-items:flex-end;padding:8px;
  font-family:var(--font-mono);font-size:10px;color:var(--paper);letter-spacing:.06em;
}

/* ——— Voice cards ——— */
.voice-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.voice-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden;display:flex;flex-direction:column}
.voice-card .hd{padding:14px 22px;font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;display:flex;align-items:center;gap:8px;font-weight:500}
.voice-card.do .hd{background:#0F1F12;color:#A8E022}
.voice-card.do .hd::before{content:"";display:block;width:10px;height:8px;clip-path:polygon(0 0,100% 0,50% 100%);background:#A8E022;transform:rotate(180deg)}
.voice-card.dont .hd{background:#1F0F12;color:#FFB098}
.voice-card.dont .hd::before{content:"";display:block;width:10px;height:8px;clip-path:polygon(0 0,100% 0,50% 100%);background:#FFB098}
.voice-card .body{padding:24px;font-family:var(--font-display);font-weight:500;font-size:20px;line-height:1.32;letter-spacing:-.015em;color:var(--ink);min-height:130px;flex:1}
.voice-card .why{padding:0 24px 22px;font-family:var(--font-mono);font-size:11px;letter-spacing:.04em;color:var(--grey-500);line-height:1.6}

/* ——— Word lists ——— */
.word-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.word-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-3);padding:24px}
.word-card .hd{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);margin-bottom:14px}
.word-card.use .hd{color:var(--red)}
.word-card .list{font-family:var(--font-mono);font-size:13.5px;line-height:2;color:var(--ink);letter-spacing:.02em}
.word-card.avoid .list{text-decoration:line-through;text-decoration-color:rgba(237,28,36,.45);text-decoration-thickness:1.5px;color:var(--grey-700)}

/* ——— Headline formula ——— */
.formula{
  background:var(--ink);color:var(--paper);
  border-radius:var(--r-3);padding:32px;
  font-family:var(--font-mono);font-size:14px;line-height:2;
  letter-spacing:.04em;
}
.formula .slot{display:inline-block;padding:2px 8px;border-radius:var(--r-2);background:rgba(237,28,36,.18);color:#FF8A8E;border:1px solid rgba(237,28,36,.35);margin:0 2px}
.formula .out{margin-top:18px;font-family:var(--font-display);font-weight:500;font-size:24px;letter-spacing:-.015em;color:#fff;text-transform:none}

/* ——— Imagery: data viz tiles ——— */
.viz-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.viz-tile{
  aspect-ratio:1/1;border-radius:var(--r-3);overflow:hidden;
  position:relative;
  display:flex;align-items:flex-end;padding:18px;
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;
}
.viz-tile .label{position:relative;z-index:2}
.viz-tile.dashboard{background:var(--ink);color:var(--paper)}
.viz-tile.line-paper{background:#fff;color:var(--ink);border:1px solid var(--line)}
.viz-tile.line-paper .grid{
  position:absolute;inset:24px;
  background:
    linear-gradient(0deg,rgba(10,15,31,.06) 1px,transparent 1px) 0 100%/100% 24px,
    linear-gradient(90deg,rgba(10,15,31,.06) 1px,transparent 1px) 0 0/24px 100%;
}
.viz-tile.dots{background:var(--ink);color:var(--paper);background-image:radial-gradient(circle,var(--red) 1.5px,transparent 1.6px);background-size:20px 20px}
.viz-tile.stat{background:var(--red);color:#fff}
.viz-tile.stat .big{position:absolute;left:18px;top:18px;font-family:var(--font-display);font-weight:500;font-size:64px;letter-spacing:-.04em;line-height:.9;color:#fff}
.viz-tile.stat .big sub{font-size:20px;font-weight:400;color:rgba(255,255,255,.8);letter-spacing:0;font-family:var(--font-mono)}
.viz-tile.bars{background:var(--paper-2);color:var(--ink)}
.viz-tile.bars .barchart{position:absolute;left:18px;right:18px;bottom:48px;height:55%;display:flex;align-items:flex-end;gap:6px}
.viz-tile.bars .barchart i{flex:1;background:var(--ink);border-radius:2px 2px 0 0}
.viz-tile.bars .barchart i.h{background:var(--red)}
.viz-tile.editorial{background:#fff;color:var(--ink);border:1px solid var(--line);align-items:center;justify-content:center;padding:24px;text-align:center}
.viz-tile.editorial .pull{font-family:var(--font-serif);font-style:italic;font-size:32px;line-height:1.15;letter-spacing:-.01em;color:var(--ink);text-transform:none;letter-spacing:-.01em}
.viz-tile.editorial .pull em{color:var(--red)}

/* ——— Chart anatomy ——— */
.anatomy{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:32px;position:relative;
}
.anatomy svg{width:100%;height:auto;display:block}
.anatomy .pin{
  position:absolute;
  font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;
  color:var(--red);
  background:#fff;padding:3px 7px;border:1px solid var(--red);border-radius:var(--r-pill);
  white-space:nowrap;
}

/* ——— Motion lab ——— */
.motion-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.motion-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:28px;min-height:240px;
  display:flex;flex-direction:column;justify-content:space-between;gap:18px;
  position:relative;overflow:hidden;cursor:pointer;
}
.motion-card .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500)}
.motion-card h4{margin-top:6px}
.motion-card .stage{
  flex:1;background:var(--paper-2);border-radius:var(--r-2);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.motion-card .stage.ink{background:var(--ink)}

/* live counter */
.counter{font-family:var(--font-display);font-weight:500;font-size:48px;letter-spacing:-.03em;color:var(--ink)}
.counter .red{color:var(--red)}
.motion-card.dark .counter{color:var(--paper)}

/* node pulse */
.node-pulse{position:relative;width:14px;height:14px;border-radius:50%;background:var(--red)}
.node-pulse::before,.node-pulse::after{
  content:"";position:absolute;inset:0;border-radius:50%;border:2px solid var(--red);
  animation:nodepulse 2s var(--ease-out) infinite;
}
.node-pulse::after{animation-delay:1s}
@keyframes nodepulse{
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(3.2);opacity:0}
}

/* button hover demo */
.motion-card .btn-demo{transform:translateY(0);transition:transform var(--t-ui) var(--ease-out)}
.motion-card:hover .btn-demo .arr{transform:translateX(6px)}

/* reveal demo */
.reveal-demo{height:48px;background:var(--ink);width:60%;border-radius:var(--r-2);position:relative;overflow:hidden}
.reveal-demo::after{
  content:"";position:absolute;inset:0;background:var(--red);
  transform:translateX(-100%);
  animation:sweep 3s var(--ease-out) infinite;
}
@keyframes sweep{
  0%,100%{transform:translateX(-100%)}
  40%,60%{transform:translateX(100%)}
}

/* ——— Components specimen sheet ——— */
.spec-sheet{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:32px;
}
.spec-sheet > .head{
  display:flex;justify-content:space-between;align-items:flex-end;
  margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--line);
}
.spec-sheet .head h4{font-size:18px;font-family:var(--font-display);font-weight:600;letter-spacing:-.015em}
.spec-row{display:grid;grid-template-columns:140px 1fr;gap:24px;align-items:center;padding:14px 0;border-top:1px solid var(--line)}
.spec-row:first-of-type{border-top:none}
.spec-row .lbl{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500)}
.spec-row .demo{display:flex;flex-wrap:wrap;gap:10px;align-items:center}

/* anatomy diagram */
.anatomy-diagram{
  display:grid;grid-template-columns:1fr 220px;gap:32px;
  background:var(--paper-2);border-radius:var(--r-3);padding:28px;
  align-items:center;
}
.anatomy-diagram .specs{font-family:var(--font-mono);font-size:11px;line-height:2;color:var(--grey-700);letter-spacing:.04em}
.anatomy-diagram .specs b{color:var(--ink);font-weight:500}

/* Stat card primitive */
.stat-card{
  background:var(--ink);color:var(--paper);
  border-radius:var(--r-3);padding:28px;
  display:flex;flex-direction:column;gap:8px;
  position:relative;overflow:hidden;
}
.stat-card::before{
  content:"";position:absolute;top:24px;right:24px;
  width:8px;height:8px;border-radius:50%;background:var(--red);
}
.stat-card .v{font-family:var(--font-display);font-size:64px;letter-spacing:-.045em;font-weight:500;color:var(--red);line-height:1}
.stat-card .v sub{font-size:24px;color:var(--paper);font-weight:400;letter-spacing:0}
.stat-card .k{font-family:var(--font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-300);margin-top:6px}
.stat-card .delta{font-family:var(--font-mono);font-size:12px;color:#A8E022;letter-spacing:.04em}

/* Form input */
.form-field{display:flex;flex-direction:column;gap:8px}
.form-field label{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500)}
.form-field input{
  width:100%;padding:14px 16px;
  border:1px solid var(--line-strong);border-radius:var(--r-2);
  background:var(--paper);font-family:var(--font-body);font-size:15px;
  color:var(--ink);outline:none;
  transition:border-color var(--t-ui) var(--ease-std);
}
.form-field input:focus{border-color:var(--ink)}
.form-field input.error{border-color:var(--red);background:#fff5f5}
.form-field .helper{font-family:var(--font-mono);font-size:10.5px;color:var(--grey-500);letter-spacing:.04em}
.form-field .helper.err{color:var(--red)}

/* Service card */
.service-card{
  background:var(--paper-2);border-radius:var(--r-3);padding:24px;
  display:flex;flex-direction:column;gap:14px;
  border:1px solid transparent;
  transition:border-color var(--t-ui) var(--ease-std);
  cursor:pointer;
}
.service-card:hover{border-color:var(--ink)}
.service-card .tag{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500)}
.service-card h3{margin:0}
.service-card p{margin:0;font-size:14px}

/* Quote */
.quote-block{background:#fff;border:1px solid var(--line);border-radius:var(--r-3);padding:32px}
.quote-block blockquote{
  margin:0;font-family:var(--font-display);font-weight:500;
  font-size:22px;line-height:1.32;letter-spacing:-.015em;color:var(--ink);
}
.quote-block .num{
  display:inline-block;font-family:var(--font-display);font-weight:500;
  font-size:32px;color:var(--red);letter-spacing:-.03em;margin-bottom:12px;
}
.quote-block footer{
  border-top:none;padding:18px 0 0;margin-top:18px;
  border-top:1px solid var(--line);
  display:flex;align-items:center;gap:12px;justify-content:flex-start;
  font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--grey-500);text-transform:uppercase;
}
.quote-block .av{
  width:36px;height:36px;border-radius:50%;background:var(--ink);
  color:var(--paper);display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:600;font-size:14px;
}

/* ——— Tone matrix ——— */
.matrix{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);overflow:hidden;
}
.matrix-row{
  display:grid;grid-template-columns:140px 160px 1fr 1.1fr;
  gap:18px;align-items:flex-start;
  padding:22px 24px;border-top:1px solid var(--line);
}
.matrix-row.head{background:var(--paper-2);border-top:none}
.matrix-row.head span{font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);font-weight:500}
.matrix-row .ctx{font-family:var(--font-display);font-weight:600;font-size:15px;letter-spacing:-.01em;color:var(--ink)}
.matrix-row .dial{font-family:var(--font-mono);font-size:11px;color:var(--red);letter-spacing:.06em}
.matrix-row .practice{font-size:14px;color:var(--grey-700);line-height:1.55}
.matrix-row .sample{font-family:var(--font-display);font-size:16px;font-weight:500;letter-spacing:-.01em;color:var(--ink);line-height:1.4}
.matrix-row .sample.mono{font-family:var(--font-mono);font-size:13px;letter-spacing:.04em;color:var(--ink)}

/* ——— Co-brand ——— */
.cobrand{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);padding:32px;
  display:flex;align-items:center;justify-content:center;gap:32px;
  min-height:140px;
}
.cobrand .partner{font-family:var(--font-display);font-weight:600;font-size:28px;letter-spacing:-.02em;color:var(--ink)}
.cobrand .div{width:1px;height:40px;background:var(--line-strong)}
.cobrand .role{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500);line-height:1.4;text-align:left}

/* ——— Social/avatar grid ——— */
.avatar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.avatar-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:24px;display:flex;flex-direction:column;align-items:center;gap:14px;
}
.avatar-card .lbl{font-family:var(--font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey-500);text-align:center}
.avatar{width:96px;height:96px;display:flex;align-items:center;justify-content:center;background:var(--red);color:#fff}
.avatar.square-r{border-radius:24px}
.avatar.circle{border-radius:50%}
.avatar.fav-light{background:var(--paper);color:var(--red);border:1px solid var(--line)}
.avatar.fav-dark{background:var(--ink);color:var(--red)}
.avatar svg{width:60%;height:60%}

/* OG card */
.og-card{
  aspect-ratio:1200/630;
  background:var(--ink);color:var(--paper);
  border-radius:var(--r-3);
  padding:48px;
  display:flex;flex-direction:column;justify-content:space-between;
  position:relative;overflow:hidden;
  border:1px solid var(--line-d);
}
.og-card::before{
  content:"";position:absolute;right:-80px;bottom:-80px;
  width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,var(--red),transparent 70%);
  opacity:.18;
}
.og-card .tlog{display:flex;align-items:center;gap:14px;position:relative;z-index:2}
.og-card .tlog svg{width:42px;height:42px;color:var(--red)}
.og-card .tlog .id{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-300)}
.og-card .head{position:relative;z-index:2}
.og-card .kicker{font-family:var(--font-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--red);margin-bottom:14px}
.og-card .h{font-family:var(--font-display);font-weight:500;font-size:54px;line-height:1.02;letter-spacing:-.035em;max-width:80%;color:#fff}
.og-card .h em{font-family:var(--font-serif);font-style:italic;color:var(--red);font-weight:400}
.og-card .url{font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;color:var(--grey-300);position:relative;z-index:2;display:flex;justify-content:space-between}

/* ——— Recommendations ——— */
.recs{display:flex;flex-direction:column;gap:14px}
.rec{
  display:grid;grid-template-columns:48px 1fr 1fr;gap:24px;align-items:flex-start;
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:28px;
}
.rec .num{font-family:var(--font-mono);font-size:11px;color:var(--red);letter-spacing:.08em;padding-top:4px}
.rec h4{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.015em;margin-bottom:8px;color:var(--ink)}
.rec .col-label{display:block;font-family:var(--font-mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--grey-500);margin-bottom:8px}
.rec p{font-size:14px;color:var(--grey-700);margin:0;max-width:none}
.rec .now{padding-right:24px;border-right:1px dashed var(--line-strong)}

/* ——— Changelog ——— */
.changelog{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  overflow:hidden;
}
.changelog-row{
  display:grid;grid-template-columns:120px 90px 1fr;gap:24px;
  padding:18px 24px;border-top:1px solid var(--line);
  font-family:var(--font-mono);font-size:12px;color:var(--grey-700);line-height:1.7;
}
.changelog-row:first-child{border-top:none}
.changelog-row .v{color:var(--red);font-weight:500;letter-spacing:.04em}
.changelog-row .d{color:var(--grey-500);font-size:11px;letter-spacing:.06em}

/* ——— Decision log ——— */
.decision{background:#fff;border:1px solid var(--line);border-radius:var(--r-3);padding:24px}
.decision .hd{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.decision .hd .id{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--red)}
.decision h4{font-size:16px}
.decision .considered{font-family:var(--font-mono);font-size:11.5px;color:var(--grey-500);line-height:1.7;margin-top:14px;letter-spacing:.04em}
.decision .considered b{color:var(--ink);font-weight:500;font-family:var(--font-mono)}
.decision .chose{margin-top:6px;font-family:var(--font-mono);font-size:11.5px;color:var(--ink);letter-spacing:.04em}
.decision .chose::before{content:"→ ";color:var(--red);font-weight:600}

/* ——— Downloads ——— */
.dl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.dl-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--r-3);
  padding:28px;display:flex;flex-direction:column;justify-content:space-between;
  min-height:220px;gap:14px;
  transition:border-color var(--t-ui) var(--ease-std), transform var(--t-ui) var(--ease-out);
  cursor:pointer;text-decoration:none;color:var(--ink);
}
.dl-card:hover{border-color:var(--ink)}
.dl-card .row{display:flex;justify-content:space-between;align-items:flex-start}
.dl-card .meta{font-family:var(--font-mono);font-size:11px;letter-spacing:.06em;color:var(--grey-500)}

/* ——— Print ——— */
@media print{
  nav.side{display:none}
  main{padding:0;max-width:none}
  section{break-inside:avoid;page-break-inside:avoid}
}
