/* ============================================================
   MENU ÁGIL — Section styles
   ============================================================ */

/* ---------- Logos / trust strip ---------- */
.logos { padding: 30px 0 8px; }
.logos__lead { text-align: center; font-family: var(--mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 22px; }
.logos__row { display: flex; flex-wrap: wrap; gap: 14px 40px; align-items: center; justify-content: center; }
.logos__row span { font-weight: 800; font-size: 17px; color: #aab3c4; letter-spacing: -.02em; display: inline-flex; align-items: center; gap: 8px; }
.logos__row span svg { width: 18px; height: 18px; opacity: .8; }

/* ---------- Section heading block ---------- */
.shead { max-width: 640px; }
.shead.center { margin: 0 auto; }

/* ---------- Feature row (alternating) ---------- */
.frow { display: grid; grid-template-columns: 1fr 1.12fr; gap: 60px; align-items: center; }
.frow + .frow { margin-top: 110px; }
.frow--rev .frow__media { order: -1; }
.frow__media { position: relative; }
.feat-ico {
  width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center;
  background: var(--primary-soft); color: var(--primary); margin-bottom: 20px;
}
.feat-ico svg { width: 23px; height: 23px; }
.feat-ico--green { background: var(--green-soft); color: var(--green); }
.feat-ico--amber { background: var(--amber-soft); color: var(--amber); }

/* order journey timeline */
.journey { display: grid; gap: 0; }
.jstep { display: flex; gap: 14px; position: relative; padding-bottom: 18px; }
.jstep:last-child { padding-bottom: 0; }
.jstep::before { content: ""; position: absolute; left: 13px; top: 26px; bottom: -2px; width: 2px; background: var(--line); }
.jstep:last-child::before { display: none; }
.jstep.done::before { background: var(--green); }
.jdot { width: 28px; height: 28px; border-radius: 50%; flex: none; display: grid; place-items: center; background: #fff; border: 2px solid var(--line); z-index: 1; }
.jstep.done .jdot { background: var(--green); border-color: var(--green); color: #fff; }
.jstep.done .jdot svg { width: 13px; height: 13px; }
.jstep.now .jdot { border-color: var(--green); background: var(--green-soft); }
.jbody b { font-size: 14px; font-weight: 700; display: block; }
.jstep:not(.done):not(.now) .jbody b { color: var(--ink-3); }
.jbody small { font-size: 12px; color: var(--ink-3); }

/* ---------- Stats band ---------- */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }
.stat { text-align: center; }
.stat .n { font-size: clamp(32px, 4vw, 50px); font-weight: 800; letter-spacing: -.03em; color: #fff; }
.stat .n span { color: #7fb0ff; }
.stat .l { color: var(--on-navy-2); font-size: 14.5px; margin-top: 6px; }
.stats .div { width: 1px; background: var(--line-navy); }

/* ---------- Feature grid (3-up cards) ---------- */
.fgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 56px; }
.fcard { padding: 26px; border-radius: var(--r-lg); }
.fcard .feat-ico { margin-bottom: 18px; }
.fcard h3 { font-size: 19px; letter-spacing: -.02em; }
.fcard p { color: var(--ink-2); font-size: 14.5px; margin-top: 9px; line-height: 1.6; }

/* ---------- Phone mockup ---------- */
.phone {
  width: 286px; border-radius: 40px; background: #0b1426; padding: 11px;
  box-shadow: var(--sh-lg); position: relative; margin: 0 auto;
}
.phone__screen { border-radius: 30px; overflow: hidden; background: #fff; }
.phone__status { display: flex; justify-content: space-between; align-items: center; padding: 10px 20px 6px; font-size: 11px; font-weight: 700; color: var(--ink); }
.phone__status .dotsr { display: flex; gap: 4px; align-items: center; }
.phone__notch { position: absolute; top: 11px; left: 50%; transform: translateX(-50%); width: 110px; height: 22px; background: #0b1426; border-radius: 0 0 14px 14px; z-index: 3; }

/* digital menu inside phone */
.dm__hero { height: 96px; position: relative; }
.dm__hero .ph { height: 100%; }
.dm__rest { padding: 13px 15px 0; }
.dm__rest .nm { font-size: 16px; font-weight: 800; letter-spacing: -.02em; }
.dm__rest .meta { font-size: 11px; color: var(--ink-3); margin-top: 2px; display: flex; gap: 8px; }
.dm__rest .meta b { color: var(--green); }
.dm__tabs { display: flex; gap: 7px; padding: 13px 15px 10px; overflow: hidden; }
.dm__tabs span { font-size: 11px; font-weight: 700; padding: 6px 11px; border-radius: 999px; background: var(--bg-soft-2); color: var(--ink-2); white-space: nowrap; }
.dm__tabs span.on { background: var(--primary); color: #fff; }
.dm__item { display: flex; gap: 11px; padding: 11px 15px; border-top: 1px solid var(--line); align-items: center; }
.dm__item .thumb { width: 50px; height: 50px; border-radius: 11px; flex: none; }
.dm__item .info { flex: 1; min-width: 0; }
.dm__item .info .t { font-size: 13px; font-weight: 700; }
.dm__item .info .d { font-size: 10.5px; color: var(--ink-3); line-height: 1.35; margin-top: 1px; }
.dm__item .info .pr { font-size: 13px; font-weight: 800; color: var(--ink); margin-top: 4px; }
.dm__item .add { width: 30px; height: 30px; border-radius: 9px; background: var(--primary); color: #fff; display: grid; place-items: center; flex: none; }
.dm__item .add svg { width: 15px; height: 15px; }
.dm__cart { margin: 11px 13px 13px; background: var(--primary); color: #fff; border-radius: 14px; padding: 12px 15px; display: flex; align-items: center; justify-content: space-between; }
.dm__cart .l { font-size: 12.5px; font-weight: 700; }
.dm__cart .l small { display: block; font-weight: 600; opacity: .8; font-size: 10.5px; }
.dm__cart .pr { font-size: 15px; font-weight: 800; }

/* QR card next to phone */
.qr-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-md);
  padding: 18px; width: 200px; text-align: center;
}
.qr-card .qr {
  width: 132px; height: 132px; margin: 0 auto 12px; border-radius: 12px; padding: 9px; background: #fff; border: 1px solid var(--line);
  display: grid; grid-template-columns: repeat(11, 1fr); grid-template-rows: repeat(11, 1fr); gap: 2px;
}
.qr i { background: var(--ink); border-radius: 1px; }
.qr i.o { background: transparent; }
.qr-card .qt { font-size: 13px; font-weight: 800; }
.qr-card .qs { font-size: 11px; color: var(--ink-3); margin-top: 2px; }

.phone-stage { display: flex; align-items: center; justify-content: center; gap: 26px; flex-wrap: wrap; }

/* ---------- Tabs (gestão) ---------- */
.tabs { display: inline-flex; gap: 4px; padding: 4px; background: var(--bg-soft-2); border-radius: var(--r-pill); margin-bottom: 26px; flex-wrap: wrap; }
.tabs button {
  border: 0; background: transparent; font-family: var(--font); font-weight: 700; font-size: 13.5px;
  padding: 9px 17px; border-radius: var(--r-pill); cursor: pointer; color: var(--ink-2); transition: all .15s;
}
.tabs button.on { background: #fff; color: var(--ink); box-shadow: var(--sh-xs); }
.tabpane { display: none; }
.tabpane.on { display: block; }

/* table map */
.tmap { display: grid; grid-template-columns: repeat(5, 1fr); gap: 12px; }
.table {
  aspect-ratio: 1; border-radius: 14px; border: 1.5px solid var(--line); display: grid; place-items: center;
  position: relative; background: #fff; text-align: center;
}
.table .tn { font-size: 15px; font-weight: 800; }
.table .ts { font-size: 10px; font-family: var(--mono); margin-top: 2px; }
.table.free { border-color: var(--line); }
.table.free .ts { color: var(--ink-3); }
.table.busy { background: var(--primary-soft); border-color: var(--primary-soft-2); }
.table.busy .ts { color: var(--primary); }
.table.bill { background: var(--amber-soft); border-color: #f4dcb6; }
.table.bill .ts { color: var(--amber); }
.table .seat { position: absolute; font-size: 9px; color: var(--ink-3); }

/* cardápio editor row */
.menu-edit { display: grid; gap: 9px; }
.medit { display: flex; align-items: center; gap: 12px; padding: 12px 14px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.medit .th { width: 38px; height: 38px; border-radius: 9px; flex: none; }
.medit .nm { font-weight: 700; font-size: 14px; flex: 1; }
.medit .pr { font-weight: 800; font-size: 14px; font-variant-numeric: tabular-nums; }
.medit .tg { font-size: 11px; font-weight: 700; padding: 3px 9px; border-radius: 7px; }
.tg--on { background: var(--green-soft); color: var(--green); }
.tg--off { background: var(--bg-soft-2); color: var(--ink-3); }
.medit .edit { color: var(--ink-3); width: 16px; height: 16px; }

/* equipe rows */
.team { display: grid; gap: 9px; }
.trow { display: flex; align-items: center; gap: 12px; padding: 11px 14px; border: 1px solid var(--line); border-radius: 12px; background: #fff; }
.trow .av { width: 36px; height: 36px; border-radius: 50%; flex: none; display: grid; place-items: center; font-weight: 800; font-size: 13px; color: #fff; }
.trow .nm { font-weight: 700; font-size: 14px; }
.trow .ro { font-size: 11.5px; color: var(--ink-3); }
.trow .perf { margin-left: auto; text-align: right; }
.trow .perf .v { font-weight: 800; font-size: 14px; }
.trow .perf .c { font-size: 10.5px; color: var(--ink-3); }

/* ---------- Reports / charts ---------- */
.rep-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px; }
.chart-card { padding: 22px; }
.chart-card h4 { font-size: 15px; }
.chart-card .cap { font-size: 12px; color: var(--ink-3); margin-top: 2px; }
.bars { display: flex; align-items: flex-end; gap: 12px; height: 168px; margin-top: 22px; }
.bar { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 8px; height: 100%; justify-content: flex-end; }
.bar .col { width: 100%; max-width: 34px; border-radius: 7px 7px 3px 3px; background: linear-gradient(var(--primary), #7aa6f6); position: relative; }
.bar .col.peak { background: linear-gradient(var(--green), #4ec77f); }
.bar .col .v { position: absolute; top: -19px; left: 50%; transform: translateX(-50%); font-size: 10.5px; font-weight: 700; color: var(--ink-2); }
.bar .x { font-size: 11px; color: var(--ink-3); font-weight: 600; }

.donut-wrap { display: flex; align-items: center; gap: 20px; margin-top: 14px; }
.donut { width: 120px; height: 120px; border-radius: 50%; flex: none; position: relative; }
.donut::after { content: ""; position: absolute; inset: 26px; background: #fff; border-radius: 50%; }
.donut .ctr { position: absolute; inset: 0; display: grid; place-items: center; z-index: 1; text-align: center; }
.donut .ctr b { font-size: 20px; font-weight: 800; }
.donut .ctr small { font-size: 10px; color: var(--ink-3); display: block; }
.legend { display: grid; gap: 9px; }
.legend li { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--ink-2); }
.legend .sw { width: 10px; height: 10px; border-radius: 3px; flex: none; }
.legend b { margin-left: auto; color: var(--ink); font-weight: 800; }

.top-dishes { margin-top: 18px; display: grid; gap: 11px; }
.tdish { display: flex; align-items: center; gap: 12px; }
.tdish .rk { font-family: var(--mono); font-size: 12px; color: var(--ink-3); width: 18px; }
.tdish .nm { font-size: 13.5px; font-weight: 700; flex: none; width: 116px; }
.tdish .track { flex: 1; height: 8px; background: var(--bg-soft-2); border-radius: 999px; overflow: hidden; }
.tdish .fill { height: 100%; background: linear-gradient(90deg, var(--primary), #7aa6f6); border-radius: 999px; }
.tdish .amt { font-size: 12px; font-weight: 800; font-variant-numeric: tabular-nums; width: 64px; text-align: right; }

/* ---------- POS ---------- */
.pos { display: grid; grid-template-columns: 1.3fr 1fr; min-height: 380px; }
.pos__menu { padding: 18px; background: #f7f9fc; }
.pos__cats { display: flex; gap: 8px; margin-bottom: 14px; flex-wrap: wrap; }
.pos__cats span { font-size: 12px; font-weight: 700; padding: 7px 13px; border-radius: 999px; background: #fff; border: 1px solid var(--line); color: var(--ink-2); }
.pos__cats span.on { background: var(--primary); color: #fff; border-color: var(--primary); }
.pos__items { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.pitem { background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 11px; cursor: pointer; transition: border-color .15s, transform .15s; }
.pitem:hover { border-color: var(--primary); transform: translateY(-2px); }
.pitem .th { height: 46px; border-radius: 8px; margin-bottom: 8px; }
.pitem .nm { font-size: 12px; font-weight: 700; line-height: 1.2; }
.pitem .pr { font-size: 12px; font-weight: 800; color: var(--primary); margin-top: 3px; }
.pos__cart { padding: 18px; background: #fff; border-left: 1px solid var(--line); display: flex; flex-direction: column; }
.pos__cart h4 { font-size: 14px; display: flex; justify-content: space-between; align-items: center; }
.pos__cart h4 .pill { font-size: 11px; }
.pos__lines { margin: 14px 0; display: grid; gap: 11px; flex: 1; }
.pline { display: flex; align-items: center; gap: 10px; }
.pline .q { font-size: 12px; font-weight: 800; color: var(--primary); width: 26px; height: 26px; border-radius: 7px; background: var(--primary-soft); display: grid; place-items: center; flex: none; }
.pline .nm { font-size: 13px; font-weight: 600; flex: 1; }
.pline .pr { font-size: 13px; font-weight: 800; font-variant-numeric: tabular-nums; }
.pos__total { border-top: 1px dashed var(--line-2); padding-top: 14px; display: grid; gap: 7px; }
.pos__total .r { display: flex; justify-content: space-between; font-size: 13px; color: var(--ink-2); }
.pos__total .r.big { font-size: 17px; font-weight: 800; color: var(--ink); }
.pos__total .btn { margin-top: 6px; width: 100%; }

/* ---------- Customization (branding) ---------- */
.brand-prev { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.brand-card { border-radius: var(--r-md); overflow: hidden; border: 1px solid var(--line); box-shadow: var(--sh-md); background: #fff; }
.brand-card__top { height: 74px; display: flex; align-items: flex-end; padding: 12px; }
.brand-card__logo { width: 28px; height: 28px; border-radius: 8px; background: rgba(255,255,255,.9); display: grid; place-items: center; font-weight: 800; font-size: 13px; }
.brand-card__body { padding: 13px; }
.brand-card__body .nm { font-weight: 800; font-size: 13px; }
.brand-card__body .ph { height: 40px; border-radius: 7px; margin-top: 9px; }
.brand-card__chips { display: flex; gap: 5px; margin-top: 10px; }
.brand-card__chips i { width: 18px; height: 18px; border-radius: 5px; }
.swatch-row { display: flex; gap: 7px; margin-top: 9px; align-items: center; }
.swatch-row i { width: 22px; height: 22px; border-radius: 6px; border: 2px solid #fff; box-shadow: 0 0 0 1px var(--line); }

/* ---------- Sponsors ---------- */
.spon { display: grid; grid-template-columns: 1fr 1.1fr; gap: 56px; align-items: center; }
.spon-menu { background: #fff; border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-md); padding: 16px; max-width: 340px; margin: 0 auto; }
.spon-banner { border-radius: 12px; padding: 13px 15px; display: flex; align-items: center; gap: 12px; margin-bottom: 11px; position: relative; overflow: hidden; }
.spon-banner .tag { position: absolute; top: 7px; right: 9px; font-size: 8.5px; font-family: var(--mono); color: rgba(255,255,255,.7); letter-spacing: .05em; }
.spon-banner .si { width: 40px; height: 40px; border-radius: 10px; background: rgba(255,255,255,.92); display: grid; place-items: center; font-weight: 800; flex: none; }
.spon-banner .st { color: #fff; }
.spon-banner .st b { font-size: 13.5px; font-weight: 800; display: block; }
.spon-banner .st small { font-size: 11px; opacity: .85; }
.spon-list { display: grid; gap: 8px; }
.spon-list .it { display: flex; gap: 10px; align-items: center; padding: 9px; border: 1px solid var(--line); border-radius: 10px; }
.spon-list .it .th { width: 34px; height: 34px; border-radius: 8px; flex: none; }
.spon-list .it .nm { font-size: 12px; font-weight: 700; flex: 1; }
.spon-list .it .pr { font-size: 12px; font-weight: 800; }

/* ---------- Testimonials ---------- */
.tgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 14px; }
.tcard { padding: 26px; border-radius: var(--r-lg); display: flex; flex-direction: column; }
.tcard .stars { color: var(--amber); letter-spacing: 2px; font-size: 14px; }
.tcard q { display: block; font-size: 15.5px; line-height: 1.6; color: var(--ink); margin: 14px 0 20px; quotes: none; font-weight: 500; }
.tcard q::before { content: ""; }
.tcard .who { display: flex; align-items: center; gap: 11px; margin-top: auto; }
.tcard .who .av { width: 40px; height: 40px; border-radius: 50%; display: grid; place-items: center; font-weight: 800; color: #fff; font-size: 14px; flex: none; }
.tcard .who .nm { font-weight: 700; font-size: 14px; }
.tcard .who .ro { font-size: 12px; color: var(--ink-3); }

/* ---------- Pricing ---------- */
.price-toggle { display: inline-flex; align-items: center; gap: 12px; margin: 24px auto 0; padding: 5px; background: var(--bg-soft-2); border-radius: var(--r-pill); }
.price-toggle button { border: 0; background: transparent; font-family: var(--font); font-weight: 700; font-size: 13.5px; padding: 9px 18px; border-radius: var(--r-pill); cursor: pointer; color: var(--ink-2); transition: all .15s; }
.price-toggle button.on { background: #fff; color: var(--ink); box-shadow: var(--sh-xs); }
.price-toggle .save { font-size: 11px; font-weight: 700; color: var(--green); background: var(--green-soft); padding: 3px 9px; border-radius: 999px; }

.pgrid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 44px; align-items: stretch; }
.pcard { padding: 30px 26px; border-radius: var(--r-lg); display: flex; flex-direction: column; background: #fff; border: 1px solid var(--line); box-shadow: var(--sh-sm); position: relative; }
.pcard--feat { border: 1.5px solid var(--primary); box-shadow: var(--sh-md); }
.pcard__badge { position: absolute; top: -12px; left: 50%; transform: translateX(-50%); background: var(--primary); color: #fff; font-size: 11px; font-weight: 700; padding: 5px 14px; border-radius: 999px; box-shadow: var(--sh-primary); white-space: nowrap; }
.pcard h3 { font-size: 18px; }
.pcard .desc { font-size: 13px; color: var(--ink-3); margin-top: 6px; min-height: 36px; }
.pcard .price { margin: 16px 0 4px; display: flex; align-items: baseline; gap: 4px; }
.pcard .price .cur { font-size: 18px; font-weight: 700; }
.pcard .price .amt { font-size: 44px; font-weight: 800; letter-spacing: -.03em; font-variant-numeric: tabular-nums; }
.pcard .price .per { font-size: 13px; color: var(--ink-3); font-weight: 600; }
.pcard .annual-note { font-size: 11.5px; color: var(--ink-3); min-height: 16px; }
.pcard .btn { width: 100%; margin: 22px 0; }
.pcard .feats { display: grid; gap: 12px; }
.pcard .feats li { display: flex; gap: 10px; font-size: 13.5px; color: var(--ink-2); align-items: flex-start; }
.pcard .feats .tick { flex: none; width: 19px; height: 19px; border-radius: 6px; background: var(--green-soft); color: var(--green); display: grid; place-items: center; margin-top: 1px; }
.pcard .feats .tick svg { width: 11px; height: 11px; }

/* ---------- FAQ ---------- */
.faq { max-width: 760px; margin: 44px auto 0; display: grid; gap: 12px; }
.qa { border: 1px solid var(--line); border-radius: var(--r-md); background: #fff; overflow: hidden; transition: box-shadow .2s; }
.qa[open] { box-shadow: var(--sh-sm); }
.qa summary { list-style: none; cursor: pointer; padding: 20px 22px; display: flex; align-items: center; justify-content: space-between; gap: 16px; font-weight: 700; font-size: 16px; }
.qa summary::-webkit-details-marker { display: none; }
.qa summary .ic { flex: none; width: 26px; height: 26px; border-radius: 8px; background: var(--bg-soft-2); display: grid; place-items: center; transition: transform .2s, background .2s; }
.qa[open] summary .ic { background: var(--primary); transform: rotate(45deg); }
.qa summary .ic svg { width: 13px; height: 13px; transition: color .2s; }
.qa[open] summary .ic svg { color: #fff; }
.qa .ans { padding: 0 22px 22px; color: var(--ink-2); font-size: 14.5px; line-height: 1.65; max-width: 64ch; }

/* ---------- Final CTA ---------- */
.cta-final { position: relative; overflow: hidden; border-radius: var(--r-xl); padding: 70px 40px; text-align: center; background: linear-gradient(150deg, #0b1426 0%, #16307a 120%); }
.cta-final::before { content: ""; position: absolute; inset: 0; background: radial-gradient(700px 360px at 50% -20%, rgba(122,166,246,.28), transparent 60%); }
.cta-final > * { position: relative; z-index: 1; }
.cta-final h2 { color: #fff; font-size: clamp(30px, 4vw, 46px); letter-spacing: -.03em; text-wrap: balance; max-width: 20ch; margin: 0 auto; }
.cta-final p { color: var(--on-navy-2); font-size: 18px; margin: 18px auto 0; max-width: 50ch; }
.cta-final .row { display: flex; gap: 14px; justify-content: center; margin-top: 30px; flex-wrap: wrap; }
.cta-final small { display: block; color: var(--on-navy-2); font-size: 13px; margin-top: 18px; }

/* ---------- Footer ---------- */
.footer { background: var(--bg-navy); color: var(--on-navy-2); padding: 70px 0 36px; }
.footer__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 40px; }
.footer__brand .logo b { color: #fff; }
.footer__brand p { margin-top: 16px; font-size: 14px; max-width: 30ch; line-height: 1.6; }
.footer__col h5 { color: #fff; font-size: 13px; font-weight: 700; letter-spacing: .02em; margin-bottom: 16px; }
.footer__col a { display: block; font-size: 14px; margin-bottom: 11px; transition: color .15s; }
.footer__col a:hover { color: #fff; }
.footer__bottom { display: flex; justify-content: space-between; align-items: center; margin-top: 50px; padding-top: 26px; border-top: 1px solid var(--line-navy); font-size: 13px; flex-wrap: wrap; gap: 14px; }
.footer__social { display: flex; gap: 10px; }
.footer__social a { width: 34px; height: 34px; border-radius: 9px; background: rgba(255,255,255,.06); display: grid; place-items: center; }
.footer__social a:hover { background: rgba(255,255,255,.14); }
.footer__social svg { width: 16px; height: 16px; color: var(--on-navy); }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .section { padding: 76px 0; }
  .hero__grid { grid-template-columns: 1fr; gap: 40px; }
  .hero__copy { text-align: center; max-width: 640px; margin: 0 auto; }
  .hero__sub { margin-left: auto; margin-right: auto; }
  .hero__cta, .hero__trust { justify-content: center; }
  .frow, .frow--rev .frow__media { grid-template-columns: 1fr; }
  .frow--rev .frow__media { order: 0; }
  .frow__copy { text-align: center; }
  .frow__copy .feat-ico { margin-left: auto; margin-right: auto; }
  .frow__copy .checks { text-align: left; max-width: 420px; margin-left: auto; margin-right: auto; }
  .frow + .frow { margin-top: 64px; }
  .fgrid, .tgrid, .pgrid, .brand-prev { grid-template-columns: 1fr; }
  .rep-grid, .spon, .pos { grid-template-columns: 1fr; }
  .stats { grid-template-columns: repeat(2, 1fr); gap: 36px 20px; }
  .stats .div { display: none; }
  .footer__top { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 620px) {
  .nav__links, .nav__cta .btn--ghost { display: none; }
  .tmap { grid-template-columns: repeat(3, 1fr); }
  .pos__items { grid-template-columns: repeat(2, 1fr); }
  .footer__top { grid-template-columns: 1fr; }
  .cta-final { padding: 50px 24px; }
  .wrap { padding: 0 18px; }
}
