/* ==========================================================================
   Revolver — marketing site design system
   Brand sampled from the production landing: cream canvas, forest-green accent,
   Instrument Sans + JetBrains Mono. Mobile-first, fluid, responsive.
   ========================================================================== */

:root{
  --bg:#fbfaf6;
  --bg-2:#f3f1ea;
  --card:#ffffff;
  --ink:#15140f;
  --muted:#5a564d;
  --muted-2:#7a7268;
  --faint:#9a8f80;
  --accent:#3f6b3a;
  --accent-dark:#345c30;
  --accent-tint:rgba(63,107,58,.09);
  --accent-tint-2:rgba(63,107,58,.05);
  --hairline:rgba(20,18,12,.10);
  --hairline-soft:rgba(20,18,12,.06);
  --on-accent:#fbfaf6;

  --d-bg:#15140f;
  --d-ink:#fbfaf6;
  --d-muted:#b8b0a2;
  --d-line:rgba(251,250,246,.13);
  --d-green:#8fbf86;

  --sans:"Instrument Sans",-apple-system,system-ui,"Segoe UI",sans-serif;
  --mono:"JetBrains Mono",ui-monospace,monospace;

  --maxw:1240px;
  --pad-x:clamp(20px,5vw,64px);
  --radius:18px;
  --radius-lg:26px;
  --nav-h:72px;

  --t-display:clamp(40px,7.2vw,86px);
  --t-h1:clamp(34px,5.4vw,68px);
  --t-h2:clamp(28px,3.8vw,50px);
  --t-h3:clamp(22px,2.4vw,30px);
  --t-lede:clamp(18px,2.1vw,24px);
  --t-body:clamp(16px,1.15vw,19px);
  --t-small:15px;
  --t-label:13px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; overflow-x:clip; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  font-size:var(--t-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--accent); color:var(--on-accent); }

/* ---------- layout ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad-x); }
.section{ padding-block:clamp(64px,9vw,128px); }
.section-sm{ padding-block:clamp(48px,6vw,84px); }
.bleed{ background:var(--bg-2); }
.dark-sec{ background:var(--d-bg); color:var(--d-ink); }

.eyebrow{
  font-family:var(--mono); font-size:var(--t-label); font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--accent);
  display:inline-flex; align-items:center; gap:11px;
}
.eyebrow::before{ content:""; width:26px; height:1.5px; background:currentColor; }
.eyebrow.nobar::before{ display:none; }
.dark-sec .eyebrow{ color:var(--d-green); }

h1,h2,h3,h4{ font-weight:600; letter-spacing:-.03em; line-height:1.04; text-wrap:balance; }
.h-display{ font-size:var(--t-display); letter-spacing:-.04em; line-height:1.0; }
h1,.h1{ font-size:var(--t-h1); }
h2,.h2{ font-size:var(--t-h2); }
h3,.h3{ font-size:var(--t-h3); line-height:1.12; }
.ital{ font-style:italic; }
.grn{ color:var(--accent); }
.dark-sec .grn{ color:var(--d-green); }

.lede{ font-size:var(--t-lede); line-height:1.45; color:var(--muted); font-weight:400; }
.muted{ color:var(--muted); }
.measure{ max-width:60ch; }
.measure-sm{ max-width:46ch; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:9px;
  font-size:16px; font-weight:600; letter-spacing:-.01em;
  padding:14px 24px; border-radius:999px; border:1.5px solid transparent;
  background:var(--ink); color:var(--on-accent);
  transition:transform .15s ease, background .15s ease, opacity .15s ease;
  white-space:nowrap;
}
.btn:hover{ background:#000; transform:translateY(-1px); }
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translateX(3px); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--hairline); }
.btn-ghost:hover{ background:var(--ink); color:var(--on-accent); border-color:var(--ink); }
.btn-green{ background:var(--accent); }
.btn-green:hover{ background:var(--accent-dark); }
.btn-sm{ padding:10px 18px; font-size:14px; }
.btn-lg{ padding:17px 30px; font-size:17px; }
.dark-sec .btn{ background:var(--d-ink); color:var(--d-bg); }
.dark-sec .btn:hover{ background:#fff; }
.dark-sec .btn-ghost{ background:transparent; color:var(--d-ink); border-color:var(--d-line); }
.dark-sec .btn-ghost:hover{ background:var(--d-ink); color:var(--d-bg); }

/* ---------- badges / chips ---------- */
.badge{
  display:inline-flex; align-items:center; gap:7px;
  font-family:var(--mono); font-size:11px; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase;
  padding:5px 11px; border-radius:999px;
  background:var(--bg-2); color:var(--muted-2); border:1px solid var(--hairline-soft);
}
.badge .dot{ width:6px; height:6px; border-radius:999px; background:currentColor; }
.badge-free{ background:var(--accent-tint); color:var(--accent); border-color:transparent; }
.badge-soon{ background:rgba(20,18,12,.06); color:var(--muted-2); border-color:transparent; }
.pill-note{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--mono); font-size:12px; letter-spacing:.06em;
  color:var(--muted); background:rgba(255,255,255,.7);
  border:1px solid var(--hairline-soft); padding:8px 15px; border-radius:999px;
}
.chips{ display:flex; flex-wrap:wrap; gap:9px; }
.chip{
  font-family:var(--mono); font-size:13px; font-weight:500; white-space:nowrap;
  padding:7px 13px; border-radius:999px; background:var(--accent-tint); color:var(--accent);
}
.chip-plain{ background:var(--bg-2); color:var(--muted); border:1px solid var(--hairline-soft); }

/* ---------- cards ---------- */
.card{
  background:var(--card); border:1px solid var(--hairline-soft);
  border-radius:var(--radius); padding:clamp(24px,3vw,38px);
  box-shadow:0 1px 3px rgba(20,18,12,.04);
}
.card-link{ transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease; }
.card-link:hover{ transform:translateY(-3px); box-shadow:0 14px 36px rgba(20,18,12,.09); border-color:var(--hairline); }
.num{ font-family:var(--mono); font-weight:500; color:var(--accent); font-size:16px; }
.kicker{ font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--faint); }

/* module card */
.mod{ display:flex; flex-direction:column; gap:12px; }
.mod .mod-top{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.mod .mod-name{ font-size:var(--t-h3); font-weight:600; letter-spacing:-.025em; display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.mod .mod-desc{ color:var(--muted); font-size:16px; line-height:1.45; }
.mod .mod-more{ font-family:var(--mono); font-size:13px; color:var(--accent); letter-spacing:.04em; margin-top:6px; display:inline-flex; gap:6px; }
.cico{ width:48px; height:48px; border-radius:14px; background:var(--accent-tint); color:var(--accent); display:grid; place-items:center; flex:none; }
.cico svg{ width:23px; height:23px; }

/* feature checklist */
.flist{ display:flex; flex-direction:column; gap:22px; list-style:none; }
.flist li{ display:grid; grid-template-columns:30px 1fr; gap:16px; align-items:start; }
.flist .ck{
  width:26px; height:26px; border-radius:999px; background:var(--accent-tint);
  color:var(--accent); display:grid; place-items:center; margin-top:2px; flex:none;
  font-size:14px; font-weight:700;
}
.flist .ft{ font-size:19px; font-weight:600; letter-spacing:-.01em; }
.flist .fd{ color:var(--muted); font-size:16px; line-height:1.45; margin-top:3px; }

/* stat row */
.stat .sv{ font-size:clamp(30px,4vw,46px); font-weight:600; letter-spacing:-.03em; line-height:1; }
.stat .sl{ font-weight:600; margin-top:12px; }
.stat .sd{ color:var(--muted-2); font-size:15px; margin-top:4px; }

/* grids */
.grid{ display:grid; gap:clamp(16px,2vw,24px); }
.g-2{ grid-template-columns:repeat(2,1fr); }
.g-3{ grid-template-columns:repeat(3,1fr); }
.g-4{ grid-template-columns:repeat(4,1fr); }

/* ---------- mockups (app-style cards) ---------- */
.mock{
  background:var(--card); border:1px solid var(--hairline);
  border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:0 30px 70px -30px rgba(20,18,12,.28);
}
.mock-bar{ display:flex; align-items:center; gap:7px; padding:13px 16px; border-bottom:1px solid var(--hairline-soft); background:var(--bg-2); }
.mock-bar i{ width:10px; height:10px; border-radius:999px; background:var(--hairline); }
.mock-bar .url{ font-family:var(--mono); font-size:11px; color:var(--faint); margin-left:10px; }
.mock-body{ padding:22px; }
.mock-row{ display:flex; align-items:center; justify-content:space-between; padding:13px 0; border-bottom:1px solid var(--hairline-soft); font-size:14px; }
.mock-row:last-child{ border-bottom:0; }
.mock-row .mono{ font-family:var(--mono); font-size:12px; color:var(--muted-2); }
.mock-stat{ display:flex; gap:10px; }
.mock-stat .ms{ flex:1; background:var(--bg-2); border-radius:12px; padding:14px; }
.mock-stat .ms .v{ font-size:22px; font-weight:600; letter-spacing:-.02em; }
.mock-stat .ms .k{ font-family:var(--mono); font-size:10px; letter-spacing:.08em; text-transform:uppercase; color:var(--faint); margin-bottom:4px; }
.tag-ok{ font-family:var(--mono); font-size:11px; color:var(--accent); background:var(--accent-tint); padding:3px 9px; border-radius:999px; }
.mock-shot{ display:block; width:100%; height:auto; }
.mock-bar .shot-soon{ margin-left:auto; font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--muted-2); background:rgba(20,18,12,.06); padding:3px 9px; border-radius:999px; }
/* blue/white chrome to match the app screenshots */
.mock-app{ border-color:#e3e8ef; box-shadow:0 32px 72px -30px rgba(30,41,59,.30); }
.mock-app .mock-bar{ background:#f7f9fc; border-bottom-color:#eef2f7; }
.mock-app .mock-bar i{ background:#cbd5e1; }
.mock-app .mock-bar .url{ color:#94a3b8; }
.mock-app .mock-bar .shot-soon{ color:#64748b; background:#eef2f7; }

/* placeholder media */
.ph{
  border-radius:var(--radius); border:1px solid var(--hairline);
  background:
    repeating-linear-gradient(135deg,var(--bg-2),var(--bg-2) 11px,rgba(63,107,58,.05) 11px,rgba(63,107,58,.05) 22px);
  display:grid; place-items:center; color:var(--faint);
  font-family:var(--mono); font-size:12px; letter-spacing:.06em; min-height:240px; text-align:center; padding:24px;
}

/* ==========================================================================
   NAVBAR + MEGA MENU
   ========================================================================== */
.nav{
  position:sticky; top:0; z-index:100;
  background:rgba(251,250,246,.82); backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid transparent; transition:border-color .2s ease, background .2s ease;
}
.nav.scrolled{ border-bottom-color:var(--hairline-soft); }
.nav-in{ height:var(--nav-h); display:flex; align-items:center; gap:18px; }
.brand{ display:flex; align-items:center; gap:11px; font-weight:600; font-size:21px; letter-spacing:-.03em; flex:none; }
.brand .mk{ width:23px; height:23px; border-radius:999px; border:2.5px solid var(--ink); position:relative; }
.brand .mk::after{ content:""; position:absolute; inset:4px; border-radius:999px; background:var(--accent); }

.nav-links{ display:flex; align-items:center; gap:2px; margin-inline:auto; position:relative; }
.nav-item{ position:static; }
.nav-trigger{
  display:inline-flex; align-items:center; gap:6px;
  font-size:15px; font-weight:500; color:var(--ink);
  background:transparent; border:0; padding:10px 13px; border-radius:10px;
  transition:background .15s ease;
}
.nav-trigger:hover, .nav-item.open .nav-trigger{ background:var(--accent-tint-2); }
.nav-trigger .car{ width:8px; height:8px; border-right:1.6px solid var(--muted-2); border-bottom:1.6px solid var(--muted-2); transform:rotate(45deg) translateY(-2px); transition:transform .2s ease; }
.nav-item.open .nav-trigger .car{ transform:rotate(-135deg) translateY(-2px); }

.nav-cta{ display:flex; align-items:center; gap:10px; flex:none; }
.nav-login{ font-size:15px; font-weight:600; color:var(--ink); padding:10px 12px; border-radius:10px; transition:background .15s ease; white-space:nowrap; }
.nav-login:hover{ background:var(--accent-tint-2); }

/* mega panel */
.mega{
  position:absolute; top:calc(100% + 10px); left:50%; transform:translateX(-50%) translateY(8px);
  width:min(880px,92vw);
  background:var(--card); border:1px solid var(--hairline); border-radius:var(--radius);
  box-shadow:0 30px 80px -24px rgba(20,18,12,.30);
  padding:26px; opacity:0; visibility:hidden; pointer-events:none;
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
}
.nav-item.open .mega{ opacity:1; visibility:visible; pointer-events:auto; transform:translateX(-50%) translateY(0); }
.mega-lead{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--faint); margin-bottom:16px; }
.mega-cols{ display:grid; gap:26px; }
.mega-col h4{ font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); margin-bottom:12px; }
.mega-link{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 12px; border-radius:11px; transition:background .14s ease; }
.mega-link:hover{ background:var(--bg-2); }
.mega-link .ml-name{ font-weight:600; font-size:16px; letter-spacing:-.01em; }
.mega-link .ml-desc{ font-size:13px; color:var(--muted-2); margin-top:1px; }
.mega-link .badge{ flex:none; }
.mega-foot{ margin-top:20px; padding-top:18px; border-top:1px solid var(--hairline-soft); display:flex; align-items:center; justify-content:space-between; gap:14px; font-size:14px; color:var(--muted); }

.mega-2{ grid-template-columns:1fr 1fr; }
.mega-3{ grid-template-columns:repeat(3,1fr); }

/* mobile nav */
.nav-burger{ display:none; width:42px; height:42px; border:0; background:transparent; flex-direction:column; gap:5px; justify-content:center; align-items:center; }
.nav-burger span{ width:22px; height:2px; background:var(--ink); border-radius:2px; transition:transform .2s ease, opacity .2s ease; }
.mobile-panel{ display:none; }

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer{ background:var(--d-bg); color:var(--d-ink); padding-block:clamp(56px,7vw,88px) 40px; }
.footer-top{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:40px; }
.footer-brand .brand{ color:var(--d-ink); margin-bottom:18px; }
.footer-brand .brand .mk{ border-color:var(--d-ink); }
.footer-tag{ color:var(--d-muted); max-width:34ch; font-size:15px; line-height:1.5; }
.footer-soc{ display:flex; gap:10px; margin-top:22px; }
.footer-soc a{ font-family:var(--mono); font-size:12px; letter-spacing:.05em; color:var(--d-muted); border:1px solid var(--d-line); padding:8px 13px; border-radius:999px; transition:color .15s,border-color .15s; }
.footer-soc a:hover{ color:var(--d-ink); border-color:var(--d-ink); }
.footer-col h5{ font-family:var(--mono); font-size:12px; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--d-green); margin-bottom:16px; }
.footer-col a{ display:block; color:var(--d-muted); font-size:15px; padding:6px 0; transition:color .15s; }
.footer-col a:hover{ color:var(--d-ink); }
.footer-bot{ margin-top:48px; padding-top:24px; border-top:1px solid var(--d-line); display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; color:var(--d-muted); font-size:13px; font-family:var(--mono); letter-spacing:.03em; }

/* ==========================================================================
   HERO + PAGE HEADERS
   ========================================================================== */
.hero{ padding-top:clamp(48px,7vw,96px); padding-bottom:clamp(40px,5vw,72px); }
.hero h1{ margin:22px 0 24px; }
.hero .lede{ max-width:34ch; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:12px; margin-top:32px; align-items:center; }
.hero-note{ margin-top:22px; }

/* two doors */
.doors{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(16px,2vw,26px); }
.door{ display:flex; flex-direction:column; gap:18px; min-height:280px; }
.door .door-h{ font-size:clamp(26px,3vw,38px); font-weight:600; letter-spacing:-.03em; }
.door .chips{ margin-top:auto; }

/* page hero (sub pages) */
.phero{ padding-top:clamp(40px,5vw,72px); padding-bottom:clamp(32px,4vw,56px); }
.phero .crumb{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; color:var(--faint); text-transform:uppercase; display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:20px; }
.phero .crumb a:hover{ color:var(--accent); }
.phero h1{ margin:14px 0 22px; }

/* sales form */
.form-grid{ display:grid; grid-template-columns:1.05fr 1.1fr; gap:clamp(28px,4vw,64px); align-items:start; }
.field{ display:flex; flex-direction:column; gap:8px; margin-bottom:18px; }
.field label{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted-2); }
.field input{
  font-family:var(--sans); font-size:17px; color:var(--ink);
  background:var(--card); border:1.5px solid var(--hairline); border-radius:13px;
  padding:15px 17px; transition:border-color .15s ease, box-shadow .15s ease; width:100%;
}
.field input::placeholder{ color:var(--faint); }
.field input:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-tint); }
.field.err input{ border-color:#b4452f; box-shadow:0 0 0 4px rgba(180,69,47,.1); }
.field .msg{ font-size:13px; color:#b4452f; display:none; }
.field.err .msg{ display:block; }
.ctype{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.ctype .opt{ display:flex; align-items:center; gap:13px; padding:18px 20px; border-radius:13px; border:1.5px solid var(--hairline); background:var(--card); font-weight:500; transition:border-color .15s, background .15s; }
.ctype .opt:hover{ border-color:var(--accent-line,rgba(63,107,58,.4)); }
.ctype .opt .rd{ width:21px; height:21px; border-radius:999px; border:2px solid var(--faint); flex:none; transition:.15s; }
.ctype .opt.on{ border-color:var(--accent); background:var(--accent-tint); color:var(--accent-dark); }
.ctype .opt.on .rd{ border-color:var(--accent); background:var(--accent); box-shadow:inset 0 0 0 4px var(--accent-tint); }
.form-card{ position:relative; }
.form-ok{ display:none; flex-direction:column; gap:16px; text-align:center; padding:30px 10px; }
.form-card.done .form-real{ display:none; }
.form-card.done .form-ok{ display:flex; }
.ok-mark{ width:64px; height:64px; border-radius:999px; background:var(--accent-tint); color:var(--accent); display:grid; place-items:center; margin:0 auto 4px; font-size:30px; }

/* retos / problem list */
.retos{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px; }
.reto{ display:flex; gap:14px; align-items:flex-start; padding:22px 24px; background:var(--card); border:1px solid var(--hairline-soft); border-radius:14px; }
.reto .rx{ font-family:var(--mono); color:var(--accent); font-size:15px; flex:none; }

/* persona */
.persona{ display:flex; flex-direction:column; gap:10px; }
.persona .pn{ font-size:20px; font-weight:600; letter-spacing:-.01em; }
.persona .pr{ color:var(--muted); font-size:15px; }

/* split section */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,72px); align-items:center; }
.split.rev .split-media{ order:-1; }

/* utility */
.center{ text-align:center; }
.mx-auto{ margin-inline:auto; }
.mt-s{ margin-top:18px; } .mt-m{ margin-top:32px; } .mt-l{ margin-top:52px; }
.stack-s{ display:flex; flex-direction:column; gap:14px; }
.flow > * + *{ margin-top:20px; }
.sec-head{ max-width:62ch; margin-bottom:clamp(36px,4vw,60px); }
.sec-head .eyebrow{ margin-bottom:18px; }
.sec-head.center{ margin-inline:auto; }

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:1024px){
  .mega{ width:min(720px,92vw); }
}
@media (max-width:980px){
  .nav-links, .nav-cta .btn-ghost, .nav-login{ display:none; }
  .nav-burger{ display:flex; }
  .doors, .g-4, .g-3, .g-2, .form-grid, .split, .retos, .mega-2, .mega-3{ grid-template-columns:1fr; }
  .split.rev .split-media{ order:0; }
  .footer-top{ grid-template-columns:1fr 1fr; gap:32px; }
  .footer-brand{ grid-column:1 / -1; }

  /* mobile menu */
  .mobile-panel{
    display:block; position:fixed; inset:var(--nav-h) 0 0; z-index:99;
    background:var(--bg); overflow-y:auto; padding:18px var(--pad-x) 60px;
    transform:translateX(100%); transition:transform .26s cubic-bezier(.4,0,.2,1);
    visibility:hidden;
  }
  body.menu-open .mobile-panel{ transform:none; visibility:visible; }
  body.menu-open{ overflow:hidden; }
  body.menu-open .nav-burger span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  body.menu-open .nav-burger span:nth-child(2){ opacity:0; }
  body.menu-open .nav-burger span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .m-acc{ border-bottom:1px solid var(--hairline-soft); }
  .m-acc-head{ display:flex; align-items:center; justify-content:space-between; width:100%; background:transparent; border:0; padding:20px 2px; font-size:21px; font-weight:600; letter-spacing:-.02em; color:var(--ink); }
  .m-acc-head .car{ width:9px; height:9px; border-right:2px solid var(--muted-2); border-bottom:2px solid var(--muted-2); transform:rotate(45deg); transition:transform .2s; }
  .m-acc.open .m-acc-head .car{ transform:rotate(-135deg); }
  .m-acc-body{ display:none; padding:0 2px 18px; flex-direction:column; gap:2px; }
  .m-acc.open .m-acc-body{ display:flex; }
  .m-acc-body a{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:11px 14px; border-radius:10px; color:var(--muted); font-size:16px; }
  .m-acc-body a:hover{ background:var(--bg-2); color:var(--ink); }
  .m-link{ display:block; padding:20px 2px; font-size:21px; font-weight:600; letter-spacing:-.02em; border-bottom:1px solid var(--hairline-soft); }
  .mobile-cta{ display:flex; flex-direction:column; gap:12px; margin-top:28px; }
  .mobile-cta .btn{ justify-content:center; }
}
@media (max-width:560px){
  .hero-cta .btn{ flex:1; justify-content:center; }
  .ctype{ grid-template-columns:1fr; }
  .footer-top{ grid-template-columns:1fr; }
}
