/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"app/layout.tsx","import":"Montserrat","arguments":[{"subsets":["latin"],"weight":["400","500","600","700","800","900"],"display":"swap","variable":"--font-montserrat"}],"variableName":"montserrat"} ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/b1f344208eb4edfe-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/48e2044251ef3125-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/bf24a9759715e608-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/1f173e5e25f3efee-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/904be59b21bd51cb-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/b1f344208eb4edfe-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/48e2044251ef3125-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/bf24a9759715e608-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/1f173e5e25f3efee-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url(/_next/static/media/904be59b21bd51cb-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/b1f344208eb4edfe-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/48e2044251ef3125-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/bf24a9759715e608-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/1f173e5e25f3efee-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/904be59b21bd51cb-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/b1f344208eb4edfe-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/48e2044251ef3125-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/bf24a9759715e608-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/1f173e5e25f3efee-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/904be59b21bd51cb-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/b1f344208eb4edfe-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/48e2044251ef3125-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/bf24a9759715e608-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/1f173e5e25f3efee-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/904be59b21bd51cb-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/b1f344208eb4edfe-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/48e2044251ef3125-s.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/bf24a9759715e608-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/1f173e5e25f3efee-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Montserrat';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/904be59b21bd51cb-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Montserrat Fallback';src: local("Arial");ascent-override: 85.79%;descent-override: 22.25%;line-gap-override: 0.00%;size-adjust: 112.83%
}.__className_0f62d1 {font-family: 'Montserrat', 'Montserrat Fallback';font-style: normal
}.__variable_0f62d1 {--font-montserrat: 'Montserrat', 'Montserrat Fallback'
}

/*!*************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./app/globals.css ***!
  \*************************************************************************************************************************************************************************************************************************************************************/
/* ============================================================
   duo-lp v2 — pixel clone mobile-first
   Paleta extraida do CSS da LP WP (lp.duogourmet.com.br):
     vinho/marrom (brand)  #6e1013   (cor dominante, 202 ocorrencias)
     vinho escuro          #690f12 / #13000a
     dourado/tan accent    #d6ac6b
     creme bg              #fff9ee / #fdf8ee / #f9f9f9
     verde (selos)         #00a335
   ============================================================ */

:root {
  --wine: #6e1013;
  --wine-dark: #4d0a0c;
  --wine-deep: #13000a;
  --gold: #d6ac6b;
  --gold-soft: #e3c894;
  --cream: #fff9ee;
  --cream-2: #fdf8ee;
  --beige: #ddd2bd;
  --green: #00a335;
  --text: #3a2b22;
  --white: #ffffff;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

/* skip link "Ir para o conteúdo" — oculto até receber foco (igual Elementor) */
.skip-content {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
  z-index: 100;
}
.skip-content:focus {
  left: 8px;
  top: 8px;
  width: auto;
  height: auto;
  background: var(--wine);
  color: #fff;
  padding: 8px 14px;
  border-radius: 6px;
}

html {
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-montserrat), "Montserrat", system-ui, -apple-system,
    "Segoe UI", Roboto, sans-serif;
  background: var(--cream);
  color: var(--text);
  line-height: 1.45;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  display: block;
}

a {
  text-decoration: none;
  color: inherit;
}

ul {
  list-style: none;
}

/* layout shell — a LP e mobile-first; centraliza num cano de ate 480px no
   desktop pra preservar a leitura mobile (alvo do clone). */
.page {
  width: 100%;
  max-width: 480px;
  margin: 0 auto;
  background: var(--cream);
  position: relative;
}

.wrap {
  padding-left: 22px;
  padding-right: 22px;
}

/* ---------- botoes ---------- */
.btn {
  display: block;
  width: 100%;
  text-align: center;
  font-weight: 700;
  letter-spacing: 0.3px;
  /* real (Elementor): border-radius 4px nos botoes primarios, nao 10px */
  border-radius: 4px;
  padding: 18px 20px;
  font-size: 16px;
  cursor: pointer;
  border: none;
  transition: transform 0.12s ease, filter 0.12s ease;
}
.btn:active {
  transform: scale(0.985);
}
.btn-wine {
  background: var(--wine);
  color: #fff;
}
.btn-gold {
  background: var(--gold);
  color: var(--wine-dark);
}
.btn-outline-wine {
  background: transparent;
  color: var(--wine);
  border: 2px solid var(--wine);
}

/* ---------- titulos de secao ---------- */
.section-title {
  font-weight: 800;
  font-size: 27px;
  line-height: 1.15;
  text-align: center;
  color: var(--wine);
  text-transform: uppercase;
  letter-spacing: 0.2px;
}
.section-title.on-wine {
  color: #fff;
}

/* ============================================================ HERO */
.hero {
  background: var(--cream);
  padding-top: 8px;
  text-align: center;
}
/* HERO regional: foto do hamburguer no topo (fundo creme) + card vinho colado
   logo abaixo. Mobile = empilhado; desktop = 2 colunas (ver bloco desktop). */
.hero-regional {
  display: block;
}
.hero-burger-wrap {
  background: var(--cream);
  text-align: center;
  padding: 8px 0 0;
}
.hero-burger {
  width: 86%;
  max-width: 360px;
  margin: 0 auto;
}
.hero-card {
  background: var(--wine);
  color: #fff;
  border-radius: 22px;
  margin: -28px 14px 0;
  padding: 34px 22px 26px;
  position: relative;
  z-index: 2;
}
.hero-card h1 {
  /* real: titulo em CREME (#fff9ee), nao branco puro; um pouco menor */
  font-size: 36px;
  line-height: 1.04;
  font-weight: 900;
  color: #fff9ee;
  text-transform: uppercase;
}
.hero-card .sub {
  margin-top: 14px;
  font-size: 17px;
  font-weight: 400;
  opacity: 0.95;
}
.hero-card .sub b {
  font-weight: 800;
}
.hero-badges {
  width: 100%;
  margin: 22px auto 0;
}
.hero-cards-img {
  width: 86%;
  margin: 18px auto 0;
}

/* faixa de 3 pills do hero regional (USE QUANTAS VEZES + DESCONTOS + UPGRADE) */
.hero-pills {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 20px;
  flex-wrap: nowrap;
}
/* punchlist pos-verify: os 3 badges ficam FLAT sobre o maroon do card (sem
   box/pill propria), separados so pelo "+" creme — igual ao real. */
.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: transparent;
  color: var(--cream);
  font-size: 9px;
  font-weight: 800;
  line-height: 1.15;
  text-transform: uppercase;
  text-align: center;
  border-radius: 0;
  padding: 0;
  flex: 1 1;
  justify-content: center;
  min-width: 0;
}
.hero-pill-plus {
  color: var(--cream);
  font-style: normal;
  font-weight: 900;
  font-size: 13px;
  margin-left: 4px;
}

/* ---------------- BANNER DE COOKIES (fixo na base) ---------------- */
.cookie-bar {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 50;
  background: var(--cream);
  border-top: 1px solid rgba(0, 0, 0, 0.12);
  box-shadow: 0 -6px 24px rgba(0, 0, 0, 0.14);
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  align-items: center;
}
.cookie-bar p {
  color: var(--text);
  font-size: 11px;
  line-height: 1.45;
  text-align: center;
  margin: 0;
}
.cookie-bar a {
  color: var(--wine);
  text-decoration: underline;
  font-weight: 700;
}
.cookie-ok {
  background: var(--wine);
  color: #fff;
  border: none;
  border-radius: 8px;
  font-weight: 800;
  font-size: 13px;
  padding: 10px 26px;
  cursor: pointer;
}

/* Inter Prime: grid imagem+conteudo (mobile = empilhado, desktop = 2-col) */
.inter-grid {
  display: block;
}
.inter-cards {
  width: 80%;
  max-width: 320px;
  margin: 0 auto 8px;
}

/* ============================================================ INTER PRIME */
.inter {
  background: var(--cream);
  padding: 10px 0 40px;
  text-align: center;
}
.inter h2 {
  color: var(--wine);
  font-size: 30px;
  font-weight: 800;
  margin-bottom: 14px;
}
.inter .lead {
  color: var(--wine);
  font-size: 17px;
  margin: 0 6px 26px;
}
.feature {
  display: flex;
  align-items: center;
  gap: 16px;
  text-align: left;
  padding: 12px 4px;
  color: var(--wine);
  font-size: 16px;
}
.feature .ico {
  flex: 0 0 38px;
  height: 38px;
  display: grid;
  place-items: center;
}
.feature .ico svg,
.feature .ico img {
  width: 34px;
  height: 34px;
}
.feature b {
  font-weight: 800;
}
.inter .note {
  margin-top: 26px;
  color: var(--wine);
  font-size: 17px;
  font-weight: 400;
}
.legal {
  font-size: 11px;
  color: var(--wine);
  opacity: 0.85;
  margin-top: 18px;
  line-height: 1.4;
}
.legal a {
  text-decoration: underline;
}

/* ============================================================ RESTAURANTES */
.rests {
  background: var(--wine);
  border-radius: 34px 34px 0 0;
  padding: 44px 0 40px;
  margin-top: 8px;
}
.carousel {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  padding: 28px 22px 10px;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
}
.carousel::-webkit-scrollbar {
  display: none;
}
.rcard {
  flex: 0 0 78%;
  scroll-snap-align: center;
  background: #fff;
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.25);
}
.rcard .ph {
  width: 100%;
  height: 190px;
  object-fit: cover;
}
.rcard .body {
  padding: 14px 16px 18px;
}
.rcard .tag {
  display: inline-block;
  background: var(--green);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 20px;
  margin-bottom: 8px;
}
.rcard h3 {
  color: var(--wine);
  font-size: 18px;
  font-weight: 800;
}
.rcard p {
  color: #8a7d72;
  font-size: 13px;
  margin-top: 2px;
}
.dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 18px;
  flex-wrap: wrap;
  padding: 0 22px;
}
.dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
}
.dot.on {
  background: #fff;
  width: 9px;
  height: 9px;
}
.rests .all {
  color: #fff;
  text-align: center;
  font-size: 16px;
  margin: 22px 26px 0;
  line-height: 1.5;
}
.rests .all a {
  text-decoration: underline;
  font-weight: 700;
}

/* ============================================================ GARANTIR OFERTA */
.offer {
  background: var(--cream);
  padding: 34px 0 38px;
}
.offer .pair {
  display: flex;
  gap: 12px;
  padding: 0 22px 22px;
}
.offer .pair img {
  flex: 1 1;
  width: 50%;
  border-radius: 14px;
  height: 150px;
  object-fit: cover;
}

/* ============================================================ ALEM DA GASTRONOMIA */
.beyond {
  background: var(--wine);
  border-radius: 34px 34px 0 0;
  padding: 44px 0 44px;
  text-align: center;
}
.beyond .sub {
  color: #fff;
  margin: 12px 22px 0;
  font-size: 17px;
}
.beyond .sub b {
  font-weight: 800;
}
.hotel {
  margin: 26px 22px 0;
  background: var(--cream);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.25);
}
.hotel img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}
.hotel .body {
  padding: 16px;
  text-align: left;
}
.hotel h3 {
  color: var(--wine);
  font-size: 19px;
  font-weight: 800;
}
.hotel .off {
  display: inline-block;
  background: var(--green);
  color: #fff;
  font-weight: 800;
  font-size: 14px;
  padding: 8px 18px;
  border-radius: 24px;
  margin-top: 10px;
}

/* ============================================================ O QUE ESTA INCLUSO */
.included {
  background: var(--beige);
  border-radius: 34px 34px 0 0;
  margin-top: -10px;
  padding: 44px 0 48px;
}
.included .lead {
  color: var(--wine);
  font-size: 22px;
  text-align: left;
  margin: 0 22px 26px;
}
.included .lead b {
  font-weight: 800;
}
.inc-card {
  background: var(--cream);
  border: 2px solid var(--wine);
  border-radius: 18px;
  margin: 0 22px;
  padding: 26px 22px 24px;
}
.inc-card h3 {
  color: var(--wine);
  font-size: 22px;
  font-weight: 800;
  margin-bottom: 18px;
}
.inc-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: var(--wine);
  font-size: 16px;
  padding: 7px 0;
}
.inc-list li::before {
  content: "✓";
  color: var(--wine);
  font-weight: 900;
  flex: 0 0 auto;
}
.inc-card .btn {
  margin-top: 24px;
}

/* ============================================================ E TUDO NO APP */
.app {
  background: var(--cream);
  padding: 44px 0 40px;
  text-align: center;
}
.app .sub {
  color: var(--wine);
  font-size: 21px;
  margin: 14px 22px 26px;
}
.video {
  margin: 0 22px;
  aspect-ratio: 16 / 9;
  border-radius: 14px;
  overflow: hidden;
  background: #161616;
}
.video iframe {
  width: 100%;
  height: 100%;
  border: 0;
}
.app .btn {
  margin: 28px 22px 0;
  width: auto;
}

/* ============================================================ VOCE JA PASSOU / influencers */
.passed {
  background: var(--cream);
  padding: 30px 0 34px;
  text-align: center;
}
.passed h2 {
  color: var(--wine);
  font-size: 27px;
  font-weight: 800;
}
.passed .pain {
  text-align: left;
  margin: 24px 22px 0;
}
.passed .pain li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: var(--wine);
  font-size: 16px;
  padding: 9px 0;
}
.passed .pain li::before {
  content: "✕";
  color: var(--wine);
  font-weight: 900;
}
.passed .lead {
  color: var(--wine);
  margin: 22px 22px 0;
  font-size: 16px;
}
.passed .lead b {
  font-weight: 800;
}
.passed .quero {
  margin: 26px 22px 0;
}
.influ-h {
  color: var(--wine);
  font-size: 16px;
  margin: 34px 22px 18px;
}
.influ-row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 0 22px 8px;
  scroll-snap-type: x mandatory;
}
.influ-row::-webkit-scrollbar {
  display: none;
}
.influ {
  flex: 0 0 70%;
  scroll-snap-align: center;
  border-radius: 16px;
  overflow: hidden;
  background: var(--wine-dark);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.2);
}
.influ img {
  width: 100%;
  height: 360px;
  object-fit: cover;
}
.influ .handle {
  color: #fff;
  font-weight: 800;
  font-size: 15px;
  padding: 12px 14px 16px;
  text-align: left;
}

/* ============================================================ FAQ */
.faq {
  background: var(--cream);
  padding: 30px 0 50px;
}
.faq h2 {
  color: var(--wine);
  text-align: center;
  font-size: 27px;
  font-weight: 800;
  margin-bottom: 22px;
}
/* REAL (Elementor toggle): NAO ha card branco arredondado. As perguntas sao
   linhas PLANAS sobre o creme, separadas por filete cinza fino embaixo
   (border-block-end:1px solid #d5d8dc), texto da pergunta em PRETO e marcador =
   triangulo CHEIO vinho (svg fill:#6E1013), nao chevron fino. */
.faq-panel {
  background: transparent;
  border-radius: 0;
  margin: 0 16px;
  padding: 0;
  box-shadow: none;
}
.faq details {
  border-bottom: 1px solid #d5d8dc; /* filete cinza fino (real) */
  padding: 0;
}
.faq details:last-child {
  border-bottom: 1px solid #d5d8dc;
}
.faq summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 4px;
  font-weight: 700;
  color: #000; /* pergunta em PRETO (real), nao vinho */
  font-size: 16px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}
.faq summary::-webkit-details-marker {
  display: none;
}
/* marcador = TRIANGULO CHEIO vinho (apontando pra baixo), nao chevron fino */
.faq summary::after {
  content: "";
  flex: 0 0 auto;
  width: 0;
  height: 0;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 9px solid var(--wine);
  transition: transform 0.2s ease;
}
.faq details[open] summary::after {
  transform: rotate(180deg);
}
.faq .answer {
  color: var(--text);
  font-size: 15px;
  line-height: 1.6;
  padding: 0 0 18px;
}
.faq .answer p {
  margin-bottom: 10px;
}
.faq .answer ul {
  list-style: disc;
  padding-left: 20px;
  margin-bottom: 10px;
}

/* ============================================================ PASSED closing */
.passed-closing {
  color: var(--wine);
  font-weight: 800;
  font-size: 18px;
  margin: 22px 22px 0;
}

/* ============================================================ CONFIRA NA PRÁTICA */
.practice {
  background: var(--cream);
  padding: 40px 0 36px;
  text-align: center;
}
.practice > .inner {
  width: 100%;
}
.practice .section-title {
  margin: 0 22px;
}
.practice-lead {
  color: var(--wine);
  font-size: 17px;
  margin: 14px 22px 24px;
}
.practice .video {
  margin: 0 22px 12px;
}
.videos-nordeste {
  margin-top: 18px;
}

/* ============================================================ BENEFÍCIOS DO DUO */
.benefits-duo {
  background: var(--wine);
  border-radius: 34px 34px 0 0;
  margin-top: 8px;
  padding: 44px 0 44px;
  text-align: center;
}
.benefits-duo > .inner {
  width: 100%;
}
.bd-list {
  text-align: left;
  margin: 26px 22px 28px;
}
.bd-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: #fff;
  font-size: 17px;
  padding: 9px 0;
}
.bd-list li::before {
  content: "✓";
  color: var(--gold);
  font-weight: 900;
  flex: 0 0 auto;
}
.benefits-duo .btn {
  margin: 0 22px;
  width: auto;
}

/* ============================================================ COMO UTILIZAR */
.howto {
  background: var(--cream);
  padding: 44px 0 40px;
  text-align: center;
}
.howto > .inner {
  width: 100%;
}
.howto .section-title {
  margin: 0 22px;
}
.howto-lead {
  color: var(--wine);
  font-size: 17px;
  margin: 14px 22px 26px;
}
.howto-steps {
  text-align: left;
  margin: 0 22px 28px;
}
.howto-steps li {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  padding: 14px 0;
  border-bottom: 1px solid rgba(110, 16, 19, 0.12);
}
.howto-steps li:last-child {
  border-bottom: none;
}
.ht-num {
  flex: 0 0 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--wine);
  color: #fff;
  font-weight: 800;
  font-size: 18px;
  display: grid;
  place-items: center;
}
.ht-body h3 {
  color: var(--wine);
  font-size: 18px;
  font-weight: 800;
}
.ht-body p {
  color: var(--text);
  font-size: 15px;
  margin-top: 2px;
}
.howto .btn {
  margin: 0 22px;
  width: auto;
}

/* ============================================================ PRA QUEM É */
.whofor {
  background: var(--wine);
  border-radius: 34px 34px 0 0;
  margin-top: 8px;
  padding: 44px 0 44px;
  text-align: center;
}
.whofor > .inner {
  width: 100%;
}
.wf-list {
  text-align: left;
  margin: 26px 22px 18px;
}
.wf-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: #fff;
  font-size: 16px;
  padding: 8px 0;
}
.wf-list li::before {
  content: "✓";
  color: var(--gold);
  font-weight: 900;
  flex: 0 0 auto;
}
.wf-closing {
  color: #fff;
  font-weight: 800;
  font-size: 18px;
  margin: 0 22px 26px;
}
.whofor .btn {
  margin: 0 22px;
  width: auto;
}

/* ============================================================ TESTE 7 DIAS */
.guarantee {
  background: var(--cream);
  padding: 44px 0 40px;
  text-align: center;
}
.guarantee > .inner {
  width: 100%;
}
.guarantee .section-title {
  margin: 0 22px;
}
.guarantee-desc {
  color: var(--wine);
  font-size: 17px;
  margin: 16px 22px 0;
}

/* ============================================================ SUPORTE / WHATSAPP */
.support {
  background: var(--wine);
  border-radius: 34px 34px 0 0;
  margin-top: 8px;
  padding: 44px 0 44px;
  text-align: center;
}
.support > .inner {
  width: 100%;
}
.support-desc {
  color: #fff;
  font-size: 17px;
  margin: 16px 22px 26px;
}
.support .btn {
  margin: 0 22px;
  width: auto;
}

/* ============================================================ FAQ foot */
.faq-foot {
  margin-top: 8px;
  font-weight: 700;
  color: var(--wine);
}

/* ============================================================ FOOTER */
.footer {
  background: var(--wine-deep);
  color: rgba(255, 255, 255, 0.85);
  text-align: center;
  padding: 30px 22px 40px;
  font-size: 13px;
}
.footer .cta {
  margin-bottom: 22px;
}


/* ============================================================
   RESPONSIVIDADE (mobile-first com min-width)
   Base = mobile (~360-430px), PRESERVADO acima desta linha intacto.
   Daqui pra baixo, so ADICOES pra tablet/desktop.
   A LP real (Elementor) no desktop usa um container boxed ~1140px
   centralizado sobre fundo creme; faixas coloridas (vinho/bege)
   pintam a tela toda e o miolo fica contido; hero e Inter Prime em
   2 colunas; os carrosseis viram grid.

   Arquitetura: ate 1024px a .page (max-width crescente) e o "cano"
   que contem tudo, igual ao mobile so que mais largo. A partir de
   1024px a .page vira full-width e o .inner / .inc-wrap / .hero /
   .inter etc centralizam o miolo de cada secao no container.
   ============================================================ */

:root {
  --container: 480px; /* mobile/tablet: cano estreito */
  --container-lg: 1140px; /* desktop: container boxed do Elementor real */
  --gutter: 22px;
}

/* o .inner so existe nas faixas full-bleed (rests/beyond); no mobile
   e um bloco passante (100% de largura, sem efeito). */
.rests > .inner,
.beyond > .inner,
.practice > .inner,
.benefits-duo > .inner,
.howto > .inner,
.whofor > .inner,
.guarantee > .inner,
.support > .inner {
  width: 100%;
}

/* ---------------- TABLET (>=768px) — cano um pouco mais largo ---------------- */
@media (min-width: 768px) and (max-width: 1023px) {
  .page {
    max-width: 560px;
    box-shadow: 0 0 60px rgba(0, 0, 0, 0.08);
  }
}

/* ============================================================
   DESKTOP (>=1024px) — FULL-WIDTH, container boxed ~1140px.
   Espelha a LP Elementor real (truth real-desktop-1280.png):
   .page vira full-width; faixas coloridas (vinho/bege) sangram a
   tela toda e o miolo de cada secao centraliza em 1140px; hero e
   Inter Prime em 2 colunas; restaurantes em grid 4-col.
   ============================================================ */
@media (min-width: 1024px) {
  .page {
    max-width: 100%;
    box-shadow: none;
  }

  /* miolo centralizado de cada secao */
  .hero,
  .inter,
  .rests > .inner,
  .beyond > .inner,
  .practice > .inner,
  .benefits-duo > .inner,
  .howto > .inner,
  .whofor > .inner,
  .guarantee > .inner,
  .support > .inner,
  .offer,
  .included .inc-wrap,
  .app,
  .passed,
  .lovers,
  .faq,
  .footer,
  .influencers .influ-row,
  .wine > .inner,
  .pricing > .inner {
    max-width: var(--container-lg);
    margin-left: auto;
    margin-right: auto;
    width: 100%;
  }

  /* ---- HERO 2 colunas: foto do burger | card vinho ----
     escala/ritmo maior pra bater a altura do real (~6100px desktop): hero mais
     alto, colunas mais largas, gap maior. */
  .hero {
    padding: 64px 24px 72px;
  }
  .hero-regional {
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: center;
    grid-gap: 52px;
    gap: 52px;
  }
  .hero-burger-wrap {
    padding: 0;
  }
  .hero-burger {
    width: 100%;
    max-width: 560px;
  }
  .hero-card {
    margin: 0;
    text-align: left;
    padding: 52px 46px 48px;
    border-radius: 26px;
  }
  .hero-card h1 {
    font-size: 64px;
  }
  .hero-card .sub {
    font-size: 20px;
    margin-top: 18px;
  }
  .hero-pills {
    margin-top: 30px;
  }
  .hero-pill {
    font-size: 11px;
    padding: 0;
  }

  /* ---- INTER PRIME 2 colunas: leque de cartoes | conteudo ---- */
  .inter {
    padding: 56px 24px;
    text-align: left;
  }
  .inter-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    align-items: center;
    grid-gap: 48px;
    gap: 48px;
  }
  .inter-cards {
    width: 100%;
    max-width: 460px;
    margin: 0;
  }
  .inter .lead {
    margin-left: 0;
    margin-right: 0;
  }

  /* ---- RESTAURANTES: grid 4-col (sem carrossel) ---- */
  .rests {
    border-radius: 48px 48px 0 0;
    padding: 64px 0 56px;
  }
  .rests .carousel {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    grid-gap: 22px;
    gap: 22px;
    overflow: visible;
    padding: 28px 0 10px;
  }
  .rcard {
    flex: none;
  }
  .rests .dots {
    display: none;
  }

  /* ---- ALEM DA GASTRONOMIA: grid 3-col de experiencias ---- */
  .beyond {
    border-radius: 48px 48px 0 0;
    padding: 64px 0 64px;
  }
  .xp-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-gap: 22px;
    gap: 22px;
  }

  /* ---- secoes brancas/bege centralizadas ---- */
  .offer .pair {
    max-width: 760px;
    margin: 0 auto;
  }
  .included {
    border-radius: 48px 48px 0 0;
  }

  /* depoimentos / influencers: a real mostra 3 cards por vez numa LINHA
     horizontal (GIF + @handle), com dots. O clone empilhava vertical (cards a
     70%) — punchlist pos-verify (blocker). Forcamos 3-por-linha SEM wrap. */
  .influencers .influ-row {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 22px;
    max-width: var(--container-lg);
    margin: 0 auto;
    padding: 0 24px 8px;
  }
  /* 3 cards por view (resto rola, como o carrossel da real) */
  .influencers .influ {
    flex-grow: 0;
    flex-shrink: 0;
    flex-basis: calc((100% - 44px) / 3);
    max-width: none;
    scroll-snap-align: start;
  }

  .cookie-bar {
    flex-direction: row;
    justify-content: space-between;
    padding: 16px 40px;
  }
  .cookie-bar p {
    text-align: left;
    max-width: 1000px;
  }
  .cookie-ok {
    flex: 0 0 auto;
  }

  /* RITMO VERTICAL regional (desktop): o clone terminava ~5800px (compacto) vs
     ~6100px do real. Folgamos os paddings das faixas regionais visiveis pra
     bater a altura total. So afeta a regional (.page:not(.is-cyt)). */
  .page:not(.is-cyt) .inter {
    padding-top: 64px;
    padding-bottom: 64px;
  }
  .page:not(.is-cyt) .rests {
    padding-top: 80px;
    padding-bottom: 72px;
  }
  .page:not(.is-cyt) .offer {
    padding-top: 56px;
    padding-bottom: 60px;
  }
  .page:not(.is-cyt) .beyond {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  .page:not(.is-cyt) .included {
    padding-top: 64px;
    padding-bottom: 72px;
  }
  .page:not(.is-cyt) .app {
    padding-top: 64px;
    padding-bottom: 64px;
  }
  .page:not(.is-cyt) .faq {
    padding-top: 56px;
    padding-bottom: 72px;
  }
}


/* ============================================================
   CYT (Concha y Toro) — secoes proprias da /duocyt-geral.
   Mobile-first; reusa a paleta/classes base. Aditivo: nao toca
   o que ja existe acima. Cores extra da campanha:
     verde campanha #1a9c4b (faixa "e tambem" / titulos verdes)
     preto card     #161210 (hero composite bg / pricing card)
     amarelo CTA    #f5b800 (botao GARANTIR OFERTA)
   ============================================================ */
:root {
  --cyt-green: #1a9c4b;
  --cyt-black: #161210;
  --cyt-yellow: #f5b800;
}

.btn-cream {
  background: var(--cream);
  color: var(--wine);
}
.is-cyt .btn-gold {
  background: var(--cyt-yellow);
  color: #161210;
}

/* ---------------- CO-BRAND HEADER ---------------- */
.cobrand {
  background: var(--cyt-black);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  padding: 14px 18px;
}
.cb-duo {
  display: flex;
  align-items: center;
  gap: 5px;
  color: #fff;
}
.cb-duo b { font-size: 17px; font-weight: 900; letter-spacing: 0.5px; }
.cb-duo span { font-size: 9px; letter-spacing: 1.5px; opacity: 0.85; }
.cb-amp { color: var(--cyt-yellow); font-size: 20px; font-weight: 700; }
.cb-partner { height: 26px; width: auto; }

/* ---------------- HERO CYT ---------------- */
.hero-cyt {
  display: block;
  background: var(--cream);
  padding: 28px 22px 0;
  text-align: center;
}
.hero-eyebrow {
  color: var(--wine);
  font-size: 16px;
  line-height: 1.35;
  margin: 0 auto 12px;
  max-width: 320px;
}
.hero-eyebrow b { font-weight: 800; }
.hero-h1-cyt {
  color: var(--cyt-green);
  font-size: 38px;
  line-height: 1.05;
  font-weight: 900;
  text-transform: uppercase;
}
.hero-sublead {
  color: var(--wine);
  font-size: 15px;
  margin: 16px auto 18px;
  max-width: 320px;
}
.offer-cards {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 360px;
  margin: 0 auto;
}
.offer-card {
  background: var(--cream);
  border: 2px solid var(--wine);
  border-radius: 14px;
  padding: 16px 18px;
  text-align: center;
}
.oc-value {
  display: block;
  color: var(--wine);
  font-size: 26px;
  font-weight: 900;
}
.oc-label {
  display: block;
  color: var(--wine);
  font-size: 16px;
  font-weight: 600;
  text-transform: uppercase;
  margin-top: 2px;
}
.hero-composite {
  width: 88%;
  max-width: 360px;
  margin: 6px auto 0;
}

/* ---------------- RESTAURANTES (cyt: faixa preta + sub) ---------------- */
.is-cyt .rests {
  background: var(--cyt-black);
}
.rests-sub {
  color: #fff;
  text-align: center;
  font-size: 16px;
  margin: 12px 22px 0;
}
.rests-sub b { font-weight: 800; }
.is-cyt .rcard h3 { color: var(--wine); }
/* cyt: cards do carrossel sao fotos completas (marca embutida) — sem body branco */
.is-cyt .rests .rcard { background: transparent; box-shadow: none; }
.is-cyt .rests .rcard .body { display: none; }
.is-cyt .rests .rcard .ph { border-radius: 16px; }

/* ---------------- R$100 OFF EM VINHOS (faixa verde) ---------------- */
.wine {
  background: var(--cyt-green);
  padding: 44px 0 48px;
  text-align: center;
}
.wine > .inner { width: 100%; padding: 0 22px; }
.wine-eyebrow {
  color: #fff;
  font-size: 16px;
  font-weight: 600;
  margin-bottom: 10px;
}
.wine .section-title.on-wine { color: #fff; }
.wine-sub {
  color: #fff;
  font-size: 16px;
  margin: 12px 22px 0;
  opacity: 0.95;
}
.wine-img {
  width: 78%;
  max-width: 380px;
  margin: 24px auto;
}
.wine-list {
  text-align: left;
  max-width: 420px;
  margin: 0 auto 28px;
}
.wine-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: #fff;
  font-size: 15px;
  padding: 8px 0;
}
.wine-list li::before {
  content: "";
  flex: 0 0 auto;
  width: 16px;
  height: 18px;
  margin-top: 1px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 22h8M12 15v7M5 3h14l-1 6a6 6 0 0 1-12 0z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.wine .btn {
  width: auto;
  max-width: 420px;
  margin: 0 auto;
  padding-left: 40px;
  padding-right: 40px;
}

/* ---------------- PRICING (plano + 4 beneficios) ---------------- */
.pricing {
  background: var(--cream);
  padding: 48px 0 44px;
  text-align: center;
}
.pricing > .inner { width: 100%; padding: 0 22px; }
.pricing .section-title { color: var(--cyt-black); margin-bottom: 30px; }
.plan-grid { width: 100%; }
.plan-card {
  background: var(--cyt-black);
  border: 2px solid var(--wine);
  border-radius: 22px;
  padding: 28px 24px 26px;
  text-align: left;
  color: #fff;
}
.pc-lead { font-size: 19px; line-height: 1.35; }
.pc-lead b { font-weight: 800; }
.pc-plan { font-size: 17px; font-weight: 700; margin-top: 22px; }
.pc-from { font-size: 14px; opacity: 0.8; text-decoration: line-through; }
.pc-from { text-decoration: none; }
.pc-from { color: rgba(255,255,255,0.75); }
.pc-price { font-size: 30px; font-weight: 900; margin-top: 4px; }
.plan-card .btn { margin-top: 22px; }
.pc-legal { font-size: 11px; opacity: 0.7; margin-top: 16px; line-height: 1.4; }

.benefits {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 28px;
}
.benefit {
  border: 1px solid rgba(110,16,19,0.25);
  border-radius: 18px;
  padding: 22px 20px;
  text-align: center;
  background: var(--cream-2);
}
.bf-seal { display: inline-flex; margin-bottom: 8px; }
.benefit h3 {
  color: var(--cyt-green);
  font-size: 19px;
  font-weight: 800;
  text-transform: uppercase;
  line-height: 1.15;
}
.benefit p { color: var(--wine); font-size: 14px; margin-top: 6px; }

/* ---------------- O DUO ALEM (cyt: grid de experiencias) ---------------- */
.is-cyt .beyond { background: var(--cyt-green); }
.xp-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 14px;
  gap: 14px;
  margin-top: 26px;
  padding: 0 22px;
}
.xp-card {
  background: var(--cream);
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 22px rgba(0,0,0,0.25);
  text-align: left;
}
.xp-card img { width: 100%; height: 130px; object-fit: cover; }
.xp-body { padding: 12px 14px 16px; }
.xp-body h3 { color: var(--wine); font-size: 15px; font-weight: 800; line-height: 1.15; }
.xp-body .off {
  display: inline-block;
  background: var(--cyt-green);
  color: #fff;
  font-weight: 700;
  font-size: 12px;
  padding: 5px 12px;
  border-radius: 20px;
  margin-top: 8px;
}

/* ============================================================ CYT RESPONSIVO */
@media (min-width: 768px) {
  .cb-partner { height: 30px; }
  .cb-duo b { font-size: 19px; }

  .hero-cyt { padding: 36px 32px 8px; max-width: var(--container); margin: 0 auto; }
  .hero-h1-cyt { font-size: 50px; }
  .offer-cards {
    flex-direction: row;
    max-width: 640px;
    gap: 20px;
  }
  .offer-card { flex: 1 1; }
  .hero-composite { width: auto; max-height: 340px; }

  .wine .section-title { font-size: 34px; }
  .wine-img { max-width: 420px; }

  /* beneficios cyt em grid 2-col */
  .benefits { display: grid; grid-template-columns: 1fr 1fr; grid-gap: 18px; gap: 18px; }
  .plan-card { max-width: 620px; margin: 0 auto; }

  /* experiencias 3-col no tablet */
  .xp-grid { grid-template-columns: repeat(3, 1fr); gap: 18px; }
  .xp-card img { height: 150px; }
}

@media (min-width: 1024px) {
  .hero-cyt { padding: 48px 32px 16px; }
  .hero-h1-cyt { font-size: 62px; }
  .hero-eyebrow, .hero-sublead { max-width: 560px; font-size: 18px; }
  .hero-composite { max-height: 420px; }

  /* faixas full-bleed (verde/preto) sangram a tela; miolo contido */
  .wine, .pricing { padding-left: 0; padding-right: 0; }
  .wine { padding-top: 64px; padding-bottom: 64px; }
  .pricing { padding-top: 64px; padding-bottom: 64px; }
  .wine > .inner,
  .pricing > .inner {
    max-width: var(--container);
    margin: 0 auto;
    padding-left: var(--gutter);
    padding-right: var(--gutter);
  }
  .wine .section-title { font-size: 40px; }

  .xp-grid { gap: 18px; }
}

/* ============================================================
   ELEMENTOS NOVOS (round FIX 1) — dentro do cano de 480px.
   ============================================================ */

/* co-brand: wordmark unico combinado Duo + Concha y Toro.
   Real (mobile 390): lockup GRANDE deslocado pra esquerda que ESTOURA o viewport
   e CLIPA "TORO" (overflow). Replicamos: header alinhado a esquerda, wordmark
   largo (>viewport) com overflow cortado, sem cap de 84%. */
.cb-wordmark { width: 460px; max-width: none; height: auto; }

/* coluna comparativa "Assinatura padrao" (regional + cyt) */
.std-card {
  border: 1px solid rgba(110, 16, 19, 0.25);
  border-radius: 18px;
  padding: 22px 20px;
  margin-top: 18px;
  background: var(--cream-2);
  text-align: left;
}
.is-cyt .std-card { background: rgba(255, 255, 255, 0.06); border-color: rgba(255,255,255,0.2); }
.std-tag { font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.4px; color: var(--wine); }
.is-cyt .std-tag { color: #fff; }
.std-plan { font-size: 16px; font-weight: 700; margin-top: 8px; color: var(--wine); }
.is-cyt .std-plan { color: #fff; }
.std-price { font-size: 26px; font-weight: 900; color: var(--wine); margin-top: 2px; }
.is-cyt .std-price { color: #fff; }
.std-list { margin-top: 14px; }
.std-list li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  font-size: 14px;
  padding: 7px 0;
  color: var(--wine);
}
.is-cyt .std-list li { color: rgba(255, 255, 255, 0.92); }
.std-list .bf-seal { flex: 0 0 auto; }
.std-list .bf-seal svg { width: 20px; height: 20px; }

/* cards de plano por bucket de cupom (dobras) */
.plan-dobras { margin-top: 22px; }
.dobra-plan {
  border: 2px solid var(--wine);
  border-radius: 16px;
  padding: 20px 18px;
  text-align: center;
  background: var(--cream);
}
.dp-tag { font-size: 16px; font-weight: 800; color: var(--wine); text-transform: uppercase; }
.dp-de { font-size: 13px; color: #8a7d72; margin-top: 10px; }
.dp-por { font-size: 34px; font-weight: 900; color: var(--wine); line-height: 1.05; }
.dp-parc { font-size: 14px; color: var(--wine); margin-top: 2px; }
.dp-ative { display: block; font-size: 14px; color: var(--green); margin-top: 12px; }
.dp-ative b { display: block; color: var(--wine); font-size: 15px; }

/* carrossel de influencers (secao propria, entre app e passed) */
.influencers {
  background: var(--cream);
  padding: 24px 0 8px;
}
.influencers .influ-row {
  display: flex;
  gap: 14px;
  overflow-x: auto;
  padding: 0 22px 8px;
  scroll-snap-type: x mandatory;
}
.influencers .influ-row::-webkit-scrollbar { display: none; }
.influencers .influ { flex: 0 0 70%; scroll-snap-align: center; }

/* depoimentos "Os Duo Lovers" */
.lovers {
  background: var(--cream);
  padding: 30px 22px 34px;
  text-align: center;
}
.lovers-sub { color: var(--wine); font-size: 16px; margin: 10px 0 18px; }
.lovers-img { width: 100%; border-radius: 14px; margin: 0 auto 18px; }
.lovers .video {
  aspect-ratio: 16 / 9;
  border-radius: 14px;
  overflow: hidden;
  background: #161616;
}
.lovers .video iframe { width: 100%; height: 100%; border: 0; }

/* ============================================================
   CYT — PASS R3 (paridade fina com lp.duogourmet.com.br/duocyt-geral)
   Tokens exatos do real: verde #04943c, amber "&" #fcb900, cupom/subhead
   preto #000/#161616, gold icones #d6ac6b, fundo preto #000000.
   ============================================================ */
:root {
  --cyt-green-real: #04943c;
  --cyt-amber: #fcb900;
  /* "&" do hero H1 = amber EXATO do real (<a style="color:#ffc412>) */
  --cyt-amp: #ffc412;
  --cyt-gold: #d6ac6b;
}

/* HEADER co-brand: fundo PRETO PURO #000000 (real), nao o quase-preto #161210
   do token --cyt-black (que segue valendo nos paineis escuros internos).
   Mobile: lockup left-shifted e maior que o viewport (clipa "TORO"), igual ao
   real — alinha a esquerda e corta o overflow. */
.cobrand {
  background: #000000;
  justify-content: flex-start;
  overflow: hidden;
  padding-left: 14px;
}

/* HERO: subhead e cupons em PRETO (nao vinho), titulo verde real, & amber */
.is-cyt .hero-eyebrow { color: #161616; }
.is-cyt .hero-sublead { color: #161616; }
.hero-h1-cyt { color: var(--cyt-green-real); }
/* "&" do hero em amber #ffc412 (real); inline-block + nowrap proprio garante
   que ele renderize sem ser colapsado por whitespace do H1. */
.hero-h1-cyt .amp {
  color: var(--cyt-amp);
  display: inline-block;
  white-space: nowrap;
}
.is-cyt .offer-card { border-color: #161616; }
.is-cyt .oc-value,
.is-cyt .oc-label { color: #000000; }

/* HERO 2 colunas no desktop: texto/cupons ESQ, imagem DIR */
@media (min-width: 1024px) {
  .hero-cyt {
    display: grid;
    grid-template-columns: 1.15fr 0.85fr;
    grid-template-rows: auto auto auto auto;
    align-items: center;
    grid-column-gap: 36px;
    column-gap: 36px;
    text-align: left;
    /* o 768px cap (.hero-cyt max-width: var(--container)) deixava o hero estreito
       e centrado no desktop, colapsando a coluna 2 (composite). reset pro container
       largo. */
    max-width: var(--container-lg);
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  /* sem white-space:nowrap no H1: a quebra e controlada pelo <br> do markup
     ("PEÇA 2" / "PRATOS & PAGUE 1"); nowrap engolia o span .amp do "&". */
  .hero-cyt .hero-h1-cyt { font-size: 54px; }
  .hero-cyt .hero-eyebrow,
  .hero-cyt .hero-sublead { margin-left: 0; margin-right: 0; text-align: left; }
  .hero-cyt .hero-h1-cyt { grid-column: 1; text-align: left; }
  .hero-cyt .hero-eyebrow { grid-column: 1; grid-row: 1; }
  .hero-cyt .hero-h1-cyt { grid-row: 2; }
  .hero-cyt .hero-sublead { grid-column: 1; grid-row: 3; }
  .hero-cyt .offer-cards { grid-column: 1; grid-row: 4; margin-left: 0; }
  .hero-cyt .hero-composite {
    grid-column: 2;
    grid-row: 1 / -1;
    align-self: center;
    justify-self: center;
    width: 100%;
    height: auto;
    max-height: 460px;
    object-fit: contain;
    margin: 0;
  }
}

/* FAIXA DE LOGOS monocromaticos ("+4.000 restaurantes") — autoplay sem setas */
.brand-strip {
  overflow: hidden;
  margin: 22px 0 6px;
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.brand-track {
  display: flex;
  align-items: center;
  gap: 38px;
  width: max-content;
  animation: brand-scroll 22s linear infinite;
}
.brand-logo {
  height: 34px;
  width: auto;
  filter: grayscale(1) brightness(0) invert(1);
  opacity: 0.78;
  flex: 0 0 auto;
}
@keyframes brand-scroll {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .brand-track { animation: none; }
}

/* GRADE 2x2 de beneficios da campanha (pricing) */
.cyt-benefits {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: 14px;
  gap: 14px;
  margin-top: 26px;
}
.cyt-benefit {
  border: 1px solid rgba(110, 16, 19, 0.22);
  border-radius: 16px;
  padding: 20px 18px;
  background: var(--cream-2);
  text-align: left;
}
.cb-seal { display: inline-flex; margin-bottom: 8px; }
.cyt-benefit h3 {
  color: var(--cyt-green-real);
  font-size: 16px;
  font-weight: 800;
  text-transform: uppercase;
  line-height: 1.18;
}
.cyt-benefit p { color: var(--wine); font-size: 13px; margin-top: 6px; }

/* GARANTA UPGRADE INTER PRIME (cyt) */
.inter-up {
  background: var(--cream);
  padding: 46px 0 44px;
  text-align: center;
}
.inter-up > .inner { width: 100%; padding: 0 22px; }
.iu-eyebrow {
  color: var(--wine);
  font-size: 15px;
  font-weight: 600;
  margin-bottom: 2px;
}
.inter-up .section-title { color: var(--cyt-gold); margin-bottom: 24px; }
.iu-grid { display: block; }
.iu-card {
  width: 86%;
  max-width: 360px;
  margin: 0 auto 24px;
  display: block;
}
.iu-benefits {
  text-align: left;
  max-width: 440px;
  margin: 0 auto 26px;
}
.iu-benefits li {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 11px 0;
}
.iu-ico { flex: 0 0 auto; }
.iu-ico svg { width: 28px; height: 28px; }
.iu-ico svg path,
.iu-ico svg circle,
.iu-ico svg rect { fill: var(--cyt-gold); }
.iu-txt { display: flex; flex-direction: column; }
.iu-txt b { color: var(--wine); font-size: 15px; font-weight: 800; text-transform: uppercase; line-height: 1.15; }
.iu-desc { color: var(--text); font-size: 13px; margin-top: 2px; }
.iu-legal { font-size: 11px; color: #8a7d72; margin-top: 16px; line-height: 1.4; max-width: 440px; margin-left: auto; margin-right: auto; }

/* COUNTDOWN — SÓ FALTA VOCÊ! OFERTA LIMITADA. */
.countdown {
  background: var(--cyt-black);
  padding: 42px 0 46px;
  text-align: center;
}
.countdown > .inner { width: 100%; padding: 0 22px; }
.cd-timer {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-bottom: 18px;
}
.cd-block {
  background: var(--cyt-amber);
  color: #161616;
  font-size: 34px;
  font-weight: 900;
  font-feature-settings: "tnum";
  font-variant-numeric: tabular-nums;
  padding: 8px 14px;
  border-radius: 8px;
  min-width: 58px;
}
.cd-sep { color: var(--cyt-amber); font-size: 30px; font-weight: 900; }
.cd-title {
  color: #fff;
  font-size: 24px;
  font-weight: 900;
  text-transform: uppercase;
  line-height: 1.15;
}
.cd-sub { color: rgba(255,255,255,0.85); font-size: 15px; margin: 12px auto 22px; max-width: 420px; }
.cd-btn {
  background: var(--cyt-green-real);
  color: #fff;
  width: auto;
  max-width: 420px;
  margin: 0 auto;
  padding-left: 36px;
  padding-right: 36px;
}

/* App section: subtexto (cyt) */
.app-subtext { color: var(--wine); font-size: 14px; margin-top: 12px; font-weight: 600; }

/* O DUO VAI ALÉM (cyt): card = foto simples com pill verde sobreposta */
.is-cyt .xp-card {
  position: relative;
  background: transparent;
  box-shadow: none;
}
.is-cyt .xp-card img { height: 200px; border-radius: 16px; }
.is-cyt .xp-body {
  position: absolute;
  left: 12px;
  bottom: 12px;
  right: 12px;
  padding: 0;
}
.is-cyt .xp-body h3 { display: none; }
.is-cyt .xp-body .off {
  margin-top: 0;
  background: var(--cyt-green-real);
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}

/* FAQ (cyt): caret TRIANGULAR cheio marrom em vez do chevron */
.is-cyt .faq summary::after {
  content: "";
  width: 0;
  height: 0;
  border: none;
  border-left: 7px solid transparent;
  border-right: 7px solid transparent;
  border-top: 9px solid var(--wine);
  transform: none;
  margin-bottom: 0;
}
.is-cyt .faq details[open] summary::after {
  transform: rotate(180deg);
  margin-bottom: 0;
}

/* ---------------- FOOTER COMPLETO (cyt) ---------------- */
.footer-full {
  background: #000000;
  color: #fff;
  padding: 0 0 34px;
  text-align: center;
}
.ff-cta-bar {
  background: var(--wine);
  padding: 26px 22px 30px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.ff-cta-bar .btn.cta { width: auto; max-width: 420px; padding-left: 40px; padding-right: 40px; }
.ff-apps { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.ff-apps img { height: 42px; width: auto; }
.ff-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 22px;
  padding: 30px 22px 4px;
  max-width: 760px;
  margin: 0 auto;
}
.ff-nav a {
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  text-decoration: none;
  opacity: 0.9;
}
.ff-nav a:hover { opacity: 1; }
.ff-social {
  display: flex;
  gap: 18px;
  justify-content: center;
  padding: 22px 0 16px;
  color: #fff;
}
.ff-social a { color: #fff; display: inline-flex; }
.ff-copy { font-size: 13px; color: rgba(255,255,255,0.9); padding: 0 22px; }
.ff-legal {
  font-size: 11px;
  color: rgba(255,255,255,0.6);
  padding: 12px 22px 0;
  line-height: 1.5;
  max-width: 640px;
  margin: 0 auto;
}

/* ============================================================
   CYT DESKTOP 2-COLUNAS (Elementor) — PASS R3
   ============================================================ */
@media (min-width: 1024px) {
  /* faixa preta full-bleed, miolo contido */
  .is-cyt .rests { padding-left: 0; padding-right: 0; }
  .is-cyt .rests .inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 56px var(--gutter);
  }
  .brand-logo { height: 40px; }

  /* GRADE 2x2 beneficios da campanha + plano a esquerda */
  .pricing .plan-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 22px;
    gap: 22px;
    align-items: start;
  }
  .pricing .plan-card { max-width: none; margin: 0; }
  .cyt-benefits {
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-top: 28px;
  }

  /* INTER PRIME upgrade em 2 colunas: cartao ESQ, beneficios DIR */
  .inter-up { padding: 64px 0; }
  .inter-up > .inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
  }
  .iu-grid {
    display: grid;
    grid-template-columns: 0.9fr 1.1fr;
    align-items: center;
    grid-gap: 44px;
    gap: 44px;
    text-align: left;
  }
  .iu-card { margin: 0; width: 100%; }
  .iu-benefits {
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 14px 28px;
    gap: 14px 28px;
    margin: 0;
    max-width: none;
  }

  /* WINE em 2 colunas: texto ESQ, garrafa DIR */
  .wine > .inner {
    display: grid;
    grid-template-columns: 1.05fr 0.95fr;
    align-items: center;
    grid-gap: 40px;
    gap: 40px;
    text-align: left;
  }
  .wine .wine-eyebrow,
  .wine .section-title,
  .wine .wine-sub,
  .wine .wine-list { grid-column: 1; text-align: left; margin-left: 0; }
  .wine .wine-list { max-width: none; }
  .wine .wine-img {
    grid-column: 2;
    grid-row: 1 / span 5;
    margin: 0;
    width: 100%;
  }
  .wine .btn { grid-column: 1; margin: 0; }

  /* experiencias cyt: 4 por linha no desktop */
  .is-cyt .xp-grid { grid-template-columns: repeat(4, 1fr); }
  .is-cyt .xp-card img { height: 220px; }

  .countdown { padding: 64px 0; }
  .cd-block { font-size: 42px; min-width: 70px; }
}

/* ============================================================
   CAROUSEL ha-carousel (Carousel.tsx) — espelho do slick do Elementor.
   Setas circulares laterais + dots, N slides/view (4 desktop / 3 tablet /
   1 mobile). Slides BARE (PNG composito com selo/%OFF baked-in), sem texto.
   Vive sobre fundos escuros (.rests vinho, .beyond vinho/verde) — setas e
   dots brancos. Mobile: arrasta (scroll-snap); desktop: clique nas setas.
   ============================================================ */
.hcar {
  position: relative;
  margin-top: 26px;
  padding: 0 6px;
}
.hcar-viewport {
  overflow: hidden;
}
.hcar-track {
  display: flex;
  gap: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding: 4px 2px;
}
.hcar-track::-webkit-scrollbar { display: none; }
.hcar-slide {
  flex: 0 0 100%;
  scroll-snap-align: center;
  min-width: 0;
}
.hcar-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 16px;
  aspect-ratio: 360 / 492;
  object-fit: cover;
}
/* setas circulares (slick prev/next): escondidas no mobile (swipe), visiveis
   a partir do tablet, igual ao widget real. */
.hcar-arrow {
  display: none;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 3;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.95);
  color: var(--wine);
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
  transition: opacity 0.15s, background 0.15s;
}
.hcar-arrow:disabled { opacity: 0.35; cursor: default; }
.hcar-prev { left: -6px; }
.hcar-next { right: -6px; }
.is-cyt .hcar-arrow { color: var(--cyt-green-real, var(--cyt-green)); }
/* dots */
.hcar-dots {
  display: flex;
  gap: 8px;
  justify-content: center;
  margin-top: 18px;
  flex-wrap: wrap;
}
.hcar-dot {
  width: 8px;
  height: 8px;
  padding: 0;
  border: none;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.4);
  cursor: pointer;
}
.hcar-dot.on {
  background: #fff;
  width: 10px;
  height: 10px;
}

/* ============================================================ PARIDADE REGIONAL
   A LP regional REAL tem MUITAS secoes no DOM que o Elementor ESCONDE via
   display:none responsivo — elas nunca renderizam visivelmente nem no desktop
   nem no mobile. O clone (rodada 3) adicionou todas e passou a renderiza-las,
   ficando ate ~2x mais alto que a real e quebrando a paridade.
   Confirmado por captura headless da real (desktop 1280 + mobile 390):
   - Secoes que a real NUNCA mostra (esconder em qualquer largura, so na
     regional): Confira-na-pratica, "Voce ja passou", "Os Duo Lovers"
     (foto mbl2 + video separado), Beneficios, Como-utilizar, Pra-quem-e,
     Teste-7-dias, Suporte. O "Duo Lovers" da real e, na verdade, o carrossel
     de influencers (GIF + @handle + frase) logo apos "E tudo no app", que
     PERMANECE visivel.
   - Inter Prime: a real MOSTRA no desktop e ESCONDE no mobile (so <=767px).
   (.is-cyt tem estrutura propria e nao e afetada.) Punchlist pos-verify. */
.page:not(.is-cyt) .practice,
.page:not(.is-cyt) .passed,
.page:not(.is-cyt) .lovers,
.page:not(.is-cyt) .benefits-duo,
.page:not(.is-cyt) .howto,
.page:not(.is-cyt) .whofor,
.page:not(.is-cyt) .guarantee,
.page:not(.is-cyt) .support,
/* FOOTER regional: o real tem o copyright com class "copyright hide"
   (.hide{display:none!important}) — a barra escura "QUERO ECONOMIZAR" NAO
   renderiza. Alinhamos o clone ao real: esconder a .footer simples na regional. */
.page:not(.is-cyt) .footer {
  display: none;
}
@media (max-width: 767px) {
  .page:not(.is-cyt) .inter {
    display: none;
  }
}

@media (min-width: 700px) {
  .hcar { padding: 0 44px; }
  .hcar-arrow { display: inline-flex; }
  /* mantem scrollavel (scrollbar oculto) pro scrollTo das setas funcionar */
  .hcar-track { gap: 18px; }
  .hcar-slide { scroll-snap-align: start; }
}
@media (min-width: 1024px) {
  .hcar { padding: 0 52px; }
  .hcar-track { gap: 22px; }
}

