/* ============================================================
   FlipAccounts — marketing site
   Direction: "Clean books, in the light" — the anti-Tally.
   Light luminous canvas · glass over mint aurora · teal→emerald→aqua
   gradients · amber money-spark · numbers as hero.
   ============================================================ */

:root {
  /* canvas */
  --canvas:      #EEF5F1;
  --canvas-2:    #E3EEE8;
  --ink:         #0A1F1A;
  --ink-soft:    #45564F;
  --ink-faint:   #7C8B84;

  /* brand */
  --brand:       #0F766E;   /* teal-700, the app's brand */
  --brand-bri:   #16C79A;   /* bright emerald */
  --aqua:        #22D3EE;    /* cyan */
  --gold:        #F59E0B;   /* amber spark (app's secondary) */
  --profit:      #15803D;
  --profit-bg:   #DCFCE7;
  --loss:        #B91C1C;

  /* glass */
  --glass-bg:    rgba(255,255,255,.58);
  --glass-brd:   rgba(255,255,255,.7);
  --glass-sh:    0 20px 50px -22px rgba(12,58,48,.34);
  --glass-blur:  20px;

  /* type */
  --f-display: "Bricolage Grotesque", "Hanken Grotesk", system-ui, sans-serif;
  --f-body:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;
  --f-mono:    "Space Mono", ui-monospace, "SFMono-Regular", monospace;

  --grad: linear-gradient(100deg, var(--brand-bri) 0%, var(--brand) 42%, var(--aqua) 100%);

  --maxw: 1180px;
  --radius: 22px;
  --radius-sm: 14px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---- reset-ish ---- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--f-body);
  color: var(--ink);
  background: var(--canvas);
  line-height: 1.55;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1,h2,h3 { font-family: var(--f-display); font-weight: 700; line-height: 1.05; letter-spacing: -.02em; margin: 0; }
p { margin: 0; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
ul, ol { margin: 0; padding: 0; list-style: none; }
button { font-family: inherit; cursor: pointer; }
:focus-visible { outline: 3px solid var(--brand-bri); outline-offset: 3px; border-radius: 6px; }

.grad-text {
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}

/* ============ ambient aurora ============ */
.aurora { position: fixed; inset: 0; z-index: -2; overflow: hidden; background:
  radial-gradient(120% 120% at 80% -10%, var(--canvas-2) 0%, var(--canvas) 55%); }
.blob { position: absolute; border-radius: 50%; filter: blur(70px); opacity: .5; will-change: transform; }
.blob-1 { width: 46vw; height: 46vw; left: -8vw; top: -6vw;
  background: radial-gradient(circle, rgba(22,199,154,.55), transparent 68%); animation: drift1 22s var(--ease) infinite alternate; }
.blob-2 { width: 40vw; height: 40vw; right: -6vw; top: 4vw;
  background: radial-gradient(circle, rgba(34,211,238,.42), transparent 68%); animation: drift2 26s var(--ease) infinite alternate; }
.blob-3 { width: 34vw; height: 34vw; left: 30vw; top: 42vw;
  background: radial-gradient(circle, rgba(245,158,11,.22), transparent 66%); animation: drift3 30s var(--ease) infinite alternate; }
.grain { position: absolute; inset: 0; opacity: .035; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }
@keyframes drift1 { to { transform: translate(6vw, 5vw) scale(1.12); } }
@keyframes drift2 { to { transform: translate(-5vw, 6vw) scale(1.08); } }
@keyframes drift3 { to { transform: translate(4vw, -6vw) scale(1.15); } }

/* ============ shared ============ */
.glass {
  background: var(--glass-bg);
  backdrop-filter: blur(var(--glass-blur)) saturate(140%);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(140%);
  border: 1px solid var(--glass-brd);
  border-radius: var(--radius);
  box-shadow: var(--glass-sh);
}
.eyebrow {
  font-family: var(--f-mono); font-size: 12.5px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--brand); font-weight: 700;
}
.btn {
  display: inline-flex; align-items: center; gap: .5em; justify-content: center;
  padding: 13px 22px; border-radius: 999px; font-weight: 600; font-size: 15.5px;
  border: none; color: #fff; background: var(--brand);
  transition: transform .18s var(--ease), box-shadow .25s var(--ease), filter .2s;
}
.btn:hover { transform: translateY(-2px); }
.btn:active { transform: translateY(0); }
.btn-grad {
  background: var(--grad); background-size: 200% 200%;
  box-shadow: 0 10px 26px -10px rgba(15,118,110,.7), inset 0 1px 0 rgba(255,255,255,.35);
  animation: gradShift 6s ease infinite;
}
.btn-grad:hover { box-shadow: 0 16px 34px -10px rgba(22,199,154,.8), inset 0 1px 0 rgba(255,255,255,.4); }
@keyframes gradShift { 0%,100% { background-position: 0% 50%; } 50% { background-position: 100% 50%; } }
.btn .arr { transition: transform .2s var(--ease); }
.btn:hover .arr { transform: translateX(3px); }
.btn-lg { padding: 17px 34px; font-size: 17px; }
.btn-block { display: flex; width: 100%; }
.link-quiet { color: var(--ink-soft); font-weight: 600; font-size: 15px; transition: color .2s; }
.link-quiet:hover { color: var(--ink); }

/* ============ NAV ============ */
.nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 22px;
  max-width: var(--maxw); margin: 0 auto; padding: 16px 26px;
  transition: padding .3s var(--ease);
}
.nav.scrolled {
  padding: 10px 18px; margin: 8px auto; border-radius: 999px;
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(16px) saturate(150%); -webkit-backdrop-filter: blur(16px) saturate(150%);
  border: 1px solid var(--glass-brd);
  box-shadow: 0 10px 30px -16px rgba(12,58,48,.4);
  width: calc(100% - 32px);
}
.brand { display: inline-flex; align-items: center; gap: 10px; font-weight: 700; }
.brand-mark { display: inline-grid; place-items: center; filter: drop-shadow(0 4px 8px rgba(15,118,110,.35)); }
.brand-name { font-family: var(--f-display); font-size: 20px; letter-spacing: -.02em; }
.nav-links { display: flex; gap: 6px; margin-left: 12px; }
.nav-links a { padding: 8px 14px; border-radius: 999px; font-weight: 600; font-size: 15px; color: var(--ink-soft); transition: background .2s, color .2s; }
.nav-links a:hover { background: rgba(15,118,110,.09); color: var(--brand); }
.nav-cta { display: flex; align-items: center; gap: 16px; margin-left: auto; }

/* ============ HERO ============ */
.hero {
  max-width: var(--maxw); margin: 0 auto; padding: 40px 26px 70px;
  display: grid; grid-template-columns: 1.02fr .98fr; gap: 54px; align-items: center;
}
.hero-copy { max-width: 560px; }
.pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 15px 7px 12px; border-radius: 999px; font-size: 13.5px; font-weight: 600;
  color: var(--brand); background: rgba(22,199,154,.12); border: 1px solid rgba(22,199,154,.3);
}
.pill-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--brand-bri); box-shadow: 0 0 0 0 rgba(22,199,154,.6); animation: ping 2.4s var(--ease) infinite; }
@keyframes ping { 0% { box-shadow: 0 0 0 0 rgba(22,199,154,.55); } 70%,100% { box-shadow: 0 0 0 9px rgba(22,199,154,0); } }

.hero-title { font-size: clamp(2.7rem, 6vw, 4.6rem); font-weight: 800; margin: 22px 0 0; }
.hero-sub { margin-top: 20px; font-size: clamp(1.05rem, 1.6vw, 1.28rem); color: var(--ink-soft); max-width: 30em; }
.hero-sub strong { color: var(--ink); font-weight: 600; }

/* signup */
.signup { margin-top: 30px; }
.signup-steps { position: relative; }
.step .field { display: flex; gap: 10px; background: rgba(255,255,255,.7); border: 1px solid var(--glass-brd); border-radius: 999px; padding: 6px; box-shadow: var(--glass-sh); backdrop-filter: blur(10px); }
.step input {
  flex: 1; min-width: 0; border: none; background: transparent; font-size: 16px; font-family: inherit;
  color: var(--ink); padding: 10px 16px;
}
.step input::placeholder { color: var(--ink-faint); }
.step input:focus { outline: none; }
.step-go { white-space: nowrap; flex-shrink: 0; }
.step-back { margin: 10px 4px 0; background: none; border: none; color: var(--ink-soft); font-size: 14px; font-weight: 600; }
.step-back:hover { color: var(--ink); }
.step-2 { animation: stepIn .4s var(--ease); }
@keyframes stepIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
.signup-note { margin-top: 14px; font-size: 13.5px; color: var(--ink-faint); }
.signup-note em { color: var(--brand); font-style: normal; font-weight: 600; }
.signup.done .signup-note { color: var(--profit); font-weight: 600; }

.trust-row { display: flex; flex-wrap: wrap; gap: 8px 20px; margin-top: 28px; font-size: 13.5px; color: var(--ink-soft); font-weight: 500; }
.trust-row li { display: inline-flex; align-items: center; gap: 6px; }

/* ============ SIGNATURE: bento preview ============ */
.hero-preview { perspective: 1400px; }
.bento {
  display: grid; grid-template-columns: 1.3fr 1fr; grid-auto-rows: auto;
  gap: 16px; transform-style: preserve-3d;
}
.cell { padding: 20px; transform-origin: 50% 60%; }
/* flip-in-on-load (the "Flip" signature) */
.js-anim .cell { opacity: 0; transform: rotateX(28deg) translateY(26px); }
.js-anim.revealed .cell { animation: cellFlip .8s var(--ease) forwards; animation-delay: calc(var(--i) * .12s); }
@keyframes cellFlip { to { opacity: 1; transform: none; } }

.cell-head { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.cell-label { font-family: var(--f-mono); font-size: 11px; letter-spacing: .06em; text-transform: uppercase; color: var(--ink-faint); }
.cell-tag { font-family: var(--f-mono); font-size: 10px; color: var(--brand); background: rgba(15,118,110,.1); padding: 3px 7px; border-radius: 6px; }

.badge-free { font-size: 10.5px; font-weight: 700; color: #7a4a00; background: rgba(245,158,11,.2); border: 1px solid rgba(245,158,11,.4); padding: 3px 9px; border-radius: 999px; }

.cell-balance { grid-column: 1 / 2; }
.big-num { font-family: var(--f-display); font-weight: 800; font-size: clamp(2rem, 3.4vw, 2.85rem); letter-spacing: -.03em; margin-top: 8px; font-variant-numeric: tabular-nums; }
.cell-foot { margin-top: 6px; font-size: 12.5px; font-weight: 600; }
.cell-foot.up { color: var(--profit); }

/* flip card */
.cell-flip { grid-column: 2 / 3; grid-row: 1 / 2; padding: 0; background: none; border: none; box-shadow: none; perspective: 900px; }
.flip { position: relative; width: 100%; height: 100%; min-height: 128px; transform-style: preserve-3d; transition: transform .8s var(--ease); }
.flip.flipped { transform: rotateY(180deg); }
.flip-face { position: absolute; inset: 0; display: flex; flex-direction: column; gap: 6px; padding: 18px; backface-visibility: hidden; -webkit-backface-visibility: hidden; }
.flip-back { transform: rotateY(180deg); }
.mid-num { font-family: var(--f-display); font-weight: 800; font-size: 1.7rem; letter-spacing: -.02em; font-variant-numeric: tabular-nums; margin-top: auto; }
.chip { align-self: flex-start; font-size: 11px; font-weight: 600; padding: 3px 9px; border-radius: 999px; }
.chip-in { color: var(--profit); background: var(--profit-bg); }
.chip-out { color: var(--gold); background: rgba(245,158,11,.14); }

/* chart */
.cell-chart { grid-column: 1 / 2; }
.chart { margin-top: 12px; }
.bars { display: flex; align-items: flex-end; gap: 4px; height: 82px; }
.bar { flex: 1; border-radius: 4px 4px 2px 2px; height: var(--h); transform-origin: bottom; }
.js-anim .bar { transform: scaleY(0); }
.js-anim.revealed .bar { animation: barGrow .7s var(--ease) forwards; }
.bars .bar:nth-child(n) { animation-delay: calc(.5s + (var(--bi, 0)) * .04s); }
@keyframes barGrow { to { transform: scaleY(1); } }
.bar-in { background: linear-gradient(var(--brand-bri), var(--brand)); }
.bar-out { background: rgba(69,86,79,.28); }
.legend { display: flex; gap: 16px; margin-top: 10px; font-size: 11.5px; color: var(--ink-soft); }
.legend .dot { width: 9px; height: 9px; border-radius: 3px; display: inline-block; margin-right: 5px; vertical-align: middle; }
.dot-in { background: var(--brand); } .dot-out { background: rgba(69,86,79,.4); }

/* ledger */
.cell-ledger { grid-column: 2 / 3; }
.ledger { margin-top: 12px; font-family: var(--f-mono); font-size: 12px; }
.ledger li { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: 8px; padding: 6px 6px; border-radius: 8px; transition: background .18s var(--ease); }
.ledger li:hover { background: rgba(15,118,110,.07); }
.lg-desc { color: var(--ink-soft); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lg-amt.pos { color: var(--profit); } .lg-amt.neg { color: var(--ink); }
.lg-ok { color: var(--brand-bri); font-family: var(--f-body); }
.balanced { margin-top: 10px; font-size: 11px; font-weight: 600; color: var(--brand); text-align: center; padding: 6px; background: rgba(22,199,154,.1); border-radius: 8px; }

/* ============ CONTRAST STRIP ============ */
.contrast { max-width: var(--maxw); margin: 30px auto; padding: 56px 26px; text-align: center; }
.contrast-line { font-family: var(--f-display); font-weight: 700; font-size: clamp(1.6rem, 3.6vw, 2.7rem); letter-spacing: -.02em; }
.strike { position: relative; color: var(--ink-faint); }
.strike::after { content: ""; position: absolute; left: -2%; right: -2%; top: 52%; height: 3px; background: var(--loss); border-radius: 2px; transform: rotate(-2.5deg); }
.contrast-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; max-width: 780px; margin: 40px auto 0; text-align: left; }
.vs { padding: 24px; border-radius: var(--radius-sm); }
.vs-tag { font-family: var(--f-mono); font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 700; }
.vs ul { margin-top: 14px; display: flex; flex-direction: column; gap: 9px; font-size: 15px; }
.vs li { padding-left: 24px; position: relative; }
.vs-old { background: rgba(69,86,79,.06); border: 1px solid rgba(69,86,79,.12); color: var(--ink-soft); }
.vs-old .vs-tag { color: var(--ink-faint); }
.vs-old li::before { content: "✕"; position: absolute; left: 0; color: var(--loss); font-weight: 700; }
.vs-new { background: var(--glass-bg); backdrop-filter: blur(var(--glass-blur)); -webkit-backdrop-filter: blur(var(--glass-blur)); border: 1px solid var(--glass-brd); box-shadow: var(--glass-sh); }
.vs-new .vs-tag { color: var(--brand); }
.vs-new li { color: var(--ink); font-weight: 500; }
.vs-new li::before { content: "✓"; position: absolute; left: 0; color: var(--brand-bri); font-weight: 700; }

/* ============ section heads ============ */
.sec-head { max-width: 640px; margin: 0 auto 44px; text-align: center; }
.sec-head h2 { font-size: clamp(1.9rem, 4vw, 3rem); margin-top: 14px; }
.sec-head p { margin-top: 16px; color: var(--ink-soft); font-size: 1.08rem; }

/* ============ FEATURES ============ */
.features { max-width: var(--maxw); margin: 40px auto; padding: 40px 26px; }
.feat-bento { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.feat { padding: 26px; display: flex; flex-direction: column; gap: 10px; transition: transform .22s var(--ease), box-shadow .3s var(--ease); }
.feat:hover { transform: translateY(-4px); box-shadow: 0 28px 60px -26px rgba(12,58,48,.45); }
.feat h3 { font-size: 1.16rem; }
.feat p { font-size: 14.5px; color: var(--ink-soft); }
.feat-ic { font-size: 24px; width: 46px; height: 46px; display: grid; place-items: center; border-radius: 13px; background: rgba(22,199,154,.14); border: 1px solid rgba(22,199,154,.25); }
.feat-lg { grid-column: span 2; grid-row: span 1; justify-content: center; }
.feat-lg h3 { font-size: 1.5rem; }
.feat-lg p { font-size: 1.02rem; max-width: 34em; }
.feat-dark { grid-column: span 2; background: var(--ink); color: #EAF3EF; border-radius: var(--radius); border: 1px solid rgba(255,255,255,.08); box-shadow: 0 30px 60px -30px rgba(10,31,26,.8); justify-content: center; }
.feat-dark h3 { font-size: 1.5rem; color: #fff; }
.feat-dark p { color: #A9C4BB; font-size: 1.02rem; max-width: 34em; }
.feat-dark .feat-ic { background: rgba(22,199,154,.18); border-color: rgba(22,199,154,.4); }
.feat-wide { grid-column: span 2; flex-direction: row; align-items: flex-start; gap: 18px; }
.feat-wide .feat-ic { flex-shrink: 0; }
.feat-wide h3 { font-size: 1.16rem; }

/* ============ HOW ============ */
.how { max-width: var(--maxw); margin: 40px auto; padding: 40px 26px; }
.steps-flow { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; counter-reset: st; }
.steps-flow li { padding: 30px 26px; position: relative; }
.step-n { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 12px; background: var(--grad); background-size: 200% 200%; color: #fff; font-family: var(--f-display); font-weight: 800; font-size: 1.2rem; margin-bottom: 16px; box-shadow: 0 8px 20px -8px rgba(15,118,110,.7); }
.steps-flow h3 { font-size: 1.2rem; }
.steps-flow p { margin-top: 8px; color: var(--ink-soft); font-size: 14.5px; }

/* ============ PRICING ============ */
.pricing { max-width: 980px; margin: 40px auto; padding: 40px 26px; }
.price-card { display: grid; grid-template-columns: 1.1fr .9fr; gap: 40px; padding: 46px; align-items: center; }
.price-left h2 { font-size: clamp(2rem, 4vw, 3.2rem); margin-top: 12px; }
.price-left p { margin-top: 16px; color: var(--ink-soft); }
.price-fine { font-size: 13.5px; color: var(--ink-faint); margin-top: 14px; }
.price-right { border-left: 1px solid rgba(69,86,79,.14); padding-left: 40px; }
.price-amt { display: flex; align-items: flex-start; gap: 2px; font-family: var(--f-display); font-weight: 800; line-height: 1; }
.price-amt .cur { font-size: 2rem; margin-top: 8px; color: var(--brand); }
.price-amt .big { font-size: clamp(4rem, 9vw, 6rem); background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }
.price-per { color: var(--ink-faint); font-size: 14px; margin: 4px 0 22px; }
.price-list { margin-top: 22px; display: flex; flex-direction: column; gap: 10px; font-size: 14.5px; color: var(--ink-soft); }
.price-list li { padding-left: 26px; position: relative; }
.price-list li::before { content: "✓"; position: absolute; left: 0; color: var(--brand-bri); font-weight: 700; }

/* ============ WHO ============ */
.who { max-width: 900px; margin: 40px auto; padding: 40px 26px; text-align: center; }
.who-lead { font-family: var(--f-display); font-weight: 600; font-size: clamp(1.4rem, 3vw, 2.1rem); letter-spacing: -.02em; }
.who-lead em { font-style: normal; color: var(--brand); }
.who-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; margin-top: 28px; }
.who-chips span { padding: 9px 18px; border-radius: 999px; font-weight: 600; font-size: 14.5px; color: var(--ink-soft); background: var(--glass-bg); border: 1px solid var(--glass-brd); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); transition: transform .2s var(--ease), color .2s; }
.who-chips span:hover { transform: translateY(-3px); color: var(--brand); }

/* ============ FINAL CTA (deep-ink spotlight) ============ */
.final { max-width: var(--maxw); margin: 60px auto 30px; padding: 0 26px; }
.final-inner {
  position: relative; overflow: hidden; text-align: center;
  padding: 72px 30px; border-radius: 34px; color: #EAF3EF;
  background:
    radial-gradient(90% 130% at 15% 0%, rgba(22,199,154,.28), transparent 55%),
    radial-gradient(80% 120% at 90% 100%, rgba(34,211,238,.24), transparent 55%),
    var(--ink);
  box-shadow: 0 40px 90px -40px rgba(10,31,26,.85);
}
.final-inner h2 { font-size: clamp(2.1rem, 5vw, 3.6rem); color: #fff; }
.final-inner > p { margin-top: 14px; color: #A9C4BB; font-size: 1.1rem; }
.final .btn-lg { margin-top: 30px; }
.final-note { margin-top: 20px; font-size: 14px; color: #8FADA3; }
.final-note a { color: var(--brand-bri); font-weight: 600; }

/* ============ FOOTER ============ */
.footer { max-width: var(--maxw); margin: 0 auto; padding: 40px 26px 60px; display: grid; grid-template-columns: 1fr auto; gap: 18px 40px; align-items: center; border-top: 1px solid rgba(69,86,79,.12); }
.foot-brand { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.foot-tag { flex-basis: 100%; color: var(--ink-faint); font-size: 13.5px; margin-top: 4px; }
.foot-links { display: flex; gap: 8px; flex-wrap: wrap; }
.foot-links a { padding: 8px 14px; border-radius: 999px; color: var(--ink-soft); font-weight: 600; font-size: 14.5px; transition: background .2s, color .2s; }
.foot-links a:hover { background: rgba(15,118,110,.09); color: var(--brand); }
.foot-legal { grid-column: 1 / -1; color: var(--ink-faint); font-size: 13px; margin-top: 6px; }

/* ============ RESPONSIVE ============ */
@media (max-width: 940px) {
  .hero { grid-template-columns: 1fr; gap: 40px; padding-top: 20px; }
  .hero-preview { order: 2; }
  .feat-bento { grid-template-columns: repeat(2, 1fr); }
  .feat-lg, .feat-dark { grid-column: span 2; }
  .feat-wide { grid-column: auto; flex-direction: column; }
  .price-card { grid-template-columns: 1fr; gap: 28px; }
  .price-right { border-left: none; border-top: 1px solid rgba(69,86,79,.14); padding-left: 0; padding-top: 28px; }
  .steps-flow { grid-template-columns: 1fr; }
  .nav-links { display: none; }
}
@media (max-width: 620px) {
  body { font-size: 16px; }
  .nav { padding: 14px 16px; gap: 12px; }
  .nav-cta .link-quiet { display: none; }
  .hide-sm { display: none; }
  .hero { padding: 16px 18px 50px; }
  .hero-title { font-size: clamp(2rem, 8.5vw, 3rem); }
  .hero-preview { min-width: 0; }
  .bento { grid-template-columns: 1fr 1fr; gap: 12px; }
  .cell { min-width: 0; padding: 16px; }
  .big-num { font-size: 1.5rem; }
  .mid-num { font-size: 1.25rem; }
  .flip { min-height: 112px; }
  .contrast-grid { grid-template-columns: 1fr; }
  .feat-bento { grid-template-columns: 1fr; }
  .feat-lg, .feat-dark { grid-column: span 1; }
  .step .field { flex-wrap: wrap; border-radius: 20px; }
  .step-go { width: 100%; }
  .footer { grid-template-columns: 1fr; }
  .final-inner { padding: 52px 22px; }
}

/* ============ reduced motion ============ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; scroll-behavior: auto !important; }
  .js-anim .cell, .js-anim .bar { opacity: 1 !important; transform: none !important; }
  .blob { animation: none; }
}
