/* =============================================================
   Pearson Clinical TV — Design System
   Fonte display: Outfit · Corpo: Inter
   Paleta: Dourado quente + Vinho escuro + Preto profundo
   ============================================================= */

:root {
  /* cores */
  --bg:         #0a0608;
  --bg-soft:    #110b0e;
  --surface:    rgba(255,255,255,.04);
  --surface-2:  rgba(255,255,255,.07);
  --line:       rgba(255,255,255,.07);
  --line-gold:  rgba(212,175,55,.22);

  --gold:       #d4af37;
  --gold-light: #f0d060;
  --gold-dim:   rgba(212,175,55,.15);
  --wine:       #8b1a4a;
  --wine-light: #c0286a;
  --rose:       #e8608a;

  --text:       #f5f0ea;
  --muted:      #a89880;
  --muted-2:    #6e5e50;

  --grad:       linear-gradient(135deg,#d4af37 0%,#f0d060 50%,#d4af37 100%);
  --grad-wine:  linear-gradient(135deg,#8b1a4a 0%,#c0286a 100%);
  --grad-hero:  linear-gradient(135deg,#1a0a10 0%,#0a0608 60%,#140818 100%);
  --glow-gold:  0 0 60px rgba(212,175,55,.25);
  --glow-wine:  0 0 60px rgba(139,26,74,.35);

  --r-sm: 10px;
  --r:    16px;
  --r-lg: 24px;
  --r-xl: 32px;
  --r-pill: 9999px;

  --maxw: 1180px;
  --t: .28s cubic-bezier(.4,0,.2,1);

  --font-display: 'Outfit', system-ui, sans-serif;
  --font-body:    'Inter', system-ui, sans-serif;
}

/* reset */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box }
html { scroll-behavior:smooth; scroll-padding-top:76px; -webkit-text-size-adjust:100% }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--text);
  line-height: 1.65;
  overflow-x: hidden;
}
a { color:inherit; text-decoration:none }
img { max-width:100%; display:block }
ul { list-style:none }
::selection { background:var(--gold); color:#0a0608 }

.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px }

/* ── tipografia ── */
h1,h2,h3,h4 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -.02em;
}
.text-gold {
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.text-rose { color: var(--rose) }

/* ── topbar ticker ── */
.topbar {
  background: linear-gradient(90deg,#1a0a10,#2a0a18,#1a0a10);
  border-bottom: 1px solid var(--line-gold);
  overflow: hidden;
  height: 36px;
}
.ticker {
  display: flex;
  gap: 48px;
  white-space: nowrap;
  padding: 8px 0;
  animation: ticker 36s linear infinite;
  font-size: .8rem;
  color: var(--gold-light);
  font-family: var(--font-display);
  font-weight: 600;
}
.ticker span { display:inline-flex; align-items:center; gap:8px }
.ticker b { color: var(--rose) }
@keyframes ticker { to { transform: translateX(-50%) } }

/* ── header ── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 300;
  background: rgba(10,6,8,.85);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--line-gold);
}
.nav {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 72px;
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.35rem;
  letter-spacing: -.03em;
  flex-shrink: 0;
}
.brand-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--grad);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  box-shadow: 0 4px 16px rgba(212,175,55,.35);
}
.brand-name { color: var(--text) }
.brand-name span { color: var(--gold) }
.nav-links {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-left: auto;
}
.nav-links a {
  padding: 8px 14px;
  border-radius: var(--r-sm);
  color: var(--muted);
  font-weight: 500;
  font-size: .9rem;
  transition: var(--t);
}
.nav-links a:hover, .nav-links a.active { color: var(--text); background: var(--surface-2) }
.nav-links a.active { color: var(--gold-light) }
.nav-cta { margin-left: 8px }
.burger {
  display: none;
  margin-left: auto;
  width: 44px;
  height: 40px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line-gold);
  background: transparent;
  color: var(--text);
  font-size: 1.15rem;
  cursor: pointer;
  flex-shrink: 0;
}

/* ── botões ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .96rem;
  padding: 13px 26px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  cursor: pointer;
  transition: var(--t);
  white-space: nowrap;
  position: relative;
  overflow: hidden;
}
.btn-gold {
  background: var(--grad);
  color: #0a0608;
  box-shadow: 0 8px 28px -6px rgba(212,175,55,.5);
}
.btn-gold:hover {
  transform: translateY(-2px);
  box-shadow: 0 14px 36px -6px rgba(212,175,55,.6);
  filter: brightness(1.08);
}
.btn-wine {
  background: var(--grad-wine);
  color: #fff;
  box-shadow: 0 8px 28px -6px rgba(139,26,74,.45);
}
.btn-wine:hover { transform:translateY(-2px); filter:brightness(1.1) }
.btn-outline {
  background: transparent;
  border-color: var(--line-gold);
  color: var(--gold-light);
}
.btn-outline:hover { background: var(--gold-dim); border-color: var(--gold) }
.btn-lg { padding: 16px 34px; font-size: 1.05rem }
.btn-block { display:flex; width:100% }
.btn:active { transform:scale(.975) }

/* ── badge / pill ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .7rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: var(--r-pill);
  border: 1px solid var(--line-gold);
  color: var(--gold-light);
  background: var(--gold-dim);
}
.badge .dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--rose);
  box-shadow: 0 0 8px var(--rose);
  animation: pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.8)} }

/* ── hero ── */
.hero {
  position: relative;
  padding: 80px 0 90px;
  overflow: hidden;
}
.hero-bg-glow {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(ellipse 70% 60% at 85% 10%, rgba(212,175,55,.12), transparent 65%),
    radial-gradient(ellipse 60% 50% at 10% 80%, rgba(139,26,74,.18), transparent 65%);
}
.hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
  position: relative;
  z-index: 1;
}
.hero h1 {
  font-size: clamp(2.6rem,5.5vw,4.4rem);
  margin: 20px 0 20px;
  line-height: 1.06;
}
.hero .lead {
  font-size: 1.12rem;
  color: var(--muted);
  max-width: 520px;
  margin-bottom: 32px;
}
.hero .lead strong { color: var(--gold-light); font-weight: 600 }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:32px }
.hero-trust {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 20px;
  color: var(--muted);
  font-size: .88rem;
}
.hero-trust span { display:inline-flex; align-items:center; gap:6px }
.hero-trust .chk { color: var(--gold); font-weight: 700 }

/* hero visual side */
.hero-visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
.hero-screen {
  position: relative;
  width: 100%;
  max-width: 460px;
  aspect-ratio: 16/10;
  border-radius: var(--r-lg);
  background: linear-gradient(135deg,#1a0a10,#200d18);
  border: 1px solid var(--line-gold);
  box-shadow:
    0 0 0 1px rgba(212,175,55,.08),
    0 40px 80px -20px rgba(0,0,0,.8),
    var(--glow-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.hero-screen-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 24px;
  width: 100%;
}
.tv-thumb {
  border-radius: 10px;
  background: linear-gradient(135deg,#1e0d15,#2a1020);
  border: 1px solid rgba(212,175,55,.12);
  aspect-ratio: 16/9;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.8rem;
  transition: var(--t);
  cursor: default;
}
.tv-thumb:hover { transform:scale(1.04); border-color:rgba(212,175,55,.3) }
.tv-thumb.active {
  border-color: var(--gold);
  box-shadow: 0 0 20px rgba(212,175,55,.2);
}
.screen-badge {
  position: absolute;
  background: var(--grad);
  color: #0a0608;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: .72rem;
  padding: 5px 12px;
  border-radius: var(--r-pill);
}
.screen-badge.live { top: -12px; right: 20px }
.screen-badge.hd  { bottom: -12px; left: 20px; background: var(--grad-wine); color:#fff }

.float-chip {
  position: absolute;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(10,6,8,.9);
  border: 1px solid var(--line-gold);
  backdrop-filter: blur(12px);
  padding: 10px 16px;
  border-radius: var(--r-pill);
  font-size: .82rem;
  font-weight: 600;
  box-shadow: 0 12px 32px -8px #000;
  z-index: 2;
}
.float-chip .fc-dot { width:8px;height:8px;border-radius:50%;background:var(--rose);box-shadow:0 0 8px var(--rose) }
.chip-1 { top: -16px; left: -12px; animation: floaty 5s ease-in-out infinite }
.chip-2 { bottom: -16px; right: -12px; animation: floaty 6.5s ease-in-out .5s infinite }
@keyframes floaty { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-10px)} }

/* ── stats ── */
.stats-row {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 16px;
}
.stat-card {
  background: var(--surface);
  border: 1px solid var(--line-gold);
  border-radius: var(--r);
  padding: 24px 20px;
  text-align: center;
  transition: var(--t);
}
.stat-card:hover { transform:translateY(-4px); box-shadow:var(--glow-gold) }
.stat-card .num {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.1rem;
  background: var(--grad);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  line-height: 1;
}
.stat-card .lbl { color: var(--muted); font-size: .84rem; margin-top: 6px }

/* ── seções ── */
section { padding: 80px 0 }
.sec-head { margin-bottom: 48px }
.sec-head.center { text-align:center; display:flex; flex-direction:column; align-items:center }
.sec-head .badge { margin-bottom: 16px }
.sec-title {
  font-family: var(--font-display);
  font-size: clamp(1.9rem,3.8vw,2.8rem);
  margin-bottom: 14px;
}
.sec-sub { color:var(--muted); font-size:1.02rem; max-width:600px }

/* ── cards de recurso (bento) ── */
.bento { display:grid; grid-template-columns:repeat(3,1fr); gap:18px }
.feat-card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px;
  transition: var(--t);
}
.feat-card:hover { border-color:var(--line-gold); transform:translateY(-5px); box-shadow:var(--glow-gold) }
.feat-card.span2 { grid-column: span 2 }
.feat-card.highlight {
  background: linear-gradient(135deg,rgba(212,175,55,.12),rgba(139,26,74,.08));
  border-color: var(--line-gold);
}
.feat-icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  background: var(--gold-dim);
  border: 1px solid var(--line-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  margin-bottom: 18px;
}
.feat-card h3 { font-size: 1.18rem; margin-bottom: 10px }
.feat-card p { color: var(--muted); font-size: .93rem; line-height: 1.6 }

/* ── como funciona ── */
.steps { display:grid; grid-template-columns:repeat(4,1fr); gap:18px }
.step {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px 22px;
  position: relative;
  transition: var(--t);
}
.step:hover { border-color:var(--line-gold); transform:translateY(-4px) }
.step-num {
  display: inline-block;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: .72rem;
  letter-spacing: .12em;
  color: #0a0608;
  background: var(--grad);
  padding: 4px 12px;
  border-radius: var(--r-pill);
  margin-bottom: 16px;
}
.step h3 { font-size: 1.1rem; margin-bottom: 8px }
.step p { color:var(--muted); font-size:.9rem }

/* ── planos ── */
.plans { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; align-items:stretch }
.plan {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px 22px;
  display: flex;
  flex-direction: column;
  transition: var(--t);
  position: relative;
}
.plan:hover { transform:translateY(-6px); border-color:var(--line-gold); box-shadow:var(--glow-gold) }
.plan.featured {
  border-color: var(--gold);
  background: linear-gradient(180deg,rgba(212,175,55,.1),var(--surface));
}
.plan-label {
  align-self: flex-start;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: var(--r-pill);
  margin-bottom: 18px;
  color: var(--gold-light);
  background: var(--gold-dim);
  border: 1px solid var(--line-gold);
}
.plan.featured .plan-label {
  background: var(--grad);
  color: #0a0608;
  border: none;
}
.plan .price {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 2.5rem;
  line-height: 1;
}
.plan .price small { font-size:.9rem; color:var(--muted); font-weight:600 }
.plan .per { color:var(--muted-2); font-size:.83rem; margin:6px 0 20px }
.plan ul { display:flex; flex-direction:column; gap:10px; margin-bottom:24px }
.plan li { display:flex; gap:9px; font-size:.9rem; color:var(--muted) }
.plan li::before { content:"✦"; color:var(--gold); font-size:.7rem; margin-top:4px; flex-shrink:0 }
.plan .btn { margin-top:auto }
.plan-best {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--grad);
  color: #0a0608;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: .65rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: var(--r-pill);
  white-space: nowrap;
}

/* ── depoimentos ── */
.quotes { display:grid; grid-template-columns:repeat(3,1fr); gap:18px }
.quote {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 26px;
  display: flex;
  flex-direction: column;
  transition: var(--t);
}
.quote:hover { border-color:var(--line-gold); transform:translateY(-4px) }
.stars { color:#fbbf24; font-size:1rem; letter-spacing:2px; margin-bottom:12px }
.quote p { color:var(--muted); font-size:.93rem; margin-bottom:18px; flex:1; font-style:italic }
.quote p::before { content:'"'; color:var(--gold); font-size:1.4rem; line-height:1; font-family:serif }
.quote .who { display:flex; align-items:center; gap:12px; margin-top:auto }
.av {
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--grad);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-weight: 800;
  font-size: .9rem;
  color: #0a0608;
  flex-shrink: 0;
}
.who-info b { font-size: .9rem; display:block }
.who-info span { font-size: .77rem; color: var(--muted-2) }
.who-tag { margin-left:auto; font-size:.7rem; color:var(--gold-light); font-weight:700; font-family:var(--font-display) }

/* ── FAQ ── */
.faq-wrap { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:10px }
.faq {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r);
  overflow: hidden;
  transition: border-color var(--t);
}
.faq[open] { border-color: var(--line-gold) }
.faq summary {
  list-style: none;
  cursor: pointer;
  padding: 20px 22px;
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;
}
.faq summary::-webkit-details-marker { display:none }
.faq summary .ic {
  margin-left: auto;
  width: 26px; height: 26px;
  border-radius: 50%;
  border: 1px solid var(--line-gold);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gold);
  font-size: .9rem;
  transition: var(--t);
  flex-shrink: 0;
}
.faq[open] summary .ic { transform:rotate(45deg); background:var(--grad); color:#0a0608; border:none }
.faq .body { padding:0 22px 20px; color:var(--muted); font-size:.94rem; line-height:1.7 }

/* ── CTA band ── */
.cta-band {
  background: linear-gradient(135deg,#1a0a10 0%,#2a0a18 50%,#1a0a10 100%);
  border: 1px solid var(--line-gold);
  border-radius: var(--r-xl);
  padding: 60px 40px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-band::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 80% at 50% 0%, rgba(212,175,55,.12), transparent 70%);
  pointer-events: none;
}
.cta-band h2 { font-size:clamp(1.8rem,3.5vw,2.6rem); color:#fff; margin-bottom:12px; position:relative }
.cta-band p { color:var(--muted); max-width:560px; margin:0 auto 28px; position:relative }
.cta-band .btn { position:relative }

/* ── blog grid ── */
.blog-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:22px }
.post {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: var(--t);
}
.post:hover { transform:translateY(-5px); border-color:var(--line-gold); box-shadow:var(--glow-gold) }
.post-thumb {
  height: 156px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  background: linear-gradient(135deg,#1a0a10,#2a0a18);
}
.post-body { padding:22px; display:flex; flex-direction:column; flex:1 }
.post-cat {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: .65rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gold-light);
  background: var(--gold-dim);
  border: 1px solid var(--line-gold);
  padding: 3px 10px;
  border-radius: var(--r-pill);
  display: inline-block;
  margin-bottom: 12px;
}
.post h2 { font-size:1.15rem; margin-bottom:8px; line-height:1.3 }
.post p { color:var(--muted); font-size:.88rem; flex:1 }
.post .more { margin-top:14px; color:var(--rose); font-weight:700; font-size:.86rem; display:inline-flex; gap:6px }
.post .arr { transition:transform .2s }
.post:hover .arr { transform:translateX(5px) }

/* ── footer ── */
.site-footer {
  border-top: 1px solid var(--line-gold);
  padding: 56px 0 28px;
  margin-top: 80px;
}
.foot-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 36px;
  margin-bottom: 44px;
}
.foot-col strong {
  font-family: var(--font-display);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--muted-2);
  display: block;
  margin-bottom: 14px;
}
.foot-col a { display:block; color:var(--muted); font-size:.87rem; padding:5px 0; transition:var(--t) }
.foot-col a:hover { color:var(--gold-light) }
.foot-bottom {
  border-top: 1px solid var(--line);
  padding-top: 22px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  color: var(--muted-2);
  font-size: .8rem;
}

/* ── páginas internas ── */
.page-hero {
  padding: 64px 0 40px;
  border-bottom: 1px solid var(--line);
}
.page-hero h1 { font-size:clamp(2rem,4.5vw,3rem); margin:12px 0 14px }
.page-hero p { color:var(--muted); max-width:640px; font-size:1.04rem }
.bc { font-size:.8rem; color:var(--muted-2); display:flex; align-items:center; gap:.5rem; flex-wrap:wrap }
.bc a { color:var(--muted-2) }
.bc a:hover { color:var(--gold-light) }
.bc span { opacity:.5 }

.prose { max-width:840px; margin:0 auto }
.prose h2 { font-size:clamp(1.4rem,3vw,1.9rem); margin:2.5rem 0 1rem }
.prose h3 { font-size:1.15rem; color:var(--gold-light); margin:1.8rem 0 .65rem }
.prose p { color:var(--muted); margin-bottom:1rem; line-height:1.75 }
.prose strong { color:var(--text); font-weight:700 }
.prose a { color:var(--gold); font-weight:600 }
.prose a:hover { text-decoration:underline }
.prose ul { margin:0 0 1.2rem; display:flex; flex-direction:column; gap:.5rem }
.prose ul li { display:flex; gap:.7rem; color:var(--muted); font-size:.95rem }
.prose ul li::before { content:"✦"; color:var(--gold); font-size:.65rem; margin-top:5px; flex-shrink:0 }

.info-box {
  background: rgba(212,175,55,.06);
  border: 1px solid var(--line-gold);
  border-radius: var(--r);
  padding: 1.1rem 1.4rem;
  margin: 1.5rem 0;
}
.info-box .lbl { font-size:.68rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--gold); margin-bottom:.4rem; font-family:var(--font-display) }
.info-box p { margin:0; font-size:.92rem }

/* ── utilitários ── */
.mt-4 { margin-top:1rem }
.mt-8 { margin-top:2rem }
a:focus-visible, button:focus-visible { outline:2px solid var(--gold); outline-offset:3px; border-radius:6px }
.mob-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:250 }
.mob-overlay.on { display:block }

/* ── responsivo ── */
@media (max-width:1024px) {
  .foot-grid { grid-template-columns:1fr 1fr }
  .hero-grid { gap:36px }
}
@media (max-width:900px) {
  .hero-grid { grid-template-columns:1fr; text-align:center }
  .hero-visual { order:-1 }
  .hero .lead { margin:0 auto 28px }
  .hero-actions { justify-content:center }
  .hero-trust { justify-content:center }
  .stats-row { grid-template-columns:repeat(2,1fr) }
  .bento { grid-template-columns:1fr 1fr }
  .feat-card.span2 { grid-column:span 2 }
  .steps { grid-template-columns:1fr 1fr }
  .plans { grid-template-columns:1fr 1fr }
  .quotes { grid-template-columns:1fr 1fr }
  .blog-grid { grid-template-columns:1fr 1fr }
}
@media (max-width:680px) {
  .nav-links {
    position: fixed;
    inset: 72px 0 auto 0;
    flex-direction: column;
    align-items: stretch;
    background: rgba(10,6,8,.97);
    border-bottom: 1px solid var(--line-gold);
    padding: 12px;
    gap: 2px;
    transform: translateY(-120%);
    transition: transform var(--t);
    max-height: calc(100vh - 72px);
    overflow-y: auto;
    z-index: 299;
  }
  .nav-links.open { transform: translateY(0) }
  .nav-links a { padding:13px 14px }
  .nav-cta { margin:8px 0 0 }
  .burger { display:flex; align-items:center; justify-content:center }
  .hero { padding:56px 0 64px }
  section { padding:60px 0 }
  .bento { grid-template-columns:1fr }
  .feat-card.span2 { grid-column:span 1 }
  .steps { grid-template-columns:1fr }
  .plans { grid-template-columns:1fr }
  .quotes { grid-template-columns:1fr }
  .blog-grid { grid-template-columns:1fr }
  .stats-row { grid-template-columns:1fr 1fr }
  .foot-grid { grid-template-columns:1fr }
  .cta-band { padding:40px 22px }
  .topbar { display:none }
  .hero-screen { max-width:340px }
}
@media (prefers-reduced-motion:reduce) {
  *, *::before, *::after { animation-duration:.01ms!important; transition-duration:.01ms!important }
}
