/* ════════════════════════════════════════════════════════════════════
   linq — homepage v2 layer
   Ported verbatim from the v2 design handoff (design_handoff_homepage/home.css).
   Loaded ONLY on the marketing homepage via {% block extra_head %} in
   templates/marketing_public/home.html — keeps the handoff styles
   isolated from every other marketing page (no `.eyebrow` cascade leak).

   Sits on top of linq-kit.css (tokens + .btn primary/signal/ghost system)
   and linq-marketing.css (loaded first, but its `.btn--*` variants and
   legacy `.eyebrow` styles are scoped not to clash with the .btn.* and
   ::before eyebrow patterns used here).

   Marketing-specific layout only. No new hex outside the kit's token set.
   ════════════════════════════════════════════════════════════════════ */

html { scroll-behavior: smooth; }
body { line-height: 1.5; overflow-x: hidden; }
img { max-width: 100%; display: block; }

/* shared shell */
.wrap { max-width: 1240px; margin: 0 auto; padding: 0 40px; width: 100%; }
.section { padding: clamp(64px, 9vw, 130px) 0; position: relative; }
.section.tight { padding: clamp(48px, 6vw, 84px) 0; }

/* dashed hairline divider, like the app's row rules */
.hairline { border: 0; border-top: 1px dashed var(--border); margin: 0; }

/* eyebrow override for marketing scale */
.eyebrow {
  display: inline-flex; align-items: center; font-family: var(--font-mono);
  font-size: 0.78rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.18em; color: var(--text-muted);
}
.eyebrow::before { content:''; width: 7px; height: 7px; background: var(--signal); border-radius: 50%; margin-right: 0.8em; flex-shrink: 0; }
.eyebrow.on-dark { color: var(--on-dark-muted); }

/* the brand period — a true round Signal dot */
.dot {
  display: inline-block; width: 0.17em; height: 0.17em; border-radius: 50%;
  background: var(--signal); vertical-align: 0.04em; margin-left: 0.06em;
  text-indent: -9999px; overflow: hidden; line-height: 0;
}
.dot-pulse { position: relative; animation: dotPop .9s cubic-bezier(.18,1.4,.4,1) .35s both; }
.dot-pulse::after {
  content: ''; position: absolute; inset: 0; border-radius: 50%;
  background: var(--signal); animation: dotRipple 2.6s ease-out 1.2s infinite;
}
@keyframes dotPop { from { transform: scale(0); } to { transform: scale(1); } }
@keyframes dotRipple {
  0% { transform: scale(1); opacity: .55; }
  70%, 100% { transform: scale(2.6); opacity: 0; }
}
@media (prefers-reduced-motion: reduce){ .dot-pulse, .dot-pulse::after { animation: none; } }

/* display type */
.display {
  font-size: clamp(2.6rem, 5.6vw, 4.6rem); font-weight: 900;
  letter-spacing: -0.045em; line-height: 0.98; color: var(--ink);
  text-wrap: balance;
}
.h2 { font-size: clamp(1.9rem, 3.4vw, 2.9rem); font-weight: 800; letter-spacing: -0.035em; line-height: 1.04; color: var(--ink); text-wrap: balance; }
.lead { font-size: clamp(1.02rem, 1.5vw, 1.18rem); color: var(--text-muted); line-height: 1.6; max-width: 56ch; }

/* buttons — marketing sizes layered on .btn */
.btn.lg { padding: 13px 24px; font-size: 0.98rem; font-weight: 700; }
.btn.lg.signal { box-shadow: 0 10px 26px -12px rgba(234,106,44,.7); }
.btn .arr { transition: transform .18s; }
.btn:hover .arr { transform: translateX(3px); }
.btn.ondark { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.22); color: var(--on-dark); }
.btn.ondark:hover { background: rgba(255,255,255,.16); border-color: rgba(255,255,255,.4); }

/* mono meta strip */
.meta-strip {
  font-family: var(--font-mono); font-size: 0.74rem; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint);
  display: flex; flex-wrap: wrap; align-items: center; gap: 8px 16px;
}
.meta-strip.center { justify-content: center; }
.meta-strip .sep { width: 4px; height: 4px; border-radius: 50%; background: var(--border-strong); }

/* section header (two-column: title left, lead right) */
.sec-head2 { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 28px 56px; align-items: end; margin-bottom: 52px; }
.sec-head2 .eyebrow { margin-bottom: 16px; }
.sec-head2 .lead { margin-bottom: 4px; }
@media (max-width: 900px){ .sec-head2 { grid-template-columns: 1fr; gap: 18px; margin-bottom: 38px; } }

/* ══════════════════════════════════════════════════════════════════
   TOP NAV
   ══════════════════════════════════════════════════════════════════ */
.nav {
  position: sticky; top: 0; z-index: 50;
  background: rgba(244,240,232,0.82); backdrop-filter: blur(12px) saturate(1.2);
  border-bottom: 1px solid var(--border);
}
.nav-in { display: flex; align-items: center; gap: 18px; height: 70px; }
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; flex-shrink: 0; }
.brand .wm { font-size: 1.5rem; font-weight: 600; letter-spacing: -0.04em; color: var(--ink); line-height: 1; }
.nav-links { display: flex; align-items: center; gap: 4px; margin-left: 14px; }
.nav-links a { font-size: 0.92rem; font-weight: 600; color: var(--text-muted); text-decoration: none; padding: 8px 13px; border-radius: var(--r-sm); transition: color .15s, background .15s; }
.nav-links a:hover { color: var(--ink); background: var(--panel); }
.nav-cta { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.nav-cta .signin { font-size: 0.92rem; font-weight: 600; color: var(--text-muted); text-decoration: none; padding: 8px 12px; }
.nav-cta .signin:hover { color: var(--ink); }
.nav-burger { display: none; width: 42px; height: 42px; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--panel); color: var(--ink); align-items: center; justify-content: center; font-size: 1.3rem; cursor: pointer; }
@media (max-width: 920px){
  .nav-links { display: none; }
  .nav-cta .signin { display: none; }
  .nav-burger { display: flex; margin-left: auto; }
  .nav-cta { margin-left: 0; }
}

/* ══════════════════════════════════════════════════════════════════
   HERO
   ══════════════════════════════════════════════════════════════════ */
.hero { padding: clamp(48px, 7vw, 96px) 0 clamp(40px, 5vw, 72px); }
.hero-grid { display: grid; grid-template-columns: 1.04fr 0.96fr; gap: clamp(36px, 5vw, 76px); align-items: center; }
@media (max-width: 980px){ .hero-grid { grid-template-columns: 1fr; gap: 48px; } }
.hero .eyebrow { margin-bottom: 22px; }
.hero .display { margin-bottom: 18px; }
.hero h2.subh { font-size: clamp(1.2rem, 2vw, 1.6rem); font-weight: 700; letter-spacing: -0.02em; color: var(--ink); line-height: 1.2; margin-bottom: 20px; max-width: 22ch; }
.hero h2.subh .muted { color: var(--text-muted); font-weight: 600; }
.hero .lead { margin-bottom: 30px; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 22px; }

/* loop cards (hero right) */
.loop-stack { display: flex; flex-direction: column; gap: 12px; position: relative; }
.loop-card {
  position: relative; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 16px;
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 16px 18px; box-shadow: var(--e-1); transition: border-color .35s, box-shadow .35s, transform .35s;
}
.loop-card .lc-idx {
  font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.12em;
  color: var(--text-faint); width: 56px; flex-shrink: 0;
}
.loop-card .lc-idx b { display: block; font-size: 1.05rem; color: var(--text-muted); letter-spacing: 0.04em; }
.loop-card .lc-body .lc-label { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); }
.loop-card .lc-body .lc-main { font-weight: 700; font-size: 0.98rem; letter-spacing: -0.01em; margin-top: 2px; }
.loop-card .lc-body .lc-sub { font-family: var(--font-mono); font-size: 0.76rem; color: var(--text-muted); margin-top: 2px; }
.loop-card .lc-mark {
  width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center;
  border: 1px solid var(--border); color: var(--text-faint); font-size: 0.8rem; flex-shrink: 0;
  background: var(--bg); transition: background .35s, color .35s, border-color .35s, transform .35s;
}
.loop-card.is-active {
  border-color: rgba(234,106,44,.42); box-shadow: 0 18px 40px -22px rgba(234,106,44,.55), var(--e-1);
  transform: translateX(-6px);
}
.loop-card.is-active .lc-idx b { color: var(--signal-deep); }
.loop-card.is-active .lc-mark { background: var(--signal); color: #fff; border-color: var(--signal); transform: scale(1.06); }
.loop-card.is-done .lc-mark { background: var(--sage); color: #fff; border-color: var(--sage); }
/* connector thread */
.loop-stack::before {
  content:''; position: absolute; left: 46px; top: 26px; bottom: 26px; width: 2px;
  background: var(--border); z-index: 0;
}
.loop-stack .loop-card { z-index: 1; }
.loop-note { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); text-align: center; margin-top: 16px; }

/* ══════════════════════════════════════════════════════════════════
   TRUST BAND
   ══════════════════════════════════════════════════════════════════ */
.trust { background: var(--bg-warm); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.trust-in { padding: 34px 0; display: flex; flex-direction: column; gap: 20px; align-items: center; text-align: center; }
.trust .eyebrow { color: var(--text-muted); }
.logo-row { display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap: 14px 38px; }
.logo-row .lg { font-weight: 700; font-size: 1.05rem; letter-spacing: -0.02em; color: var(--text-muted); opacity: .72; transition: opacity .2s; white-space: nowrap; }
.logo-row .lg:hover { opacity: 1; }
.logo-row .lg .om { color: var(--text-faint); font-weight: 600; }
.trust-stat { font-family: var(--font-mono); font-size: 0.86rem; color: var(--text-muted); letter-spacing: 0.02em; }
.trust-stat b { color: var(--ink); font-weight: 600; }

/* ══════════════════════════════════════════════════════════════════
   THE LOOP — 5 mini cards
   ══════════════════════════════════════════════════════════════════ */
.loop5 { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; }
@media (max-width: 1040px){ .loop5 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px){ .loop5 { grid-template-columns: 1fr; } }
.loop5-card {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 22px 20px 20px; display: flex; flex-direction: column; gap: 12px; position: relative;
  transition: border-color .15s, transform .12s, box-shadow .15s; text-decoration: none; color: inherit;
}
.loop5-card:hover { border-color: var(--border-strong); transform: translateY(-3px); box-shadow: var(--e-2); }
.loop5-card .l5-top { display: flex; align-items: center; justify-content: space-between; }
.loop5-card .l5-n { font-family: var(--font-mono); font-size: 0.78rem; font-weight: 600; letter-spacing: 0.1em; color: var(--signal-deep); }
.loop5-card .l5-ico { width: 34px; height: 34px; border-radius: var(--r-sm); background: var(--ocean-soft); color: var(--ocean); display: grid; place-items: center; font-size: 1rem; }
.loop5-card h3 { font-size: 1.12rem; font-weight: 700; letter-spacing: -0.01em; }
.loop5-card p { font-size: 0.9rem; color: var(--text-muted); line-height: 1.5; flex: 1; }
.loop5-card .l5-link { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.04em; color: var(--text-faint); display: inline-flex; align-items: center; gap: 6px; }
.loop5-card:hover .l5-link { color: var(--signal-deep); }

/* ══════════════════════════════════════════════════════════════════
   MODULES GRID — 6 tiles
   ══════════════════════════════════════════════════════════════════ */
.modules { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 1040px){ .modules { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 680px){ .modules { grid-template-columns: 1fr; } }
.mod {
  background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 24px 24px 22px; display: flex; flex-direction: column; gap: 14px; min-height: 280px;
}
.mod .mod-eye { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); display: inline-flex; align-items: center; gap: 8px; }
.mod .mod-eye i { font-size: 0.95rem; color: var(--ocean); }
.mod h3 { font-size: 1.22rem; font-weight: 800; letter-spacing: -0.02em; line-height: 1.1; }
.mod p { font-size: 0.92rem; color: var(--text-muted); line-height: 1.55; }
.mod .mod-micro { margin-top: auto; font-family: var(--font-mono); font-size: 0.74rem; color: var(--signal-deep); letter-spacing: 0.02em; padding-top: 8px; }

/* dispatch demo (tile 2) */
.demo-dispatch { margin-top: auto; background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-md); padding: 13px 14px; }
.demo-dispatch .dd-top { display: flex; align-items: center; justify-content: space-between; gap: 10px; margin-bottom: 10px; }
.demo-dispatch .dd-cust { font-weight: 700; font-size: 0.9rem; }
.demo-dispatch .dd-svc { font-family: var(--font-mono); font-size: 0.74rem; color: var(--text-muted); }
.demo-dispatch .dd-acts { display: flex; gap: 7px; }
.dd-btn { flex: 1; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.06em; text-transform: uppercase; font-weight: 600; padding: 8px 6px; border-radius: var(--r-sm); border: 1px solid var(--border); background: var(--panel); color: var(--text-muted); cursor: pointer; transition: all .15s; }
.dd-btn.go:hover { border-color: var(--violet); color: var(--violet); background: var(--violet-soft); }
.dd-btn.no:hover { border-color: var(--red); color: var(--red); background: var(--red-soft); }
.demo-dispatch .dd-eta { font-family: var(--font-mono); font-size: 0.74rem; color: var(--text-muted); margin-top: 10px; display: none; }
.demo-dispatch .dd-eta.show { display: block; }
.demo-dispatch .dd-eta b { color: var(--violet); }

/* pill (used by the dispatch demo) */
.pill { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; padding: 4px 10px; border-radius: var(--r-pill); border: 1px solid transparent; white-space: nowrap; }
.pill.amber { background: var(--amber-soft); color: var(--amber); border-color: rgba(201,138,30,.22); }
.pill.violet { background: var(--violet-soft); color: var(--violet); border-color: rgba(124,92,214,.22); }
.pill.ghost { background: transparent; color: var(--text-faint); border-color: var(--border); }

/* payments / signature demo (tile 4) */
.demo-sig { margin-top: auto; }
.demo-sig .sig-pad { background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-md); height: 92px; position: relative; cursor: crosshair; overflow: hidden; }
.demo-sig .sig-pad canvas { display: block; width: 100%; height: 100%; touch-action: none; }
.demo-sig .sig-hint { position: absolute; inset: 0; display: grid; place-items: center; font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); pointer-events: none; transition: opacity .2s; }
.demo-sig .sig-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 8px; }
.demo-sig .sig-amt { font-family: var(--font-mono); font-weight: 600; font-size: 0.86rem; }
.demo-sig .sig-amt b { color: var(--signal-deep); }
.demo-sig .sig-clear { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-faint); background: none; border: 0; cursor: pointer; letter-spacing: 0.04em; }
.demo-sig .sig-clear:hover { color: var(--ink); }

/* reports demo (tile 6) */
.demo-reports { margin-top: auto; }
.demo-reports .rp-tabs { display: flex; gap: 3px; background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 3px; margin-bottom: 12px; }
.rp-tab { flex: 1; font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.04em; border: 0; background: transparent; color: var(--text-muted); padding: 6px 4px; border-radius: var(--r-pill); cursor: pointer; transition: all .15s; }
.rp-tab.active { background: var(--surface-dark); color: var(--on-dark); }
.demo-reports .rp-panel { display: none; }
.demo-reports .rp-panel.active { display: block; }
.rp-bars { display: flex; align-items: flex-end; gap: 8px; height: 72px; }
.rp-bars .bar { flex: 1; background: var(--ocean-soft); border-radius: 4px 4px 0 0; position: relative; transition: height .4s; }
.rp-bars .bar::after { content: attr(data-v); position: absolute; bottom: 4px; left: 0; right: 0; text-align: center; font-family: var(--font-mono); font-size: 0.6rem; color: var(--ocean-deep); }
.rp-bars .bar.hi { background: var(--ocean); }
.rp-bars .bar.hi::after { color: #fff; }
.demo-reports .rp-cap { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-muted); margin-top: 8px; }

/* below-grid utility line */
.mod-foot-line { margin-top: 24px; }
.mod-foot-line a { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-muted); text-decoration: none; display: inline-flex; flex-wrap: wrap; gap: 8px 12px; align-items: center; }
.mod-foot-line a:hover { color: var(--signal-deep); }
.mod-foot-line .pluslead { color: var(--signal-deep); }

/* ══════════════════════════════════════════════════════════════════
   COMPARISON BAND
   ══════════════════════════════════════════════════════════════════ */
.cmp { background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
.cmp table { width: 100%; border-collapse: collapse; }
.cmp thead th { text-align: left; padding: 22px 24px 18px; border-bottom: 1px solid var(--border); vertical-align: bottom; }
.cmp thead th .ch-lbl { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); }
.cmp thead th .ch-name { font-size: 1.05rem; font-weight: 700; letter-spacing: -0.01em; margin-top: 4px; }
.cmp thead th.col-linq { background: var(--surface-dark); }
.cmp thead th.col-linq .ch-lbl { color: var(--on-dark-muted); }
.cmp thead th.col-linq .ch-name { color: #fff; display: inline-flex; align-items: center; gap: 8px; }
.cmp thead th.col-linq .ch-name .wmm { font-weight: 600; letter-spacing: -0.03em; }
.cmp tbody td { padding: 16px 24px; font-size: 0.92rem; border-bottom: 1px dashed var(--border); vertical-align: top; }
.cmp tbody tr:last-child td { border-bottom: 0; }
.cmp tbody td.row-key { font-family: var(--font-mono); font-size: 0.74rem; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-muted); white-space: nowrap; }
.cmp tbody td.col-linq { background: var(--surface-dark); color: var(--on-dark); font-weight: 600; }
.cmp tbody td .other { color: var(--text-muted); }
.cmp tbody td.col-linq .ok { color: var(--signal); margin-right: 7px; }
.cmp-foot { padding: 18px 24px; border-top: 1px solid var(--border); background: var(--bg-warm); }
.cmp-foot a { font-size: 0.92rem; font-weight: 600; color: var(--ocean); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.cmp-foot a:hover { color: var(--ocean-deep); }
@media (max-width: 760px){
  .cmp { border: 0; background: transparent; }
  .cmp table, .cmp thead, .cmp tbody, .cmp tr, .cmp td, .cmp th { display: block; }
  .cmp thead { position: absolute; left: -9999px; }
  .cmp tbody tr { background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); margin-bottom: 12px; overflow: hidden; }
  .cmp tbody td { border-bottom: 1px dashed var(--border); display: flex; justify-content: space-between; gap: 16px; }
  .cmp tbody td.row-key { background: var(--bg-warm); }
  .cmp tbody td.col-linq::before { content: 'lınq'; font-family: var(--font-display); }
  .cmp tbody td::before { content: attr(data-h); font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-faint); }
  .cmp-foot { background: transparent; border: 0; padding: 6px 0; }
}

/* ══════════════════════════════════════════════════════════════════
   BUILT BY LINQ — 2 customer cards
   ══════════════════════════════════════════════════════════════════ */
.built { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 860px){ .built { grid-template-columns: 1fr; } }
.built-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 26px 26px 24px; display: flex; flex-direction: column; gap: 16px; }
.built-card .bc-eye { font-family: var(--font-mono); font-size: 0.68rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-faint); }
.built-card .bc-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.built-card h3 { font-size: 1.5rem; font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; }
.built-card .bc-meta { font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-muted); margin-top: 6px; }
.built-card .bc-link { font-family: var(--font-mono); font-size: 0.78rem; color: var(--ocean); text-decoration: none; white-space: nowrap; }
.built-card .bc-link:hover { color: var(--ocean-deep); }
.built-card .bc-stack { display: flex; flex-direction: column; gap: 0; }
.built-card .bc-stack li { display: flex; align-items: flex-start; gap: 11px; padding: 11px 0; border-bottom: 1px dashed var(--border); font-size: 0.92rem; list-style: none; }
.built-card .bc-stack li:last-child { border-bottom: 0; }
.built-card .bc-stack li i { color: var(--sage); font-size: 0.95rem; margin-top: 2px; flex-shrink: 0; }
.built-card .bc-cta { margin-top: 6px; }
.built-card .bc-cta a { font-size: 0.92rem; font-weight: 700; color: var(--ink); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.built-card .bc-cta a:hover { color: var(--signal-deep); }
.built-card .bc-cta a .arr { transition: transform .18s; }
.built-card .bc-cta a:hover .arr { transform: translateX(3px); }

/* ══════════════════════════════════════════════════════════════════
   STATS BAND
   ══════════════════════════════════════════════════════════════════ */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--border); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; }
@media (max-width: 880px){ .stats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 460px){ .stats { grid-template-columns: 1fr; } }
.stat { background: var(--panel); padding: 30px 26px; display: flex; flex-direction: column; gap: 10px; }
.stat .st-num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: clamp(2.6rem, 4vw, 3.4rem); font-weight: 500; letter-spacing: -0.03em; line-height: 0.9; color: var(--ink); }
.stat .st-num .u { color: var(--signal); }
.stat .st-src { font-size: 0.84rem; color: var(--text-muted); line-height: 1.45; }

/* ══════════════════════════════════════════════════════════════════
   TESTIMONIAL
   ══════════════════════════════════════════════════════════════════ */
.quote-block { max-width: 920px; margin: 0 auto; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 26px; }
.quote-block .eyebrow { justify-content: center; }
.quote-block blockquote { font-size: clamp(1.5rem, 3.2vw, 2.5rem); font-weight: 800; letter-spacing: -0.03em; line-height: 1.16; color: var(--ink); text-wrap: balance; }
.quote-block .attr { font-family: var(--font-mono); font-size: 0.86rem; color: var(--text-muted); letter-spacing: 0.02em; }
.quote-block .attr b { color: var(--ink); font-weight: 600; }
.result-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.result-chips .rc { display: inline-flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 0.8rem; font-weight: 600; color: var(--ink); background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-pill); padding: 7px 16px; }
.result-chips .rc .ar { color: var(--sage); }
.quote-cta a { font-size: 0.92rem; font-weight: 700; color: var(--ink); text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.quote-cta a:hover { color: var(--signal-deep); }

/* ══════════════════════════════════════════════════════════════════
   DARK BANDS (payments promo + final CTA)
   ══════════════════════════════════════════════════════════════════ */
.dark-band {
  background: var(--surface-dark); color: var(--on-dark); position: relative; overflow: hidden;
}
.dark-band::after {
  content:''; position: absolute; right: -8%; top: -40%; width: 540px; height: 540px; border-radius: 50%;
  background: radial-gradient(circle, rgba(234,106,44,.22), transparent 66%); pointer-events: none;
}
.dark-band .h2, .dark-band h3 { color: #fff; }

/* payments promo */
.pay-grid { display: grid; grid-template-columns: 0.85fr 1.15fr; gap: clamp(32px, 5vw, 72px); align-items: center; position: relative; z-index: 1; }
@media (max-width: 880px){ .pay-grid { grid-template-columns: 1fr; gap: 32px; } }
.pay-rate { display: flex; flex-direction: column; gap: 4px; }
.pay-rate .pr-big { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: clamp(4.5rem, 11vw, 8rem); font-weight: 500; letter-spacing: -0.05em; line-height: 0.82; color: var(--signal); }
.pay-rate .pr-lock { font-family: var(--font-mono); font-size: 0.82rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--on-dark-muted); margin-top: 14px; }
.pay-copy h3 { font-size: clamp(1.6rem, 3vw, 2.3rem); font-weight: 800; letter-spacing: -0.03em; line-height: 1.08; margin-bottom: 16px; }
.pay-copy p { color: var(--on-dark-muted); font-size: 1.04rem; line-height: 1.6; margin-bottom: 24px; max-width: 54ch; }
.pay-fine { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(242,237,226,.4); margin-top: 22px; position: relative; z-index: 1; }

/* ══════════════════════════════════════════════════════════════════
   BOOKING DEMO
   ══════════════════════════════════════════════════════════════════ */
.book-grid { display: grid; grid-template-columns: 0.95fr 1.05fr; gap: clamp(32px, 5vw, 72px); align-items: start; }
@media (max-width: 920px){ .book-grid { grid-template-columns: 1fr; } }
.book-card { background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 26px; box-shadow: var(--e-2); }
.book-card .bk-head { display: flex; align-items: center; gap: 11px; padding-bottom: 16px; border-bottom: 1px solid var(--border); margin-bottom: 18px; }
.book-card .bk-head .bk-logo { width: 34px; height: 34px; }
.book-card .bk-head .bk-biz { font-weight: 800; letter-spacing: -0.02em; }
.book-card .bk-head .bk-tag { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-faint); }
.bk-label { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 10px; }
.bk-days { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-bottom: 20px; }
.bk-day { border: 1px solid var(--border); background: var(--bg); border-radius: var(--r-md); padding: 10px 4px; text-align: center; cursor: pointer; transition: all .15s; }
.bk-day .d-dow { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); }
.bk-day .d-num { font-size: 1.2rem; font-weight: 700; margin-top: 3px; }
.bk-day:hover { border-color: var(--border-strong); }
.bk-day.sel { background: var(--surface-dark); border-color: var(--surface-dark); }
.bk-day.sel .d-dow { color: var(--on-dark-muted); }
.bk-day.sel .d-num { color: #fff; }
.bk-windows { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 20px; }
.bk-win { font-family: var(--font-mono); font-size: 0.8rem; border: 1px solid var(--border); background: var(--bg); color: var(--text-muted); border-radius: var(--r-pill); padding: 8px 16px; cursor: pointer; transition: all .15s; }
.bk-win:hover { border-color: var(--border-strong); color: var(--ink); }
.bk-win.sel { background: var(--signal-soft); border-color: rgba(234,106,44,.4); color: var(--signal-deep); font-weight: 600; }
.bk-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 18px; }
.bk-fields .span2 { grid-column: 1 / -1; }
.bk-fields input, .bk-fields textarea { width: 100%; font-family: var(--font-display); font-size: 0.92rem; color: var(--text); background: var(--bg); border: 1px solid var(--border); border-radius: var(--r-md); padding: 11px 14px; outline: none; transition: border-color .15s, box-shadow .15s; }
.bk-fields input:focus, .bk-fields textarea:focus { border-color: var(--ocean); box-shadow: 0 0 0 3px var(--ocean-soft); }
.bk-fields input::placeholder, .bk-fields textarea::placeholder { color: var(--text-faint); }
.bk-submit { width: 100%; justify-content: center; }
.bk-success { display: none; flex-direction: column; align-items: center; text-align: center; gap: 12px; padding: 24px 10px; }
.bk-success.show { display: flex; }
.bk-success .bs-ico { width: 56px; height: 56px; border-radius: 50%; background: var(--sage-soft); color: var(--sage); display: grid; place-items: center; font-size: 1.6rem; }
.bk-success h4 { font-size: 1.2rem; font-weight: 800; letter-spacing: -0.02em; }
.bk-success p { font-size: 0.9rem; color: var(--text-muted); max-width: 38ch; line-height: 1.5; }
.bk-success .bs-again { font-family: var(--font-mono); font-size: 0.74rem; color: var(--ocean); background: none; border: 0; cursor: pointer; letter-spacing: 0.04em; }

/* ══════════════════════════════════════════════════════════════════
   PRICING TEASER
   ══════════════════════════════════════════════════════════════════ */
.price-teaser { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 26px; }
.price-teaser .lead { text-align: center; }
.price-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }
.price-chips .pc { display: flex; flex-direction: column; align-items: center; gap: 2px; background: var(--panel); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px 32px; min-width: 150px; }
.price-chips .pc .pc-name { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--text-muted); }
.price-chips .pc .pc-price { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 1.7rem; font-weight: 500; letter-spacing: -0.02em; }
.price-chips .pc .pc-price .per { font-size: 0.86rem; color: var(--text-faint); }
.price-chips .pc.feature { background: var(--surface-dark); border-color: var(--surface-dark); }
.price-chips .pc.feature .pc-name { color: var(--on-dark-muted); }
.price-chips .pc.feature .pc-price { color: #fff; }
.price-chips .pc.feature .pc-price .per { color: var(--on-dark-muted); }
.price-cta { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }

/* ══════════════════════════════════════════════════════════════════
   FAQ
   ══════════════════════════════════════════════════════════════════ */
.faq { max-width: 880px; margin: 0 auto; border-top: 1px solid var(--border); }
.faq-item { border-bottom: 1px solid var(--border); }
.faq-q { width: 100%; display: flex; align-items: center; gap: 16px; padding: 22px 4px; background: none; border: 0; cursor: pointer; text-align: left; }
.faq-q h3 { font-size: clamp(1.05rem, 1.7vw, 1.22rem); font-weight: 700; letter-spacing: -0.01em; color: var(--ink); flex: 1; }
.faq-q .faq-ico { width: 30px; height: 30px; border-radius: 50%; border: 1px solid var(--border); display: grid; place-items: center; color: var(--text-muted); flex-shrink: 0; transition: transform .25s, background .2s, color .2s, border-color .2s; }
.faq-item.open .faq-q .faq-ico { transform: rotate(45deg); background: var(--signal); color: #fff; border-color: var(--signal); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-a .faq-a-in { padding: 0 50px 24px 4px; font-size: 1rem; color: var(--text-muted); line-height: 1.6; max-width: 64ch; }

/* ══════════════════════════════════════════════════════════════════
   FINAL CTA
   ══════════════════════════════════════════════════════════════════ */
.final-cta { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 24px; position: relative; z-index: 1; }
.final-cta .display { color: #fff; }
.final-cta .lead { color: var(--on-dark-muted); text-align: center; max-width: 50ch; }
.final-cta .fc-btns { display: flex; flex-wrap: wrap; justify-content: center; gap: 12px; }

/* ══════════════════════════════════════════════════════════════════
   FOOTER (v2)
   ══════════════════════════════════════════════════════════════════ */
.footer-v2 { background: var(--bg-warm); border-top: 1px solid var(--border); }
.footer-v2 .footer-in { padding: 64px 0 0; }
.footer-v2 .footer-cols { display: grid; grid-template-columns: 1.6fr repeat(5, 1fr); gap: 32px 24px; padding-bottom: 48px; }
@media (max-width: 1040px){ .footer-v2 .footer-cols { grid-template-columns: 1fr 1fr 1fr; } .footer-v2 .footer-cols .f-brand { grid-column: 1 / -1; } }
@media (max-width: 560px){ .footer-v2 .footer-cols { grid-template-columns: 1fr 1fr; } }
.footer-v2 .f-brand .brand { margin-bottom: 14px; }
.footer-v2 .f-brand p { font-size: 0.9rem; color: var(--text-muted); line-height: 1.6; max-width: 34ch; }
.footer-v2 .f-col h4 { font-family: var(--font-mono); font-size: 0.7rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--text-faint); margin-bottom: 14px; }
.footer-v2 .f-col a { display: block; font-size: 0.88rem; color: var(--text-muted); text-decoration: none; padding: 5px 0; transition: color .15s; }
.footer-v2 .f-col a:hover { color: var(--ink); }
.footer-v2 .footer-base { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 0; border-top: 1px solid var(--border); font-family: var(--font-mono); font-size: 0.76rem; color: var(--text-faint); flex-wrap: wrap; }
.footer-v2 .footer-base .fb-mark { display: flex; align-items: center; gap: 8px; }

/* reveal on scroll */
.reveal { opacity: 0; transform: translateY(22px); transition: opacity .7s cubic-bezier(.16,1,.3,1), transform .7s cubic-bezier(.16,1,.3,1); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce){ .reveal { opacity: 1; transform: none; transition: none; } html { scroll-behavior: auto; } }

/* mobile menu */
.mobile-menu { position: fixed; inset: 0; z-index: 60; background: var(--bg); display: none; flex-direction: column; padding: 24px 28px; }
.mobile-menu.open { display: flex; }
.mobile-menu .mm-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 30px; }
.mobile-menu .mm-x { width: 42px; height: 42px; border: 1px solid var(--border); border-radius: var(--r-sm); background: var(--panel); font-size: 1.3rem; cursor: pointer; }
.mobile-menu a { font-size: 1.4rem; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); text-decoration: none; padding: 14px 0; border-bottom: 1px dashed var(--border); }
.mobile-menu .mm-cta { margin-top: 26px; display: flex; flex-direction: column; gap: 12px; }
.mobile-menu .mm-cta .btn { justify-content: center; }
