/* =====================================================================
   features.css  ::  shared styles for Heatcord product/feature pages
   Loaded AFTER styles.css. Everything namespaced .fp-* so it never
   collides. Brand tokens only (see styles.css :root). Stripe/Linear
   restraint: generous whitespace, one shadow language, hairlines.
   ===================================================================== */

:root{
  --fp-shadow:    0 1px 2px rgba(7,10,20,.04), 0 18px 40px -24px rgba(7,10,20,.22);
  --fp-shadow-sm: 0 1px 2px rgba(7,10,20,.04), 0 8px 24px -16px rgba(7,10,20,.16);
  --fp-pad: clamp(72px, 9vw, 128px);
}

.fp main{ display:block; }
.fp-wrap{ width:min(1120px, 92vw); margin-inline:auto; }
.fp-wrap--narrow{ width:min(780px, 92vw); margin-inline:auto; }

/* ---- section shell ---- */
.fp-section{ padding-block: var(--fp-pad); }
.fp-section + .fp-section{ border-top:1px solid var(--hair); }
.fp-section--tint{ background:var(--canvas-2); border-top:1px solid var(--hair); border-bottom:1px solid var(--hair); }

/* ---- shared centered header ---- */
.fp-head{ max-width:680px; margin:0 auto clamp(48px,6vw,72px); text-align:center; }
.fp-head--left{ margin-inline:0; text-align:left; }
.fp-eyebrow{
  display:inline-block; font-family:var(--mono);
  font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase;
  color:var(--brand); margin-bottom:18px;
}
.fp-h2{
  font-weight:700; font-size:clamp(27px,3.3vw,38px); line-height:1.16;
  letter-spacing:-.025em; color:var(--ink); text-wrap:balance; margin:0;
}
.fp-head p{
  margin:18px auto 0; max-width:56ch; font-size:17px; line-height:1.6;
  color:var(--ink-2); text-wrap:pretty;
}
.fp-mark{ background:var(--accent); color:var(--ink); padding:0 7px 2px; border-radius:5px;
  box-decoration-break:clone; -webkit-box-decoration-break:clone; }

/* ---- buttons spacing helpers (reuse .btn from styles.css) ---- */
.fp-ctas{ display:flex; flex-wrap:wrap; gap:12px; }
.fp-btn-row{ display:flex; justify-content:center; margin-top:clamp(40px,5vw,56px); }
/* ghost button for dark bands (CTA) */
.btn--ghost-dark{ background:transparent; color:#fff; border:1px solid rgba(255,255,255,.28); }
.btn--ghost-dark:hover{ background:rgba(255,255,255,.09); border-color:rgba(255,255,255,.55); transform:translateY(-1px); }

/* ---- checklist ---- */
.fp-list{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.fp-list li{ display:flex; gap:11px; align-items:flex-start; font-size:15px; line-height:1.5; color:var(--ink); }
.fp-list svg{ width:19px; height:19px; flex-shrink:0; margin-top:1px; color:var(--ok); }
.fp-list--brand svg{ color:var(--brand); }

/* ---- clean screenshot / art frame ---- */
.fp-shot{ margin:0; border-radius:16px; overflow:hidden; border:1px solid var(--hair-strong);
  box-shadow:var(--fp-shadow); background:var(--canvas); }
.fp-shot img{ width:100%; height:auto; display:block; }
.fp-shot--sm{ box-shadow:var(--fp-shadow-sm); border-radius:14px; }

/* =====================================================================
   BREADCRUMB
   ===================================================================== */
.fp-crumb{ padding:22px 0 0; }
.fp-crumb ol{ list-style:none; display:flex; flex-wrap:wrap; gap:8px; margin:0; padding:0;
  font-family:var(--mono); font-size:12px; color:var(--ink-3); }
.fp-crumb a{ color:var(--ink-3); text-decoration:none; }
.fp-crumb a:hover{ color:var(--brand); }
.fp-crumb li[aria-current]{ color:var(--ink-2); }
.fp-crumb svg{ width:12px; height:12px; opacity:.5; }

/* =====================================================================
   HERO
   ===================================================================== */
.fp-hero{ padding-block: clamp(40px,5vw,64px) clamp(64px,8vw,96px); }
.fp-hero__grid{ display:grid; grid-template-columns:1fr 1.06fr; gap:clamp(40px,5vw,68px); align-items:center; }
.fp-pill{ display:inline-flex; align-items:center; gap:9px; padding:7px 14px 7px 11px; border-radius:100px;
  background:var(--brand-soft); color:var(--brand-deep); font-family:var(--mono); font-size:12px; font-weight:600;
  letter-spacing:.02em; margin-bottom:22px; }
.fp-pill svg{ width:15px; height:15px; }
.fp-hero h1{
  font-weight:800; font-size:clamp(33px,4.1vw,52px); line-height:1.07;
  letter-spacing:-.03em; color:var(--ink); margin:0 0 22px; max-width:16ch; text-wrap:balance;
}
.fp-hero__sub{ font-size:18px; line-height:1.62; color:var(--ink-2); margin:0 0 32px; max-width:52ch; }
.fp-hero__sub strong{ color:var(--ink); font-weight:600; }
.fp-replaces{ margin-top:30px; display:flex; flex-wrap:wrap; align-items:center; gap:10px 14px;
  font-size:13.5px; color:var(--ink-2); }
.fp-replaces__lbl{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); }
.fp-replaces b{ color:var(--ink); font-weight:600; }
.fp-replaces s{ color:var(--ink-3); }

/* =====================================================================
   ALTERNATING FEATURE ROWS
   ===================================================================== */
.fp-rows{ display:flex; flex-direction:column; gap:clamp(64px,8vw,108px); }
.fp-row{ display:grid; grid-template-columns:1fr 1.12fr; gap:clamp(36px,5vw,72px); align-items:center; }
.fp-row--flip .fp-row__media{ order:-1; }
.fp-row__tag{ font-family:var(--mono); font-size:11px; font-weight:600; letter-spacing:.09em;
  text-transform:uppercase; color:var(--brand); }
.fp-row h3{ font-size:clamp(22px,2.6vw,29px); font-weight:700; letter-spacing:-.025em; color:var(--ink);
  line-height:1.18; margin:13px 0 14px; text-wrap:balance; }
.fp-row__lead{ font-size:16.5px; line-height:1.62; color:var(--ink-2); margin:0 0 20px; }
.fp-row__media{ min-width:0; }

/* =====================================================================
   SMALL FEATURE GRID ("everything else")
   ===================================================================== */
.fp-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.fp-card{ background:var(--canvas); border:1px solid var(--hair-strong); border-radius:16px; padding:26px 24px;
  transition:border-color 200ms var(--ease-out), box-shadow 200ms var(--ease-out), transform 200ms var(--ease-out); }
.fp-card:hover{ border-color:var(--hair-stronger); box-shadow:var(--fp-shadow-sm); transform:translateY(-2px); }
.fp-card__ico{ width:40px; height:40px; border-radius:11px; display:grid; place-items:center;
  background:var(--brand-soft); color:var(--brand); margin-bottom:16px; }
.fp-card__ico svg{ width:20px; height:20px; }
.fp-card h4{ font-size:16px; font-weight:700; letter-spacing:-.01em; color:var(--ink); margin:0 0 8px; }
.fp-card p{ font-size:14px; line-height:1.55; color:var(--ink-2); margin:0; }

/* =====================================================================
   FINAL CTA BAND
   ===================================================================== */
.fp-cta{ background:var(--ink); }
.fp-cta__inner{ text-align:center; max-width:680px; margin:0 auto; }
.fp-cta .fp-eyebrow{ color:var(--accent-deep); }
.fp-cta h2{ font-weight:800; font-size:clamp(30px,3.6vw,44px); line-height:1.1; letter-spacing:-.03em;
  color:#fff; margin:0 0 18px; text-wrap:balance; }
.fp-cta p{ font-size:17.5px; line-height:1.6; color:rgba(255,255,255,.74); margin:0 auto 34px; max-width:52ch; }
.fp-cta .fp-ctas{ justify-content:center; }
.fp-cta__fine{ margin-top:26px; font-family:var(--mono); font-size:12.5px; color:rgba(255,255,255,.5); }

/* =====================================================================
   RELATED FEATURES (cross-link the suite)
   ===================================================================== */
.fp-related .fp-grid{ grid-template-columns:repeat(3,1fr); }
.fp-rel{ display:block; background:var(--canvas); border:1px solid var(--hair-strong); border-radius:14px;
  padding:20px 22px; text-decoration:none; transition:border-color 180ms var(--ease-out), box-shadow 180ms var(--ease-out), transform 180ms var(--ease-out); }
.fp-rel:hover{ border-color:var(--hair-stronger); box-shadow:var(--fp-shadow-sm); transform:translateY(-2px); }
.fp-rel__top{ display:flex; align-items:center; gap:11px; margin-bottom:9px; }
.fp-rel__ico{ width:32px; height:32px; border-radius:9px; display:grid; place-items:center;
  background:var(--brand-soft); color:var(--brand); flex-shrink:0; }
.fp-rel__ico svg{ width:17px; height:17px; }
.fp-rel__name{ font-size:15px; font-weight:700; color:var(--ink); letter-spacing:-.01em; }
.fp-rel p{ font-size:13.5px; line-height:1.5; color:var(--ink-2); margin:0; }
.fp-rel__go{ display:inline-flex; align-items:center; gap:6px; margin-top:12px; font-size:13px; font-weight:600; color:var(--brand); }
.fp-rel__go svg{ width:13px; height:13px; }

/* =====================================================================
   NAV: FEATURES DROPDOWN (desktop + mobile overlay)
   ===================================================================== */
.nav__has-drop{ position:relative; }
.nav__drop-toggle{ display:inline-flex; align-items:center; gap:5px; cursor:pointer; background:none; border:0;
  font:inherit; font-size:14.5px; font-weight:500; color:var(--ink-2); padding:0; line-height:1; }
.nav__drop-toggle:hover{ color:var(--brand); }
.nav__drop-toggle svg{ width:11px; height:11px; transition:transform .2s var(--ease-out); }
.nav__has-drop:hover .nav__drop-toggle svg,
.nav__has-drop:focus-within .nav__drop-toggle svg{ transform:rotate(180deg); }

.nav__drop{
  position:absolute; top:calc(100% + 16px); left:50%;
  transform:translateX(-50%) translateY(7px);
  width:540px; max-width:92vw; background:var(--canvas);
  border:1px solid var(--hair-strong); border-radius:18px;
  box-shadow:0 1px 2px rgba(7,10,20,.04), 0 28px 64px -28px rgba(7,10,20,.30);
  padding:12px; display:grid; grid-template-columns:1fr 1fr; gap:2px;
  opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .18s var(--ease-out), transform .18s var(--ease-out), visibility 0s linear .18s;
  z-index:60;
}
.nav__has-drop:hover .nav__drop,
.nav__has-drop:focus-within .nav__drop{
  opacity:1; visibility:visible; pointer-events:auto;
  transform:translateX(-50%) translateY(0);
  transition:opacity .18s var(--ease-out), transform .18s var(--ease-out), visibility 0s linear 0s;
}
/* invisible hover bridge so the gap doesn't drop the menu */
.nav__has-drop::after{ content:""; position:absolute; top:100%; left:-20px; right:-20px; height:20px; }
.nav__drop-item{ display:flex; gap:13px; align-items:flex-start; padding:13px; border-radius:12px;
  text-decoration:none; transition:background .15s var(--ease-out); }
.nav__drop-item:hover{ background:var(--canvas-2); }
.nav__drop-ico{ flex:0 0 36px; width:36px; height:36px; border-radius:10px; display:grid; place-items:center;
  background:var(--brand-soft); color:var(--brand); }
.nav__drop-ico svg{ width:18px; height:18px; }
.nav__drop-name{ font-size:14px; font-weight:600; color:var(--ink); display:block; line-height:1.3; }
.nav__drop-desc{ font-size:12.5px; color:var(--ink-3); line-height:1.42; margin-top:2px; }
.nav__drop-foot{ grid-column:1 / -1; margin-top:4px; padding:13px; border-top:1px solid var(--hair);
  display:flex; align-items:center; justify-content:space-between; }
.nav__drop-foot span{ font-size:13px; color:var(--ink-2); }
.nav__drop-foot a{ display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:600;
  color:var(--brand); text-decoration:none; }
.nav__drop-foot svg{ width:13px; height:13px; }

/* grouped mega-menu (10 products in 3 app-groups) */
.nav__drop--mega{ width:600px; grid-template-columns:1fr 1fr; gap:4px 16px; align-items:start; }
.nav__drop-col{ display:flex; flex-direction:column; min-width:0; }
.nav__drop-group{ font-family:var(--mono); font-size:10.5px; font-weight:600; letter-spacing:.1em;
  text-transform:uppercase; color:var(--ink-3); padding:11px 13px 5px; }
.nav__drop--mega .nav__drop-item{ padding:10px 13px; }

/* mobile overlay: expand the dropdown into a clean white-text list */
.nav__overlay .nav__has-drop{ position:static; }
.nav__overlay .nav__has-drop::after{ display:none; }
.nav__overlay .nav__drop-toggle{ color:rgba(255,255,255,.45); font-family:var(--mono); font-size:13px;
  font-weight:600; letter-spacing:.12em; text-transform:uppercase; cursor:default; pointer-events:none; }
.nav__overlay .nav__drop-toggle svg{ display:none; }
.nav__overlay .nav__drop{
  position:static; transform:none; opacity:1; visibility:visible; pointer-events:auto;
  width:auto; max-width:none; background:transparent; border:0; box-shadow:none;
  padding:16px 0 4px; display:flex; flex-direction:column; gap:16px;
}
.nav__overlay .nav__drop-item{ justify-content:center; padding:0; background:transparent; }
.nav__overlay .nav__drop-item:hover{ background:transparent; }
.nav__overlay .nav__drop-ico,
.nav__overlay .nav__drop-desc,
.nav__overlay .nav__drop-foot{ display:none; }
.nav__overlay .nav__drop-name{ color:#fff; font-size:19px; font-weight:600; letter-spacing:-.018em; }
.nav__overlay .nav__drop-item:hover .nav__drop-name{ color:var(--accent); }
.nav__overlay .nav__drop-col{ display:contents; }
.nav__overlay .nav__drop-group{ display:block; color:rgba(255,255,255,.4); text-align:center;
  font-size:12px; padding:6px 0 0; }

/* =====================================================================
   CSS ART  ::  on-brand product visuals (no fake browser chrome)
   ===================================================================== */
.fp-art{ background:var(--canvas); border:1px solid var(--hair-strong); border-radius:18px;
  box-shadow:var(--fp-shadow); padding:22px; }
.fp-art--tint{ background:var(--canvas-2); }
.fp-art__cap{ display:flex; align-items:center; gap:9px; font-family:var(--mono); font-size:11px;
  letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); margin-bottom:16px; }
.fp-art__cap svg{ width:14px; height:14px; color:var(--brand); }

/* ---- PIPELINE (kanban) ---- */
.fp-pipe{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.fp-pipe__col{ background:var(--canvas-2); border:1px solid var(--hair); border-radius:12px; padding:10px; min-width:0; }
.fp-pipe__h{ display:flex; align-items:center; justify-content:space-between; margin-bottom:9px; }
.fp-pipe__h b{ font-size:11px; font-weight:700; color:var(--ink-2); letter-spacing:.02em; }
.fp-pipe__n{ font-family:var(--mono); font-size:10px; color:var(--ink-3); background:var(--canvas); border:1px solid var(--hair);
  border-radius:100px; padding:1px 7px; }
.fp-deal{ background:var(--canvas); border:1px solid var(--hair-strong); border-radius:9px; padding:9px 10px; margin-bottom:7px;
  box-shadow:0 1px 2px rgba(7,10,20,.03); }
.fp-deal:last-child{ margin-bottom:0; }
.fp-deal__top{ display:flex; align-items:center; gap:7px; margin-bottom:6px; }
.fp-deal__av{ width:18px; height:18px; border-radius:100px; background:var(--brand-soft); color:var(--brand-deep);
  display:grid; place-items:center; font-size:9px; font-weight:700; flex-shrink:0; }
.fp-deal__name{ font-size:11.5px; font-weight:600; color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.fp-deal__val{ font-family:var(--mono); font-size:11px; font-weight:600; color:var(--ok); }
.fp-deal--won{ border-color:rgba(31,190,105,.4); background:linear-gradient(0deg, rgba(31,190,105,.06), rgba(31,190,105,.06)), var(--canvas); }
.fp-pipe__col--hot .fp-pipe__h b{ color:var(--brand-deep); }

/* ---- BOOKING (HeatCalendly) ---- */
.fp-book{ max-width:380px; margin-inline:auto; background:var(--canvas); border:1px solid var(--hair-strong);
  border-radius:16px; box-shadow:var(--fp-shadow-sm); padding:22px; }
.fp-book__head{ display:flex; align-items:center; gap:13px; margin-bottom:18px; }
.fp-book__icon{ width:42px; height:42px; border-radius:11px; background:var(--brand-soft); color:var(--brand);
  display:grid; place-items:center; flex-shrink:0; }
.fp-book__icon svg{ width:21px; height:21px; }
.fp-book__title{ font-size:16px; font-weight:700; color:var(--ink); }
.fp-book__meta{ font-size:13px; color:var(--ink-2); margin-top:1px; }
.fp-book__label{ font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  color:var(--ink-3); margin-bottom:10px; }
.fp-book__slots{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; margin-bottom:18px; }
.fp-book__slot{ text-align:center; padding:10px 0; border:1px solid var(--hair-strong); border-radius:9px;
  font-size:13.5px; font-weight:600; color:var(--ink-2); background:var(--canvas); }
.fp-book__slot--on{ background:var(--brand); color:#fff; border-color:var(--brand); box-shadow:0 6px 16px -8px var(--brand-shadow); }
.fp-book__foot{ display:flex; align-items:center; gap:8px; padding-top:15px; border-top:1px solid var(--hair);
  font-size:13px; color:var(--ink-2); }
.fp-book__foot svg{ width:16px; height:16px; color:var(--brand); flex-shrink:0; }
.fp-book__foot strong{ color:var(--ink); font-weight:600; }

/* ---- FORM (HeatYform) ---- */
.fp-form{ max-width:420px; margin-inline:auto; background:var(--canvas); border:1px solid var(--hair-strong);
  border-radius:16px; box-shadow:var(--fp-shadow-sm); padding:24px; }
.fp-form__step{ font-family:var(--mono); font-size:11px; color:var(--ink-3); margin-bottom:14px; }
.fp-form__q{ font-size:18px; font-weight:700; color:var(--ink); letter-spacing:-.01em; margin:0 0 16px; line-height:1.3; }
.fp-form__opt{ display:flex; align-items:center; gap:11px; padding:13px 15px; border:1px solid var(--hair-strong);
  border-radius:11px; margin-bottom:10px; font-size:14.5px; color:var(--ink); background:var(--canvas); }
.fp-form__opt--on{ border-color:var(--brand); background:var(--brand-tint); box-shadow:0 0 0 1px var(--brand) inset; }
.fp-form__key{ width:24px; height:24px; border-radius:6px; background:var(--canvas-3); color:var(--ink-2);
  display:grid; place-items:center; font-family:var(--mono); font-size:11px; font-weight:600; flex-shrink:0; }
.fp-form__opt--on .fp-form__key{ background:var(--brand); color:#fff; }
.fp-form__bar{ height:5px; border-radius:100px; background:var(--canvas-3); margin-top:6px; overflow:hidden; }
.fp-form__bar i{ display:block; height:100%; width:66%; background:var(--brand); border-radius:100px; }

/* ---- AUTOMATION FLOW ---- */
.fp-flow{ display:flex; flex-direction:column; gap:0; max-width:340px; margin-inline:auto; }
.fp-node{ display:flex; align-items:center; gap:12px; background:var(--canvas); border:1px solid var(--hair-strong);
  border-radius:12px; padding:13px 15px; box-shadow:0 1px 2px rgba(7,10,20,.03); position:relative; z-index:1; }
.fp-node__ico{ width:34px; height:34px; border-radius:9px; display:grid; place-items:center; flex-shrink:0; }
.fp-node__ico svg{ width:17px; height:17px; }
.fp-node__t{ display:block; font-size:13.5px; font-weight:600; color:var(--ink); line-height:1.25; }
.fp-node__s{ display:block; font-size:12px; color:var(--ink-3); margin-top:2px; }
.fp-node--trigger{ border-color:rgba(55,103,218,.35); background:linear-gradient(0deg,var(--brand-tint),var(--brand-tint)),var(--canvas); }
.fp-node--trigger .fp-node__ico{ background:var(--brand); color:#fff; }
.fp-node--step .fp-node__ico{ background:var(--brand-soft); color:var(--brand); }
.fp-node--goal{ border-color:rgba(31,190,105,.4); }
.fp-node--goal .fp-node__ico{ background:rgba(31,190,105,.12); color:var(--ok); }
.fp-flow__link{ width:2px; height:20px; background:var(--hair-stronger); margin-inline:auto; }

/* ---- TRIGGER / ACTION CHIPS ---- */
.fp-chips{ display:flex; flex-wrap:wrap; gap:8px; }
.fp-chip{ display:inline-flex; align-items:center; gap:7px; padding:8px 13px; border-radius:100px;
  background:var(--canvas); border:1px solid var(--hair-strong); font-size:13px; font-weight:500; color:var(--ink); }
.fp-chip svg{ width:14px; height:14px; color:var(--brand); }
.fp-chip--accent{ background:var(--accent-soft); border-color:var(--accent-deep); }
.fp-chip--accent svg{ color:var(--accent-deep); }

/* ---- AI DRAFT CARD ---- */
.fp-ai__prompt{ display:flex; gap:10px; align-items:flex-start; padding:13px 15px; border:1px solid var(--brand);
  border-radius:12px; background:var(--brand-tint); font-size:14px; line-height:1.4; color:var(--ink); margin-bottom:16px; }
.fp-ai__prompt svg{ width:17px; height:17px; color:var(--brand); flex-shrink:0; margin-top:1px; }
.fp-ai__out{ display:grid; gap:8px; }
.fp-ai__line{ display:flex; gap:11px; align-items:center; padding:12px 14px; border:1px solid var(--hair-strong);
  border-radius:11px; background:var(--canvas); font-size:13.5px; color:var(--ink); box-shadow:0 1px 2px rgba(7,10,20,.03); }
.fp-ai__line svg{ width:16px; height:16px; color:var(--brand); flex-shrink:0; }
.fp-ai__line b{ font-weight:600; }
.fp-ai__line span{ margin-left:auto; color:var(--ink-3); font-family:var(--mono); font-size:11px; white-space:nowrap; }
.fp-ai__foot{ display:flex; align-items:center; justify-content:space-between; margin-top:16px; }
.fp-ai__foot em{ font-style:normal; font-family:var(--mono); font-size:11.5px; color:var(--ink-3); }
.fp-ai__use{ font-size:13px; font-weight:600; color:#fff; background:var(--brand); padding:8px 15px; border-radius:9px;
  box-shadow:0 6px 16px -8px var(--brand-shadow); }

/* ---- SCORE / CDP CARD ---- */
.fp-score{ max-width:380px; margin-inline:auto; background:var(--canvas); border:1px solid var(--hair-strong);
  border-radius:16px; box-shadow:var(--fp-shadow-sm); padding:22px; }
.fp-score__head{ display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.fp-score__av{ width:44px; height:44px; border-radius:100px; background:var(--brand-soft); color:var(--brand-deep);
  display:grid; place-items:center; font-size:15px; font-weight:700; flex-shrink:0; }
.fp-score__name{ font-size:15.5px; font-weight:700; color:var(--ink); }
.fp-score__mail{ font-size:12.5px; color:var(--ink-3); margin-top:1px; }
.fp-score__tags{ display:flex; flex-wrap:wrap; gap:6px; margin-left:auto; }
.fp-tag{ font-family:var(--mono); font-size:10.5px; font-weight:600; padding:3px 9px; border-radius:100px;
  background:var(--canvas-3); color:var(--ink-2); }
.fp-tag--hot{ background:#FFE9E3; color:#C0432A; }
.fp-score__metric{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:9px; }
.fp-score__metric b{ font-family:var(--mono); font-size:28px; font-weight:700; color:var(--ink); letter-spacing:-.02em; }
.fp-score__metric span{ font-size:12.5px; color:var(--ink-2); }
.fp-score__bar{ height:8px; border-radius:100px; background:var(--canvas-3); overflow:hidden; margin-bottom:18px; }
.fp-score__bar i{ display:block; height:100%; width:84%; border-radius:100px;
  background:linear-gradient(90deg, var(--brand), var(--brand-2)); }
.fp-score__row{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.fp-score__cell{ text-align:center; background:var(--canvas-2); border:1px solid var(--hair); border-radius:10px; padding:9px 4px; }
.fp-score__cell b{ display:block; font-family:var(--mono); font-size:15px; font-weight:700; color:var(--ink); }
.fp-score__cell span{ font-size:10px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.fp-score__cell--on b{ color:var(--ok); }

/* ---- IN-ROOM OFFER ---- */
.fp-offer{ max-width:360px; margin-inline:auto; background:var(--canvas); border:1px solid var(--hair-strong);
  border-radius:16px; box-shadow:var(--fp-shadow); overflow:hidden; }
.fp-offer__bar{ display:flex; align-items:center; justify-content:space-between; padding:9px 15px;
  background:var(--ink); color:#fff; font-family:var(--mono); font-size:11.5px; letter-spacing:.04em; }
.fp-offer__bar b{ color:var(--accent); }
.fp-offer__body{ padding:20px; }
.fp-offer__name{ font-size:17px; font-weight:700; color:var(--ink); margin:0 0 4px; }
.fp-offer__price{ display:flex; align-items:baseline; gap:9px; margin:10px 0 16px; }
.fp-offer__price b{ font-size:26px; font-weight:800; color:var(--ink); letter-spacing:-.02em; }
.fp-offer__price s{ font-size:15px; color:var(--ink-3); }
.fp-offer__price em{ font-style:normal; font-family:var(--mono); font-size:11px; font-weight:600; color:var(--ok);
  background:rgba(31,190,105,.1); padding:2px 8px; border-radius:100px; }
.fp-offer__btn{ display:flex; align-items:center; justify-content:center; gap:8px; width:100%; padding:13px;
  border-radius:11px; background:var(--brand); color:#fff; font-size:14.5px; font-weight:700;
  box-shadow:0 8px 22px -8px var(--brand-shadow); }
.fp-offer__btn svg{ width:16px; height:16px; }
.fp-offer__fine{ text-align:center; font-size:11.5px; color:var(--ink-3); margin-top:10px; }

/* ---- LIVE ROOM CHAT (offer shows up in chat + AI assistant) ---- */
.fp-roomchat{ max-width:404px; margin-inline:auto; background:var(--canvas); border:1px solid var(--hair-strong);
  border-radius:16px; box-shadow:var(--fp-shadow); overflow:hidden; }
.fp-roomchat__head{ display:flex; align-items:center; justify-content:space-between; padding:12px 16px; border-bottom:1px solid var(--hair); }
.fp-roomchat__head b{ font-size:13px; font-weight:700; color:var(--ink); display:inline-flex; align-items:center; gap:8px; }
.fp-roomchat__live{ width:7px; height:7px; border-radius:100px; background:#FF5A4D; box-shadow:0 0 0 3px rgba(255,90,77,.16); }
.fp-roomchat__count{ font-family:var(--mono); font-size:11px; color:var(--ink-3); }
.fp-roomchat__body{ padding:15px 16px; display:flex; flex-direction:column; gap:13px; background:var(--canvas-2); }
.fp-msg{ display:flex; gap:9px; align-items:flex-start; }
.fp-msg__av{ width:26px; height:26px; border-radius:100px; flex-shrink:0; display:grid; place-items:center;
  font-size:10px; font-weight:700; color:#fff; }
.fp-msg__av svg{ width:14px; height:14px; }
.fp-msg__av--a{ background:#3767DA; } .fp-msg__av--b{ background:#1FBE69; }
.fp-msg__av--c{ background:#8B5CF6; } .fp-msg__av--d{ background:#E0992A; }
.fp-msg__av--ai{ background:var(--ink); color:var(--accent); }
.fp-msg__t{ font-size:13px; line-height:1.42; }
.fp-msg__t b{ font-weight:600; color:var(--ink); margin-right:6px; font-size:12px; }
.fp-msg__t span{ color:var(--ink-2); }
.fp-msg--ai .fp-msg__t b{ color:var(--brand-deep); }
.fp-msg--ai .fp-msg__t b::after{ content:"AI"; margin-left:6px; font-size:9px; font-weight:700; letter-spacing:.04em;
  background:var(--brand-soft); color:var(--brand-deep); padding:1px 5px; border-radius:100px; vertical-align:middle; }
/* the offer pinned inside the chat stream */
.fp-pinned{ border:1px solid var(--brand); border-radius:12px; overflow:hidden; background:var(--canvas);
  box-shadow:0 10px 24px -14px var(--brand-shadow); }
.fp-pinned__tag{ display:flex; align-items:center; gap:7px; padding:7px 12px; background:var(--ink); color:#fff;
  font-family:var(--mono); font-size:10.5px; letter-spacing:.03em; }
.fp-pinned__tag svg{ width:12px; height:12px; color:var(--accent); }
.fp-pinned__tag em{ font-style:normal; margin-left:auto; color:var(--accent); }
.fp-pinned__row{ display:flex; align-items:center; gap:12px; padding:13px 14px; }
.fp-pinned__name{ font-size:14px; font-weight:700; color:var(--ink); line-height:1.2; }
.fp-pinned__price{ margin-top:3px; }
.fp-pinned__price b{ font-size:17px; font-weight:800; color:var(--ink); }
.fp-pinned__price s{ font-size:12.5px; color:var(--ink-3); margin-left:6px; }
.fp-pinned__btn{ margin-left:auto; flex-shrink:0; background:var(--brand); color:#fff; font-size:13px; font-weight:700;
  padding:9px 16px; border-radius:9px; box-shadow:0 6px 16px -8px var(--brand-shadow); }

/* ---- STAT STRIP (analytics) ---- */
.fp-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.fp-stat{ background:var(--canvas); border:1px solid var(--hair-strong); border-radius:14px; padding:20px; }
.fp-stat__lbl{ font-family:var(--mono); font-size:11px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); }
.fp-stat__val{ font-size:30px; font-weight:800; color:var(--ink); letter-spacing:-.025em; margin:8px 0 3px; }
.fp-stat__delta{ font-size:12.5px; font-weight:600; color:var(--ok); display:inline-flex; align-items:center; gap:4px; }
.fp-stat__delta svg{ width:13px; height:13px; }

/* ---- MEDIA LIBRARY GRID ---- */
.fp-medgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; }
.fp-medtile{ position:relative; aspect-ratio:4/3; border-radius:11px; border:1px solid var(--hair-strong);
  background:var(--canvas-2); display:grid; place-items:center; color:var(--ink-3); overflow:hidden; }
.fp-medtile svg{ width:22px; height:22px; }
.fp-medtile--v{ background:linear-gradient(135deg, #1b2236, #0f1424); color:rgba(255,255,255,.85); border-color:transparent; }
.fp-medtile--i{ background:linear-gradient(135deg, var(--brand-soft), #DCE6FB); color:var(--brand-deep); }
.fp-medtile__tag{ position:absolute; bottom:6px; left:7px; font-family:var(--mono); font-size:9px; letter-spacing:.04em;
  background:rgba(7,10,20,.55); color:#fff; padding:2px 6px; border-radius:5px; }
.fp-medtile--i .fp-medtile__tag, .fp-medtile--p .fp-medtile__tag{ background:rgba(7,10,20,.12); color:var(--ink-2); }

/* ---- AI CREATOR BRIEF ---- */
.fp-brief__f{ display:flex; gap:10px; padding:11px 13px; border:1px solid var(--hair-strong); border-radius:10px;
  margin-bottom:8px; font-size:13.5px; color:var(--ink); line-height:1.4; }
.fp-brief__f b{ font-family:var(--mono); font-size:10px; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  color:var(--ink-3); flex:0 0 62px; padding-top:2px; }
.fp-brief__gen{ display:flex; align-items:center; justify-content:center; gap:8px; margin-top:13px; padding:12px;
  border-radius:10px; background:var(--brand); color:#fff; font-weight:700; font-size:14px;
  box-shadow:0 8px 22px -8px var(--brand-shadow); }
.fp-brief__gen svg{ width:16px; height:16px; }

/* ---- FUNNEL ---- */
.fp-funnel{ display:flex; flex-direction:column; gap:10px; }
.fp-funnel__row{ display:grid; grid-template-columns:96px 1fr auto; align-items:center; gap:12px; }
.fp-funnel__lbl{ font-size:13px; font-weight:600; color:var(--ink-2); }
.fp-funnel__track{ height:30px; border-radius:8px; background:var(--canvas-3); overflow:hidden; }
.fp-funnel__fill{ height:100%; border-radius:8px; background:linear-gradient(90deg,var(--brand),var(--brand-2)); }
.fp-funnel__val{ font-family:var(--mono); font-size:13px; font-weight:600; color:var(--ink); }

/* =====================================================================
   COMPARE (/vs/) PAGES
   ===================================================================== */
.vs-cards{ display:grid; grid-template-columns:1fr 1fr; gap:20px; margin-top:clamp(36px,5vw,52px); }
.vs-card{ background:var(--canvas); border:1px solid var(--hair-strong); border-radius:18px; padding:26px 26px 28px; }
.vs-card--us{ border-color:var(--brand); box-shadow:0 0 0 1px var(--brand) inset, 0 24px 60px -34px var(--brand-shadow); }
.vs-card__name{ display:inline-flex; align-items:center; gap:8px; font-size:18px; font-weight:800; letter-spacing:-.02em; color:var(--ink); }
.vs-card__name svg{ width:18px; height:18px; color:var(--brand); }
.vs-card--us .vs-card__name{ color:var(--brand-deep); }
.vs-card__title{ font-size:14px; font-weight:600; color:var(--ink-2); margin:10px 0 6px; }
.vs-card__sub{ font-size:14px; line-height:1.55; color:var(--ink-2); margin:0 0 16px; }
.vs-card__price{ font-family:var(--mono); font-size:20px; font-weight:700; color:var(--ink); }
.vs-card__price small{ font-family:var(--font, inherit); font-size:12.5px; font-weight:500; color:var(--ink-3); }

/* the matrix */
.vs-table-wrap{ margin-top:clamp(40px,5vw,56px); border:1px solid var(--hair-strong); border-radius:18px; overflow:hidden; }
.vs-table{ width:100%; border-collapse:collapse; font-size:14.5px; }
.vs-table thead th{ background:var(--canvas-2); text-align:left; font-size:13px; font-weight:700; color:var(--ink);
  padding:15px 18px; border-bottom:1px solid var(--hair-strong); }
.vs-table thead th.vs-col{ text-align:center; width:130px; }
.vs-table thead th.vs-col--us{ color:var(--brand-deep); }
.vs-table tbody td{ padding:13px 18px; border-bottom:1px solid var(--hair); color:var(--ink); vertical-align:middle; }
.vs-table tbody tr:last-child td{ border-bottom:none; }
.vs-table td.vs-feat{ font-weight:500; color:var(--ink); }
.vs-table td.vs-cell{ text-align:center; }
.vs-table td.vs-cell--us{ background:var(--brand-tint); }
.vs-table tbody tr.vs-group td{ background:var(--ink); color:#fff; font-family:var(--mono); font-size:11.5px; font-weight:600;
  letter-spacing:.08em; text-transform:uppercase; padding:11px 18px; }
.vs-table tbody tr.vs-group td .vs-group__hint{ color:var(--accent); text-transform:none; letter-spacing:0; font-weight:500; margin-left:10px; }
.vs-yes{ display:inline-grid; place-items:center; width:24px; height:24px; border-radius:100px;
  background:rgba(31,190,105,.12); color:var(--ok); }
.vs-yes svg{ width:14px; height:14px; }
.vs-no{ display:inline-grid; place-items:center; width:24px; height:24px; border-radius:100px;
  background:var(--canvas-3); color:var(--ink-3); }
.vs-no svg{ width:13px; height:13px; }
.vs-partial{ font-family:var(--mono); font-size:11px; font-weight:600; color:var(--accent-deep);
  background:var(--accent-soft); padding:3px 9px; border-radius:100px; }
.vs-val{ font-size:13.5px; color:var(--ink-2); }
.vs-val--us{ font-weight:700; color:var(--ink); }
.vs-note{ margin-top:16px; font-size:13px; color:var(--ink-3); text-align:center; }
.vs-note a{ color:var(--ink-2); }

@media (max-width:760px){
  .vs-cards{ grid-template-columns:1fr; }
  .vs-table{ font-size:13px; }
  .vs-table thead th, .vs-table tbody td{ padding:11px 10px; }
  .vs-table thead th.vs-col{ width:64px; }
  .vs-table td.vs-feat{ font-size:12.5px; }
}

/* =====================================================================
   REVEAL
   ===================================================================== */
.fp-reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease-out), transform .7s var(--ease-out); }
.fp-reveal.is-in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){ .fp-reveal{ opacity:1; transform:none; transition:none; } }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 920px){
  .fp-hero__grid{ grid-template-columns:1fr; gap:40px; }
  .fp-hero h1{ max-width:20ch; }
  .fp-row{ grid-template-columns:1fr; gap:30px; }
  .fp-row--flip .fp-row__media{ order:0; }
  .fp-grid, .fp-related .fp-grid{ grid-template-columns:1fr 1fr; }
  .fp-stats{ grid-template-columns:1fr; }
  .fp-pipe{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 560px){
  .fp-grid, .fp-related .fp-grid{ grid-template-columns:1fr; }
  .fp-pipe{ grid-template-columns:1fr 1fr; }
  .fp-funnel__row{ grid-template-columns:72px 1fr auto; }
  .nav__drop{ grid-template-columns:1fr; }
}
