/* ==========================================================================
   Baseview • Global Site Styles
   File: /assets/css/site.css
   Applies to: all pages EXCEPT the report output page
   ========================================================================== */

/* -------------------------------
   0) CSS Reset + Root Variables
   ------------------------------- */
:root{
  /* Brand palette */
  --brand:        #0b5fff;  /* Primary */
  --brand-600:    #0a53e9;
  --brand-700:    #0949cc;
  --ink:          #0b1020;  /* Body text */
  --ink-soft:     #27324a;  /* Headlines on light panels */
  --muted-ink:    #5a6882;  /* Secondary text */
  --bg:           #ffffff;  /* Page bg */
  --panel:        #f7f9fc;  /* Subtle panel/hero bg */
  --line:         #e7ebf3;  /* Dividers */

  /* Accents & states */
  --ok:#12b886; --warn:#f59f00; --err:#e03131; --info:#228be6;
  
  /* alt 12A6A6 */

  /* Layout scales */
  --radius-xs: 8px;
  --radius:    12px;
  --radius-lg: 18px;
  --shadow:    0 6px 20px rgba(8,15,40,.06);

  /* Typography */
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  /* Type sizes */
  --fs-hero: clamp(28px, 5vw, 44px);
  --fs-h1: clamp(24px, 3.2vw, 32px);
  --fs-h2: clamp(20px, 2.6vw, 24px);
  --fs-h3: clamp(18px, 2.2vw, 20px);
  --fs-body: 16px;
  --fs-small: 14px;

  /* Spacing scale (t-shirt sizing) */
  --s-1: 4px;
  --s-2: 8px;
  --s-3: 12px;
  --s-4: 16px;
  --s-5: 20px;
  --s-6: 24px;
  --s-7: 32px;
  --s-8: 40px;
  --s-9: 48px;
  --s-10: 64px;

  /* Container widths */
  --max: 1100px;
  --max-narrow: 840px;
  --max-wide: 1280px;
}

*{box-sizing: border-box;}
html,body{margin:0;padding:0;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:var(--brand);}
a:hover{color:var(--brand-700);}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--bg);
  font-size:var(--fs-body);
  line-height:1.6;
}
:focus-visible{outline:3px solid rgba(11,95,255,.35); outline-offset:2px;}
@media (prefers-reduced-motion: reduce){
  *{animation:none!important;transition:none!important}
}

/* -------------------------------
   1) Global Layout Helpers
   ------------------------------- */
.container{ width:100%; max-width:var(--max); margin:0 auto; padding:0 var(--s-5); }
.container-wide{ width:100%; max-width:var(--max-wide); margin:0 auto; padding:0 var(--s-5); }

.section{ padding:var(--s-9) 0; }
.section.alt{
  background:var(--panel);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}

.grid{ display:grid; grid-template-columns:repeat(12, 1fr); gap:var(--s-4); }
.grid.col-2 > *{ grid-column: span 12; }
.grid.col-3 > *{ grid-column: span 12; }
.grid.col-4 > *{ grid-column: span 12; }
@media (min-width:720px){
  .grid.col-2 > *{ grid-column: span 6; }
  .grid.col-3 > *{ grid-column: span 4; }
  .grid.col-4 > *{ grid-column: span 3; }
}

.split{ display:grid; grid-template-columns:1fr; gap:var(--s-6); }
@media (min-width:920px){ .split{ grid-template-columns:1.1fr .9fr; } }

.stack > * + *{ margin-top:var(--s-5); }

.mt-0{margin-top:0!important}
.mt-8{margin-top:8px!important}
.mt-16{margin-top:16px!important}
.mt-24{margin-top:24px!important}
.mt-32{margin-top:32px!important}
.p-16{padding:16px!important}
.p-24{padding:24px!important}

.only-site{display:block}

.sr-only{
  position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;
}

/* -------------------------------
   2) Header + Nav + Footer
   ------------------------------- */
/* Header */
.site-header{
  position:sticky; top:0; z-index:40;
  background:#fff; border-bottom:1px solid var(--line);
}
.site-header .bar{
  display:flex; align-items:center; justify-content:space-between;
  height:64px;
}

/* Brand */
.brand{ display:flex; align-items:center; gap:12px; font-weight:700; color:var(--ink); }
.brand-mark{ /*width:28px;*/ width:auto; height:42px; display:block; }
.brand-text{ display:inline-block; }

/* Primary nav */
.nav{ display:flex; align-items:center; gap:8px; }
.nav a{
  display:inline-block; padding:10px 12px; color:var(--muted-ink); border-radius:8px;
  text-decoration:none; font-weight:600;
}
.nav a:hover{ color:var(--ink); background:#f3f7ff; }
.nav a.is-active{
  color:var(--ink); background:transparent; /* no pill fill */
  text-decoration:underline; font-weight:700;
}

/* CTA button in header */
.get-started{ margin-left:8px; }

/* Hamburger (image version) */
.hamburger-btn{
  margin-left:8px;
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border:1px solid var(--line); border-radius:10px; background:#fff;
}
.hamburger-btn img{ width:36px; height:36px; display:block; }
.hamburger-btn:hover img{ width:37px; height:37px; cursor: pointer; }

/* Responsive: hide inline nav on small screens (drawer will handle it) */
@media (max-width:900px){
  .nav{ display:none; }
  .get-started{ display:none; }
}
@media (min-width:901px){
  .hamburger-btn{ display:inline-flex; }
}

.menu-toggle{
  display:inline-flex; align-items:center; justify-content:center;
  width:42px; height:42px; border:1px solid var(--line); border-radius:10px; background:#fff;
}
.menu-toggle span{ width:18px; height:2px; background:var(--ink); position:relative; }
.menu-toggle span::before, .menu-toggle span::after{
  content:""; position:absolute; left:0; width:18px; height:2px; background:var(--ink);
}
.menu-toggle span::before{ top:-6px; } .menu-toggle span::after{ top:6px; }

@media (max-width:860px){
  .nav{ display:none; position:absolute; top:64px; right:0; left:0; background:#fff; border-bottom:1px solid var(--line); padding:var(--s-4) var(--s-5); }
  .nav.open{ display:block; }
}
@media (min-width:861px){ .menu-toggle{ display:none; } }

.site-footer{
  border-top:1px solid var(--line); color:var(--muted-ink); padding:20px 0; background:#fff;
}
.site-footer .links a{ color:var(--muted-ink); margin-right:12px; }
.site-footer .links a:hover{ color:var(--ink); }

/* -------------------------------
   3) Hero / Landing
   ------------------------------- */
.hero{
  padding:var(--s-10) 0 var(--s-10);
  background:linear-gradient(180deg, var(--panel), #fff 70%);
  border-bottom:1px solid var(--line);
  text-align:center;
}
.hero h1{ font-size:var(--fs-hero); line-height:1.15; margin:0 0 var(--s-3); color:var(--ink-soft); }
.hero p{ max-width:var(--max-narrow); margin:0 auto; color:var(--muted-ink); font-size:18px; }
.hero .kickers{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:var(--s-4); }
.kicker{ font-size:12px; padding:6px 10px; border:1px solid var(--line); border-radius:999px; color:var(--muted-ink); background:#fff; }

/* CTA row */
.cta{ display:flex; gap:12px; flex-wrap:wrap; justify-content:center; margin-top:var(--s-5); }

/* -------------------------------
   4) Cards, Panels, Buttons
   ------------------------------- */
.card{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:18px; box-shadow:var(--shadow);
}
.card h3{ margin:0 0 8px; font-size:var(--fs-h2); color:var(--ink); }
.card .meta{ color:var(--muted-ink); font-size:var(--fs-small); }

.panel{
  background:#fff; border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:var(--s-7); box-shadow:var(--shadow);
}

.btn{
  display:inline-block; padding:12px 16px; border-radius:10px;
  border:1px solid var(--line); background:#fff; color:var(--ink);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  font-weight:600;
}
.btn:hover{ transform:translateY(-1px); box-shadow:var(--shadow); }
.btn.primary{ background:var(--brand); border-color:var(--brand); color:#fff; }
.btn.primary:hover{ background:var(--brand-600); color:#fff;}
.btn.ghost{ background:transparent; }
.btn.block{ display:block; width:100%; text-align:center; }

.btn.mini{
  padding:6px 10px;
  font-size:12px;
  border-radius:8px;
  line-height:1.2;
}

/* Badges */
.badge{
  display:inline-block; padding:4px 8px; border-radius:999px;
  font-size:12px; border:1px solid var(--line); color:var(--muted-ink);
}
.badge.ok{ background:#eafaf3; border-color:#c7f0e2; color:#0f7a5f; }
.badge.warn{ background:#fff7e3; border-color:#fde0a2; color:#8c5a00; }
.badge.err{ background:#ffebeb; border-color:#f4b4b4; color:#8f1f1f; }

/* -------------------------------
   5) Forms
   ------------------------------- */
.form{ max-width:720px; margin:0 auto; }
.form .row{ display:grid; grid-template-columns:1fr; gap:12px; }
@media (min-width:680px){ .form .row.two > *{ grid-column:span 1; } }
label{ display:block; font-weight:600; margin:8px 0 6px; }
input[type="text"], input[type="email"], input[type="url"], input[type="number"], textarea, select{
  width:100%; padding:12px 12px; border:1px solid var(--line);
  border-radius:10px; background:#fff; outline:none;
}
textarea{ min-height:120px; resize:vertical; }
input:focus, textarea:focus, select:focus{ border-color:#c9d4ee; box-shadow:0 0 0 3px rgba(11,95,255,.08); }

.step{
  border:1px dashed var(--line); border-radius:12px; padding:14px;
  background:#fff; margin:12px 0;
}

/* -------------------------------
   6) Tables
   ------------------------------- */
.table{ width:100%; border-collapse:collapse; border:1px solid var(--line); }
.table th, .table td{
  border-top:1px solid var(--line);
  padding:10px 12px; text-align:left; vertical-align:top; font-size:14px;
}
.table th{ background:#f7f9fc; }

/* -------------------------------
   7) Alerts / Notes / Code
   ------------------------------- */
.alert{
  border:1px solid var(--line); background:#fff; border-left:4px solid var(--info);
  padding:12px 14px; border-radius:8px; color:#0e3560;
}
.alert.ok{ border-left-color:var(--ok); }
.alert.warn{ border-left-color:var(--warn); }
.alert.err{ border-left-color:var(--err); }

pre, code, .mono{ font-family:var(--mono); }
pre{
  background:#0b1020; color:#e9edf7; padding:12px; border-radius:10px; overflow:auto;
}

/* -------------------------------
   8) Page structure helper
   ------------------------------- */
.page{ min-height:100vh; display:flex; flex-direction:column; }
.page > .main{ flex:1; }


/* Admin UI helpers */
.btn.mini{padding:6px 10px;font-size:12px;border-radius:8px;line-height:1.2;}
.status-chip{
  display:inline-block;padding:4px 10px;border-radius:999px;
  font-size:12px;font-weight:600;user-select:none;border:1px solid var(--line);
}
.status-chip.draft{background:#eef2ff;color:#364fc7;border-color:#dbe4ff;}
.status-chip.manager_edit{background:#fff7e3;color:#8c5a00;border-color:#fde0a2;}
.status-chip.complete{background:#eafaf3;color:#0f7a5f;border-color:#c7f0e2;}
.status-chip.paid{background:#f0f9ff;color:#0b5fff;border-color:#cfe3ff;}

.account-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:20px;
}
.review-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:16px;box-shadow:var(--shadow);display:flex;flex-direction:column;}
.review-card h3{margin:0 0 4px;font-size:18px;}
.review-card .meta{font-size:14px;color:var(--muted-ink);margin-bottom:12px;}
.review-card .actions{margin-top:auto;display:flex;gap:8px;flex-wrap:wrap;}

/* ===============================
   MANAGER EDITOR LAYOUT (updated)
   =============================== */

.manager-editor {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 16px;
  min-height: 60vh;
}

/* Sidebar list */
.section-list {
  border-right: 1px solid var(--line);
  overflow-y: auto;
  padding: 12px;
  background: var(--panel);
}

/* Main editor column */
.editor-pane {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Toolbar */
.editor-pane .toolbar {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

/* Markdown + Preview split */
.editor-pane .editor-split {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  align-items: flex-start;
  /* Removed fixed height so page scrolls naturally */
}

/* Markdown textarea */
.editor-pane textarea {
  width: 100%;
  min-height: 280px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 12px;
  font-family: var(--mono);
  resize: vertical;
  background: #fff;
  line-height: 1.5;
  overflow: hidden;           /* no internal scroll */
}

/* Preview panel (auto-height iframe) */
.editor-pane .preview {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fff;
  overflow: visible !important; /* allow iframe to size itself */
}

.preview iframe,
iframe.preview {
  display: block;
  width: 100%;
  border: none;
  border-radius: var(--radius);
  background: #fff;
  overflow: hidden;           /* hide internal scrollbars */
  min-height: 300px;
}

/* Responsive: single-column on narrow screens */
@media (max-width: 900px) {
  .manager-editor { grid-template-columns: 1fr; }
  .editor-pane .editor-split { grid-template-columns: 1fr; }
}

/* Drawer (right-side slide in) */
.no-scroll{ overflow:hidden; }

.drawer{
  position:fixed; top:0; right:0; height:100vh; width:0;
  background:var(--brand); color:#fff; overflow:hidden;
  transition: width .25s ease; z-index:50;
  box-shadow: -8px 0 24px rgba(0,0,0,.12);
}
.drawer.open{ width:min(86vw, 380px); }

.drawer-inner{ display:flex; flex-direction:column; height:100%; }
.drawer-head{
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 16px 12px 16px; border-bottom:1px solid rgba(255,255,255,.15);
}
.drawer-logo{ height:24px; }

.drawer-close{
  background:transparent; border:1px solid rgba(255,255,255,.35);
  color:#fff; width:36px; height:36px; border-radius:8px; font-size:22px; line-height:1;
  cursor:pointer;
}

.drawer-nav{
  display:flex; flex-direction:column; gap:6px;
  padding:16px;
}
.drawer-nav a{
  color:#fff; text-decoration:none; padding:10px 12px; border-radius:8px;
}
.drawer-nav a:hover{
  background:rgba(255,255,255,.12);
}

.drawer-cta{ margin-top:auto; padding:16px; }
.drawer-cta .btn{
  background:#fff; color:var(--ink); border-color:#fff;
}
.drawer-cta .btn:hover{
  background:#f5f7ff;
}

/* Backdrop */
.drawer-backdrop{
  position:fixed; inset:0; background:rgba(0,0,0,.35);
  opacity:0; visibility:hidden; transition:opacity .2s ease, visibility .2s ease;
  z-index:45;
}
.drawer-backdrop.show{
  opacity:1; visibility:visible;
}

/* Footer */
.site-footer{
  border-top:1px solid var(--line); background:#fff; color:var(--muted-ink);
}
.footer-grid{
  display:grid; grid-template-columns:1.4fr repeat(4, 1fr); gap:24px; padding:28px 0;
}
.footer-brand .footer-logo{ height:28px; display:block; margin-bottom:10px; }
.footer-tagline{ margin:0; color:var(--muted-ink); }

.footer-col h4{ margin:0 0 10px; color:var(--ink); font-size:16px; }
.footer-col ul{ margin:0; padding:0; list-style:none; }
.footer-col li + li{ margin-top:8px; }
.footer-col a{ color:var(--muted-ink); text-decoration:none; }
.footer-col a:hover{ color:var(--ink); text-decoration:underline; }

.footer-bottom{ border-top:1px solid var(--line); background:#fff; }
.footer-bottom-inner{
  display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 0;
}
.footer-links{ display:flex; align-items:center; gap:14px; }
.footer-social a{ display:inline-flex; width:22px; height:22px; }
.footer-social img{ width:100%; height:100%; display:block; }

@media (max-width:920px){
  .footer-grid{ grid-template-columns:1fr 1fr; padding: 20px;}
}
@media (max-width:640px){
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom-inner{ flex-direction:column; align-items:flex-start; gap:8px; padding: 12px 20px;}
}

/* ===== Baseview landing enhancements (non-breaking) ===== */
.eyebrow{letter-spacing:.04em;text-transform:uppercase;font-weight:700;font-size:12px;color:var(--muted-ink);margin:0 0 var(--s-2);}
.lead{max-width:var(--max-narrow);margin:0 auto;color:var(--muted-ink);font-size:18px;}
.sublead{color:var(--muted-ink);max-width:var(--max-narrow);margin:0;}

.hero-kickers{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-top:var(--s-4);padding:0;}
.hero-kickers li{list-style:none;font-size:12px;padding:6px 10px;border:1px solid var(--line);border-radius:999px;color:var(--muted-ink);background:#fff;}

.feature{display:flex;flex-direction:column;gap:10px;}
.feature-icon{width:36px;height:36px;opacity:.9}

.step{position:relative;padding-top:18px;}
.step-num{position:absolute;top:12px;right:12px;width:26px;height:26px;border-radius:999px;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-weight:700;color:var(--muted-ink);}

.checks ul{margin:0;padding-left:22px}
.checks li{margin:6px 0; position:relative;}
.checks li::marker{content:"";} /* Hide default marker in some browsers */
.checks li::before{content:"";position:absolute;left:-22px;top:.4em;width:14px;height:14px;border-radius:3px;background:var(--brand);box-shadow:inset 0 0 0 2px #fff;}
@media (max-width:720px){ .checks li::before{top:.45em;} }

.plan{display:flex;flex-direction:column;}
.plan-head .meta{color:var(--muted-ink);}
.plan-list{margin:8px 0 0;padding-left:18px;}
.plan-list li + li{margin-top:6px;}
.table-lite > div{padding:8px 0;border-bottom:1px solid var(--line);}
.table-lite > div:nth-child(-n+4){border-bottom:2px solid var(--line);}

/* === Enhancements for landing + selector (additive, safe) === */
/* ===== Refinements (additive) ===== */

/* Headings contrast — ensure visible */
h1, h2, h3, h4 { color: var(--ink); }

/* Secondary + ghost buttons */
.btn.secondary{
  background:#fff;
  border-color: var(--brand);
  color: var(--brand);
}
.btn.secondary:hover{ background:#f5f9ff; }

.btn.ghost{
  background:transparent;
  border-color: var(--line);
  color: var(--ink);
}
.btn.ghost:hover{ background:#f7f9fc; }

/* Mobile-wide CTAs: near full width on small screens */
.btn-wide-mobile{ }
@media (max-width:720px){
  .cta-stack-mobile .btn{ display:block; width:100%; }
}

/* Plan cards: consistent height & aligned footers */
.plans-grid .plan{ display:flex; flex-direction:column; }
.plan-tall{ min-height: 100%; }
.plan-head{ margin-bottom: 8px; }
.plan-list{ margin: 10px 0 0; padding-left: 18px; }
.plan-footer{
  margin-top:auto;
  display:flex; align-items:center; gap:12px; justify-content:space-between;
}
.price{ font-weight:800; font-size:20px; color: var(--ink); }

/* Hover polish (consistent) */
.plan{
  position:relative;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.plan:hover{ transform: translateY(-3px); box-shadow: 0 10px 28px rgba(8,15,40,.09); border-color:#dfe6f3; }

/* Steps: no overlap; clearer badge */
.step-clean{ position:relative; padding-top: 8px; }
.step-badge{
  position:absolute; top:-12px; left:-12px;
  width: 32px; height: 32px; border-radius: 999px;
  background: var(--brand); color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:800;
  box-shadow: var(--shadow);
  border: 3px solid #fff;
}
.step h3{ margin-top: 12px; }

/* Feature cards: remove icon dependency */
.feature{ min-height: 100%; }

/* Tabs (keep prior styles, just ensure visibility) */
.tabs{ display:flex; gap:8px; border-bottom:1px solid var(--line); }
.tab{
  appearance:none; background:#fff; border:1px solid var(--line); border-bottom:none;
  padding:10px 14px; border-top-left-radius:10px; border-top-right-radius:10px;
  font-weight:600; color:var(--muted-ink); cursor:pointer;
}
.tab.is-active{ background:#f7f9fc; color:var(--ink); }
.tab-panel{ display:none; padding-top:16px; }
.tab-panel.is-active{ display:block; }

/* Card & panel spacing fixes on small screens */
@media (max-width:720px){
  .card{ padding:16px; }
  .panel{ padding:20px; }
}

/* ===== Final pass refinements ===== */

/* Section titles vs card titles */
.section-title{
  font-size: clamp(22px, 2.8vw, 30px);
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-5);
}
.panel-title{
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 800;
  color: var(--ink);
  margin: 0;
}

/* Hero optional visual */
.hero-visual{ max-width: 860px; margin: var(--s-6) auto 0; border-radius: 14px; box-shadow: var(--shadow); }

/* Combined split tweaks */
.aside-note{
  background: #f7f9fc;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 14px;
}

/* Less repetitive benefits row */
.benefits{
  display: grid; grid-template-columns: 1fr; gap: var(--s-4);
}
.benefit h3{ margin: 0 0 6px; }
@media (min-width: 780px){
  .benefits{ grid-template-columns: repeat(3, 1fr); }
}

/* Steps (not cards) */
.steps{
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: 1fr; gap: var(--s-6);
}
.steps li{ display: grid; grid-template-columns: 38px 1fr; align-items: start; gap: 12px; }
.badge-num{
  display:inline-flex; align-items:center; justify-content:center;
  width: 32px; height: 32px; border-radius: 999px;
  background: var(--brand); color:#fff; font-weight:800;
  box-shadow: var(--shadow);
}
.steps-compact{ gap: var(--s-4); }
@media (min-width: 820px){
  .steps{ grid-template-columns: repeat(3, 1fr); }
  .steps li{ grid-template-columns: 38px 1fr; }
}

/* Quotes panel */
.quotes{
  display:grid; gap: var(--s-5);
}
.quotes blockquote{
  margin:0; padding:14px 16px; background:#fff; border:1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.quotes blockquote p{ margin:0 0 6px; }
.quotes blockquote cite{ color: var(--muted-ink); font-style: normal; font-size: 14px; }

/* FAQ details */
.faq details{
  border:1px solid var(--line); border-radius: var(--radius); background:#fff;
  padding: 10px 12px; margin-bottom: 10px;
}
.faq summary{ cursor:pointer; font-weight:700; color: var(--ink); }
.faq p{ margin: 8px 0 0; }

/* CTA band */
.cta-band{
  background: linear-gradient(180deg, #f7f9fc, #fff 70%);
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.centered{ text-align:center; }

/* Secondary + ghost buttons (ensure distinct) */
.btn.secondary{ background:#fff; border-color: var(--brand); color: var(--brand); }
.btn.secondary:hover{ background:#f3f7ff; }
.btn.ghost{ background:transparent; border-color: var(--line); color: var(--ink); }
.btn.ghost:hover{ background:#f7f9fc; }

/* Mobile-wide CTAs */
@media (max-width:720px){
  .cta-stack-mobile .btn{ display:block; width:100%; }
}

/* Plan cards (detail page) — ribbons, aligned titles, spacing) */
.plan{ position:relative; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.plan:hover{ transform: translateY(-3px); box-shadow: 0 10px 28px rgba(8,15,40,.09); border-color:#dfe6f3; }
.plan-tall{ display:flex; flex-direction:column; min-height:100%; }
.plan-title{ margin-top: 0; margin-bottom: 6px; }
.plan-list{ margin: 6px 0 16px; padding-left: 18px; }
.plan-footer{ margin-top:auto; display:flex; align-items:center; justify-content:space-between; gap:12px; }
.price{ font-weight:800; font-size:20px; color: var(--ink); }

/* Ribbons (don’t push headings) */
.ribbon{
  position:absolute; top:10px; right:10px;
  background:#eef2ff; color:#364fc7; border:1px solid #dbe4ff;
  padding:4px 8px; border-radius: 999px; font-size:12px; font-weight:700;
}
.ribbon-ok{ background:#eafaf3; border-color:#c7f0e2; color:#0f7a5f; }
.ribbon-neutral{ background:#f7f9fc; border-color:#e7ebf3; color:#5a6882; }

/* Tabs polish */
.tabs{ display:flex; gap:8px; border-bottom:1px solid var(--line); margin-top: var(--s-4); }
.tab{
  appearance:none; background:#fff; border:1px solid var(--line); border-bottom:none;
  padding:10px 14px; border-top-left-radius:10px; border-top-right-radius:10px;
  font-weight:600; color:var(--muted-ink); cursor:pointer;
}
.tab.is-active{ background:#f7f9fc; color:var(--ink); }
.tab-panel{ display:none; padding-top:16px; }
.tab-panel.is-active{ display:block; }

/* Utility: panel headings */
.panel h2, .panel .panel-title{ margin-bottom: var(--s-4); }

/* Small spacing tune on cards & panels for phones */
@media (max-width:720px){
  .card{ padding:16px; }
  .panel{ padding:20px; }
}
/* === Fixes & polish for world-class pass === */

/* Section & panel titles */
.section-title{
  font-size: clamp(22px, 2.8vw, 30px);
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.01em;
  margin: 0 0 var(--s-5);
}
.panel-title{
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 800;
  color: var(--ink);
  margin: 0 0 var(--s-4);
}
.centered{ text-align:center; }

/* Containers */
.container-narrow{ width:100%; max-width: 760px; margin:0 auto; padding:0 var(--s-5); }
.container-wide{ width:100%; max-width: 1280px; margin:0 auto; padding:0 var(--s-5); }

/* Why split (clean) */
.why-split{
  display:grid; grid-template-columns: 1fr; gap: var(--s-8);
}
.what-get{
  border:1px solid var(--line); background:#fff; border-radius: var(--radius);
  padding: var(--s-6); box-shadow: var(--shadow);
}
@media (min-width: 980px){
  .why-split{ grid-template-columns: 1.1fr .9fr; align-items:start; }
}

/* Card rows with breathing room */
.card-row{
  display:grid; grid-template-columns: 1fr; gap: var(--s-5);
}
@media (min-width: 820px){ .card-row{ grid-template-columns: repeat(3, 1fr); } }

/* Steps as cards */
.steps-cards .step-card{ position:relative; padding-top: 32px; }
.steps-cards {gap: var(--s-8);}
.badge-num{
  position:absolute; top:-16px; left:-16px;
  width: 34px; height: 34px; border-radius: 999px;
  background: var(--brand); color:#fff; font-weight:800;
  display:flex; align-items:center; justify-content:center;
  box-shadow: var(--shadow); border:3px solid #fff;
}

/* FULL-WIDTH CAROUSEL */
.carousel-band{ position:relative; overflow:hidden; border-top:1px solid var(--line); border-bottom:1px solid var(--line); background: linear-gradient(180deg, #f7f9fc, #fff 70%); }
.carousel.fw{ position:relative; width:100vw; margin-left:calc(50% - 50vw); }
.fw-track{ display:flex; width:100%; transition: transform .25s ease; }
.fw-slide{ min-width:100vw; padding:40px 0; display:flex; align-items:center; justify-content:center; }
.fw-slide blockquote{
  margin:0; padding:24px 28px; background:#fff; border:1px solid var(--line);
  border-radius: var(--radius); box-shadow: var(--shadow); text-align:center; max-width:760px;
}
.fw-slide blockquote p{ margin:0 0 8px; font-size: clamp(18px, 2vw, 22px); }
.fw-slide blockquote cite{ color: var(--muted-ink); font-style: normal; font-size:14px; }
.car-btn{
  position:absolute; top:50%; transform:translateY(-50%);
  width:38px; height:38px; border-radius:10px; border:1px solid var(--line);
  background:#fff; cursor:pointer; box-shadow:var(--shadow);
}
.car-prev{ left:16px; } .car-next{ right:16px; }
.car-btn:hover{ background:#f5f7ff; }

/* FAQs (same on both pages) */
.faq-narrow{ max-width: 680px; margin: 0 auto; text-align:left; }
.faq details{
  border:1px solid var(--line); border-radius: var(--radius); background:#fff;
  padding: 10px 12px; margin-bottom: 10px;
}
.faq summary{ cursor:pointer; font-weight:700; color: var(--ink); }
.faq p{ margin: 8px 0 0; }

/* CTA band alignment */
.cta-band{ background: linear-gradient(180deg, #f7f9fc, #fff 70%); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.cta-sublead{ max-width:720px; margin: 0 auto var(--s-5); }

/* Buttons */
.btn.secondary{ background:#fff; border-color: var(--brand); color: var(--brand); }
.btn.secondary:hover{ background:#f3f7ff; }
.btn.ghost{ background:transparent; border-color: var(--line); color: var(--ink); }
.btn.ghost:hover{ background:#f7f9fc; }

/* Mobile-wide CTAs */
@media (max-width:720px){
  .cta-stack-mobile .btn{ display:block; width:100%; }
}

/* Plan cards (detail page) — ribbons, aligned titles, price above bullets */
.plans-grid{ gap: var(--s-5); }
.plan{ position:relative; transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.plan:hover{ transform: translateY(-3px); box-shadow: 0 10px 28px rgba(8,15,40,.09); border-color:#dfe6f3; }
.plan-tall{ display:flex; flex-direction:column; min-height:100%; }
.plan-title{ margin-top: 0; margin-bottom: 6px; }
.price-above{ margin: 10px 0 8px; }
.plan-list{ margin: 0 0 18px; padding-left: 18px; }
.plan-footer{ margin-top:auto; }
.ribbon{
  position:absolute; top:12px; right:12px;
  background:#eef2ff; color:#364fc7; border:1px solid #dbe4ff;
  padding:4px 8px; border-radius: 999px; font-size:12px; font-weight:700;
}
.ribbon-ok{ background:#eafaf3; border-color:#c7f0e2; color:#0f7a5f; }
.ribbon-neutral{ background:#f7f9fc; border-color:#e7ebf3; color:#5a6882; }

/* Tabs polish */
.tabs{ display:flex; gap:8px; border-bottom:1px solid var(--line); margin-top: var(--s-4); }
.tab{
  appearance:none; background:#fff; border:1px solid var(--line); border-bottom:none;
  padding:10px 14px; border-top-left-radius:10px; border-top-right-radius:10px;
  font-weight:600; color:var(--muted-ink); cursor:pointer;
}
.tab.is-active{ background:#f7f9fc; color:var(--ink); }
.tab-panel{ display:none; padding-top:16px; }
.tab-panel.is-active{ display:block; }

/* Small tune for phones */
@media (max-width:720px){
  .card{ padding:16px; }
  .panel{ padding:20px; }
}

#how-it-works.section, #how-it-works.panel {
	background-color: var(--brand);
}
#how-it-works.section h2, #how-it-works.panel h2 {color: #ffffff;}


/* Flash messages */
.flash{
  margin: 16px 0; padding: 12px 14px; border-radius: 10px; font-weight:600;
  border:1px solid var(--line);
}
.flash-ok{ background:#eafaf3; color:#0f7a5f; border-color:#c7f0e2; }
.flash-warn{ background:#fff7e3; color:#8c5a00; border-color:#fde0a2; }
.flash-err{ background:#ffebeb; color:#8f1f1f; border-color:#f4b4b4; }
.flash-info{ background:#f0f7ff; color:#0b5fff; border-color:#cfe3ff; }


/* OTHER -------------------------------------------------------- */
.bubble-list {
  list-style: none;
  padding-left: 0;
}
.bubble-list li {
  margin-bottom: 8px;
}