/* ============================================================
   cardful — marketing site v2.  One shared stylesheet, no build step.
   Vault design tokens (mirror the iOS app: warm paper, ink, SF Pro,
   tabular figures, restrained Liquid Glass chrome, gold/green status).
   ============================================================ */
:root {
  --bg: #F5F2EC;
  --bg-2: #EFEBE3;
  --surface: #FFFFFF;
  --surface-sub: #EDEAE3;
  --ink: #1A1714;
  --text-sec: #6F6960;
  --text-ter: #A39C90;
  --divider: rgba(26, 23, 20, 0.10);
  --hairline: rgba(26, 23, 20, 0.07);
  --good: #3C7A4E;
  --good-soft: #E4EFE5;
  --warn: #B8742B;
  --warn-soft: #FBEBD3;
  --radius-card: 18px;
  --radius-surface: 22px;
  --radius-lg: 28px;
  --shadow-sm: 0 1px 2px rgba(26, 23, 20, 0.06);
  --shadow-md: 0 10px 30px rgba(26, 23, 20, 0.10);
  --shadow-lg: 0 24px 60px rgba(26, 23, 20, 0.18);
  --shadow-phone: 0 40px 90px rgba(26, 23, 20, 0.28), 0 8px 24px rgba(26,23,20,0.18);
  --maxw: 1120px;
  --font: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Arial, sans-serif;
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.tnum { font-variant-numeric: tabular-nums; }
a { color: inherit; }
img { max-width: 100%; }
.container { width: 100%; max-width: var(--maxw); margin: 0 auto; padding: 0 24px; }
.section { padding: 88px 0; }
.section-tight { padding: 52px 0; }
.center { text-align: center; }
.muted { color: var(--text-sec); }

/* ---- Header ---- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(245, 242, 236, 0.78);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--divider);
}
.header-inner { display: flex; align-items: center; gap: 22px; height: 66px; }
.brand { display: inline-flex; align-items: center; gap: 9px; text-decoration: none; color: var(--ink); font-weight: 600; letter-spacing: -0.02em; font-size: 20px; }
.brand-mark { color: var(--ink); display: block; }
.nav { display: flex; gap: 28px; margin-left: 14px; }
.nav a { text-decoration: none; color: var(--text-sec); font-size: 15px; font-weight: 500; transition: color .15s ease; }
.nav a:hover, .nav a.active { color: var(--ink); }
.header-cta { margin-left: auto; display: flex; gap: 10px; align-items: center; }

/* ---- Buttons (consistent pill scale; height-driven for even baselines) ---- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border-radius: 999px; font-weight: 600; font-size: 15.5px; letter-spacing: -0.01em;
  min-height: 46px; padding: 0 24px; text-decoration: none; cursor: pointer;
  border: 1px solid transparent; white-space: nowrap;
  transition: transform .12s ease, box-shadow .15s ease, background .15s ease, border-color .15s ease;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--ink); color: #FBFAF7; box-shadow: var(--shadow-sm); }
.btn-primary:hover { box-shadow: var(--shadow-md); }
.btn-secondary { background: transparent; color: var(--ink); border-color: var(--divider); }
.btn-secondary:hover { background: var(--surface-sub); }
.btn-ghost { background: transparent; color: var(--ink); min-height: auto; padding: 0 4px; }
.btn-ghost:hover { color: var(--warn); }
.btn-sm { min-height: 38px; padding: 0 17px; font-size: 14px; }
.btn-lg { min-height: 54px; padding: 0 30px; font-size: 16.5px; }

/* ---- Eyebrow / kicker / section head ---- */
.eyebrow { display: inline-block; font-size: 13px; font-weight: 600; letter-spacing: 0.09em; text-transform: uppercase; color: var(--warn); margin-bottom: 18px; }
.kicker { font-size: 13px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-ter); margin: 0 0 12px; }
.section-head { max-width: 40em; margin-bottom: 48px; }
.section-head.center { margin-left: auto; margin-right: auto; }
.section-head h2 { font-size: clamp(30px, 4.2vw, 44px); letter-spacing: -0.035em; font-weight: 600; line-height: 1.05; margin: 0 0 16px; }
.section-head p { font-size: 19px; color: var(--text-sec); margin: 0; }

/* ---- Hero ---- */
.hero { padding: 72px 0 48px; position: relative; overflow: hidden; }
.hero::before { content: ""; position: absolute; top: -120px; right: -120px; width: 620px; height: 620px; background: radial-gradient(circle, rgba(184,116,43,0.08), transparent 68%); pointer-events: none; }
.hero-grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 44px; align-items: center; position: relative; }
.hero h1 { font-size: clamp(42px, 6.2vw, 68px); line-height: 1.0; letter-spacing: -0.04em; font-weight: 600; margin: 0 0 22px; }
.hero p.lede { font-size: 19px; line-height: 1.55; color: var(--text-sec); max-width: 30em; margin: 0 0 30px; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.hero-note { font-size: 13.5px; color: var(--text-ter); margin-top: 20px; display: flex; gap: 8px; align-items: center; }
.hero-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--good); flex: 0 0 auto; }
.applinks { display: flex; gap: 12px; align-items: center; margin-top: 26px; }
.store-badge { display: inline-flex; align-items: center; gap: 9px; background: var(--ink); color: #FBFAF7; border-radius: 14px; padding: 9px 16px; text-decoration: none; }
.store-badge .sb-small { font-size: 10px; letter-spacing: 0.04em; opacity: 0.75; display: block; line-height: 1.1; }
.store-badge .sb-big { font-size: 17px; font-weight: 600; letter-spacing: -0.01em; display: block; line-height: 1.15; }
.store-badge.soon { background: transparent; color: var(--text-sec); border: 1px solid var(--divider); }

/* ============================================================
   iPhone frame + app screens (CSS recreations, stylized art)
   ============================================================ */
.phone-stage { position: relative; display: flex; justify-content: center; }
.iphone {
  position: relative; width: 332px; height: 684px; background: #0c0c0e;
  border-radius: 54px; padding: 12px; box-shadow: var(--shadow-phone), 0 0 0 2px rgba(255,255,255,0.45) inset;
  flex: 0 0 auto;
}
.iphone.sm { width: 286px; height: 590px; border-radius: 47px; padding: 10px; }
.screen { position: relative; width: 100%; height: 100%; background: var(--bg); border-radius: 43px; overflow: hidden; }
.iphone.sm .screen { border-radius: 38px; }
.island { position: absolute; top: 12px; left: 50%; transform: translateX(-50%); width: 106px; height: 31px; background: #0c0c0e; border-radius: 18px; z-index: 30; }
.iphone.sm .island { width: 92px; height: 27px; }
.statusbar { position: absolute; top: 0; left: 0; right: 0; height: 52px; display: flex; align-items: center; justify-content: space-between; padding: 18px 28px 0; font-size: 14px; font-weight: 600; color: var(--ink); z-index: 20; }
.sb-r { display: flex; gap: 6px; align-items: center; }
.scr-pad { padding: 60px 18px 0; height: 100%; }
.scr-kick { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-ter); }
.scr-title { font-size: 28px; font-weight: 600; letter-spacing: -0.03em; margin: 2px 0 0; }

/* money-on-the-table pill (dark glass summary) */
.mott { margin: 14px 0 16px; background: var(--ink); color: #F4F1EA; border-radius: 18px; padding: 14px 16px; display: flex; align-items: center; justify-content: space-between; box-shadow: var(--shadow-md); }
.mott .lbl { font-size: 11px; letter-spacing: 0.07em; text-transform: uppercase; color: rgba(244,241,234,0.6); }
.mott .amt { font-size: 26px; font-weight: 600; letter-spacing: -0.02em; margin-top: 1px; }
.mott .sub { font-size: 12px; color: rgba(244,241,234,0.65); }
.mott .chev { width: 30px; height: 30px; border-radius: 50%; background: rgba(244,241,234,0.14); display: grid; place-items: center; flex: 0 0 auto; }

/* card stack */
.stack { position: relative; }
.wcard { height: 120px; border-radius: 18px; padding: 15px 16px; color: #fff; position: relative; box-shadow: 0 8px 22px rgba(26,23,20,0.22); margin-top: -80px; border: 1px solid rgba(255,255,255,0.08); }
.wcard:first-child { margin-top: 0; }
.wcard .wi { font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.82; }
.wcard .wchip { position: absolute; top: 15px; right: 16px; width: 26px; height: 20px; border-radius: 5px; background: linear-gradient(135deg, rgba(255,255,255,0.85), rgba(255,255,255,0.4)); }
.wcard .wnum { position: absolute; left: 16px; bottom: 13px; font-size: 12px; letter-spacing: 0.16em; opacity: 0.7; }
/* stylized card art (no issuer marks) */
.c-navy { background: linear-gradient(135deg, #0A1A33, #1E4E8C 72%, #0A1A33); }
.c-gold { background: linear-gradient(135deg, #3A2A0E, #6E521C 58%, #B8893A); }
.c-dark { background: linear-gradient(140deg, #26231E, #3a352c); }
.c-black { background: linear-gradient(140deg, #141414, #2c2c2c); }
.c-green { background: linear-gradient(135deg, #0E3B2E, #15634A 66%, #3F8E6E); }
.c-plum { background: linear-gradient(135deg, #2A1430, #5A2C57 65%, #8A4A6E); }

/* glass tab bar */
.tabbar { position: absolute; left: 50%; transform: translateX(-50%); bottom: 16px; width: 270px; height: 62px; background: rgba(248,246,241,0.7); backdrop-filter: blur(18px) saturate(180%); -webkit-backdrop-filter: blur(18px) saturate(180%); border-radius: 34px; box-shadow: 0 8px 30px rgba(26,23,20,0.16), 0 0 0 1px rgba(255,255,255,0.5) inset; display: flex; align-items: center; justify-content: space-around; padding: 0 14px; z-index: 25; }
.iphone.sm .tabbar { width: 232px; height: 56px; }
.tab { display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: 10px; color: var(--text-ter); font-weight: 500; }
.tab.on { color: var(--ink); }
.tab svg { display: block; }
.fab { position: absolute; right: -4px; bottom: 30px; width: 54px; height: 54px; border-radius: 50%; background: var(--ink); display: grid; place-items: center; box-shadow: 0 8px 24px rgba(26,23,20,0.3); z-index: 26; }

/* best-card ranked list screen */
.rank-head { margin-bottom: 4px; }
.rank-list { background: var(--surface); border-radius: 18px; box-shadow: var(--shadow-sm); overflow: hidden; }
.rrow { display: flex; align-items: center; gap: 11px; padding: 13px 14px; border-bottom: 1px solid var(--hairline); }
.rrow:last-child { border-bottom: none; }
.rrow .rn { font-size: 13px; font-weight: 700; color: var(--text-ter); width: 12px; }
.rmini { width: 40px; height: 26px; border-radius: 6px; flex: 0 0 auto; position: relative; box-shadow: 0 1px 3px rgba(0,0,0,0.2); }
.rname { font-size: 14px; font-weight: 600; letter-spacing: -0.01em; }
.rmeta { font-size: 11.5px; color: var(--text-sec); }
.rval { margin-left: auto; text-align: right; }
.rmult { font-size: 15px; font-weight: 700; }
.rcpp { font-size: 11px; color: var(--text-ter); }
.best-tag { display: inline-block; background: var(--ink); color: #F4F1EA; font-size: 9px; font-weight: 700; letter-spacing: 0.06em; padding: 2px 6px; border-radius: 5px; margin-left: 6px; vertical-align: middle; }

/* credits / expiring screen rows */
.credit-row { display: flex; align-items: center; gap: 12px; padding: 13px 0; border-bottom: 1px solid var(--hairline); }
.credit-row:last-child { border-bottom: none; }
.cic { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; font-size: 12px; font-weight: 700; color: #fff; flex: 0 0 auto; }
.cname { font-size: 14.5px; font-weight: 600; }
.cmeta { font-size: 12px; color: var(--text-sec); }
.cval { margin-left: auto; text-align: right; }
.camt { font-size: 15px; font-weight: 600; }
.ctag { font-size: 11px; font-weight: 600; color: var(--warn); }

/* ============================================================
   "Money on the table" statement (problem/solution beat)
   ============================================================ */
.problem-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 56px; align-items: center; }
.problem-copy h2 { font-size: clamp(30px, 4vw, 42px); letter-spacing: -0.035em; font-weight: 600; line-height: 1.06; margin: 0 0 18px; }
.problem-copy h2 .amt { color: var(--warn); }
.problem-copy p { font-size: 18px; color: var(--text-sec); margin: 0 0 14px; max-width: 30em; }
.leak-list { list-style: none; padding: 0; margin: 22px 0 0; display: grid; gap: 12px; }
.leak-list li { display: flex; gap: 11px; align-items: flex-start; font-size: 15.5px; color: var(--ink); }
.leak-list .x { flex: 0 0 auto; width: 22px; height: 22px; border-radius: 50%; background: var(--warn-soft); color: var(--warn); display: grid; place-items: center; margin-top: 1px; }

.stmt { background: var(--surface); border: 1px solid var(--divider); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; }
.stmt-top { padding: 24px 26px 18px; border-bottom: 1px solid var(--divider); display: flex; justify-content: space-between; align-items: flex-start; }
.stmt-k { font-size: 12px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--text-ter); }
.stmt-total { font-size: 54px; font-weight: 600; letter-spacing: -0.03em; color: var(--warn); line-height: 1; margin-top: 8px; }
.stmt-sub { font-size: 14px; color: var(--text-sec); margin-top: 6px; }
.stmt-badge { background: var(--warn-soft); color: #8a5a1e; font-size: 12px; font-weight: 600; padding: 6px 11px; border-radius: 999px; border: 1px solid rgba(184,116,43,0.25); white-space: nowrap; }
.stmt-rows { padding: 6px 26px 14px; }
.stmt-foot { padding: 15px 26px; background: var(--surface-sub); display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text-sec); }

/* ---- Feature grid ---- */
.features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.feature { background: var(--surface); border: 1px solid var(--divider); border-radius: var(--radius-surface); padding: 28px 26px; box-shadow: var(--shadow-sm); transition: transform .18s ease, box-shadow .18s ease; }
.feature:hover { transform: translateY(-3px); box-shadow: var(--shadow-md); }
.feature .ficon { width: 44px; height: 44px; border-radius: 13px; background: var(--surface-sub); display: grid; place-items: center; margin-bottom: 18px; color: var(--ink); }
.feature h3 { font-size: 19px; letter-spacing: -0.015em; margin: 0 0 8px; }
.feature p { font-size: 15px; color: var(--text-sec); margin: 0; line-height: 1.55; }
.feature .flink { display: inline-block; margin-top: 14px; font-size: 14px; font-weight: 600; color: var(--warn); text-decoration: none; }

/* ---- Showcase (alternating phone + copy) ---- */
.showcase { display: grid; grid-template-columns: 1fr 1fr; gap: 56px; align-items: center; }
.showcase + .showcase { margin-top: 96px; }
.showcase.flip .sc-media { order: 2; }
.sc-copy .tag { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; color: var(--warn); letter-spacing: 0.02em; margin-bottom: 14px; }
.sc-copy h3 { font-size: clamp(26px, 3.2vw, 34px); letter-spacing: -0.03em; font-weight: 600; line-height: 1.08; margin: 0 0 14px; }
.sc-copy p { font-size: 17px; color: var(--text-sec); margin: 0 0 12px; max-width: 32em; }
.sc-points { list-style: none; padding: 0; margin: 20px 0 0; display: grid; gap: 11px; }
.sc-points li { display: flex; gap: 10px; align-items: flex-start; font-size: 15.5px; }
.sc-points .ck { flex: 0 0 auto; width: 22px; height: 22px; border-radius: 50%; background: var(--good-soft); color: var(--good); display: grid; place-items: center; margin-top: 1px; }
.sc-media { display: flex; justify-content: center; }

/* ---- How it works steps ---- */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.step { padding-top: 16px; border-top: 2px solid var(--ink); }
.step .step-n { font-size: 13px; font-weight: 700; color: var(--warn); letter-spacing: 0.06em; }
.step h3 { font-size: 20px; letter-spacing: -0.015em; margin: 10px 0 8px; }
.step p { font-size: 15.5px; color: var(--text-sec); margin: 0; }

/* ---- Trust band (dark) ---- */
.band { background: var(--ink); color: #F4F1EA; border-radius: var(--radius-lg); padding: 56px 48px; position: relative; overflow: hidden; }
.band::after { content: ""; position: absolute; right: -80px; bottom: -80px; width: 300px; height: 300px; background: radial-gradient(circle, rgba(184,116,43,0.18), transparent 70%); }
.band .eyebrow { color: #D9A05B; }
.band h2 { color: #fff; font-size: clamp(26px, 3.6vw, 38px); letter-spacing: -0.03em; margin: 0 0 14px; max-width: 18em; }
.band > p { color: rgba(244,241,234,0.75); font-size: 18px; margin: 0; max-width: 44em; position: relative; }
.band-points { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px; margin-top: 38px; position: relative; }
.band-points .bp h4 { color: #fff; font-size: 16px; margin: 0 0 7px; display: flex; align-items: center; gap: 8px; }
.band-points .bp p { color: rgba(244,241,234,0.66); font-size: 14.5px; margin: 0; line-height: 1.55; }
.band-points .bp .bpi { color: #D9A05B; }

/* ---- Comparison table (positioning, no logos) ---- */
.compare-wrap { overflow-x: auto; border: 1px solid var(--divider); border-radius: var(--radius-lg); background: var(--surface); box-shadow: var(--shadow-sm); }
table.compare { width: 100%; border-collapse: collapse; min-width: 720px; }
table.compare th, table.compare td { padding: 17px 18px; text-align: left; border-bottom: 1px solid var(--hairline); }
table.compare thead th { font-size: 13px; font-weight: 600; color: var(--text-sec); letter-spacing: 0.02em; vertical-align: bottom; }
table.compare thead th.cf { color: var(--ink); }
table.compare tbody tr:last-child td { border-bottom: none; }
table.compare td.row-label { font-size: 15px; font-weight: 600; color: var(--ink); width: 34%; }
table.compare td.cell { text-align: center; }
table.compare th.col { text-align: center; }
table.compare th.cf, table.compare td.cf { background: var(--bg-2); }
table.compare thead th.cf { border-top-left-radius: 0; }
.cf-head { display: inline-flex; flex-direction: column; align-items: center; gap: 4px; }
.cf-head .nm { font-size: 16px; font-weight: 700; color: var(--ink); letter-spacing: -0.01em; }
.cf-head .pill { font-size: 10px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--warn); background: var(--warn-soft); padding: 2px 8px; border-radius: 999px; }
.yes { color: var(--good); }
.no { color: var(--text-ter); }
.partial { color: var(--warn); font-size: 13px; font-weight: 600; }

/* ---- Recommended cards (single row) ---- */
.reccards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
.reccard { background: var(--surface); border: 1px solid var(--divider); border-radius: var(--radius-surface); padding: 22px; box-shadow: var(--shadow-sm); display: flex; flex-direction: column; }
.reccard .art { height: 130px; border-radius: 14px; position: relative; box-shadow: 0 6px 18px rgba(26,23,20,0.22); margin-bottom: 18px; overflow: hidden; }
.reccard .art .ci { position: absolute; top: 14px; left: 16px; font-size: 11px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.85); }
.reccard .art .cchip { position: absolute; top: 14px; right: 16px; width: 26px; height: 20px; border-radius: 5px; background: linear-gradient(135deg, rgba(255,255,255,0.85), rgba(255,255,255,0.4)); }
.reccard .cat { font-size: 12px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: var(--warn); margin-bottom: 6px; }
.reccard h4 { font-size: 18px; letter-spacing: -0.01em; margin: 0 0 6px; }
.reccard p { font-size: 14.5px; color: var(--text-sec); margin: 0 0 18px; flex: 1; }
.reccard .rc-foot { display: flex; align-items: center; margin-top: auto; }
.reccard .rc-foot a:not(.btn) { font-size: 14px; font-weight: 600; color: var(--ink); text-decoration: none; display: inline-flex; align-items: center; gap: 5px; }
.reccard .rc-foot a:not(.btn):hover { color: var(--warn); }
.rec-note { font-size: 13px; color: var(--text-ter); margin: 22px 0 0; display: flex; gap: 8px; align-items: flex-start; max-width: 52em; }
.rec-note a { color: var(--text-sec); }

/* ---- Pricing ---- */
.pricing-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; max-width: 880px; margin: 0 auto; }
.plan { background: var(--surface); border: 1px solid var(--divider); border-radius: var(--radius-lg); padding: 34px 32px; box-shadow: var(--shadow-sm); position: relative; display: flex; flex-direction: column; }
.plan.featured { border-color: rgba(26,23,20,0.22); box-shadow: var(--shadow-md); }
.plan.soon { background: var(--ink); color: #F4F1EA; border-color: transparent; }
.plan .plan-name { font-size: 14px; font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-sec); }
.plan.soon .plan-name { color: #D9A05B; }
.plan .plan-badge { position: absolute; top: 26px; right: 28px; font-size: 11px; font-weight: 700; letter-spacing: 0.05em; text-transform: uppercase; padding: 5px 11px; border-radius: 999px; }
.plan.featured .plan-badge { background: var(--good-soft); color: var(--good); }
.plan.soon .plan-badge { background: rgba(217,160,91,0.18); color: #E7B574; }
.plan .price { display: flex; align-items: baseline; gap: 8px; margin: 18px 0 6px; }
.plan .price .amt { font-size: 48px; font-weight: 600; letter-spacing: -0.03em; line-height: 1; }
.plan .price .per { font-size: 16px; color: var(--text-sec); }
.plan.soon .price .per { color: rgba(244,241,234,0.65); }
.plan .price-sub { font-size: 14.5px; color: var(--text-sec); margin: 0 0 24px; }
.plan.soon .price-sub { color: rgba(244,241,234,0.7); }
.plan .plan-list { list-style: none; padding: 0; margin: 0 0 28px; display: grid; gap: 13px; flex: 1; }
.plan .plan-list li { display: flex; gap: 11px; align-items: flex-start; font-size: 15.5px; line-height: 1.45; }
.plan .plan-list .ck { flex: 0 0 auto; width: 21px; height: 21px; border-radius: 50%; background: var(--good-soft); color: var(--good); display: grid; place-items: center; margin-top: 1px; }
.plan.soon .plan-list .ck { background: rgba(217,160,91,0.18); color: #E7B574; }
.plan .plan-cta { margin-top: auto; }
.plan .plan-cta .btn { width: 100%; }
.plan.soon .btn-primary { background: #F4F1EA; color: var(--ink); }

/* ---- FAQ ---- */
.faq { max-width: 760px; margin: 0 auto; }
.faq details { border-bottom: 1px solid var(--divider); padding: 6px 0; }
.faq summary { list-style: none; cursor: pointer; padding: 20px 40px 20px 0; font-size: 18px; font-weight: 600; letter-spacing: -0.01em; position: relative; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; position: absolute; right: 6px; top: 50%; transform: translateY(-50%); font-size: 24px; font-weight: 400; color: var(--text-ter); transition: transform .2s ease; }
.faq details[open] summary::after { content: "\2013"; }
.faq details p { font-size: 16px; color: var(--text-sec); margin: 0 0 20px; max-width: 60em; }

/* ---- Final CTA ---- */
.cta-final { text-align: center; padding: 100px 0; }
.cta-final h2 { font-size: clamp(32px, 5vw, 52px); letter-spacing: -0.04em; margin: 0 0 18px; line-height: 1.02; }
.cta-final p { font-size: 19px; color: var(--text-sec); margin: 0 0 30px; }
.cta-final .hero-note { justify-content: center; }

/* ---- Footer ---- */
.site-footer { border-top: 1px solid var(--divider); padding: 56px 0 40px; margin-top: 24px; }
.footer-grid { display: grid; grid-template-columns: 1.7fr 1fr 1fr 1fr; gap: 32px; }
.footer-brand p { font-size: 14px; color: var(--text-sec); max-width: 26em; margin: 14px 0 0; }
.footer-links h4 { font-size: 13px; letter-spacing: 0.04em; text-transform: uppercase; color: var(--text-ter); margin: 0 0 14px; font-weight: 600; }
.footer-links a { display: block; text-decoration: none; color: var(--text-sec); font-size: 15px; margin-bottom: 11px; }
.footer-links a:hover { color: var(--ink); }
.footer-bottom { margin-top: 44px; padding-top: 26px; border-top: 1px solid var(--divider); }
.disclosure-line { font-size: 13px; color: var(--text-sec); margin: 0 0 10px; max-width: 64em; line-height: 1.55; }
.disclosure-line a { color: var(--ink); }
.copyright { font-size: 13px; color: var(--text-ter); margin: 0; }

/* ---- Prose / legal pages ---- */
.prose-head { padding: 60px 0 8px; }
.prose-head h1 { font-size: clamp(34px, 5vw, 50px); letter-spacing: -0.035em; margin: 0 0 10px; }
.prose-head .updated { font-size: 14px; color: var(--text-ter); }
.prose { max-width: 720px; padding: 24px 0 72px; }
.prose h2 { font-size: 23px; letter-spacing: -0.02em; margin: 40px 0 12px; }
.prose p, .prose li { color: #2c2823; font-size: 16.5px; }
.prose ul { padding-left: 22px; }
.prose li { margin-bottom: 8px; }
.prose a { color: var(--warn); }
.prose .lead { font-size: 18px; color: var(--text-sec); }

/* ---- Page intro (sub-pages) ---- */
.page-intro { padding: 64px 0 8px; text-align: center; }
.page-intro h1 { font-size: clamp(36px, 5.4vw, 58px); letter-spacing: -0.04em; font-weight: 600; line-height: 1.02; margin: 14px 0 18px; }
.page-intro p { font-size: 20px; color: var(--text-sec); max-width: 34em; margin: 0 auto; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .hero-grid { grid-template-columns: 1fr; gap: 32px; text-align: left; }
  .problem-grid { grid-template-columns: 1fr; gap: 36px; }
  .showcase, .showcase.flip { grid-template-columns: 1fr; gap: 36px; }
  .showcase.flip .sc-media { order: 0; }
  .features { grid-template-columns: 1fr 1fr; }
  .band-points { grid-template-columns: 1fr; gap: 22px; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .reccards { grid-template-columns: 1fr; max-width: 420px; margin: 0 auto; }
  .nav { display: none; }
}
@media (max-width: 680px) {
  .section { padding: 64px 0; }
  .features { grid-template-columns: 1fr; }
  .steps { grid-template-columns: 1fr; gap: 22px; }
  .pricing-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .band { padding: 36px 26px; }
  .header-cta .btn-secondary { display: none; }
  .hero { padding: 48px 0 24px; }
}

/* ---- Contact form (carried from v1) ---- */
.contact-wrap { display: grid; grid-template-columns: 1.08fr 0.92fr; gap: 44px; align-items: start; padding: 8px 0 64px; }
.form-card { background: var(--surface); border: 1px solid var(--divider); border-radius: var(--radius-surface); padding: 28px; box-shadow: var(--shadow-sm); }
.field { margin-bottom: 18px; }
.field label { display: block; font-size: 14px; font-weight: 600; color: var(--ink); margin-bottom: 7px; }
.field input, .field select, .field textarea { width: 100%; font: inherit; font-size: 16px; color: var(--ink); background: var(--bg); border: 1px solid var(--divider); border-radius: 12px; padding: 12px 14px; appearance: none; }
.field textarea { min-height: 130px; resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--ink); box-shadow: 0 0 0 3px rgba(26,23,20,0.08); }
@media (max-width: 760px) { .contact-wrap { grid-template-columns: 1fr; gap: 26px; } }

/* ---- Contact form: honeypot + status + aside (design covers .form-card/.field/.contact-wrap) ---- */
.hp { position: absolute !important; left: -9999px !important; }
.form-actions .btn { width: 100%; justify-content: center; }
.form-status { font-size: 14.5px; margin: 14px 0 0; min-height: 1.2em; }
.form-status.success { color: var(--good); font-weight: 600; }
.form-status.error { color: #B23B3B; }
.form-status.pending { color: var(--text-sec); }
.contact-aside { padding-top: 4px; }
.contact-aside h3 { font-size: 16px; margin: 0 0 6px; letter-spacing: -0.01em; }
.contact-aside p { font-size: 15px; color: var(--text-sec); margin: 0 0 8px; }
.contact-aside .email-big { font-size: 19px; font-weight: 600; letter-spacing: -0.01em; }
.contact-aside ul { padding-left: 18px; margin: 6px 0 0; }
.contact-aside li { font-size: 14.5px; color: var(--text-sec); margin-bottom: 7px; }
.aside-divider { height: 1px; background: var(--divider); margin: 22px 0; }

/* credit-row icons: real App Store app icons (full-bleed) + category glyphs */
.cic.app { overflow: hidden; }
.cic.app img { width: 100%; height: 100%; object-fit: cover; display: block; border-radius: inherit; }
.cic.glyph { background: var(--surface-sub); color: var(--text-sec); }

/* real app screenshot framed inside the iPhone bezel */
.screen .shot { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top center; display: block; }

/* a real screenshot already includes the status bar + Dynamic Island, so hide the frame's */
.iphone:has(.shot) .island { display: none; }
