/* ============================================================
   Droplet website — Approachable Light mode
   Layered AFTER styles.css. Softens the indigo intensity,
   warms the section palette, converts the brain stage's dark
   surfaces into friendly white tiles. Goal: small-business
   shopper should feel welcomed, not interrogated by enterprise
   chrome.
   ============================================================ */

:root {
  /* Softer aurora — peach, sky, soft lavender. Less neon. */
  --aurora-1: #ffd9c2;   /* warm peach */
  --aurora-2: #cfe0ff;   /* clean sky */
  --aurora-3: #e6dcff;   /* soft lavender */

  /* Friendlier emphasis color — denim, not electric */
  --accent-soft: #7c83f5;
  --accent-warm: #4f55c4;

  /* Warm cream surface for alternating sections */
  --surface-cream: #fbf9f4;
  --surface-sky:   #f4f7fc;
}

/* ── Base copy: a touch warmer & easier on the eyes ── */
body {
  --text-body: #3f404a;
  --text-body-soft: #5a5c66;
  --text-meta: #76798280;
  color: #1d1d1f;
}

/* ── Aurora dialed back across the page ── */
.aurora { opacity: 0.42; filter: blur(56px); }
.aurora-hero {
  background:
    radial-gradient(46% 60% at 16% 16%, var(--aurora-1) 0%, transparent 64%),
    radial-gradient(52% 70% at 88% 8%,  var(--aurora-3) 0%, transparent 64%),
    radial-gradient(60% 90% at 60% 110%, var(--aurora-2) 0%, transparent 62%);
}
.aurora-sov   { opacity: 0.30; }
.aurora-what  { opacity: 0.30; }
.aurora-cta   { opacity: 0.52; }
.aurora-track { opacity: 0.30; }

/* ── Section background rhythm: white / cream / sky ──
   Replaces the cold #f2f2f7 alternation. Same surface
   primary, but breathing gets warmer.                 */
.how       { background: var(--surface-cream); }
.tools     { background: var(--surface-cream); }
.replaces  { background: var(--surface-sky); }
.sov       { background: linear-gradient(180deg, var(--surface-sky) 0%, #ffffff 100%); }
.what-is   { background: linear-gradient(180deg, #ffffff 0%, var(--surface-cream) 100%); }
.demo      { background: #ffffff; }
.surfaces  { background: #ffffff; }
.pricing   { background: var(--surface-cream); }
.cta       { background: linear-gradient(180deg, var(--surface-cream) 0%, #ffffff 70%); }
.cases     { background: #ffffff; }
.comp      { background: #ffffff; }
.specs     { background: var(--surface-sky); }

/* Hero: warm cream → white wash */
.hero {
  background: linear-gradient(180deg, #fff7ef 0%, #ffffff 70%);
}

/* ── Nav: cleaner, less brittle ── */
.nav {
  background: rgba(255, 255, 255, 0.85);
  border-bottom-color: rgba(0, 0, 0, 0.06);
}
.brand-svg {
  /* Drop the bright indigo halo; let the mark sit naturally on cream */
  filter: drop-shadow(0 2px 8px rgba(99, 102, 241, 0.12));
}

/* ── Pill / status nuance ── */
.hero-pill {
  background: #ffffff;
  border-color: rgba(0, 0, 0, 0.08);
  color: #4a4c55;
  box-shadow: 0 2px 8px -4px rgba(99, 102, 241, 0.18);
}

/* ── Type emphasis softened ── */
.hero-h em,
.section-h em,
.what-h em,
.cta-h em,
.comp-h em {
  color: var(--accent-warm);
}
.eyebrow,
.loop-num,
.wp-num,
.tmpl-cat,
.ra-label,
.pc-from,
.pn-l,
.sf-label,
.specs-cta,
.comp-link,
.sf-link {
  color: var(--accent-warm);
}

/* ── Buttons: keep the brand action, soften the halo ── */
.btn-accent {
  background: #5b62e0;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.22) inset,
    0 6px 16px -10px rgba(91, 98, 224, 0.55);
}
.btn-accent:hover {
  background: #4f55c4;
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.22) inset,
    0 10px 22px -10px rgba(91, 98, 224, 0.65);
}

/* ── Cards: pull back the dramatic tile shadow ── */
.loop-step,
.wp,
.surf,
.tmpl,
.case-card,
.price-card,
.lan-card,
.demo-window {
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 8px 24px -16px rgba(17, 24, 39, 0.10);
  border-color: rgba(0, 0, 0, 0.07);
}

/* ============================================================
   HERO — convert the dark glassy "brain stage" into
   friendly white tiles. This is the biggest legibility win.
   ============================================================ */

/* Orbital nodes: light card style */
.bs-node {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  color: #1d1d1f;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.05),
    0 8px 20px -12px rgba(17, 24, 39, 0.16);
  backdrop-filter: none;
}
.bs-node .bn-i {
  background: rgba(91, 98, 224, 0.10);
  color: var(--accent-warm);
}
.bs-node:hover {
  background: #ffffff;
  border-color: rgba(91, 98, 224, 0.35);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.05),
    0 14px 28px -14px rgba(91, 98, 224, 0.30);
}
.bs-node.lit {
  background: #ffffff;
  border-color: rgba(91, 98, 224, 0.55);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.05),
    0 18px 36px -14px rgba(91, 98, 224, 0.45),
    0 0 0 4px rgba(91, 98, 224, 0.08);
}
.bs-node.lit .bn-i {
  background: rgba(91, 98, 224, 0.18);
  color: var(--accent-warm);
}

/* The prompt: a friendly cream "you said:" capsule */
.bs-prompt {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 10px 24px -16px rgba(91, 98, 224, 0.22);
  backdrop-filter: none;
}
.bs-prompt-text { color: #1d1d1f; }
.bs-caret { background: var(--accent-warm); }

/* The answer card: white tile with soft tint, dark text */
.bs-answer {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 12px 28px -16px rgba(91, 98, 224, 0.22);
  backdrop-filter: none;
}
.bs-a-icon {
  background: rgba(91, 98, 224, 0.10);
  color: var(--accent-warm);
}
.bs-a-icon-build {
  background: rgba(52, 199, 89, 0.12);
  color: #14894d;
}
.bs-a-title { color: #1d1d1f; }
.bs-a-row { border-top-color: rgba(0, 0, 0, 0.06); }
.bs-a-name { color: #1d1d1f; }
.bs-a-meta { color: #76798e; }
.bs-a-build .bs-a-name { color: #14894d; }
.bs-build-bar { background: rgba(52, 199, 89, 0.12); }
.bs-build-bar i { background: linear-gradient(90deg, #34c759, #7c83f5); }

/* Soften the core droplet halo on light bg */
.bs-core-glow {
  background: radial-gradient(50% 60% at 50% 50%, rgba(91, 98, 224, 0.35) 0%, transparent 70%);
}
.bs-core svg {
  filter: drop-shadow(0 12px 24px rgba(91, 98, 224, 0.35));
}

/* Connection ring strokes a bit darker so they read on white */
.bs-ring-1 { stroke: rgba(91, 98, 224, 0.22) !important; }
.bs-ring-2 { stroke: rgba(91, 98, 224, 0.30) !important; }

/* Aurora "track" mouse-follower: much subtler */
.aurora-track {
  background:
    radial-gradient(36% 48% at var(--mx, 60%) var(--my, 30%), rgba(207, 224, 255, 0.55) 0%, transparent 60%);
}

/* ============================================================
   "How it works" loop: friendlier tiles
   ============================================================ */
.loop-step { background: #ffffff; }
.loop-icon {
  background: rgba(91, 98, 224, 0.10);
  color: var(--accent-warm);
}
.loop-list li::before { color: var(--accent-warm); }

/* ============================================================
   Live demo: lighten the chat window chrome
   ============================================================ */
.ds-btn.active {
  border-color: rgba(91, 98, 224, 0.40);
  background: rgba(91, 98, 224, 0.04);
  box-shadow:
    0 1px 0 rgba(91, 98, 224, 0.05) inset,
    0 8px 22px -14px rgba(91, 98, 224, 0.30);
}
.ds-btn.active .ds-n { background: var(--accent-warm); }
.msg-user .msg-b { background: var(--accent-warm); }
.msg-mark { background: var(--accent-warm); }
.tool-card-proposed {
  background: linear-gradient(180deg, rgba(91, 98, 224, 0.04) 0%, #ffffff 60%);
  border-color: rgba(91, 98, 224, 0.30);
}
.tcp-icon,
.rc-mark,
.tcb-mark,
.mt-i,
.tmpl-empty-mark { color: var(--accent-warm); background: rgba(91, 98, 224, 0.10); }
.tcp-badge {
  background: rgba(91, 98, 224, 0.10); color: var(--accent-warm);
}
.tcp-flow .arr { color: var(--accent-soft); }

/* ============================================================
   Tool templates: airier, less corporate
   ============================================================ */
.tmpl { background: #ffffff; }
.tmpl:hover {
  border-color: rgba(91, 98, 224, 0.30);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 14px 28px -16px rgba(91, 98, 224, 0.22);
}
.tf.active {
  background: #1d1d1f; border-color: #1d1d1f;
}

/* ============================================================
   Product surfaces: soften the feature card tint
   ============================================================ */
.surf-i {
  background: rgba(91, 98, 224, 0.10);
  color: var(--accent-warm);
}
.surf-feature {
  background: linear-gradient(180deg, rgba(91, 98, 224, 0.05) 0%, #ffffff 60%);
  border-color: rgba(91, 98, 224, 0.16);
}
.mini-a {
  background: rgba(91, 98, 224, 0.07);
  border-left-color: var(--accent-warm);
}

/* ============================================================
   Sovereignty + LAN diagram: keep the metaphor, soften the
   "enterprise security console" look
   ============================================================ */
.lan-droplet {
  border-color: rgba(91, 98, 224, 0.50);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.8) inset,
    0 12px 28px -16px rgba(91, 98, 224, 0.40),
    0 0 0 6px rgba(91, 98, 224, 0.06);
}
.sov-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(52, 199, 89, 0.14);
  border: none;
}
.sov-list li::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 11px;
  width: 7px;
  height: 4px;
  border-left: 1.8px solid #14894d;
  border-bottom: 1.8px solid #14894d;
  transform: rotate(-45deg);
  border-radius: 0.5px;
  color: transparent;
}

/* ============================================================
   "What it replaces": keep the comparison punch but soften
   the deep navy to a friendlier indigo
   ============================================================ */
.rep-after {
  background: linear-gradient(180deg, #3c3fae 0%, #2c2f8c 100%);
  border-color: rgba(255, 255, 255, 0.10);
  box-shadow: 0 24px 60px -36px rgba(91, 98, 224, 0.55);
}
.rep-aurora {
  background:
    radial-gradient(40% 60% at 20% 0%, rgba(255, 217, 194, 0.30) 0%, transparent 60%),
    radial-gradient(50% 70% at 90% 100%, rgba(207, 224, 255, 0.28) 0%, transparent 60%);
}

/* ============================================================
   Pricing: warm the featured card slightly
   ============================================================ */
.pc-featured {
  border-color: rgba(91, 98, 224, 0.40);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 16px 36px -18px rgba(91, 98, 224, 0.28);
}

/* ============================================================
   CTA / form
   ============================================================ */
.cta-form {
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 24px 60px -36px rgba(91, 98, 224, 0.32);
}
.cf-in:focus {
  border-color: var(--accent-warm);
  box-shadow: 0 0 0 3px rgba(91, 98, 224, 0.15);
}

/* ============================================================
   Footer brand tint
   ============================================================ */
.ft-brand,
.ft-brand .brand-mark { color: var(--accent-warm); }

/* ============================================================
   NEW · Page-header for sub-pages (Product / Why / Pricing).
   Smaller than hero, sets context.
   ============================================================ */
.page-head {
  position: relative;
  padding: 80px 0 64px;
  background: linear-gradient(180deg, #fff7ef 0%, #ffffff 100%);
  overflow: hidden;
}
.page-head > .wrap { position: relative; z-index: 1; }
.aurora-pagehead {
  position: absolute;
  inset: -20% 0 0 0;
  opacity: 0.40;
  filter: blur(60px);
  background:
    radial-gradient(40% 50% at 18% 30%, var(--aurora-1) 0%, transparent 64%),
    radial-gradient(45% 55% at 85% 30%, var(--aurora-3) 0%, transparent 64%);
}
.page-h {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 56px;
  line-height: 1.08;
  letter-spacing: -0.025em;
  margin: 8px 0 20px;
  color: var(--color-label-primary);
  max-width: 820px;
  text-wrap: pretty;
}
.page-h em { font-style: italic; color: var(--accent-warm); }
.page-lede {
  font-size: 19px;
  line-height: 1.55;
  color: var(--text-body);
  margin: 0;
  max-width: 720px;
}

/* Active nav link */
.nav-links .link.active {
  color: var(--color-label-primary);
  font-weight: 600;
}

/* ============================================================
   NEW · "One chat. Every system." — single chat-window mockup
   replacing the old surfaces tile grid.
   ============================================================ */
.caps2 {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-cream) 65%, #ffffff 100%);
}
.caps2-stage {
  max-width: 720px;
  margin: 48px auto 0;
}
.cw-frame {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 22px;
  overflow: hidden;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 28px 64px -36px rgba(91, 98, 224, 0.30),
    0 16px 36px -20px rgba(17, 24, 39, 0.10);
}
.cw-top {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: var(--surface-cream);
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
}
.cw-tab {
  flex: 1;
  text-align: center;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-body-soft);
}
.cw-body {
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cw-msg {
  display: flex;
  max-width: 100%;
}
.cw-msg-user { justify-content: flex-end; }
.cw-msg-ai { justify-content: flex-start; }
.cw-msg-b {
  max-width: 78%;
  padding: 11px 15px;
  border-radius: 16px;
  font-size: 14.5px;
  line-height: 1.5;
}
.cw-msg-user .cw-msg-b {
  background: var(--accent-warm);
  color: #ffffff;
  border-bottom-right-radius: 5px;
}
.cw-msg-ai .cw-msg-b {
  background: #f5f5f0;
  color: #1d1d1f;
  border-bottom-left-radius: 5px;
}
.cw-msg-ai .cw-msg-b code {
  font-family: var(--font-mono);
  font-size: 12.5px;
  background: rgba(0, 0, 0, 0.06);
  padding: 1px 6px;
  border-radius: 4px;
  color: #1d1d1f;
}
.cw-src {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-right: 8px;
  padding: 3px 9px 3px 7px;
  border-radius: 9999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
  vertical-align: 2px;
}
.cw-src-files  { background: rgba(91, 98, 224, 0.10);  color: var(--accent-warm); }
.cw-src-cams   { background: rgba(255, 149, 0, 0.12);  color: #b86200; }
.cw-src-net    { background: rgba(0, 122, 255, 0.10);  color: #0066d1; }
.cw-src-tools  { background: rgba(52, 199, 89, 0.14);  color: #14894d; }
.cw-input {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 4px 18px 18px;
  padding: 10px 10px 10px 16px;
  background: var(--surface-cream);
  border: 1px solid rgba(0, 0, 0, 0.05);
  border-radius: 9999px;
}
.cw-input-ph {
  flex: 1;
  font-size: 13.5px;
  color: var(--text-meta);
}
.cw-input-send {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--accent-warm);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 700;
}

/* ============================================================
   NEW · "Explore more" link cards on the home page.
   4 cards pointing at sub-pages.
   ============================================================ */
.explore {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-cream) 100%);
  padding: 96px 0;
}
.explore-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 48px;
}
.ex-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 24px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 18px;
  text-decoration: none;
  color: inherit;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 8px 24px -18px rgba(17, 24, 39, 0.10);
  transition: all 200ms var(--ease-smooth);
}
.ex-card:hover {
  transform: translateY(-2px);
  border-color: rgba(91, 98, 224, 0.30);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 16px 32px -16px rgba(91, 98, 224, 0.28);
}
.ex-tag {
  align-self: flex-start;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent-warm);
  font-weight: 600;
}
.ex-card h3 {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 4px 0 0;
  color: #1d1d1f;
}
.ex-card p {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-body);
  margin: 0;
  flex: 1;
}
.ex-go {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--accent-warm);
}
.ex-card:hover .ex-go span { transform: translateX(2px); display: inline-block; transition: transform 200ms var(--ease-smooth); }

/* ============================================================
   NEW · Tool templates compact header
   ============================================================ */
.tmpl-head {
  max-width: 720px;
  margin: 0 auto 32px;
  text-align: center;
}
.tmpl-head .eyebrow { margin-bottom: 8px; }
.tmpl-head-h {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 32px;
  line-height: 1.12;
  letter-spacing: -0.02em;
  margin: 0 0 8px;
  color: #1d1d1f;
}
.tmpl-head-sub {
  font-size: 15px;
  line-height: 1.55;
  color: var(--text-body);
  margin: 0;
}
.tmpl-more {
  max-width: 720px;
  margin: 32px auto 0;
  text-align: center;
  font-size: 14px;
  color: var(--text-body-soft);
  line-height: 1.5;
}

/* ── Responsive for explore cards & page head & chat window ── */
@media (max-width: 1024px) {
  .explore-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 900px) {
  .page-h { font-size: 38px; }
  .cw-msg-b { max-width: 90%; }
  .explore { padding: 64px 0; }
}
@media (max-width: 560px) {
  .explore-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   NEW · Workspace section — text feature list + big dashboard
   mockup side by side. Replaces the abstract pillars.
   ============================================================ */
.ws {
  position: relative;
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-sky) 100%);
  padding: 96px 0;
  overflow: hidden;
}
.ws-in {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 80px;
  align-items: center;
}
.ws-copy { max-width: 460px; }
.ws-copy .section-h { font-size: 44px; margin-bottom: 20px; }
.ws-copy .section-lede { margin-bottom: 36px; }
.ws-feats {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 18px;
  counter-reset: wsf;
}
.ws-feats li {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 14px;
  align-items: flex-start;
}
.wsf-n {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: var(--accent-warm);
  margin-top: 2px;
}
.ws-feats h4 {
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 4px;
  color: #1d1d1f;
}
.ws-feats p {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-body);
  margin: 0;
}
.ws-stage { position: relative; }
.ws-device { max-width: 640px; }
.ws-main {
  padding: 22px 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.ws-tiles {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}
.ws-tile {
  padding: 12px 14px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 12px;
  box-shadow: 0 1px 2px rgba(17, 24, 39, 0.03);
}
.ws-t-l {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-meta);
  font-weight: 600;
  margin-bottom: 4px;
}
.ws-t-v {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 22px;
  line-height: 1;
  letter-spacing: -0.015em;
  color: #1d1d1f;
  margin-bottom: 3px;
}
.ws-t-s {
  font-size: 11px;
  color: var(--text-body-soft);
}

/* ============================================================
   NEW · caps2 side-by-side: text left, chat-window right
   ============================================================ */
.caps2 { padding: 80px 0; }
.caps2-in {
  display: grid;
  grid-template-columns: 1fr 0.78fr;
  gap: 72px;
  align-items: center;
}
.caps2-copy { padding: 0; max-width: 520px; }
.caps2-copy .section-head { margin-bottom: 0; max-width: 100%; }
.caps2-copy .section-h { font-size: 42px; }
.caps2 .caps2-stage { margin: 0; max-width: 380px; justify-self: end; }
.caps2 .cw-frame { border-radius: 16px; }
.caps2 .cw-body { padding: 14px 14px; gap: 8px; }
.caps2 .cw-msg-b {
  font-size: 12.5px;
  padding: 8px 12px;
  border-radius: 12px;
  max-width: 90%;
  line-height: 1.45;
}
.caps2 .cw-msg-user .cw-msg-b { border-bottom-right-radius: 4px; }
.caps2 .cw-msg-ai .cw-msg-b { border-bottom-left-radius: 4px; }
.caps2 .cw-src {
  font-size: 9.5px;
  padding: 2px 6px 2px 5px;
  margin-right: 5px;
}
.caps2 .cw-src svg { width: 9px; height: 9px; }
.caps2 .cw-input { margin: 4px 12px 12px; padding: 7px 7px 7px 12px; }
.caps2 .cw-input-ph { font-size: 11.5px; }
.caps2 .cw-input-send { width: 24px; height: 24px; font-size: 11px; }
.caps2 .cw-top { padding: 9px 12px; }
.caps2 .cw-tab { font-size: 11px; }

.caps2-tags {
  list-style: none;
  padding: 0;
  margin: 28px 0 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.caps2-tags li {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 12px 7px 10px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 9999px;
  font-size: 13px;
  font-weight: 500;
  color: #1d1d1f;
  box-shadow: 0 1px 2px rgba(17, 24, 39, 0.04);
}
.caps2-tags li svg { color: var(--accent-warm); flex-shrink: 0; }
.caps2-cap {
  font-size: 13px;
  font-style: italic;
  color: var(--text-body-soft);
  margin: 0;
}

@media (max-width: 1024px) {
  .ws-in,
  .caps2-in {
    grid-template-columns: 1fr;
    gap: 48px;
  }
  .ws-copy .section-h,
  .caps2-copy .section-h { font-size: 36px; }
  .ws-copy { max-width: none; }
}
.wp { padding-top: 0; }
.wp-illo {
  margin: -8px -10px 14px;
  height: 130px;
  border-radius: 14px;
  background: linear-gradient(180deg, var(--surface-cream) 0%, #ffffff 100%);
  border: 1px solid rgba(0, 0, 0, 0.05);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}
.wp-illo svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* ============================================================
   NEW · Pillar mockups v2 (.wp2 with .wp-screen) — show real
   product UI, not abstract icons.
   ============================================================ */
.what-pillars { gap: 18px; }
.wp2 { padding: 0; background: transparent; border: none; box-shadow: none; }
.wp2 .wp-num { margin: 16px 24px 8px; padding-top: 0; }
.wp2 h3, .wp2 p { padding: 0 24px; }
.wp2 p { padding-bottom: 24px; }
.wp-screen {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 14px 14px 0 0;
  overflow: hidden;
  height: 200px;
  display: flex;
  flex-direction: column;
}
.wp2 {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 18px;
  overflow: hidden;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 8px 24px -16px rgba(17, 24, 39, 0.10);
  transition: all 200ms var(--ease-smooth);
  display: flex;
  flex-direction: column;
}
.wp2:hover {
  transform: translateY(-2px);
  border-color: rgba(91, 98, 224, 0.20);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 14px 30px -16px rgba(91, 98, 224, 0.22);
}
.wp2 .wp-screen {
  border: none;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 18px 18px 0 0;
}
.wp-screen-top {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: var(--surface-cream);
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}
.wp-dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(0, 0, 0, 0.12);
}
.wp-screen-tab {
  margin-left: 8px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  color: var(--text-meta);
  letter-spacing: 0.02em;
}
.wp-screen-body {
  flex: 1;
  padding: 14px 16px;
  background: #ffffff;
  overflow: hidden;
}

/* — Chat preview (pillar 1) — */
.wp-screen-chat {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.wp-msg-u {
  align-self: flex-end;
  background: var(--accent-warm);
  color: #ffffff;
  padding: 6px 12px;
  border-radius: 12px 12px 4px 12px;
  font-size: 12px;
  max-width: 85%;
}
.wp-msg-ai {
  background: #f5f5f0;
  border-radius: 12px 12px 12px 4px;
  padding: 10px 12px;
  font-size: 11.5px;
}
.wp-msg-ai-h {
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 6px;
}
.wp-msg-ai-row {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 8px;
  padding: 4px 0;
  font-size: 11.5px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
}
.wp-msg-ai-row:first-of-type { border-top: none; }
.wp-msg-ai-row svg { color: var(--accent-warm); }
.wp-msg-ai-row .n { color: #1d1d1f; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.wp-msg-ai-row .m {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-meta);
}

/* — Memory / privacy preview (pillar 2) — */
.wp-screen-mem {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.wp-mem-big {
  display: flex;
  align-items: baseline;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 1px dashed rgba(0, 0, 0, 0.08);
}
.wp-mem-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 40px;
  line-height: 1;
  letter-spacing: -0.025em;
  color: #14894d;
}
.wp-mem-sub {
  font-size: 11.5px;
  color: var(--text-body);
}
.wp-mem-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11.5px;
  color: #1d1d1f;
}
.wp-mem-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #34c759;
  box-shadow: 0 0 0 3px rgba(52, 199, 89, 0.15);
  flex-shrink: 0;
}

/* — Greet preview (pillar 3) — */
.wp-screen-greet {
  display: flex;
  flex-direction: column;
  gap: 10px;
  justify-content: space-between;
}
.wp-greet-h {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 17px;
  line-height: 1.18;
  letter-spacing: -0.01em;
  color: #1d1d1f;
}
.wp-greet-h em { font-style: italic; color: var(--accent-warm); }
.wp-greet-sugg {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.wp-greet-sugg span {
  font-size: 10.5px;
  padding: 5px 9px;
  background: var(--surface-cream);
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 9999px;
  color: var(--text-body);
}
.wp-greet-input {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 6px 6px 12px;
  background: var(--surface-cream);
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 9999px;
}
.wp-greet-input .ph { flex: 1; font-size: 11px; color: var(--text-meta); }
.wp-greet-input .send {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--accent-warm); color: #ffffff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
}

/* — Tools shelf preview (pillar 4) — */
.wp-screen-tools {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.wp-tool-row {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  background: var(--surface-cream);
  border-radius: 8px;
  font-size: 11.5px;
}
.wp-tool-mark {
  width: 18px; height: 18px; border-radius: 5px;
  background: rgba(52, 199, 89, 0.14);
  color: #14894d;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
}
.wp-tool-n { flex: 1; color: #1d1d1f; font-weight: 500; }
.wp-tool-m {
  font-family: var(--font-mono);
  font-size: 10px;
  color: var(--text-meta);
}
.wp-tool-add {
  margin-top: 4px;
  padding: 7px 10px;
  border: 1px dashed rgba(91, 98, 224, 0.30);
  border-radius: 8px;
  font-size: 11px;
  color: var(--accent-warm);
  text-align: center;
}

/* ============================================================
   NEW · Use cases 2.0 — 3 visual cards
   ============================================================ */
.cases2 { background: #ffffff; }
.cases2-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  margin-top: 48px;
}
.case2 {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 20px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 12px 28px -18px rgba(17, 24, 39, 0.12);
  transition: all 200ms var(--ease-smooth);
}
.case2:hover {
  transform: translateY(-2px);
  border-color: rgba(91, 98, 224, 0.20);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 16px 36px -16px rgba(91, 98, 224, 0.22);
}
.case2-illo svg {
  display: block;
  width: 100%;
  height: auto;
}
.case2-tag {
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent-warm);
  font-weight: 600;
  padding: 22px 24px 0;
}
.case2 h3 {
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 8px 24px 0;
  color: #1d1d1f;
  line-height: 1.35;
  flex: 1;
}
.case2-stat {
  margin: 18px 24px 22px;
  padding-top: 14px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  font-size: 13px;
  color: var(--text-body-soft);
}
.case2-stat strong { color: #1d1d1f; }
@media (max-width: 1024px) {
  .cases2-grid { grid-template-columns: 1fr; gap: 14px; }
}

/* ============================================================
   NEW · case3 cards with mini-dashboard mockups at top
   ============================================================ */
.cases3 { background: #ffffff; padding: 96px 0; }
.cases3-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 48px;
}
.case3 {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 18px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 12px 28px -18px rgba(17, 24, 39, 0.12);
  transition: all 200ms var(--ease-smooth);
}
.case3:hover {
  transform: translateY(-2px);
  border-color: rgba(91, 98, 224, 0.20);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 16px 36px -16px rgba(91, 98, 224, 0.22);
}
.case3-mock {
  background: #ffffff;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
  height: 220px;
  display: flex;
  flex-direction: column;
}
.case3-mock .wp-screen-top {
  border-radius: 0;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}
.case3-mock-body {
  flex: 1;
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  overflow: hidden;
}
.case3-mock-tools {
  gap: 6px;
}
.case3-mock-mem {
  gap: 10px;
}
.case3-head {
  padding: 22px 24px 0;
}
.case3 h3 {
  font-size: 19px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 4px;
  color: #1d1d1f;
}
.case3-for {
  font-size: 12.5px;
  color: var(--accent-warm);
  font-weight: 500;
  margin: 0;
}
.case3-p {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-body);
  margin: 14px 24px 0;
  flex: 1;
}
.case3-stat {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin: 18px 24px 22px;
  padding-top: 14px;
  border-top: 1px solid rgba(0, 0, 0, 0.06);
  font-size: 13px;
  color: var(--text-body-soft);
}
.case3-stat strong {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--accent-warm);
}
@media (max-width: 1024px) {
  .cases3-grid { grid-template-columns: 1fr; gap: 16px; }
}

/* ============================================================
   NEW · Hardware specs 2.0 — device showcase + cards + tiers
   ============================================================ */
.specs2 {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-sky) 100%);
  padding: 112px 0;
}

.dev-showcase {
  position: relative;
  margin: 48px auto 56px;
  max-width: 920px;
  background: linear-gradient(135deg, #1c1c25 0%, #2a2a3a 100%);
  border-radius: 24px;
  overflow: hidden;
  padding: 32px;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 24px 60px -28px rgba(17, 24, 39, 0.30);
}
.dev-figure {
  margin: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.dev-figure img {
  width: 100%;
  max-width: 720px;
  height: auto;
  display: block;
}
.dev-figure figcaption {
  margin-top: 14px;
  text-align: center;
  color: rgba(255, 255, 255, 0.85);
}
.dev-cap-name {
  display: block;
  font-size: 15px;
  font-weight: 600;
  color: #ffffff;
}
.dev-cap-sub {
  display: block;
  font-size: 12.5px;
  font-family: var(--font-mono);
  color: rgba(255, 255, 255, 0.55);
  margin-top: 4px;
  letter-spacing: 0.02em;
}
.dev-tags { position: absolute; inset: 0; pointer-events: none; }
.dev-tag {
  position: absolute;
  padding: 6px 12px;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 9999px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.85);
  font-weight: 600;
  backdrop-filter: blur(8px);
}
.dev-tag-tl { top: 56px; left: 56px; }
.dev-tag-br { bottom: 84px; right: 56px; }

.specs2-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 48px;
}
.spec2 {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 16px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 8px 22px -16px rgba(17, 24, 39, 0.10);
}
.spec2-i {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(91, 98, 224, 0.10);
  color: var(--accent-warm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 18px;
}
.spec2 h4 {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 8px;
  color: #1d1d1f;
}
.spec2 p {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-body);
  margin: 0;
}

.sizes-row {
  display: grid;
  grid-template-columns: 220px 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 24px 28px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 20px;
  box-shadow: 0 1px 2px rgba(17, 24, 39, 0.04);
}
.sizes-row-label .eyebrow { margin: 0 0 4px; }
.sizes-row-sub {
  font-size: 14px;
  color: var(--text-body);
}
.sizes-tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.size-tier {
  position: relative;
  padding: 14px 16px;
  background: var(--surface-cream);
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.size-tier-mid {
  background: linear-gradient(180deg, rgba(91, 98, 224, 0.10) 0%, #ffffff 60%);
  border-color: rgba(91, 98, 224, 0.35);
}
.size-tier-flag {
  position: absolute;
  top: -10px;
  left: 12px;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--accent-warm);
  color: #ffffff;
  padding: 3px 8px;
  border-radius: 6px;
  font-weight: 600;
}
.size-tier-name {
  font-size: 14px;
  font-weight: 600;
  color: #1d1d1f;
}
.size-tier-for {
  font-size: 12px;
  color: var(--text-body-soft);
}
.sf-link {
  font-size: 13px;
  font-weight: 600;
  color: var(--accent-warm);
}

@media (max-width: 900px) {
  .specs2-grid { grid-template-columns: 1fr; }
  .sizes-row { grid-template-columns: 1fr; gap: 16px; }
  .sizes-tiers { grid-template-columns: 1fr; }
  .dev-tag { display: none; }
}

/* ============================================================
   NEW · Hero is now just product + copy (brain stage moved
   to its own section), so remove the 720px floor.
   ============================================================ */
.hero { min-height: 0; padding: 96px 0 80px; }
.hero-in { gap: 80px; align-items: center; }
.hero-h { font-size: 64px; }

/* ============================================================
   NEW · "One brain · every system" section — gives the brain
   stage room to breathe with a proper section head above it.
   ============================================================ */
.brain-section {
  background: linear-gradient(180deg, #ffffff 0%, var(--surface-sky) 65%, #ffffff 100%);
  position: relative;
  padding: 96px 0 112px;
}
.brain-section .wrap { position: relative; z-index: 1; }
.brain-section .section-head { margin-bottom: 32px; }
.aurora-brain {
  position: absolute;
  inset: 5% 0 5% 0;
  opacity: 0.35;
  filter: blur(70px);
  background:
    radial-gradient(40% 50% at 20% 30%, var(--aurora-1) 0%, transparent 65%),
    radial-gradient(40% 50% at 80% 70%, var(--aurora-2) 0%, transparent 65%);
}
.brain-section .brain-stage {
  margin: 0 auto;
  max-width: 680px;
}
.brain-section .bs-field { max-width: 520px; margin: 0 auto; }
.brain-section .bs-convo { max-width: 520px; margin: 0 auto; }

/* ============================================================
   NEW · "Chat capabilities" — replaces the awkward 6-tile grid
   with a clean row-based list. Each row: icon · title+copy · example.
   ============================================================ */
.caps { background: var(--surface-cream); }
.caps-list {
  list-style: none;
  padding: 0;
  margin: 48px 0 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.cap {
  display: grid;
  grid-template-columns: 56px minmax(0, 1.1fr) minmax(0, 1.4fr);
  align-items: center;
  gap: 28px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 16px;
  padding: 20px 24px;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 8px 24px -18px rgba(17, 24, 39, 0.10);
  transition: all 200ms var(--ease-smooth);
}
.cap:hover {
  border-color: rgba(91, 98, 224, 0.20);
  transform: translateY(-1px);
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 12px 30px -16px rgba(91, 98, 224, 0.22);
}
.cap-i {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: rgba(91, 98, 224, 0.10);
  color: var(--accent-warm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.cap-i-tools {
  background: rgba(52, 199, 89, 0.12);
  color: #14894d;
}
.cap-body h4 {
  font-size: 20px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin: 0 0 6px;
  color: #1d1d1f;
}
.cap-body p {
  font-size: 14.5px;
  line-height: 1.5;
  color: var(--text-body);
  margin: 0;
}
.cap-eg {
  align-self: stretch;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 14px 16px;
  background: var(--surface-cream);
  border-radius: 12px;
  font-size: 13px;
  line-height: 1.4;
  color: var(--text-body);
  justify-content: center;
}
.cap-eg-q {
  font-style: italic;
  color: #1d1d1f;
}
.cap-eg-a {
  color: var(--text-body);
}
.cap-eg-chip {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--accent-warm);
  background: rgba(91, 98, 224, 0.06);
  border-radius: 9999px;
  padding: 8px 14px;
  align-self: center;
  justify-self: start;
  letter-spacing: 0.04em;
}
.cap-eg-tools {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  gap: 0;
  padding: 4px 0;
}
.cap-eg-tools .ce-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  font-size: 13px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.05);
}
.cap-eg-tools .ce-row:last-child { border-bottom: none; }
.cap-eg-tools .ce-i {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  background: rgba(52, 199, 89, 0.12);
  color: #14894d;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  flex-shrink: 0;
}
.cap-eg-tools .ce-n {
  flex: 1;
  font-weight: 500;
  color: #1d1d1f;
}
.cap-eg-tools .ce-m {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text-meta);
}
.cap-feature {
  border-color: rgba(91, 98, 224, 0.18);
  background: linear-gradient(180deg, rgba(91, 98, 224, 0.03) 0%, #ffffff 60%);
}

/* ============================================================
   NEW · "Six bills, one box" — warmer story-driven layout.
   Top: pile of chips (today's stack).
   Middle: down arrow.
   Bottom: one Droplet card.
   Below: 3 happy stats.
   ============================================================ */
.replaces .section-head.center { margin-bottom: 56px; }

.rep2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 880px;
  margin: 0 auto;
}

/* OLD STACK */
.rep2-old {
  width: 100%;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 20px;
  padding: 24px 28px 28px;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 12px 28px -22px rgba(17, 24, 39, 0.10);
}
.rep2-old-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 18px;
  padding-bottom: 18px;
  border-bottom: 1px dashed rgba(0, 0, 0, 0.10);
}
.rep2-tag {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-body-soft);
  font-weight: 600;
  align-self: center;
}
.rep2-old-total {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.rep2-old-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.025em;
  color: #1d1d1f;
  position: relative;
}
.rep2-old-num::after {
  content: "";
  position: absolute;
  left: -2px; right: -2px;
  top: 52%;
  height: 2.5px;
  background: var(--color-system-red);
  transform: rotate(-3deg);
  border-radius: 2px;
  opacity: 0.85;
}
.rep2-old-per {
  font-size: 13px;
  color: var(--text-body-soft);
}
.rep2-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.r2c {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--surface-sky);
  border: 1px solid rgba(0, 0, 0, 0.05);
  border-radius: 10px;
  font-size: 13px;
}
.r2c-n {
  color: #1d1d1f;
  font-weight: 500;
}
.r2c-p {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-meta);
}

/* ARROW */
.rep2-arrow {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 18px 0;
  color: var(--accent-warm);
}
.rep2-arrow-l {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 600;
}

/* NEW DROPLET CARD */
.rep2-new {
  width: 100%;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 24px;
  padding: 28px 32px;
  background: linear-gradient(135deg, #3c3fae 0%, #4f55c4 55%, #6b71d8 100%);
  color: #ffffff;
  border-radius: 20px;
  box-shadow: 0 22px 48px -24px rgba(91, 98, 224, 0.55);
  position: relative;
  overflow: hidden;
}
.rep2-new::before {
  content: "";
  position: absolute;
  inset: -10%;
  background:
    radial-gradient(36% 50% at 18% 30%, rgba(255, 217, 194, 0.30) 0%, transparent 60%),
    radial-gradient(42% 60% at 88% 80%, rgba(207, 224, 255, 0.30) 0%, transparent 65%);
  pointer-events: none;
}
.rep2-new-mark {
  position: relative;
  width: 56px;
  height: 64px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.10);
  border-radius: 14px;
}
.rep2-new-body {
  position: relative;
}
.rep2-new-name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 30px;
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.rep2-new-sub {
  font-size: 14.5px;
  color: rgba(255, 255, 255, 0.85);
  margin-top: 4px;
  line-height: 1.45;
}
.rep2-new-price {
  position: relative;
  text-align: right;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}
.rep2-from {
  font-family: var(--font-mono);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: rgba(255, 255, 255, 0.70);
  font-weight: 600;
}
.rep2-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 48px;
  line-height: 1;
  letter-spacing: -0.025em;
}
.rep2-per {
  font-size: 13px;
  color: rgba(255, 255, 255, 0.85);
}

/* HAPPY STATS */
.rep2-stats {
  margin-top: 28px;
  width: 100%;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 16px;
}
.r2s {
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 16px;
  padding: 22px 24px;
  box-shadow:
    0 1px 2px rgba(17, 24, 39, 0.04),
    0 8px 24px -18px rgba(17, 24, 39, 0.10);
}
.r2s-feature {
  background: linear-gradient(180deg, rgba(91, 98, 224, 0.05) 0%, #ffffff 60%);
  border-color: rgba(91, 98, 224, 0.20);
}
.r2s-num {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 44px;
  line-height: 1;
  letter-spacing: -0.025em;
  color: var(--accent-warm);
  margin-bottom: 8px;
}
.r2s-feature .r2s-num {
  background: linear-gradient(135deg, #3c3fae 0%, #6b71d8 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.r2s-feature .r2s-num::before {
  content: "−";
  margin-right: 0;
}
.r2s-l {
  font-size: 14.5px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 4px;
}
.r2s-s {
  font-size: 13px;
  color: var(--text-body-soft);
}
.rep-foot {
  max-width: 880px;
  margin: 36px auto 0;
  font-size: 13px;
  color: var(--text-body-soft);
  text-align: center;
  line-height: 1.5;
}

/* ── Responsive for new patterns ── */
@media (max-width: 900px) {
  .hero-h { font-size: 44px; }
  .cap {
    grid-template-columns: 48px 1fr;
    gap: 18px;
  }
  .cap-eg { grid-column: 1 / -1; }
  .rep2-new {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 16px;
  }
  .rep2-new-mark { margin: 0 auto; }
  .rep2-new-price {
    align-items: center;
    text-align: center;
  }
  .rep2-stats { grid-template-columns: 1fr; }
}

/* ============================================================
   NEW · Tool templates as visible workflows.
   Each .tmpl.tw card shows: when it runs → pulls from chips →
   produces output line. Concrete, scannable, "I can see how
   this would actually work for my team".
   ============================================================ */
.tmpl.tw {
  padding: 22px 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.tmpl.tw .tmpl-cat {
  margin-bottom: 0;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-warm);
  font-weight: 600;
}
.tmpl.tw h4 {
  margin: 2px 0 0;
}
.tmpl.tw .tmpl-foot {
  margin-top: auto;
}

.tw-flow {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 14px 14px 12px;
  background: var(--surface-cream);
  border-radius: 12px;
  flex: 1;
  position: relative;
}
.tw-step {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.tw-step-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-meta);
  font-weight: 600;
}
.tw-step-items {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.tw-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 11px 6px 9px;
  background: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.07);
  border-radius: 9999px;
  font-size: 12px;
  line-height: 1;
  color: #1d1d1f;
  font-weight: 500;
  white-space: nowrap;
}
.tw-pill svg {
  color: var(--accent-warm);
  flex-shrink: 0;
}
.tw-out {
  display: block;
  padding: 10px 12px;
  background: rgba(91, 98, 224, 0.07);
  border-left: 3px solid var(--accent-warm);
  border-radius: 4px 10px 10px 4px;
  font-size: 13px;
  color: #1d1d1f;
  line-height: 1.45;
}

/* Empty "Droplet proposes" card stays clean */
.tmpl.tmpl-empty h4 { margin-top: 2px; }
.tmpl.tmpl-empty p {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-body);
  margin: 6px 0 0;
}
