/* Devplan marketing — Brand alignment v2
   Same layouts as before, restyled to match the Devplan brand:
   white paper, cobalt accent, Geist sans-only, near-black dark sections.
   Variable names from the previous version (--teal, --paper-edge, etc.)
   are intentionally retained so existing inline `style="..."` attributes
   in page markup continue to render correctly — they are just remapped
   to the brand palette.
*/

/* ────────────────────────────────────────────────────────────
   Design tokens — brand
   ──────────────────────────────────────────────────────────── */
:root{
  /* Paper system — clean neutral, no warmth */
  --paper:        #FFFFFF;
  --paper-2:      #F7F7F8;     /* card / inset surface */
  --paper-3:      #FBFBFC;     /* very subtle layering */
  --paper-edge:   #ECECEE;     /* hairline strong */

  /* Ink */
  --ink:          #0A0A0B;     /* near black */
  --ink-2:        #1A1A1C;
  --ink-dim:      #52525A;
  --ink-faint:    #8A8A92;
  --ink-ghost:    #B6BAC0;

  /* Brand accent — cobalt */
  --accent:       #1F3DFF;
  --accent-2:     #2D49FF;
  --accent-soft:  rgba(31, 61, 255, 0.10);
  --accent-soft-2:rgba(31, 61, 255, 0.16);
  --accent-on-dark:#5A77FF;    /* lighter cobalt for text on dark surfaces */

  /* Legacy "teal" aliases → all mapped to cobalt brand accent.
     Kept so inline style="color:var(--teal)" still works. */
  --teal:         var(--accent);
  --teal-2:       var(--accent-2);
  --teal-3:       var(--accent-on-dark);
  --teal-ink:     #0A0A0B;            /* footer / deep panel background */
  --teal-soft:    var(--accent-soft);
  --teal-soft-2:  var(--accent-soft-2);

  /* "On dark" tokens used by the dark sections + footer */
  --on-teal:      #FFFFFF;
  --on-teal-dim:  rgba(255,255,255,0.62);
  --on-teal-rule: rgba(255,255,255,0.10);
  --on-teal-rule-strong: rgba(255,255,255,0.18);

  /* Amber — kept for warnings + a touch of warmth on dark panels */
  --amber:        #C18A35;
  --amber-2:      #E6A437;
  --amber-soft:   rgba(230, 164, 55, 0.14);

  /* Hairlines */
  --rule:         rgba(10, 10, 11, 0.08);
  --rule-2:       rgba(10, 10, 11, 0.14);
  --rule-strong:  rgba(10, 10, 11, 0.22);

  /* Type — Geist for everything. `--serif` alias kept for compatibility,
     but it just falls through to Geist sans (so headlines look modern). */
  --sans:         "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --serif:        "Geist", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --mono:         "JetBrains Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;

  /* Layout */
  --maxw:         1320px;
  --content-w:    920px;
  --gutter:       clamp(20px, 4vw, 56px);

  /* Motion */
  --ease:         cubic-bezier(.22,.61,.36,1);
  --ease-out:     cubic-bezier(.16,1,.3,1);
}

/* ────────────────────────────────────────────────────────────
   Reset & base
   ──────────────────────────────────────────────────────────── */
*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{
  background:var(--paper);
  scroll-behavior:smooth;
  -webkit-text-size-adjust:100%;
}
body{
  font-family:var(--sans);
  font-weight:400;
  font-size:15px;
  line-height:1.55;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  font-feature-settings:"ss01","ss03","cv11";
  position:relative;
  overflow-x:hidden;
}

::selection{ background:var(--accent); color:#fff; }

a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; background:none; border:0; color:inherit; padding:0; }
img,svg{ display:block; max-width:100%; }

/* ────────────────────────────────────────────────────────────
   Typography utilities — Geist throughout, weight + tracking for hierarchy
   ──────────────────────────────────────────────────────────── */
.serif{ font-family:var(--sans); }   /* legacy alias — no italics anymore */
.mono{ font-family:var(--mono); }

/* Eyebrow */
.eyebrow{
  font-family:var(--mono);
  font-size:11px; font-weight:500;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink-dim);
  display:inline-flex; align-items:center; gap:12px;
}
.eyebrow::before{
  content:"";
  width:18px; height:1px; background:var(--ink-dim);
}
.eyebrow.no-rule::before{ display:none; }
.eyebrow.on-teal{ color:var(--on-teal-dim); }
.eyebrow.on-teal::before{ background:var(--on-teal-dim); }

/* Display heading — Geist tight & light */
.display{
  font-family:var(--sans);
  font-weight:340;
  font-size:clamp(30px, 4.25vw, 62px);
  line-height:1.04;
  letter-spacing:-0.034em;
  color:var(--ink);
  margin:0;
}
.display .it{ color:var(--accent); font-weight:500; font-style:normal; }
.display .dim{ color:var(--ink-faint); font-weight:320; }

.h2{
  font-family:var(--sans);
  font-weight:400;
  font-size:clamp(25px, 3vw, 40px);
  line-height:1.08;
  letter-spacing:-0.028em;
  color:var(--ink);
  margin:0;
}
.h2 .it{ color:var(--accent); font-weight:550; font-style:normal; }
.h2 .dim{ color:var(--ink-faint); font-weight:340; }

.h3{
  font-family:var(--sans);
  font-weight:500;
  font-size:clamp(20px, 1.9vw, 25px);
  line-height:1.25;
  letter-spacing:-0.02em;
  color:var(--ink);
  margin:0;
}

.lede{
  font-family:var(--sans);
  font-weight:400;
  font-size:clamp(14px, 1.1vw, 16px);
  line-height:1.6;
  letter-spacing:-0.005em;
  color:var(--ink-dim);
  max-width:62ch;
}
.lede strong{ color:var(--ink); font-weight:500; }

.kicker{
  font-family:var(--mono);
  font-size:10.5px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:var(--ink-faint);
}

/* ────────────────────────────────────────────────────────────
   Layout primitives
   ──────────────────────────────────────────────────────────── */
.shell{
  width:100%;
  max-width:var(--maxw);
  margin-inline:auto;
  padding-inline:var(--gutter);
  position:relative;
}
.shell-narrow{
  width:100%;
  max-width:1080px;
  margin-inline:auto;
  padding-inline:var(--gutter);
  position:relative;
}

section{ position:relative; }
.section{ padding-block:clamp(72px, 9vw, 144px); position:relative; }
.section-sm{ padding-block:clamp(48px, 6vw, 96px); position:relative; }

/* The hero already provides ample bottom padding — collapse the top
   padding of the next-following section so it doesn't double up. */
.hero + .section,
.hero + .section-sm{
  padding-top:clamp(8px, 1.5vw, 24px);
}

.rule{ height:1px; background:var(--rule); border:0; margin:0; }
.rule-strong{ height:1px; background:var(--rule-2); border:0; }

/* On-dark surfaces (formerly surface-teal) */
.surface-teal{
  background:#0A0A0B;
  color:var(--on-teal);
  position:relative;
}
/* subtle radial tint inside dark sections so they read as Devplan, not generic */
.surface-teal::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(120% 80% at 110% 0%, rgba(31,61,255,0.12), transparent 60%);
  pointer-events:none;
}
.surface-teal > *{ position:relative; }
.surface-teal a{ color:var(--on-teal); }
.surface-teal .h2,
.surface-teal .h3,
.surface-teal .display{ color:var(--on-teal); }
.surface-teal .lede{ color:var(--on-teal-dim); }

/* ────────────────────────────────────────────────────────────
   Nav
   ──────────────────────────────────────────────────────────── */
.nav{
  position:sticky; top:0; z-index:60;
  background:rgba(255,255,255,0.84);
  backdrop-filter:blur(18px) saturate(160%);
  -webkit-backdrop-filter:blur(18px) saturate(160%);
  border-bottom:1px solid var(--rule);
}
.nav-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:64px;
}
.nav-logo{
  display:inline-flex; align-items:center; gap:10px;
  color:var(--ink);
  transition:opacity .2s var(--ease);
}
.nav-logo:hover{ opacity:.7; }
.nav-logo-mark{
  width:22px; height:22px; flex-shrink:0;
  color:var(--accent);
}
.nav-logo-text{
  font-family:var(--sans);
  font-size:17px;
  font-weight:600;
  letter-spacing:-0.018em;
  color:var(--ink);
}

.nav-meta{ display:flex; align-items:center; gap:4px; }

.nav-link{
  font-size:13.5px; font-weight:500;
  color:var(--ink-dim);
  padding:9px 14px;
  letter-spacing:-0.005em;
  border-radius:6px;
  position:relative;
  transition:color .2s var(--ease), background .2s var(--ease);
}
.nav-link:hover, .nav-link.is-open{ color:var(--ink); background:rgba(10,10,11,.04); }
.nav-link.is-active{ color:var(--ink); }
.nav-link.has-dropdown::after{
  content:"";
  display:inline-block;
  width:6px; height:6px;
  margin-left:6px; vertical-align:1px;
  border-right:1.4px solid currentColor;
  border-bottom:1.4px solid currentColor;
  transform:rotate(45deg) translate(-2px,-2px);
  opacity:.55;
  transition:transform .25s var(--ease), opacity .25s var(--ease);
}
.nav-link.has-dropdown.is-open::after{ transform:rotate(-135deg) translate(-1px,-1px); opacity:1; }

.nav-divider{
  width:1px; height:18px; background:var(--rule-2); margin:0 8px;
}

.nav-login{
  font-size:13.5px; font-weight:500;
  color:var(--ink);
  padding:9px 14px;
  letter-spacing:-0.005em;
  border-radius:6px;
  transition:background .2s var(--ease);
}
.nav-login:hover{ background:rgba(10,10,11,.04); }

.nav-cta{
  font-size:13.5px; font-weight:500;
  color:#fff; background:var(--ink);
  padding:10px 16px; border-radius:6px;
  letter-spacing:-0.005em;
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--ink);
  transition:background .25s var(--ease), border-color .25s var(--ease);
  margin-left:10px;
}
.nav-cta:hover{ background:var(--accent); border-color:var(--accent); }
.nav-cta .arrow{ transition:transform .25s var(--ease); }
.nav-cta:hover .arrow{ transform:translateX(3px); }

/* Dropdown panel */
.nav-dropdown-wrap{ position:relative; }
.nav-dropdown{
  position:absolute; top:100%; left:-12px;
  margin-top:14px;            /* visual gap between button and panel */
  min-width:520px;
  background:var(--paper);
  border:1px solid var(--rule-2);
  border-radius:14px;
  box-shadow:0 32px 80px -20px rgba(10,10,11,.18), 0 8px 24px -8px rgba(10,10,11,.10);
  padding:12px;
  opacity:0; visibility:hidden; transform:translateY(-6px);
  transition:opacity .22s var(--ease), transform .22s var(--ease), visibility .22s;
  z-index:80;
}
/* Invisible hover-bridge that fills the gap above the panel.
   Without this, moving the cursor from the button to the panel
   crosses dead space and triggers mouseleave on the wrap. */
.nav-dropdown::before{
  content:"";
  position:absolute;
  left:-12px; right:-12px;        /* slightly wider than panel to catch diagonals */
  top:-24px; height:24px;         /* taller than the 14px gap for margin of error */
  background:transparent;
  pointer-events:auto;
}
.nav-dropdown-wrap.is-open .nav-dropdown{ opacity:1; visibility:visible; transform:translateY(0); }
.nav-dropdown-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:6px;
}
.nav-dd-item{
  display:flex; flex-direction:column; gap:4px;
  padding:14px;
  border-radius:10px;
  transition:background .2s var(--ease);
}
.nav-dd-item:hover{ background:var(--paper-2); }
.nav-dd-item .dd-eyebrow{
  font-family:var(--mono); font-size:9.5px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink-faint);
}
.nav-dd-item .dd-title{
  font-family:var(--sans); font-weight:500;
  font-size:15px; letter-spacing:-0.015em; color:var(--ink);
  margin:2px 0 4px;
}
.nav-dd-item .dd-sub{
  font-size:12.5px; color:var(--ink-dim); line-height:1.45;
}
.nav-dd-item.dd-overview{
  grid-column:1 / -1;
  background:var(--ink);
  color:var(--on-teal);
}
.nav-dd-item.dd-overview .dd-title{ color:#fff; font-size:16px; }
.nav-dd-item.dd-overview .dd-sub{ color:var(--on-teal-dim); }
.nav-dd-item.dd-overview .dd-eyebrow{ color:var(--accent-on-dark); }
.nav-dd-item.dd-overview:hover{ background:#171719; }

@media (max-width: 860px){
  .nav-link:not(.has-dropdown), .nav-login, .nav-divider{ display:none; }
  .nav-dropdown{ display:none; }
}
@media (max-width: 540px){
  .nav-link{ display:none; }
}

/* ────────────────────────────────────────────────────────────
   Buttons / CTAs
   ──────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--sans);
  font-size:14px; font-weight:500;
  padding:12px 18px;
  border-radius:8px;
  letter-spacing:-0.005em;
  line-height:1;
  border:1px solid transparent;
  transition:background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease), transform .2s var(--ease);
  white-space:nowrap;
}
.btn .arrow{ transition:transform .25s var(--ease); }
.btn:hover .arrow{ transform:translateX(4px); }

.btn-primary{
  background:var(--ink); color:#fff;
  border-color:var(--ink);
}
.btn-primary:hover{ background:var(--accent); border-color:var(--accent); }

.btn-ghost{
  background:transparent; color:var(--ink);
  border-color:var(--rule-2);
}
.btn-ghost:hover{ border-color:var(--ink); background:rgba(10,10,11,.03); }

.btn-on-teal{
  background:#fff; color:var(--ink);
  border-color:#fff;
}
.btn-on-teal:hover{ background:var(--accent); color:#fff; border-color:var(--accent); }

.btn-link{
  font-family:var(--sans);
  font-size:13.5px; font-weight:500;
  color:var(--ink);
  display:inline-flex; align-items:center; gap:8px;
  padding-bottom:3px;
  border-bottom:1px solid var(--rule-2);
  transition:border-color .25s var(--ease), color .25s var(--ease);
}
.btn-link:hover{ border-color:var(--accent); color:var(--accent); }
.btn-link .arrow{ transition:transform .25s var(--ease); }
.btn-link:hover .arrow{ transform:translateX(3px); }

.btn-link.on-teal{ color:#fff; border-color:var(--on-teal-rule); }
.btn-link.on-teal:hover{ border-color:var(--accent-on-dark); color:var(--accent-on-dark); }

/* ────────────────────────────────────────────────────────────
   Hero
   ──────────────────────────────────────────────────────────── */
.hero{
  position:relative;
  padding-top:clamp(64px, 10vw, 144px);
  padding-bottom:clamp(56px, 8vw, 112px);
  overflow:hidden;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.45fr 1fr;
  gap:clamp(36px, 5vw, 80px);
  align-items:end;
}
@media (max-width: 960px){
  .hero-grid{ grid-template-columns:1fr; gap:48px; }
}

.hero-eyebrow{ margin-bottom:32px; }

.hero-title{
  font-family:var(--sans);
  font-weight:320;
  font-size:clamp(35px, 4.9vw, 68px);
  line-height:1.02;
  letter-spacing:-0.036em;
  margin:0;
  color:var(--ink);
  text-wrap:balance;           /* let the browser pick equal-length break points */
}
.hero-title .it{ color:var(--accent); font-weight:500; font-style:normal; }
.hero-title .dim{ color:var(--ink-faint); font-weight:280; }
.hero-title .accent{ color:var(--accent); }

.hero-sub{
  font-family:var(--sans);
  font-style:normal;
  font-weight:500;
  font-size:clamp(14px, 1.15vw, 16px);
  line-height:1.4;
  color:var(--ink);
  margin:20px 0 0;
  max-width:36ch;
  letter-spacing:-0.012em;
}
/* On dark surfaces the hero-sub stays readable in white */
.surface-teal .hero-sub{ color:#fff; }

.hero-body{
  font-size:14.5px; line-height:1.6; letter-spacing:-0.005em;
  color:var(--ink-dim);
  max-width:50ch;
  margin:0;
}

.hero-actions{
  display:flex; align-items:center; gap:16px;
  margin-top:36px;
  flex-wrap:wrap;
}

/* Hero meta row — used when the title spans the full width and the
   body copy + CTAs sit beneath it as a horizontal pairing. */
.hero-meta{
  display:grid;
  grid-template-columns:1.3fr auto;
  gap:clamp(36px, 5vw, 80px);
  align-items:end;
  margin-top:clamp(28px, 3vw, 40px);
}
.hero-meta .hero-actions{ margin-top:0; flex-shrink:0; }
@media (max-width: 860px){
  .hero-meta{ grid-template-columns:1fr; gap:24px; align-items:start; }
}

/* Numbered section marker */
.section-num{
  font-family:var(--mono);
  font-size:11px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--ink-faint);
  display:flex; align-items:baseline; gap:14px;
  margin-bottom:24px;
}
.section-num .n{
  color:var(--ink);
  font-weight:600;
}

/* ────────────────────────────────────────────────────────────
   Stat strip
   ──────────────────────────────────────────────────────────── */
.stats{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(180px, 1fr));
  gap:1px;
  background:var(--rule);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.stat{
  background:var(--paper);
  padding:32px clamp(20px, 2vw, 32px);
  display:flex; flex-direction:column; gap:6px;
}
.stat-n{
  font-family:var(--sans);
  font-weight:340;
  font-size:clamp(24px, 2.4vw, 32px);
  line-height:1; letter-spacing:-0.036em;
  color:var(--ink);
}
.stat-n.accent{ color:var(--accent); }
.stat-n .small{ font-size:.5em; color:var(--ink-faint); vertical-align:baseline; margin-left:4px; font-weight:400; }
.stat-label{
  font-size:13.5px; color:var(--ink); line-height:1.35; font-weight:500;
  letter-spacing:-0.005em;
}
.stat-note{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-faint); margin-top:4px;
}

.stats.on-teal{
  background:var(--on-teal-rule);
  border-color:var(--on-teal-rule);
}
.stats.on-teal .stat{ background:#0A0A0B; }
.stats.on-teal .stat-n{ color:#fff; }
.stats.on-teal .stat-n.accent{ color:var(--accent-on-dark); }
.stats.on-teal .stat-label{ color:#fff; }
.stats.on-teal .stat-note{ color:var(--on-teal-dim); }

/* ────────────────────────────────────────────────────────────
   Integration logo strip
   ──────────────────────────────────────────────────────────── */
.logo-strip{
  display:flex; flex-wrap:wrap; align-items:center; gap:16px 28px;
  padding:28px 0;
}
.logo-strip-label{
  font-family:var(--mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--ink-faint);
  flex-basis:100%;
  margin-bottom:4px;
}
.logo-strip .logo-name{
  font-family:var(--sans);
  font-weight:500;
  font-size:15px; letter-spacing:-0.012em;
  color:var(--ink);
  display:inline-flex; align-items:center; gap:10px;
  line-height:1;
}
.logo-strip .logo-name svg,
.logo-strip .logo-name img{
  width:22px; height:22px; display:block; flex-shrink:0;
}
.logo-strip .logo-name .sep{ display:none; }

/* ────────────────────────────────────────────────────────────
   Section headers
   ──────────────────────────────────────────────────────────── */
.section-head{
  display:flex;
  flex-direction:column;
  gap:16px;
  max-width:980px;
  margin-bottom:clamp(40px, 5vw, 64px);
}
.section-head .lede{ max-width:64ch; }

/* ────────────────────────────────────────────────────────────
   Quote cards
   ──────────────────────────────────────────────────────────── */
.quote-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--rule-2);
  border-bottom:1px solid var(--rule-2);
}
@media (max-width: 960px){ .quote-grid{ grid-template-columns:1fr; } }

.quote-card{
  background:transparent;
  border:0;
  border-left:1px solid var(--rule);
  border-radius:0;
  padding:clamp(36px, 4vw, 48px) clamp(24px, 2.6vw, 36px);
  display:flex; flex-direction:column; gap:20px;
  position:relative;
  transition:background .25s var(--ease);
}
.quote-card:first-child{ border-left:0; }
.quote-card:hover{ background:var(--paper-2); transform:none; }
.quote-card::before{
  content:"";
  position:relative; top:0; left:0;
  width:18px; height:2px;
  background:var(--accent);
  margin-bottom:4px;
}
@media (max-width: 960px){
  .quote-card{ border-left:0; border-top:1px solid var(--rule); }
  .quote-card:first-child{ border-top:0; }
}
.quote-card .q{
  font-family:var(--sans);
  font-weight:420;
  font-size:16px; line-height:1.5;
  color:var(--ink);
  letter-spacing:-0.012em;
  position:relative;
  margin:0;
}
.quote-card .who{
  font-size:12.5px; line-height:1.5; color:var(--ink-dim);
  margin-top:auto;
  padding-top:18px;
  border-top:1px solid var(--rule);
}
.quote-card .who strong{ color:var(--ink); font-weight:500; }

/* Featured quote — large editorial type on plain paper. No floating card. */
.quote-feature{
  background:transparent;
  color:var(--ink);
  border-radius:0;
  padding:clamp(56px, 7vw, 96px) 0;
  display:block;
  position:relative;
}
.quote-feature::before{ display:none; }

/* Dot-matrix quotation mark — rendered by JS as a grid of <span class="qmark-dot">
   elements that gently repel away from the cursor as it crosses the section. */
.quote-feature .qmark{
  display:block;
  position:relative;
  height:auto;
  margin:0 0 clamp(28px, 3vw, 40px);
  pointer-events:none;
  color:transparent;        /* hide the literal " character fallback */
  font-size:0;
  line-height:0;
}
.qmark-dot{
  position:absolute;
  width:4px; height:4px;
  border-radius:50%;
  background:var(--accent);
  transition:transform .42s cubic-bezier(.22,.61,.36,1);
  will-change:transform;
}
.surface-teal .qmark-dot{
  background:rgba(255,255,255,0.55);
}

/* Standalone dot-matrix icon block (e.g. integrations "Don't see yours?"
   plug). The element is sized by JS via cols * pitch / rows * pitch and
   the dots inside use the shared .qmark-dot styling. */
.dotmatrix-block{
  display:inline-block;
  pointer-events:none;
}
.dotmatrix-block .qmark-dot{
  width:5px; height:5px;       /* slightly chunkier than the quote dots */
}
.quote-feature .q{
  font-family:var(--sans);
  font-weight:340;
  font-size:clamp(28px, 3.6vw, 52px);
  line-height:1.15;
  letter-spacing:-0.03em;
  color:var(--ink);
  max-width:28ch;
  margin:0;
  text-wrap:balance;
}
.quote-feature .who{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint);
  margin-top:clamp(28px, 3vw, 40px);
}

/* Dark-surface variant — same scale, white text on the inherited dark bg. */
.surface-teal .quote-feature{
  color:#fff;
}
.surface-teal .quote-feature .q{ color:#fff; }
.surface-teal .quote-feature .who{ color:var(--on-teal-dim); }

/* ────────────────────────────────────────────────────────────
   Comparison table (Claude+MCP vs Devplan)
   Default = light. Inside .surface-teal, the dark overrides apply.
   ──────────────────────────────────────────────────────────── */
.compare{
  border:1px solid var(--rule-2);
  border-radius:14px;
  overflow:hidden;
  background:var(--paper-2);
}
.compare-row{
  display:grid;
  grid-template-columns:1fr 1.3fr 1.3fr;
  border-top:1px solid var(--paper-edge);
}
.compare-row:first-child{ border-top:0; }
.compare-cell{
  padding:18px 22px;
  font-size:13px; line-height:1.55;
  color:var(--ink);
  border-left:1px solid var(--paper-edge);
}
.compare-cell:first-child{ border-left:0; }
.compare-cell.h{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-dim);
  background:var(--paper-3);
}
.compare-cell.h .h-vs{ color:var(--ink-faint); }
.compare-cell.row-h{
  font-family:var(--sans); font-weight:500;
  font-size:14px; letter-spacing:-0.015em;
  color:var(--ink);
  background:var(--paper-3);
}
.compare-cell.neg{ color:var(--ink-dim); }
.compare-cell.pos{
  color:var(--ink);
  background:rgba(31,61,255,0.04);
}
.compare-cell.pos strong{ color:var(--accent); font-weight:600; }

/* Dark variant — applies when nested inside .surface-teal */
.surface-teal .compare{
  background:rgba(255,255,255,0.02);
  border-color:var(--on-teal-rule);
}
.surface-teal .compare-row{ border-top-color:var(--on-teal-rule); }
.surface-teal .compare-cell{
  color:#fff;
  border-left-color:var(--on-teal-rule);
}
.surface-teal .compare-cell.h{
  color:var(--on-teal-dim);
  background:rgba(255,255,255,0.04);
}
.surface-teal .compare-cell.h .h-vs{ color:var(--on-teal-dim); opacity:.7; }
.surface-teal .compare-cell.row-h{
  color:#fff;
  background:rgba(255,255,255,0.04);
}
.surface-teal .compare-cell.neg{ color:var(--on-teal-dim); }
.surface-teal .compare-cell.pos{
  color:#fff;
  background:rgba(255,255,255,0.04);
}
.surface-teal .compare-cell.pos strong{ color:#fff; font-weight:650; }

@media (max-width: 820px){
  .compare-row{ grid-template-columns:1fr; }
  .compare-cell{ border-left:0; border-top:1px solid var(--paper-edge); }
  .compare-cell.row-h{ border-top:0; }
  .surface-teal .compare-cell{ border-top-color:var(--on-teal-rule); }
}

/* ────────────────────────────────────────────────────────────
   Product cards (Weaver / Insights / Specs)
   ──────────────────────────────────────────────────────────── */
.product-cards{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--rule-2);
  border-bottom:1px solid var(--rule-2);
}
@media (max-width:960px){ .product-cards{ grid-template-columns:1fr; } }
.product-card{
  padding:clamp(40px, 4vw, 56px) clamp(28px, 3vw, 40px);
  display:flex; flex-direction:column; gap:22px;
  border-left:1px solid var(--rule);
  position:relative;
  transition:background .25s var(--ease);
}
.product-card:first-child{ border-left:0; }
@media (max-width:960px){
  .product-card{ border-left:0; border-top:1px solid var(--rule); }
  .product-card:first-child{ border-top:0; }
}
.product-card:hover{ background:var(--paper-2); }
.product-card-head{
  display:flex; align-items:center; justify-content:space-between;
}
.product-card-name{
  font-family:var(--sans);
  font-weight:500;
  font-size:25px; letter-spacing:-0.026em;
  color:var(--ink);
}
.product-card-num{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.2em; color:var(--ink-faint);
}
.product-card-tag{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint); font-weight:500;
}
.product-card-body{
  font-size:14px; line-height:1.55;
  color:var(--ink-dim);
  flex:1;
  margin-top:-11px;          /* halves the gap immediately below the product name */
}
.product-card-link{
  font-size:13.5px; font-weight:500;
  color:var(--ink);
  display:inline-flex; align-items:center; gap:8px;
  padding-bottom:3px;
  border-bottom:1px solid var(--rule-2);
  align-self:flex-start;
  transition:border-color .25s var(--ease), color .25s var(--ease);
}
.product-card-link:hover{ border-color:var(--accent); color:var(--accent); }
.product-card-link .arrow{ transition:transform .25s var(--ease); }
.product-card-link:hover .arrow{ transform:translateX(3px); }

/* ────────────────────────────────────────────────────────────
   Capability row (alternating, with visual placeholder)
   ──────────────────────────────────────────────────────────── */
.cap{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:center;
  padding-block:clamp(56px, 7vw, 96px);
  border-top:1px solid var(--rule);
}
.cap:first-of-type{ border-top:0; padding-top:0; }
.cap.reverse .cap-text{ order:2; }
.cap.reverse .cap-visual{ order:1; }
@media (max-width: 960px){
  .cap{ grid-template-columns:1fr; gap:36px; }
  .cap.reverse .cap-text{ order:1; }
  .cap.reverse .cap-visual{ order:2; }
}
.cap-eyebrow{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink); font-weight:600;
  margin-bottom:18px;
  display:flex; align-items:baseline; gap:12px;
}
.cap-eyebrow .cnum{ color:var(--ink-faint); font-weight:400; }
.cap-title{
  font-family:var(--sans);
  font-weight:430;
  font-size:clamp(22px, 2.25vw, 30px);
  line-height:1.15; letter-spacing:-0.026em;
  color:var(--ink);
  margin:0 0 18px;
}
.cap-title .it{ color:var(--accent); font-weight:550; font-style:normal; }
.cap-title .dim{ color:var(--ink-faint); font-weight:380; }
.cap-body{
  font-size:14px; line-height:1.6; color:var(--ink-dim);
  letter-spacing:-0.005em;
  max-width:52ch;
}
.cap-body strong{ color:var(--ink); font-weight:500; }

.cap-visual{
  position:relative;
  aspect-ratio: 4 / 3;
  background:var(--paper-2);
  border:1px solid var(--paper-edge);
  border-radius:14px;
  overflow:hidden;
}
.cap-visual .visual-label{
  position:absolute; top:18px; left:20px;
  font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint);
}
.cap-visual.dark{
  background:#0A0A0B;
  border-color:#1A1A1C;
}
.cap-visual.dark .visual-label{ color:var(--on-teal-dim); }
.cap-visual.dark::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(80% 60% at 80% 20%, rgba(31,61,255,0.18), transparent 60%);
  pointer-events:none;
}

/* ────────────────────────────────────────────────────────────
   Mock UI primitives (used inside cap-visual)
   ──────────────────────────────────────────────────────────── */
.mock{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:14px;
  display:flex; flex-direction:column; gap:8px;
  font-family:var(--sans);
  font-size:12px;
  overflow:hidden;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
}
.mock-row{
  display:flex; align-items:center; gap:10px;
  padding:8px 10px;
  border-radius:6px;
  background:var(--paper-2);
  font-size:11.5px;
  line-height:1.35;
}
.mock-row .dot{
  width:6px; height:6px; border-radius:50%; flex-shrink:0;
  background:var(--accent);
}
.mock-row .dot.warn{ background:var(--amber-2); }
.mock-row .dot.muted{ background:var(--ink-ghost); }
.mock-row .label{ color:var(--ink); font-weight:500; }
.mock-row .meta{
  margin-left:auto; font-family:var(--mono); font-size:10px;
  color:var(--ink-faint); letter-spacing:.06em;
}
.mock-row .src{
  font-family:var(--mono); font-size:10px;
  color:var(--ink-faint); letter-spacing:.04em;
}

/* Devplan home mockup — sits inside the homepage hero visual frame.
   Static HTML mirroring the prototype Home view. */
.dp-mock{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%, -50%);
  width:min(720px, 90%);
  background:#fff;
  border:1px solid var(--paper-edge);
  border-radius:12px;
  box-shadow:0 32px 80px -28px rgba(10,10,11,.22), 0 8px 24px -8px rgba(10,10,11,.08);
  font-family:var(--sans);
  overflow:hidden;
}
.dp-mock-bar{
  display:flex; align-items:center; gap:10px;
  padding:10px 16px;
  border-bottom:1px solid var(--paper-edge);
  background:var(--paper-3);
}
.dp-mock-bar-eyebrow{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint);
}
.dp-mock-bar-ic{
  display:inline-flex; align-items:center; justify-content:center;
  width:14px; height:14px;
  color:var(--accent);
  font-size:12px; line-height:1;
}
.dp-mock-bar-spacer{ flex:1; }
.dp-mock-bar-meta{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-faint);
}
.dp-mock-body{ padding:20px 22px 22px; }
.dp-mock-h1{
  font-family:var(--sans);
  font-weight:600;
  font-size:22px; letter-spacing:-0.022em;
  color:var(--ink);
  line-height:1.15;
  margin:0 0 6px;
}
.dp-mock-sub{
  font-size:13px; line-height:1.55;
  color:var(--ink-dim);
  margin:0 0 18px;
  max-width:52ch;
}
.dp-mock-card{
  border:1px solid var(--paper-edge);
  border-radius:10px;
  padding:14px;
  background:var(--paper);
  box-shadow:0 2px 6px -3px rgba(10,10,11,.06);
}
.dp-mock-card-head{
  display:flex; align-items:center; gap:10px;
  margin-bottom:10px;
}
.dp-mock-card-ic{
  width:22px; height:22px;
  border-radius:6px;
  background:var(--accent-soft);
  color:var(--accent);
  display:inline-flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:600;
  flex-shrink:0;
}
.dp-mock-card-title{
  font-size:13.5px; font-weight:600;
  color:var(--ink);
  letter-spacing:-0.01em;
}
.dp-mock-card-eyebrow{
  margin-left:auto;
  font-family:var(--mono); font-size:9.5px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint);
}
.dp-mock-textarea{
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:10px 12px;
  font-size:12px; line-height:1.5;
  color:var(--ink-faint);
  background:var(--paper-3);
  min-height:72px;
}
.dp-mock-actions{
  display:flex; align-items:center; gap:6px;
  margin-top:10px;
  flex-wrap:wrap;
}
.dp-mock-mini{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--sans); font-size:11.5px; font-weight:500;
  color:var(--ink-dim);
  background:transparent;
  border:1px solid var(--paper-edge);
  padding:5px 10px;
  border-radius:6px;
}
.dp-mock-mini-ic{
  font-family:var(--mono); font-size:11px;
  color:var(--ink-faint);
}
.dp-mock-hint{
  font-size:11px; color:var(--ink-faint);
  margin-left:4px;
}
.dp-mock-spacer{ flex:1; }
.dp-mock-cta{
  display:inline-flex; align-items:center; gap:6px;
  font-family:var(--sans); font-size:12px; font-weight:500;
  color:#fff; background:var(--ink);
  padding:6px 12px; border-radius:6px;
}
.dp-mock-cta .arrow{ font-family:var(--mono); }
.dp-mock-brief{
  margin-top:18px;
  padding-top:14px;
  border-top:1px solid var(--paper-edge);
}
.dp-mock-brief-eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint);
  margin-bottom:6px;
}
.dp-mock-live-dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 3px var(--accent-soft);
  animation:dp-mock-pulse 2.6s ease-in-out infinite;
}
@keyframes dp-mock-pulse{
  0%,100%{ opacity:1; }
  50%{ opacity:.5; }
}
.dp-mock-brief-title{
  font-family:var(--sans); font-weight:600;
  font-size:14px; letter-spacing:-0.012em;
  color:var(--ink);
}

/* Slack-style notification (homepage hero visual) */
.slack-notif{
  position:absolute;
  background:#fff;
  border:1px solid var(--paper-edge);
  border-radius:10px;
  box-shadow:0 24px 56px -20px rgba(10,10,11,.22), 0 6px 18px -6px rgba(10,10,11,.08);
  padding:14px 16px 16px;
  width:min(360px, 92%);
  font-family:var(--sans);
}
.slack-notif .sn-head{
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:var(--ink-dim);
  margin-bottom:8px;
}
.slack-notif .sn-avatar{
  width:22px; height:22px; border-radius:5px;
  background:var(--accent); color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--sans); font-size:12px; font-weight:600;
}
.slack-notif .sn-name{ font-weight:600; color:var(--ink); font-size:12.5px; }
.slack-notif .sn-app{
  font-family:var(--mono); font-size:9px;
  letter-spacing:.14em; text-transform:uppercase;
  color:#fff; background:var(--accent);
  padding:2px 5px; border-radius:3px;
}
.slack-notif .sn-time{ margin-left:auto; font-size:11px; color:var(--ink-faint); }
.slack-notif .sn-body{
  font-size:13.5px; line-height:1.5; color:var(--ink);
  letter-spacing:-0.005em;
}
.slack-notif .sn-body strong{ color:var(--ink); font-weight:600; }
.slack-notif .sn-body .ref{ color:var(--accent); font-weight:500; }
.slack-notif .sn-evidence{
  margin-top:10px;
  display:flex; flex-direction:column; gap:5px;
  padding-top:10px; border-top:1px solid var(--paper-edge);
}
.slack-notif .sn-ev-row{
  font-size:11.5px; color:var(--ink-dim);
  display:flex; align-items:center; gap:8px;
}
.slack-notif .sn-ev-row .ic{
  width:14px; height:14px; border-radius:3px;
  background:var(--paper-2);
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--mono); font-size:9px; color:var(--ink-faint);
}

/* ────────────────────────────────────────────────────────────
   Knowledge graph (Weaver hero visual) — pure SVG composition
   ──────────────────────────────────────────────────────────── */
.weaver-graph{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
}
.weaver-graph svg{ width:100%; height:100%; }

/* ────────────────────────────────────────────────────────────
   Insight cards / query tables
   ──────────────────────────────────────────────────────────── */
.insight-card{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:12px;
  padding:22px;
  display:flex; flex-direction:column; gap:14px;
  transition:border-color .25s var(--ease), transform .25s var(--ease);
}
.insight-card:hover{ border-color:var(--rule-2); transform:translateY(-2px); }
.insight-card .ic-head{
  display:flex; align-items:center; justify-content:space-between;
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint);
}
.insight-card .ic-tag{
  background:var(--accent-soft); color:var(--accent);
  padding:3px 8px; border-radius:4px;
  font-weight:500;
}
.insight-card .ic-tag.risk{ background:rgba(230,164,55,.14); color:#A67116; }
.insight-card .ic-tag.opp{ background:var(--accent-soft); color:var(--accent); }
.insight-card .ic-title{
  font-family:var(--sans); font-weight:500;
  font-size:16px; line-height:1.3; letter-spacing:-0.02em;
  color:var(--ink);
}
.insight-card .ic-body{
  font-size:13.5px; color:var(--ink-dim); line-height:1.5;
}
.insight-card .ic-sources{
  display:flex; flex-wrap:wrap; gap:6px;
  margin-top:auto; padding-top:12px;
  border-top:1px solid var(--paper-edge);
}
.insight-card .src-chip{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.06em;
  color:var(--ink-dim);
  background:var(--paper-2);
  padding:3px 7px; border-radius:3px;
}

/* Two-column table — for queries / sub-capabilities */
.dl-table{
  border-top:1px solid var(--rule-2);
}
.dl-row{
  display:grid;
  grid-template-columns:1fr 1.6fr;
  gap:clamp(24px, 4vw, 56px);
  padding:24px 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
}
.dl-row .dl-q{
  font-family:var(--sans); font-weight:500;
  font-size:16px; letter-spacing:-0.02em;
  color:var(--ink);
  line-height:1.35;
}
.dl-row .dl-q .it{ color:var(--accent); font-style:normal; font-weight:500; }
.dl-row .dl-a{
  font-size:14px; line-height:1.55; color:var(--ink-dim);
}
.dl-row .dl-a strong{ color:var(--ink); font-weight:500; }
.dl-row .dl-src{
  display:block;
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--ink-faint); margin-top:8px;
}
@media (max-width:780px){
  .dl-row{ grid-template-columns:1fr; gap:10px; }
}

/* Insight type table */
.itype-table{ border-top:1px solid var(--rule-2); }
.itype-row{
  display:grid;
  grid-template-columns:200px 1fr 200px;
  gap:clamp(20px, 3vw, 48px);
  padding:22px 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
}
.itype-row .it-type{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); font-weight:600;
}
.itype-row .it-ex{
  font-family:var(--sans); font-weight:450;
  font-size:15px; line-height:1.45; letter-spacing:-0.015em;
  color:var(--ink);
}
.itype-row .it-src{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-faint); line-height:1.5;
}
@media (max-width:820px){
  .itype-row{ grid-template-columns:1fr; gap:6px; }
}

/* ────────────────────────────────────────────────────────────
   Pillars (3-up)
   ──────────────────────────────────────────────────────────── */
.pillars{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--rule-2);
}
@media (max-width:960px){ .pillars{ grid-template-columns:1fr; } }
.pillar{
  padding:44px clamp(20px, 2.4vw, 36px) 52px;
  border-left:1px solid var(--rule);
  display:flex; flex-direction:column; gap:14px;
}
.pillar:first-child{ border-left:0; }
@media (max-width:960px){
  .pillar{ border-left:0; border-top:1px solid var(--rule); }
  .pillar:first-child{ border-top:0; }
}
.pillar-num{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; color:var(--ink-faint);
}
.pillar-title{
  font-family:var(--sans);
  font-weight:500;
  font-size:clamp(21px, 1.75vw, 25px);
  line-height:1.2; letter-spacing:-0.022em;
  color:var(--ink);
  margin:6px 0 10px;
}
.pillar-title .it{ color:var(--accent); font-style:normal; font-weight:600; }
.pillar-body{
  font-size:14.5px; line-height:1.55; color:var(--ink-dim);
}

/* ────────────────────────────────────────────────────────────
   Three-pillars on dark (Weaver moat)
   ──────────────────────────────────────────────────────────── */
.moat-pillars{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:1px solid var(--on-teal-rule);
  border-bottom:1px solid var(--on-teal-rule);
}
@media (max-width:960px){ .moat-pillars{ grid-template-columns:1fr; } }
.moat-pillar{
  padding:36px clamp(20px, 2vw, 32px) 40px;
  border-left:1px solid var(--on-teal-rule);
}
.moat-pillar:first-child{ border-left:0; }
@media (max-width:960px){
  .moat-pillar{ border-left:0; border-top:1px solid var(--on-teal-rule); }
  .moat-pillar:first-child{ border-top:0; }
}
.moat-pillar h4{
  font-family:var(--sans);
  font-weight:450;
  font-size:21px; line-height:1.25; letter-spacing:-0.022em;
  color:#fff; margin:0 0 10px;
}
.moat-pillar h4 .it{ color:#fff; font-style:normal; font-weight:650; }
.moat-pillar p{
  font-size:13px; line-height:1.55;
  color:var(--on-teal-dim); margin:0;
}

/* ────────────────────────────────────────────────────────────
   Process / step flow
   ──────────────────────────────────────────────────────────── */
.flow{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:0;
  border-top:1px solid var(--on-teal-rule);
}
@media (max-width:960px){ .flow{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .flow{ grid-template-columns:1fr; } }
.flow-step{
  padding:36px clamp(20px, 2vw, 32px) 44px;
  border-left:1px solid var(--on-teal-rule);
  display:flex; flex-direction:column; gap:12px;
  position:relative;
}
.flow-step:first-child{ border-left:0; }
.flow-step.is-highlight{
  background:rgba(31,61,255,0.08);
}
@media (max-width:960px){
  .flow-step{ border-left:0; border-top:1px solid var(--on-teal-rule); }
  .flow-step:first-child, .flow-step:nth-child(2){ border-top:0; }
}
@media (max-width:560px){
  .flow-step:nth-child(2){ border-top:1px solid var(--on-teal-rule); }
}
.flow-num{
  font-family:var(--sans);
  font-weight:320;
  font-size:32px; line-height:.95; letter-spacing:-0.04em;
  color:rgba(255,255,255,0.55);
}
.flow-num .it{ font-style:normal; }
.flow-title{
  font-family:var(--sans); font-weight:550;
  font-size:15px; line-height:1.25; letter-spacing:-0.018em;
  color:#fff;
}
.flow-body{
  font-size:12.5px; line-height:1.55; color:var(--on-teal-dim);
}

/* ────────────────────────────────────────────────────────────
   Role table
   ──────────────────────────────────────────────────────────── */
.role-table{
  border-top:1px solid var(--on-teal-rule);
}
.role-row{
  display:grid;
  grid-template-columns:280px 1fr;
  gap:clamp(20px, 4vw, 56px);
  padding:22px 0;
  border-bottom:1px solid var(--on-teal-rule);
  align-items:start;
}
.role-row .role-name{
  font-family:var(--sans); font-weight:500;
  font-size:17px; letter-spacing:-0.02em;
  color:#fff;
}
.role-row .role-feed{
  font-size:14px; line-height:1.55; color:var(--on-teal-dim);
}
.role-row .role-feed .dot{
  display:inline-block; width:3px; height:3px; border-radius:50%;
  background:var(--on-teal-dim);
  margin:0 12px; vertical-align:middle;
}
@media (max-width:780px){
  .role-row{ grid-template-columns:1fr; gap:8px; }
}

/* ────────────────────────────────────────────────────────────
   Integration filter rail + card grid
   ──────────────────────────────────────────────────────────── */
.filter-rail{
  display:flex; flex-wrap:wrap; gap:6px;
  margin-bottom:clamp(20px, 2vw, 28px);
}
.filter-chip{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sans); font-size:13px; font-weight:500;
  color:var(--ink-dim);
  background:transparent;
  border:1px solid var(--rule-2);
  padding:7px 14px;
  border-radius:999px;
  cursor:pointer;
  transition:background .2s var(--ease), color .2s var(--ease), border-color .2s var(--ease);
  letter-spacing:-0.005em;
  font-feature-settings:"ss01","ss03","cv11";
}
.filter-chip:hover{
  color:var(--ink);
  background:var(--paper-2);
  border-color:var(--rule-strong);
}
.filter-chip.is-active{
  background:var(--ink);
  color:#fff;
  border-color:var(--ink);
}
.filter-chip.is-active:hover{
  background:var(--accent);
  border-color:var(--accent);
}
.filter-chip .count{
  font-family:var(--mono); font-size:10.5px; font-weight:400;
  color:var(--ink-faint);
  letter-spacing:.04em;
}
.filter-chip.is-active .count{ color:rgba(255,255,255,0.66); }

.int-cards{
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px, 1fr));
  gap:10px;
}
.int-card{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:12px;
  padding:18px 18px 20px;
  display:flex; flex-direction:column; gap:12px;
  min-height:140px;
  transition:border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease);
}
.int-card:hover{
  border-color:var(--rule-strong);
  transform:translateY(-1px);
  box-shadow:0 8px 24px -16px rgba(10,10,11,.18);
}
.int-card[hidden]{ display:none; }
.int-card-head{
  display:flex; align-items:center; gap:12px;
}
.int-card-mark{
  width:36px; height:36px;
  border-radius:8px;
  background:var(--paper-2);
  display:inline-flex; align-items:center; justify-content:center;
  flex-shrink:0;
  font-family:var(--sans); font-weight:600; font-size:14px;
  color:var(--ink);
  letter-spacing:-0.01em;
  overflow:hidden;
}
.int-card-mark svg,
.int-card-mark img{ width:22px; height:22px; display:block; }
.int-card-text{ flex:1; min-width:0; }
.int-card-name{
  font-family:var(--sans); font-weight:600; font-size:14.5px;
  color:var(--ink); letter-spacing:-0.012em;
  line-height:1.2;
}
.int-card-cat{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink-faint);
  margin-top:3px;
}
.int-card-desc{
  font-size:13px; line-height:1.5;
  color:var(--ink-dim);
  margin:0;
}
.int-card.is-soon{
  background:var(--paper-2);
  border-style:dashed;
}
.int-card.is-soon .int-card-name{ color:var(--ink-dim); }

/* ────────────────────────────────────────────────────────────
   CTA block
   ──────────────────────────────────────────────────────────── */
.cta-block{
  background:#0A0A0B;
  color:var(--on-teal);
  padding:clamp(64px, 9vw, 144px) 0 clamp(64px, 9vw, 128px);
  position:relative; overflow:hidden;
}
.cta-block::before{
  content:""; position:absolute;
  inset:0;
  background:
    radial-gradient(46% 70% at 0% 100%, rgba(31,61,255,0.20), transparent 65%),
    radial-gradient(40% 60% at 100% 0%, rgba(31,61,255,0.10), transparent 65%);
  pointer-events:none;
}
.cta-inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:48px;
  align-items:end;
  position:relative; z-index:1;
}
@media (max-width:820px){
  .cta-inner{ grid-template-columns:1fr; gap:24px; align-items:start; }
}
.cta-block .h2{
  color:#fff; max-width:22ch;
  font-size:clamp(31px, 3.75vw, 50px);    /* +25% over the default .h2 scale */
  line-height:1.06;
}
.cta-block .h2 .it{ color:#fff; font-weight:650; }
.cta-block .lede{ color:var(--on-teal-dim); margin-top:14px; }

/* ───── Dark-surface emphasis: never use blue text on black.
   Differentiate via weight + white. ───── */
.surface-teal .h2 .it,
.surface-teal .display .it,
.surface-teal .hero-title .it,
.surface-teal .cap-title .it,
.surface-teal .pillar-title .it{
  color:#fff;
  font-weight:650;
}
.surface-teal .h2 .dim,
.surface-teal .display .dim,
.surface-teal .hero-title .dim{
  color:rgba(255,255,255,0.45);
  font-weight:280;
}
.surface-teal .locked-line{
  color:#fff;
  font-weight:650;
}
.surface-teal .section-num .n{
  color:#fff;
  font-weight:500;
}
.surface-teal .compare-cell.pos strong{
  color:#fff;
  font-weight:650;
}
/* Nav-dropdown dark overview card — drop blue eyebrow */
.nav-dd-item.dd-overview .dd-eyebrow{
  color:rgba(255,255,255,0.55);
}

/* ────────────────────────────────────────────────────────────
   Footer
   ──────────────────────────────────────────────────────────── */
.site-footer{
  background:#0A0A0B;
  color:var(--on-teal-dim);
  padding-top:clamp(72px, 8vw, 120px);
  padding-bottom:32px;
  position:relative;
  z-index:2;
  border-top:1px solid #0A0A0B;
}
.foot-top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(28px, 4vw, 64px);
  padding-bottom:clamp(48px, 5vw, 72px);
  border-bottom:1px solid var(--on-teal-rule);
}
@media (max-width:880px){
  .foot-top{ grid-template-columns:1fr 1fr; gap:48px 36px; }
}
@media (max-width:540px){
  .foot-top{ grid-template-columns:1fr; }
}
.foot-brand{ display:flex; flex-direction:column; gap:0; }
.foot-brand-row{
  display:inline-flex; align-items:center; gap:10px; margin:0 0 18px;
}
.foot-brand-mark{
  width:22px; height:22px; flex-shrink:0;
  color:var(--accent);
}
.foot-brand .foot-mark{
  font-family:var(--sans);
  font-weight:600;
  font-size:17px;
  line-height:1; letter-spacing:-0.018em;
  color:#fff; margin:0;
}
.foot-brand .foot-tag{
  font-family:var(--sans);
  font-weight:400;
  font-size:14px; line-height:1.55;
  color:var(--on-teal-dim);
  margin:0 0 24px;
  max-width:32ch;
  letter-spacing:-0.005em;
}

/* Footer newsletter signup */
.foot-newsletter{
  display:flex; flex-direction:column;
  gap:10px;
  max-width:340px;
}
.foot-newsletter-label{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.18em; text-transform:uppercase;
  color:rgba(255,255,255,0.55);
}
.foot-newsletter-row{
  display:flex; align-items:stretch;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--on-teal-rule);
  border-radius:8px;
  overflow:hidden;
  transition:border-color .2s var(--ease), background .2s var(--ease);
}
.foot-newsletter-row:focus-within{
  border-color:rgba(255,255,255,0.32);
  background:rgba(255,255,255,0.06);
}
.foot-newsletter input{
  flex:1; min-width:0;
  background:transparent;
  border:0; outline:none;
  color:#fff;
  font-family:var(--sans);
  font-size:14px;
  letter-spacing:-0.005em;
  padding:10px 12px;
}
.foot-newsletter input::placeholder{
  color:rgba(255,255,255,0.36);
}
.foot-newsletter button{
  background:rgba(255,255,255,0.06);
  color:rgba(255,255,255,0.55);
  border:0; border-left:1px solid var(--on-teal-rule);
  padding:0 16px;
  font-family:var(--sans); font-size:14px; font-weight:500;
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  transition:background .2s var(--ease), color .2s var(--ease);
  letter-spacing:-0.005em;
}
.foot-newsletter button .arrow{
  transition:transform .25s var(--ease);
}
.foot-newsletter button:hover{
  background:rgba(255,255,255,0.12);
  color:#fff;
}
.foot-newsletter button:hover .arrow{ transform:translateX(3px); }
.foot-col h5{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:#fff; font-weight:500;
  margin:0 0 18px;
}
.foot-col ul{ list-style:none; padding:0; margin:0; }
.foot-col li{ margin:0 0 10px; }
.foot-col a{
  font-size:14px; color:var(--on-teal-dim);
  letter-spacing:-0.005em;
  transition:color .2s var(--ease);
}
.foot-col a:hover{ color:#fff; }
.foot-bottom{
  padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  gap:16px; flex-wrap:wrap;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.14em; text-transform:uppercase;
  color:var(--on-teal-dim);
}
.foot-bottom a{
  color:var(--on-teal-dim);
  transition:color .2s var(--ease);
}
.foot-bottom a:hover{ color:#fff; }
.foot-bottom .links{ display:flex; gap:24px; flex-wrap:wrap; }

/* ────────────────────────────────────────────────────────────
   Misc utilities
   ──────────────────────────────────────────────────────────── */
.gap-xs{ height:14px; }
.gap-sm{ height:24px; }
.gap-md{ height:48px; }
.gap-lg{ height:80px; }

.center-text{ text-align:center; }
.muted{ color:var(--ink-dim); }
.dim{ color:var(--ink-faint); }
.teal{ color:var(--accent); }

/* Locked-line — the verbatim spec copy. No italics; cobalt accent. */
.locked-line{
  font-family:var(--sans);
  font-weight:500;
  color:var(--accent);
  font-style:normal;
  letter-spacing:-0.01em;
}

/* Anti-DIY surface */
.antidiy-head{
  display:grid; grid-template-columns:1fr 1fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:end;
  margin-bottom:clamp(48px, 6vw, 80px);
}
@media (max-width:860px){ .antidiy-head{ grid-template-columns:1fr; gap:24px; } }

/* MCP/agent surface pills */
.agent-surfaces{
  display:flex; flex-wrap:wrap; gap:10px;
  margin-top:32px;
}
.agent-surfaces .pill{
  font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase;
  color:#fff;
  border:1px solid var(--on-teal-rule);
  padding:8px 14px; border-radius:999px;
  transition:background .2s var(--ease), border-color .2s var(--ease);
}
.agent-surfaces .pill:hover{ background:rgba(255,255,255,.06); border-color:var(--accent-on-dark); }

/* Suggested-projects accent card */
.sugg-card{
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:14px;
  padding:32px;
  display:flex; flex-direction:column; gap:18px;
}
.sugg-card .sc-tag{
  font-family:var(--mono); font-size:10.5px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
}
.sugg-card .sc-title{
  font-family:var(--sans); font-weight:500;
  font-size:18px; letter-spacing:-0.022em;
  color:var(--ink); line-height:1.3;
}
.sugg-card .sc-evidence{
  font-size:13.5px; color:var(--ink-dim); line-height:1.55;
}
.sugg-card .sc-cta{
  align-self:flex-start;
  font-family:var(--mono); font-size:11px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 14px;
  border:1px solid var(--accent-soft-2);
  border-radius:999px;
  transition:background .2s var(--ease);
}
.sugg-card .sc-cta:hover{ background:var(--accent-soft); }

/* Spec mock */
.mock-spec{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:18px;
  display:flex; flex-direction:column; gap:10px;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
  overflow:hidden;
}
.mock-spec h6{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint); margin:0 0 4px; font-weight:500;
}
.mock-spec .spec-title{
  font-family:var(--sans); font-weight:500; font-size:14px;
  color:var(--ink); letter-spacing:-0.015em; line-height:1.3;
}
.mock-spec .ac-list{
  display:flex; flex-direction:column; gap:6px;
  margin-top:4px;
}
.mock-spec .ac-row{
  display:flex; align-items:center; gap:8px;
  font-size:11px; color:var(--ink-dim);
  padding:6px 8px; border-radius:5px;
  background:var(--paper-2);
}
.mock-spec .ac-row .chk{
  width:12px; height:12px; border-radius:3px;
  background:var(--accent); color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:8px; flex-shrink:0;
}
.mock-spec .ac-row.todo .chk{ background:transparent; border:1px solid var(--ink-ghost); }
.mock-spec .ac-row.warn .chk{ background:var(--amber-2); }
.mock-spec .ac-row .meta{
  margin-left:auto; font-family:var(--mono); font-size:9.5px;
  color:var(--ink-faint); letter-spacing:.04em;
}

/* Estimate mock */
.mock-est{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:18px;
  display:flex; flex-direction:column; gap:14px;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
}
.mock-est .est-head{
  display:flex; justify-content:space-between; align-items:baseline;
}
.mock-est .est-num{
  font-family:var(--sans); font-weight:320;
  font-size:34px; letter-spacing:-0.04em;
  color:var(--ink);
}
.mock-est .est-num .unit{ font-size:14px; color:var(--ink-faint); margin-left:4px; font-weight:400; }
.mock-est .est-conf{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--accent); font-weight:500;
  background:var(--accent-soft);
  padding:3px 8px; border-radius:4px;
}
.mock-est .est-track{
  height:24px; border-radius:4px;
  background:linear-gradient(90deg,
    var(--paper-2) 0%, var(--paper-2) 22%,
    var(--accent-soft) 22%, var(--accent-soft) 72%,
    var(--paper-2) 72%);
  position:relative;
  overflow:hidden;
}
.mock-est .est-track::before{
  content:""; position:absolute;
  top:0; bottom:0; left:38%;
  width:2px; background:var(--accent);
}
.mock-est .est-labels{
  display:flex; justify-content:space-between;
  font-family:var(--mono); font-size:9.5px;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-faint);
}
.mock-est .est-foot{
  margin-top:auto;
  font-size:11px; color:var(--ink-dim);
  line-height:1.5;
  padding-top:8px; border-top:1px dashed var(--paper-edge);
}

/* Pulse mock */
.mock-pulse{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:14px;
  display:flex; flex-direction:column; gap:6px;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
  overflow:hidden;
}
.mock-pulse .pulse-tabs{
  display:flex; gap:0;
  border-bottom:1px solid var(--paper-edge);
  margin-bottom:8px;
}
.mock-pulse .pulse-tab{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.16em; text-transform:uppercase;
  color:var(--ink-faint);
  padding:6px 12px 8px;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
}
.mock-pulse .pulse-tab.active{ color:var(--ink); border-bottom-color:var(--accent); }
.mock-pulse .pulse-row{
  display:grid; grid-template-columns:auto 1fr auto;
  gap:10px; align-items:center;
  padding:7px 8px; border-radius:5px;
  font-size:11.5px;
}
.mock-pulse .pulse-row:hover{ background:var(--paper-2); }
.mock-pulse .pulse-row .time{
  font-family:var(--mono); font-size:9.5px;
  color:var(--ink-faint); letter-spacing:.04em;
}
.mock-pulse .pulse-row .what{ color:var(--ink); }
.mock-pulse .pulse-row .what strong{ color:var(--accent); font-weight:500; }
.mock-pulse .pulse-row .src{
  font-family:var(--mono); font-size:9px;
  color:var(--ink-faint); letter-spacing:.06em;
  background:var(--paper-2); padding:2px 5px; border-radius:3px;
}

/* Market-intel mock */
.mock-market{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:18px;
  display:flex; flex-direction:column; gap:10px;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
}
.mock-market .mm-head{
  font-family:var(--mono); font-size:10px;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--ink-faint);
}
.mock-market .mm-card{
  display:grid; grid-template-columns:auto 1fr;
  gap:10px; align-items:start;
  padding:10px; border-radius:6px;
  background:var(--paper-2);
}
.mock-market .mm-card .icon{
  width:24px; height:24px; border-radius:5px;
  background:var(--accent); color:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  font-family:var(--sans); font-size:11px; font-weight:600;
  flex-shrink:0;
}
.mock-market .mm-card h6{
  font-family:var(--sans); font-weight:500; font-size:13px;
  color:var(--ink); margin:0 0 2px; letter-spacing:-0.015em;
}
.mock-market .mm-card p{
  font-size:11px; color:var(--ink-dim); margin:0; line-height:1.45;
}

/* Feature catalog mock */
.mock-catalog{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:14px;
  display:grid; grid-template-columns:120px 1fr;
  gap:10px;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
  overflow:hidden;
}
.mock-catalog .cat-tree{
  display:flex; flex-direction:column; gap:2px;
  border-right:1px solid var(--paper-edge);
  padding-right:8px;
}
.mock-catalog .cat-item{
  font-size:11.5px; padding:5px 8px; border-radius:4px;
  color:var(--ink-dim); display:flex; align-items:center; gap:6px;
}
.mock-catalog .cat-item.active{ background:var(--accent-soft); color:var(--accent); font-weight:500; }
.mock-catalog .cat-item .ic{
  width:10px; height:10px; border-radius:2px;
  background:currentColor; opacity:.5;
}
.mock-catalog .cat-detail{
  display:flex; flex-direction:column; gap:8px;
}
.mock-catalog .cat-detail h6{
  font-family:var(--sans); font-weight:500; font-size:14px;
  color:var(--ink); margin:0; letter-spacing:-0.015em;
}
.mock-catalog .cat-detail .meta{
  display:grid; grid-template-columns:1fr 1fr; gap:6px;
}
.mock-catalog .cat-detail .meta div{
  font-size:10.5px; color:var(--ink-dim);
  padding:5px 7px; background:var(--paper-2); border-radius:4px;
}
.mock-catalog .cat-detail .meta strong{
  font-family:var(--mono); font-size:9.5px;
  letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink-faint); font-weight:500; display:block; margin-bottom:1px;
}

/* Ask-Weaver chat mock */
.mock-ask{
  position:absolute; inset:48px 24px 24px 24px;
  background:var(--paper);
  border:1px solid var(--paper-edge);
  border-radius:8px;
  padding:14px;
  display:flex; flex-direction:column; gap:8px;
  box-shadow:0 18px 36px -16px rgba(10,10,11,.18);
}
.mock-ask .ask-q{
  align-self:flex-end;
  font-family:var(--sans); font-style:normal;
  font-weight:450;
  font-size:13px; line-height:1.35;
  color:var(--ink);
  background:var(--paper-2);
  padding:8px 12px; border-radius:10px 10px 2px 10px;
  max-width:80%;
  letter-spacing:-0.012em;
}
.mock-ask .ask-a{
  background:var(--accent); color:#fff;
  padding:10px 12px; border-radius:10px 10px 10px 2px;
  font-size:12px; line-height:1.5;
  max-width:90%;
}
.mock-ask .ask-a .src{
  display:flex; gap:5px; margin-top:6px; flex-wrap:wrap;
}
.mock-ask .ask-a .src span{
  font-family:var(--mono); font-size:9px;
  letter-spacing:.06em;
  background:rgba(255,255,255,.18);
  padding:2px 5px; border-radius:3px;
}
.mock-ask .ask-input{
  margin-top:auto; padding:8px 10px;
  border:1px solid var(--paper-edge); border-radius:6px;
  font-family:var(--mono); font-size:10px;
  letter-spacing:.06em; color:var(--ink-faint);
  display:flex; align-items:center; gap:6px;
}
.mock-ask .ask-input::before{
  content:""; width:6px; height:6px; border-radius:50%;
  background:var(--accent); flex-shrink:0;
}

/* Anchor offset for sticky nav */
[id]{ scroll-margin-top:80px; }

@media (prefers-reduced-motion: no-preference){
  .reveal{
    opacity:0; transform:translateY(12px);
    animation:reveal .9s var(--ease-out) forwards;
  }
  .reveal.d-1{ animation-delay:.08s; }
  .reveal.d-2{ animation-delay:.16s; }
  .reveal.d-3{ animation-delay:.24s; }
  .reveal.d-4{ animation-delay:.32s; }
}
@keyframes reveal{
  to{ opacity:1; transform:translateY(0); }
}

/* Footer needs its own stacking context so its background doesn't peek through
   any overlapping cards. The nav and main keep their original stacking. */
.site-footer{ position:relative; z-index:1; }

.bleed{ width:100vw; margin-inline:calc(50% - 50vw); }

.cap-list{ display:flex; flex-direction:column; }
