/* ============================================================
   Orange Viagens · Tênis — Design System
   "Court green + luxury gold" · editorial premium · light mode
   Display: Cormorant Garamond · UI: Manrope · Mono: Space Mono
   (reskin baseado no handoff TennisElite, marca Orange Viagens)
   ============================================================ */

:root{
  /* verdes da marca */
  --green:#1B5E3F; --green-deep:#123F2A; --green-soft:#2C7A54; --green-tint:#EAF1ED; --green-wash:#F3F7F4;
  /* dourado de luxo */
  --gold:#C9A227; --gold-bright:#D4AF37; --gold-deep:#A8841D; --gold-soft:#E7CE7E; --gold-tint:#FBF4DE;
  /* neutros quentes */
  --ink:#16201B; --ink-2:#525B55; --ink-3:#8A938C;
  --paper:#FBF9F3; --surface:#FFFFFF; --surface-2:#F6F4EC; --line:#E7E3D8; --line-soft:#F0ECE1;
  /* status */
  --success:#2E8B57; --success-tint:#E7F2EB; --warn:#A8841D; --danger:#B23A2E; --link:#1463C7;
  /* superfícies por piso da quadra */
  --clay:#C06A38; --grass:#2C7A54; --hard:#2F6FB0; --indoor:#6A4A8C;
  /* CTA accent */
  --accent-1:var(--gold-bright); --accent-2:var(--gold-deep);
  /* aliases de compatibilidade (estilos inline antigos do JS) */
  --orange-deep:var(--gold-deep); --ok:var(--success); --ink-soft:var(--ink-2); --ink-faint:var(--ink-3);
  --paper-2:var(--surface-2); --line-strong:var(--line); --orange:var(--gold-deep); --orange-tint:var(--gold-tint);
  /* fontes */
  --font-display:"Bricolage Grotesque","Manrope",system-ui,sans-serif;
  --font-sans:"Manrope",system-ui,-apple-system,sans-serif;
  --font-mono:"Space Mono",ui-monospace,monospace;
  /* raios */
  --r-xs:8px; --r-sm:12px; --r-md:18px; --r-lg:24px; --r-xl:36px; --r-pill:999px;
  --radius:var(--r-sm); --radius-lg:var(--r-lg);
  /* sombras */
  --sh-1:0 1px 2px rgba(22,32,27,.05), 0 2px 6px rgba(22,32,27,.04);
  --sh-2:0 10px 24px rgba(22,32,27,.08), 0 30px 60px -18px rgba(22,32,27,.16);
  --shadow-gold:0 8px 18px -4px rgba(201,162,39,.45), 0 18px 40px -14px rgba(201,162,39,.40);
  --shadow-green:0 8px 18px -4px rgba(27,94,63,.32), 0 18px 40px -14px rgba(27,94,63,.30);
  --ease:cubic-bezier(.22,1,.36,1);
  --maxw:1200px; --nav-h:80px;
}

*{box-sizing:border-box}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-sans); font-size:16px; line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
body.nav-locked{ overflow:hidden }
a{ color:inherit; text-decoration:none }
img{ max-width:100%; display:block }
::selection{ background:var(--gold-soft); color:var(--green-deep) }

/* tipografia ----------------------------------------------------------- */
.display{ font-family:var(--font-display); font-weight:600; line-height:1.04; letter-spacing:-.01em; text-transform:none }
h1,h2,h3{ margin:0 0 .35em }
.mono{ font-family:var(--font-mono); font-variant-numeric:tabular-nums; letter-spacing:-.02em }
.eyebrow{ font:700 12px/1 var(--font-sans); letter-spacing:.22em; text-transform:uppercase; color:var(--gold-deep) }
.muted{ color:var(--ink-3) }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 40px }

/* botões --------------------------------------------------------------- */
.btn{ display:inline-flex; align-items:center; gap:10px; justify-content:center;
  padding:14px 28px; border-radius:var(--r-pill); border:1.5px solid transparent;
  font:700 15px/1 var(--font-sans); letter-spacing:.005em; cursor:pointer; white-space:nowrap;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease), color .2s, border-color .2s; }
.btn:active{ transform:scale(.98) }
.btn > svg{ pointer-events:none; width:18px; height:18px }
/* --orange = CTA primário dourado (mantém nome da classe usada no JS) */
.btn--orange{ background:linear-gradient(135deg,var(--accent-1),var(--accent-2)); color:#2A2208; box-shadow:var(--shadow-gold) }
.btn--orange:hover{ transform:translateY(-2px); box-shadow:0 12px 24px -4px rgba(201,162,39,.55), 0 24px 50px -14px rgba(201,162,39,.45) }
.btn--green{ background:var(--green); color:#fff; box-shadow:var(--shadow-green) }
.btn--green:hover{ background:var(--green-deep); transform:translateY(-2px) }
.btn--ghost{ background:transparent; color:var(--green); border-color:var(--green) }
.btn--ghost:hover{ background:var(--green); color:#fff }
.btn--sm{ padding:9px 16px; font-size:13px }
.btn--block{ width:100% }

.tag{ display:inline-flex; align-items:center; gap:.4em; font:800 11.5px/1 var(--font-sans);
  letter-spacing:.08em; text-transform:uppercase; padding:6px 12px; border-radius:var(--r-pill);
  background:var(--green-wash); color:var(--green); border:1px solid var(--line) }
.tag--surface{ color:#fff; border:none }
.tag.clay{ background:var(--clay) } .tag.grass{ background:var(--grass) }
.tag.hard{ background:var(--hard) } .tag.indoor{ background:var(--indoor) }
.tag--tier{ background:var(--green-tint); color:var(--green); border:none }
.tag--ground{ background:var(--gold-tint); color:var(--gold-deep); border-color:#ecd9a0 }

/* ===================== NAV ===================== */
.nav{ position:sticky; top:0; z-index:60; height:var(--nav-h);
  background:rgba(251,249,243,.82); backdrop-filter:blur(20px) saturate(1.2);
  border-bottom:1px solid var(--line-soft) }
.nav__in{ height:100%; display:flex; align-items:center; gap:28px; max-width:var(--maxw); margin:0 auto; padding:0 40px }
/* marca = logo-mãe Orange Viagens (vetor oficial) + descritor da vertical "Tênis" */
.brand{ display:flex; align-items:center; gap:10px; line-height:1 }
.brand__logo{ height:32px; width:auto; display:block }
.brand__sep{ width:1.5px; height:23px; background:var(--gold); border-radius:2px; opacity:.7 }
.brand__tenis{ font-family:var(--font-display); font-weight:600; font-style:italic; font-size:25px; line-height:1; color:var(--gold-deep); letter-spacing:-.01em }
@media (max-width:640px){ .brand__logo{ height:27px } .brand__tenis{ font-size:21px } .brand__sep{ height:20px } }
.nav__links{ display:flex; align-items:center; gap:4px; margin-left:auto }
.nav__links a{ font:600 14.5px/1 var(--font-sans); padding:9px 16px; border-radius:var(--r-pill); color:var(--ink-2) }
.nav__links a:hover,.nav__links a.active{ color:var(--green); background:var(--green-wash) }
.nav__cart{ position:relative }
.nav__cart .count{ position:absolute; top:-6px; right:-4px; background:linear-gradient(135deg,var(--accent-1),var(--accent-2)); color:#2A2208;
  font:800 11px/1 var(--font-mono); min-width:18px; height:18px; border-radius:999px; display:grid; place-items:center; padding:0 4px }
.burger{ display:none; margin-left:auto; width:46px; height:46px; border:1px solid var(--line); background:var(--surface); border-radius:var(--r-sm); cursor:pointer; flex-direction:column; gap:4px; align-items:center; justify-content:center }
.burger span{ width:20px; height:2px; background:var(--green); border-radius:2px }

.drawer{ position:fixed; inset:0 0 0 auto; width:min(86vw,360px); background:var(--paper);
  border-left:1px solid var(--line); transform:translateX(100%); transition:transform .35s var(--ease);
  z-index:80; padding:24px; display:flex; flex-direction:column; gap:6px; box-shadow:var(--sh-2) }
.drawer.open{ transform:translateX(0) }
.drawer a{ font:600 18px/1 var(--font-sans); padding:15px 8px; border-bottom:1px solid var(--line-soft); color:var(--ink) }
.drawer__close{ align-self:flex-end; background:none; border:none; font-size:30px; cursor:pointer; color:var(--green) }
.scrim{ position:fixed; inset:0; background:rgba(18,32,25,.46); opacity:0; pointer-events:none; transition:opacity .3s; z-index:70 }
.scrim.show{ opacity:1; pointer-events:auto }

/* ===================== HERO ===================== */
.hero{ position:relative; overflow:hidden; isolation:isolate;
  background:linear-gradient(105deg,#0E3322,#1B5E3F 60%,#123F2A) }
.hero__bg{ position:absolute; inset:0; opacity:.32; background-size:cover; background-position:center; filter:saturate(.85) contrast(1.02); z-index:0 }
.hero__grain{ position:absolute; inset:0; z-index:1; opacity:.5; mix-blend-mode:overlay;
  background:radial-gradient(120% 80% at 80% 0%, rgba(212,175,55,.28), transparent 55%) }
.hero__court{ position:absolute; right:-4%; top:50%; transform:translateY(-50%); width:48%; opacity:.18; z-index:1; pointer-events:none; stroke:var(--gold-soft) }
.hero__in{ position:relative; z-index:2; max-width:var(--maxw); margin:0 auto; padding:96px 40px 84px; color:#fff }
.hero__in .eyebrow{ color:var(--gold-soft) }
.hero h1{ font-family:var(--font-display); font-weight:600; font-size:clamp(52px,7.5vw,84px); margin:.14em 0 .26em; color:#fff; line-height:1.02; letter-spacing:-.015em; max-width:11ch }
.hero h1 .o{ color:var(--gold-bright); font-style:italic }
.hero__sub{ max-width:540px; font-size:19px; color:rgba(255,255,255,.82); line-height:1.6 }
.hero__cta{ display:flex; gap:14px; margin-top:32px; flex-wrap:wrap }

.courtline{ height:5px; background:linear-gradient(90deg,var(--gold-deep),var(--gold-bright),var(--gold-deep)) }

/* ===================== PILL FILTER BAR (Travel Tech) ===================== */
.searchbar{ position:relative; z-index:40; margin:-32px auto 0; max-width:980px; padding:0 40px }
.searchbar__in{ display:flex; align-items:stretch; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-pill); box-shadow:var(--sh-2); overflow:visible }
.seg{ position:relative; flex:1; padding:14px 24px; cursor:pointer; border-right:1px solid var(--line-soft); display:flex; flex-direction:column; gap:2px; transition:background .2s var(--ease) }
.seg:first-of-type{ border-top-left-radius:var(--r-pill); border-bottom-left-radius:var(--r-pill) }
.seg:last-of-type{ border-right:none }
.seg:hover{ background:var(--green-wash) }
.seg .k{ font:700 11px/1 var(--font-sans); letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3) }
.seg .v{ font:600 14px/1.2 var(--font-sans); color:var(--ink); white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.seg.is-set .v{ color:var(--green) }
.searchbar__go{ flex:0 0 auto; margin:7px; border-radius:var(--r-pill); padding:0 24px }
.popover{ position:absolute; top:calc(100% + 12px); left:0; min-width:240px; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--sh-2); padding:10px; display:flex; flex-direction:column; gap:2px; z-index:50 }
.popover[hidden]{ display:none !important }
.popover button{ text-align:left; background:none; border:none; padding:10px 12px; border-radius:var(--r-xs);
  font:500 14px/1.2 var(--font-sans); cursor:pointer; color:var(--ink); display:flex; justify-content:space-between; gap:12px }
.popover button:hover{ background:var(--green-wash) }
.popover button.sel{ background:var(--green-tint); color:var(--green); font-weight:700 }

/* ===================== SEÇÕES / GRID ===================== */
.section{ padding:88px 0 }
.section__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:32px; flex-wrap:wrap }
.section__head h2{ font-family:var(--font-display); font-weight:600; font-size:clamp(34px,4.4vw,50px); color:var(--green); margin:0; line-height:1.04 }
.rule{ height:1px; background:var(--line); margin:0 0 28px }
.grid{ display:grid; grid-template-columns:repeat(auto-fill,minmax(330px,1fr)); gap:28px }

/* ===================== CARD DE TORNEIO ===================== */
.tcard{ position:relative; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  overflow:hidden; box-shadow:var(--sh-1); transition:transform .3s var(--ease), box-shadow .3s var(--ease); display:flex; flex-direction:column }
.tcard:hover{ transform:translateY(-6px); box-shadow:var(--sh-2) }
.tcard__img{ aspect-ratio:16/10; background:#0E3322 center/cover; position:relative }
.tcard__img::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(14,51,34,.05) 35%,rgba(14,51,34,.82)) }
.tcard__surf{ position:absolute; top:14px; left:14px; z-index:2 }
.tcard__urg{ position:absolute; top:50px; left:14px; z-index:2; display:inline-flex; align-items:center; gap:6px;
  font:800 10.5px/1 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; padding:6px 11px; border-radius:var(--r-pill);
  background:rgba(255,255,255,.94); color:var(--green); box-shadow:var(--sh-1) }
.tcard__urg::before{ content:""; width:6px; height:6px; border-radius:50%; background:currentColor }
.tcard__urg.hot{ background:linear-gradient(135deg,var(--gold-bright),var(--gold-deep)); color:#2A2208 }
.tcard__logo{ position:absolute; top:12px; right:14px; z-index:2; width:46px; height:46px; border-radius:12px; background:rgba(255,255,255,.94); padding:6px; box-shadow:var(--sh-1); object-fit:contain }
.tcard__cap{ position:absolute; left:18px; right:18px; bottom:16px; z-index:2; color:#fff }
.tcard__cap h3{ font-family:var(--font-display); font-weight:600; font-size:30px; margin:0; line-height:1.02 }
.tcard__cap .loc{ font:600 12.5px/1 var(--font-sans); letter-spacing:.01em; opacity:.92; display:flex; gap:6px; align-items:center; margin-top:4px }
.tcard__body{ padding:18px 20px; display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:auto }
.tcard__dates{ font:500 13px/1.3 var(--font-mono); color:var(--ink-2) }
.tcard__from .k{ font:700 10px/1 var(--font-sans); letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3) }
.tcard__from .p{ font-family:var(--font-sans); font-weight:800; font-size:22px; color:var(--green); font-variant-numeric:tabular-nums }
.tcard__from .p small{ font-family:var(--font-sans); font-weight:600; font-size:11px; color:var(--ink-3) }

.chips{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px }
.chip{ font:600 13.5px/1 var(--font-sans); padding:10px 18px; border-radius:var(--r-pill); background:var(--surface);
  border:1px solid var(--line); cursor:pointer; color:var(--ink-2); transition:.2s var(--ease) }
.chip:hover{ border-color:var(--green-soft); background:var(--green-wash); color:var(--green) }
.chip.active{ background:var(--green); color:#fff; border-color:var(--green); box-shadow:var(--shadow-green) }

/* ===================== HOME OTA ===================== */
.hhero{ position:relative; isolation:isolate; z-index:2; background:#0E3322 }
.hhero__bg,.hhero__veil{ border-radius:inherit }
.hhero__bg{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; opacity:.34; filter:saturate(.9) }
.hhero__veil{ position:absolute; inset:0; z-index:1; background:linear-gradient(120deg,#0E3322 8%,rgba(14,51,34,.74) 48%,rgba(14,51,34,.5)),radial-gradient(110% 90% at 88% 0%,rgba(212,175,55,.26),transparent 55%) }
.hhero__in{ position:relative; z-index:2; padding:70px 40px 30px; color:#fff }
.hhero__in .eyebrow{ color:var(--gold-soft) }
.hhero h1{ font-family:var(--font-display); font-weight:600; font-size:clamp(40px,5.6vw,68px); line-height:1.02; letter-spacing:-.015em; margin:.16em 0 .2em; color:#fff }
.hhero h1 .o{ color:var(--gold-bright); font-style:italic }
.hhero__sub{ max-width:600px; font-size:18px; color:rgba(255,255,255,.84); line-height:1.55 }
/* barra de busca — segmentos rotulados (Torneio/destino · Quando) */
.hsearch{ position:relative; z-index:20; margin:30px 0 16px; max-width:760px }
.hsearch__box{ position:relative; display:flex; align-items:stretch; gap:0; background:var(--surface);
  border-radius:var(--r-pill); box-shadow:var(--sh-2); padding:8px }
.hseg{ display:flex; flex-direction:column; justify-content:center; gap:4px; padding:8px 22px; min-width:0; border-radius:var(--r-pill); transition:background .15s }
.hseg--where{ flex:1 1 auto }
.hseg:hover{ background:var(--green-wash) }
.hseg__label{ font:700 10.5px/1 var(--font-sans); letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep) }
.hseg__field{ display:flex; align-items:center; gap:9px }
.hseg__ic{ width:18px; height:18px; color:var(--green-soft); flex:0 0 auto }
.hsearch__input{ flex:1; min-width:0; border:none; outline:none; background:none; font:600 16px/1.3 var(--font-sans); color:var(--ink); padding:0 }
.hsearch__input::placeholder{ color:var(--ink-3); font-weight:500 }
.hseg--when .hseg__field{ position:relative }
.hseg__trigger{ display:flex; align-items:center; gap:10px; background:none; border:none; cursor:pointer; font:600 15px/1.3 var(--font-sans); color:var(--ink); padding:0; white-space:nowrap }
.hseg__trigger.is-set{ color:var(--green) }
.hseg__chev{ width:14px; height:14px; color:var(--ink-3); transition:transform .2s var(--ease); flex:0 0 auto }
.hseg__trigger[aria-expanded="true"] .hseg__chev{ transform:rotate(180deg) }
.hseg__menu{ position:absolute; top:calc(100% + 14px); right:0; z-index:70; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--r-md); box-shadow:var(--sh-2); padding:6px; min-width:210px; max-height:320px; overflow:auto }
.hseg__menu[hidden]{ display:none !important }
.hopt{ display:block; width:100%; text-align:left; background:none; border:none; cursor:pointer; padding:11px 13px; border-radius:var(--r-sm); font:600 14px/1.2 var(--font-sans); color:var(--ink) }
.hopt:hover{ background:var(--green-wash) }
.hopt.on{ background:var(--green-tint); color:var(--green) }
/* selo "ou" entre os dois eixos de busca */
.hsearch__or{ align-self:center; flex:0 0 auto; display:grid; place-items:center; width:30px; height:30px; border-radius:50%;
  background:var(--green-wash); color:var(--green-soft); font:700 11px/1 var(--font-sans); border:1px solid var(--green-tint); margin:0 2px }
.hsearch__go{ align-self:center; flex:0 0 auto; border-radius:var(--r-pill); padding:15px 28px; margin-left:6px }
/* filtros do /torneios */
.filters{ display:flex; align-items:center; gap:16px; flex-wrap:wrap; margin-bottom:28px }

/* dropdown multi-select "Quando" (Travel Tech) */
.mselect{ position:relative }
.mselect__trigger{ display:flex; align-items:center; gap:9px; background:var(--surface); border:1px solid var(--line-strong);
  border-radius:var(--r-pill); padding:10px 15px; cursor:pointer; transition:border-color .18s var(--ease), box-shadow .18s var(--ease) }
.mselect__trigger:hover{ border-color:var(--green-soft) }
.mselect.is-set .mselect__trigger{ border-color:var(--green); box-shadow:0 0 0 3px var(--green-tint) }
.mselect[aria-expanded] .mselect__trigger{}
.mselect__ic{ width:18px; height:18px; color:var(--gold-deep); flex:none }
.mselect__cap{ font:700 11px/1 var(--font-sans); letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3) }
.mselect__label{ font:600 14px/1 var(--font-sans); color:var(--green); white-space:nowrap }
.mselect__count{ display:grid; place-items:center; min-width:18px; height:18px; padding:0 5px; border-radius:9px;
  background:var(--green); color:#fff; font:700 11px/1 var(--font-mono) }
.mselect__chev{ width:16px; height:16px; color:var(--ink-3); transition:transform .2s var(--ease) }
.mselect__trigger[aria-expanded="true"] .mselect__chev{ transform:rotate(180deg) }
.mselect__menu{ position:absolute; top:calc(100% + 8px); left:0; z-index:60; width:288px; max-width:88vw;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); box-shadow:var(--sh-2); overflow:hidden }
.mselect__menu[hidden]{ display:none }
.mselect__head{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:13px 16px 10px;
  font:700 11px/1 var(--font-sans); letter-spacing:.06em; text-transform:uppercase; color:var(--ink-3); border-bottom:1px solid var(--line-soft) }
.mselect__clear{ background:none; border:none; cursor:pointer; font:700 11px/1 var(--font-sans); letter-spacing:.04em; text-transform:uppercase; color:var(--gold-deep); padding:2px 4px }
.mselect__clear:hover{ color:var(--green) }
.mselect__opts{ max-height:264px; overflow:auto; padding:6px }
.mopt{ display:flex; align-items:center; gap:11px; width:100%; padding:10px 12px; border:none; background:none; cursor:pointer;
  border-radius:var(--r-sm); font:600 14px/1 var(--font-sans); color:var(--ink); text-align:left; transition:background .14s var(--ease) }
.mopt:hover{ background:var(--green-wash) }
.mopt__check{ display:grid; place-items:center; width:20px; height:20px; flex:none; border-radius:6px;
  border:1.5px solid var(--line-strong); background:var(--surface); color:#fff; transition:background .14s var(--ease), border-color .14s var(--ease) }
.mopt__check svg{ width:14px; height:14px; opacity:0; transition:opacity .14s var(--ease) }
.mopt.on .mopt__check{ background:var(--green); border-color:var(--green) }
.mopt.on .mopt__check svg{ opacity:1 }
.mopt.on{ color:var(--green) }
.mselect__foot{ padding:10px 12px; border-top:1px solid var(--line-soft) }
.mselect__apply{ width:100% }
.chips{ margin-bottom:0 }
.chips__div{ width:1px; background:var(--line); margin:4px 6px; align-self:stretch }
.hsearch__sug{ position:absolute; top:calc(100% + 10px); left:0; right:0; z-index:60; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--sh-2); padding:6px;
  max-height:340px; overflow:auto }
.hsearch__sug[hidden]{ display:none !important }
.hsug{ display:flex; align-items:center; gap:13px; width:100%; text-align:left; background:none; border:none; cursor:pointer;
  padding:11px 12px; border-radius:var(--r-sm); color:var(--ink) }
.hsug:hover,.hsug.on{ background:var(--green-wash) }
.hsug--empty{ display:block; padding:14px 12px; font-size:14px; color:var(--ink-3); cursor:default }
.hsug--empty a{ color:var(--green); font-weight:700 }
.hsug__dot{ width:10px; height:10px; border-radius:50%; flex:0 0 auto }
.hsug__dot.clay{ background:var(--clay) } .hsug__dot.grass{ background:var(--grass) }
.hsug__dot.hard{ background:var(--hard) } .hsug__dot.indoor{ background:var(--indoor) } .hsug__dot.varies{ background:var(--gold-deep) }
.hsug__t{ flex:1; display:flex; flex-direction:column; line-height:1.25; min-width:0 }
.hsug__t b{ font:700 15px/1.2 var(--font-sans); white-space:nowrap; overflow:hidden; text-overflow:ellipsis }
.hsug__t small{ font-size:12.5px; color:var(--ink-3) }
.hsug__p{ font:600 12.5px/1 var(--font-mono); color:var(--green); white-space:nowrap }
.hsearch__chips{ display:flex; align-items:center; gap:9px; flex-wrap:wrap; font:600 13px/1 var(--font-sans); color:rgba(255,255,255,.66) }
.hsearch__chips a{ padding:7px 14px; border-radius:var(--r-pill); background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2); color:#fff }
.hsearch__chips a:hover{ background:rgba(255,255,255,.2) }
.trust{ display:flex; flex-wrap:wrap; gap:18px; color:rgba(255,255,255,.86); font:600 13.5px/1 var(--font-sans) }
.trust span{ display:inline-flex; align-items:center; gap:6px }

/* trilho horizontal */
.rail{ display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; padding:4px 2px 18px; margin:0 -2px;
  scrollbar-width:thin }
.rail .tcard{ flex:0 0 320px; scroll-snap-align:start }
.rail::-webkit-scrollbar{ height:8px }
.rail::-webkit-scrollbar-thumb{ background:var(--line-strong); border-radius:99px }

/* seções alternadas */
.section--green{ background:var(--green-deep); color:#fff }
.section--alt{ background:var(--surface-2) }

/* concierge */
.concierge{ display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:center }
.concierge__lead h2{ font-size:clamp(32px,4vw,46px); color:#fff; line-height:1.05; margin:8px 0 14px }
.concierge__lead h2 .i{ color:var(--gold-soft); font-style:italic }
.concierge__lead p{ color:rgba(255,255,255,.78); font-size:16.5px; line-height:1.65; max-width:46ch; margin-bottom:22px }
.concierge__grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px }
.cpoint{ background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.12); border-radius:var(--r-lg); padding:20px }
.cpoint__ic{ display:grid; place-items:center; width:46px; height:46px; border-radius:var(--r-md); background:rgba(212,175,55,.16); color:var(--gold-soft); margin-bottom:12px }
.cpoint__ic svg{ width:24px; height:24px }
.cpoint b{ display:block; font:700 15px/1.3 var(--font-sans); color:#fff; margin-bottom:4px }
.cpoint p{ font-size:13.5px; line-height:1.55; color:rgba(255,255,255,.7) }

/* prova social */
.proof{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; padding:8px 0;
  border-top:1px solid var(--line); border-bottom:1px solid var(--line) }
.proof__stat{ padding:24px 8px }
.proof__stat span{ font:600 14px/1.4 var(--font-sans); color:var(--ink-2) }
.proof__n{ font-family:var(--font-display); font-weight:600; font-size:48px; color:var(--green); line-height:1 }

/* faixa de CTA */
.ctaband{ background:linear-gradient(135deg,var(--green),var(--green-deep)) }
.ctaband__in{ display:flex; align-items:center; justify-content:space-between; gap:30px; padding:56px 40px; color:#fff; flex-wrap:wrap }
.ctaband__in h2{ font-size:clamp(28px,3.4vw,40px); color:#fff; margin:6px 0 8px }
.ctaband__in p{ color:rgba(255,255,255,.8); font-size:16px; max-width:48ch }
.btn--lg{ padding:18px 38px; font-size:16px }

/* FAQ */
.faq{ display:flex; flex-direction:column; gap:10px; text-align:left }
.faq__item{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:0 20px; box-shadow:var(--sh-1) }
.faq__item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px;
  padding:18px 0; font:700 16px/1.4 var(--font-sans); color:var(--ink) }
.faq__item summary::-webkit-details-marker{ display:none }
.faq__chev{ flex:0 0 auto; width:26px; height:26px; display:grid; place-items:center; border-radius:50%;
  background:var(--green-wash); color:var(--green); font-size:18px; transition:transform .2s var(--ease) }
.faq__item[open] .faq__chev{ transform:rotate(45deg) }
.faq__item p{ margin:0; padding:0 0 20px; color:var(--ink-2); font-size:15px; line-height:1.65; max-width:64ch }

@media (max-width:880px){
  .concierge{ grid-template-columns:1fr; gap:28px }
  .hsearch{ max-width:none }
  .hsearch__box{ flex-direction:column; align-items:stretch; border-radius:var(--r-lg); padding:8px 12px }
  .hseg{ border-radius:var(--r-md); padding:10px 8px }
  .hseg--where{ flex:0 0 auto }
  .hsearch__or{ align-self:center; margin:4px 0 }
  .hseg__menu{ left:0; right:0; min-width:0 }
  .hsearch__go{ align-self:stretch; margin:8px 0 2px; border-radius:var(--r-sm) }
  .proof{ grid-template-columns:repeat(2,1fr) }
  .ctaband__in{ flex-direction:column; align-items:flex-start; text-align:left }
}

/* ===================== WHY STRIP ===================== */
.why-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:24px }
.why{ background:var(--green-wash); border:1px solid var(--line-soft); border-radius:var(--r-xl); padding:34px 30px }
.why__ic{ display:grid; place-items:center; width:54px; height:54px; border-radius:var(--r-md); background:var(--surface);
  box-shadow:var(--sh-1); color:var(--gold-deep); margin-bottom:18px }
.why__ic svg{ width:26px; height:26px }
.why h3{ font-family:var(--font-display); font-weight:600; font-size:24px; color:var(--green); margin:0 0 8px; line-height:1.05 }
.why p{ font-size:14.5px; line-height:1.6; margin:0 }

/* ===================== FASES DA CHAVE (pacotes) ===================== */
.phases{ display:grid; grid-template-columns:repeat(auto-fill,minmax(245px,1fr)); gap:18px; margin-bottom:18px }
.phase{ text-align:left; background:var(--surface); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:20px;
  cursor:pointer; transition:transform .2s var(--ease), box-shadow .2s var(--ease), border-color .2s; display:flex; flex-direction:column; gap:8px; box-shadow:var(--sh-1) }
.phase:hover{ transform:translateY(-4px); box-shadow:var(--sh-2); border-color:var(--green-soft) }
.phase.on{ border-color:var(--green); background:var(--green-wash); box-shadow:0 0 0 3px var(--green-tint) }
.phase__top{ display:flex; align-items:center; justify-content:space-between; gap:8px }
.phase__label{ font-family:var(--font-display); font-weight:600; font-size:21px; color:var(--green); line-height:1 }
.phase__count{ font:600 11px/1 var(--font-mono); color:var(--ink-3); white-space:nowrap }
.phase__dates{ font:600 12.5px/1.2 var(--font-mono); color:var(--ink-2) }
.phase__blurb{ font-size:13px; line-height:1.5; color:var(--ink-2); margin:2px 0 8px }
.phase__foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:auto }
.phase__k{ font:700 9.5px/1 var(--font-sans); letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3); display:block }
.phase__p{ font-family:var(--font-sans); font-weight:800; font-size:18px; color:var(--green) }
.phase__cta{ font:700 12.5px/1 var(--font-sans); color:var(--gold-deep); white-space:nowrap }
.phase-cta{ display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  background:var(--green-wash); border:1px solid var(--green-tint); border-radius:var(--r-lg); padding:16px 22px; font-size:14.5px; color:var(--ink) }
@media (max-width:560px){ .phase-cta{ flex-direction:column; align-items:flex-start } }

/* ===================== VITRINE DE SESSÕES (lista travel-tech) ===================== */
.daygroup{ margin-bottom:24px }
.dayhead{ display:flex; align-items:center; gap:12px; margin-bottom:12px; position:sticky; top:var(--nav-h); z-index:20; background:var(--paper); padding:10px 0 }
.dayhead__date{ font-family:var(--font-display); font-weight:600; font-size:18px; line-height:1; color:var(--ink); text-transform:capitalize; letter-spacing:-.01em }
.dayhead__rounds{ display:flex; gap:6px; flex-wrap:wrap }

.srows{ display:flex; flex-direction:column; gap:10px }
.srow{ display:grid; grid-template-columns:1fr auto 42px; align-items:center; gap:20px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:15px 18px;
  transition:border-color .18s, box-shadow .18s, transform .18s var(--ease) }
.srow:hover{ border-color:var(--green-soft); box-shadow:var(--sh-1); transform:translateX(3px) }
.srow__court{ font:700 16px/1.25 var(--font-sans); color:var(--ink); display:flex; align-items:center; gap:10px; flex-wrap:wrap }
.srow__club{ font-size:12.5px; color:var(--ink-3); margin-top:2px }
.srow__chips{ display:flex; align-items:center; gap:7px; flex-wrap:wrap; margin-top:10px }
.schip{ display:inline-flex; align-items:center; gap:5px; font:600 11.5px/1 var(--font-sans); padding:6px 11px; border-radius:var(--r-pill);
  background:var(--surface-2); color:var(--ink-2); border:1px solid var(--line-soft) }
.schip svg{ width:13px; height:13px; flex:0 0 auto }
.schip--day{ background:#FBF1D6; color:#977b1c; border-color:#eddca6 }
.schip--night{ background:var(--green-tint); color:var(--green); border-color:#cfe2d7 }
.schip--time{ font-family:var(--font-mono); font-weight:500; letter-spacing:-.02em }
.schip--ground{ background:var(--gold-tint); color:var(--gold-deep); border-color:#ecd9a0 }
.srow__price{ text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:2px; white-space:nowrap }
.srow__k{ font:700 9.5px/1 var(--font-sans); letter-spacing:.1em; text-transform:uppercase; color:var(--ink-3) }
.srow__p{ font:800 21px/1 var(--font-sans); color:var(--green); font-variant-numeric:tabular-nums }
.srow__pix{ font:700 9.5px/1 var(--font-sans); letter-spacing:.08em; text-transform:uppercase; color:var(--gold-deep) }
.srow__go{ width:40px; height:40px; display:grid; place-items:center; border-radius:50%; background:var(--green-wash); color:var(--green); transition:background .18s, color .18s }
.srow:hover .srow__go{ background:var(--green); color:#fff }
.srow__go svg{ width:18px; height:18px }
@media (max-width:640px){
  .srow{ grid-template-columns:1fr auto; gap:12px }
  .srow__go{ display:none }
}

/* ===================== DETALHE DA SESSÃO + OFERTAS ===================== */
.detail{ display:grid; grid-template-columns:minmax(0,1fr) .82fr; gap:40px; align-items:start }
.detail__media{ position:sticky; top:calc(var(--nav-h) + 20px) }
.detail__media img{ border-radius:var(--r-xl); border:1px solid var(--line); box-shadow:var(--sh-1); width:100% }
.detail__facts{ display:flex; flex-wrap:wrap; gap:10px; margin:18px 0 }
.fact{ background:var(--surface-2); border:1px solid var(--line); border-radius:var(--r-sm); padding:11px 14px }
.fact .k{ font:700 10px/1 var(--font-sans); letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3) }
.fact .v{ font:700 15px/1.2 var(--font-sans); margin-top:4px }

/* oferta = linha tech (categoria+chips · preço PIX · stepper+CTA) */
.offrow{ position:relative; display:grid; grid-template-columns:1fr auto auto; align-items:center; gap:22px;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:16px 18px; margin-bottom:10px;
  transition:border-color .18s var(--ease), box-shadow .18s var(--ease) }
.offrow:hover{ border-color:var(--green-soft); box-shadow:var(--sh-1) }
.offrow--vip{ border-color:var(--gold-soft); background:linear-gradient(180deg,var(--gold-tint),var(--surface)) }
.offrow__info{ min-width:0 }
.offrow__name{ font:700 15px/1.3 var(--font-sans); color:var(--ink); display:flex; align-items:center; gap:8px; flex-wrap:wrap }
.offrow__sub{ font-size:12.5px; color:var(--ink-3); margin-top:3px; line-height:1.4 }
.offrow__chips{ margin-top:9px }
.schip--vip{ background:linear-gradient(135deg,var(--gold-bright,#E3C257),var(--gold-deep)); color:#2A2208; border:none; font-weight:700 }
.offrow__price{ text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:2px; white-space:nowrap }
.offrow__pixk{ font:700 9px/1 var(--font-sans); letter-spacing:.09em; text-transform:uppercase; color:var(--gold-deep) }
.offrow__pix{ font:800 22px/1 var(--font-sans); color:var(--green); font-variant-numeric:tabular-nums }
.offrow__inst{ background:none; border:none; cursor:pointer; font:500 11.5px/1.3 var(--font-mono); color:var(--ink-3);
  border-bottom:1px dashed var(--line-strong,var(--line)); padding:2px 0; margin-top:3px }
.offrow__inst:hover{ color:var(--green) }
.offrow__actions{ display:flex; align-items:center; gap:10px }
@media (max-width:640px){
  .offrow{ grid-template-columns:1fr; gap:13px }
  .offrow__price{ align-items:flex-start; text-align:left }
  .offrow__actions{ justify-content:space-between }
}
.stepper{ display:flex; align-items:center; border:1.5px solid var(--line); border-radius:var(--r-sm); overflow:hidden; background:var(--surface-2) }
.stepper button{ width:38px; height:42px; border:none; background:transparent; font-size:18px; cursor:pointer; color:var(--green) }
.stepper button:disabled{ opacity:.3; cursor:not-allowed }
.stepper .qty{ width:42px; text-align:center; font-family:var(--font-mono); font-weight:700; font-size:15px; line-height:42px }

.installments{ position:absolute; z-index:55; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); box-shadow:var(--sh-2); padding:8px; min-width:240px; max-height:320px; overflow:auto }
.installments[hidden]{ display:none !important }
.installments .row{ display:flex; justify-content:space-between; gap:18px; padding:8px 10px; border-radius:var(--r-xs); font-family:var(--font-mono); font-weight:500; font-size:13px }
.installments .row:hover{ background:var(--green-wash) }
.installments .row b{ font-weight:700; color:var(--green) }

/* ===================== CARRINHO (offcanvas) ===================== */
.cart{ position:fixed; inset:0 0 0 auto; width:min(94vw,420px); background:var(--paper); border-left:1px solid var(--line);
  transform:translateX(100%); transition:transform .35s var(--ease); z-index:90; display:flex; flex-direction:column; box-shadow:var(--sh-2) }
.cart.open{ transform:translateX(0) }
.cart__head{ display:flex; align-items:center; justify-content:space-between; padding:22px 24px; border-bottom:1px solid var(--line) }
.cart__head h3{ font-family:var(--font-display); font-weight:600; font-size:28px; margin:0; color:var(--green) }
.cart__items{ flex:1; overflow:auto; padding:18px 24px; display:flex; flex-direction:column; gap:14px }
.citem{ display:flex; gap:12px; align-items:flex-start; border-bottom:1px solid var(--line-soft); padding-bottom:14px }
.citem__body{ flex:1; min-width:0 }
.citem__t{ font:700 14px/1.3 var(--font-sans) }
.citem__m{ font:500 12px/1.4 var(--font-mono); color:var(--ink-3); margin-top:3px }
.citem__right{ display:grid; grid-template-columns:auto auto; grid-template-areas:"price x" "pk x"; align-items:center; column-gap:8px; text-align:right }
.citem__p{ grid-area:price; font:800 15px/1 var(--font-sans); color:var(--green); font-variant-numeric:tabular-nums; white-space:nowrap }
.citem__pk{ grid-area:pk; font:700 8.5px/1 var(--font-sans); letter-spacing:.08em; text-transform:uppercase; color:var(--gold-deep); margin-top:2px }
.citem__x{ grid-area:x; background:none; border:none; cursor:pointer; color:var(--ink-3); font-size:20px; line-height:1; padding:0 0 0 4px }
.citem__x:hover{ color:var(--danger) }
.cart__foot{ padding:20px 24px; border-top:1px solid var(--line); background:var(--surface) }
.cart__total{ display:flex; justify-content:space-between; align-items:baseline; margin-bottom:14px }
.cart__total .p{ font-family:var(--font-sans); font-weight:800; font-size:26px; color:var(--green) }
.cart__empty{ text-align:center; color:var(--ink-3); padding:60px 20px }

/* ===================== FOOTER ===================== */
.footer{ background:var(--green-deep); color:rgba(255,255,255,.78); margin-top:auto; border-top:4px solid var(--gold) }
.footer__in{ max-width:var(--maxw); margin:0 auto; padding:72px 40px 36px; display:grid; grid-template-columns:1.6fr 1fr 1fr; gap:40px }
.footer h4{ font:800 13px/1 var(--font-sans); letter-spacing:.14em; text-transform:uppercase; color:#fff; margin:0 0 16px }
.footer a{ display:block; color:rgba(255,255,255,.66); padding:6px 0; font-size:14.5px; transition:color .18s var(--ease) }
.footer a:hover{ color:var(--gold-soft) }
.trust{ max-width:var(--maxw); margin:0 auto; padding:26px 40px; display:grid; grid-template-columns:repeat(4,1fr); gap:18px;
  border-top:1px solid rgba(255,255,255,.12) }
.trust__item{ display:flex; align-items:center; gap:12px }
.trust__item svg{ flex:none; width:26px; height:26px; fill:var(--gold-soft) }
.trust__item div{ display:flex; flex-direction:column; line-height:1.3 }
.trust__item b{ font:700 13.5px/1.2 var(--font-sans); color:#fff }
.trust__item span{ font-size:12px; color:rgba(255,255,255,.6) }
@media (max-width:880px){ .trust{ grid-template-columns:repeat(2,1fr); gap:16px 22px } }
@media (max-width:480px){ .trust{ grid-template-columns:1fr } }
.social{ margin-top:22px }
.social__lbl{ display:block; font:800 11px/1 var(--font-sans); letter-spacing:.16em; text-transform:uppercase; color:var(--gold-soft); margin-bottom:11px }
.social__row{ display:flex; gap:10px }
.footer .social__ic{ display:grid; place-items:center; width:40px; height:40px; padding:0; border-radius:50%;
  background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.14); transition:background .18s var(--ease), border-color .18s var(--ease), transform .18s var(--ease) }
.footer .social__ic svg{ width:19px; height:19px; fill:rgba(255,255,255,.82); transition:fill .18s var(--ease) }
.footer .social__ic:hover{ background:var(--gold); border-color:var(--gold); transform:translateY(-2px) }
.footer .social__ic:hover svg{ fill:var(--green-deep) }
.footer__lockup{ display:flex; align-items:center; gap:12px }
.footer__logo{ height:42px; width:auto; display:block }
.footer__sep{ width:1.5px; height:30px; background:var(--gold-soft); border-radius:2px; opacity:.65 }
.footer__tenis{ font-family:var(--font-display); font-weight:600; font-style:italic; font-size:32px; line-height:1; color:var(--gold-soft); letter-spacing:-.01em }
.footer__legal{ border-top:1px solid rgba(255,255,255,.12); margin:30px auto 0; padding:24px 40px 0; max-width:var(--maxw);
  font-size:13px; color:rgba(255,255,255,.5); display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap }

/* ===================== WHATSAPP FAB ===================== */
.fab{ position:fixed; right:24px; bottom:24px; z-index:85; width:58px; height:58px; border-radius:50%;
  background:#25d366; display:grid; place-items:center; box-shadow:0 8px 24px rgba(0,0,0,.22); transition:transform .2s var(--ease) }
.fab:hover{ transform:scale(1.07) }
.fab svg{ width:30px; height:30px; fill:#fff }

/* ===================== UTIL / ESTADOS ===================== */
.skeleton{ background:linear-gradient(90deg,var(--surface-2) 25%,#efeadd 37%,var(--surface-2) 63%); background-size:400% 100%; animation:sk 1.3s ease infinite; border-radius:var(--r-sm) }
@keyframes sk{ 0%{background-position:100% 0} 100%{background-position:-100% 0} }
.empty{ text-align:center; padding:70px 20px; color:var(--ink-3) }
.empty .display{ font-family:var(--font-display); font-weight:600; font-size:42px; color:var(--green) }
.breadcrumb{ display:flex; gap:8px; align-items:center; font:600 13px/1 var(--font-sans); color:var(--ink-3); margin:22px 0 }
.breadcrumb a:hover{ color:var(--green) }
.reveal{ animation:rise .55s var(--ease) both }
@keyframes rise{ from{ transform:translateY(16px) } to{ transform:none } }
.toast{ position:fixed; left:50%; bottom:28px; transform:translateX(-50%) translateY(20px); z-index:100;
  background:var(--green); color:#fff; padding:14px 22px; border-radius:var(--r-pill); font:700 14px/1 var(--font-sans);
  box-shadow:var(--sh-2); opacity:0; pointer-events:none; transition:.3s var(--ease) }
.toast.show{ opacity:1; transform:translateX(-50%) translateY(0) }

/* ===================== ADMIN / FORMS ===================== */
.fld{ display:flex; flex-direction:column; gap:7px; font:700 12px/1 var(--font-sans); letter-spacing:.02em; text-transform:uppercase; color:var(--ink-3) }
.fld input,.fld select{ font:500 15px/1 var(--font-sans); text-transform:none; letter-spacing:0; color:var(--ink);
  height:50px; padding:0 16px; border:1.5px solid var(--line); border-radius:var(--r-sm); background:var(--surface); transition:border-color .2s, box-shadow .2s }
.fld input:focus,.fld select:focus{ outline:none; border-color:var(--green-soft); box-shadow:0 0 0 4px var(--green-wash) }
.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:12px }
.card-soft{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:20px; box-shadow:var(--sh-1) }

.adminbar{ background:var(--green-deep); color:#fff; position:sticky; top:0; z-index:50 }
.adminbar__in{ display:flex; align-items:center; gap:18px; height:66px; flex-wrap:wrap }
.adminbar .display{ font-family:var(--font-display); font-weight:600 }
.adminbar__tabs{ display:flex; gap:4px; margin-left:10px }
.atab{ color:rgba(255,255,255,.72); font:600 14px/1 var(--font-sans); padding:9px 14px; border-radius:var(--r-pill) }
.atab:hover{ background:rgba(255,255,255,.08); color:#fff }
.atab.active{ background:linear-gradient(135deg,var(--accent-1),var(--accent-2)); color:#2A2208 }
.adminbar__user{ margin-left:auto; display:flex; align-items:center; gap:10px; font-size:13px; color:rgba(255,255,255,.72) }
.adminbar__user .btn{ --fg:#fff; color:#fff; border-color:rgba(255,255,255,.4) }

.qrow{ display:grid; grid-template-columns:1fr 120px 80px 38px; gap:8px; margin-bottom:8px }
.qrow input{ height:46px; padding:0 12px; border:1.5px solid var(--line); border-radius:var(--r-sm); background:var(--surface); font-size:14px }
.qi-del{ border:1px solid var(--line); background:var(--surface-2); border-radius:var(--r-sm); cursor:pointer; font-size:18px; color:var(--ink-3) }
.ok-box{ background:var(--green-wash); border:1px solid var(--green-tint); border-radius:var(--r-lg); padding:16px }
.ok-box input{ width:100%; height:44px; padding:0 12px; border:1.5px solid var(--line); border-radius:var(--r-sm); font:500 13px/44px var(--font-mono); background:#fff }

.tbl{ width:100%; border-collapse:collapse; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden }
.tbl th{ text-align:left; font:800 11px/1 var(--font-sans); letter-spacing:.08em; text-transform:uppercase; color:var(--ink-3); padding:13px 16px; border-bottom:1px solid var(--line); background:var(--surface-2) }
.tbl td{ padding:13px 16px; border-bottom:1px solid var(--line-soft); font-size:14px }
.tbl tr:last-child td{ border-bottom:none }

.qline{ display:flex; justify-content:space-between; align-items:center; padding:13px 0; border-bottom:1px solid var(--line-soft) }
.qline--total{ border-bottom:none; border-top:2px solid var(--green); margin-top:4px; padding-top:14px }
.qline .display{ font-family:var(--font-sans); font-weight:800; color:var(--green) }

/* pagamento */
.paytabs{ display:flex; gap:10px }
.paytab{ flex:1; display:flex; flex-direction:column; gap:4px; align-items:center; padding:16px; cursor:pointer;
  border:1.5px solid var(--line); border-radius:var(--r-lg); background:var(--surface); font:700 15px/1 var(--font-sans); color:var(--ink); transition:.2s var(--ease) }
.paytab small{ font:600 11px/1 var(--font-sans); color:var(--ink-3) }
.paytab.active{ border-color:var(--green); background:var(--green-wash); color:var(--green); box-shadow:0 0 0 3px var(--green-tint) }
.paytab.active small{ color:var(--green-soft) }

/* ===================== RESPONSIVO ===================== */
@media (max-width:980px){
  .nav__links{ display:none }
  .burger{ display:flex }
  .nav__in,.hero__in,.footer__in,.footer__legal,.wrap{ padding-left:24px; padding-right:24px }
  .detail{ grid-template-columns:1fr; gap:22px }
  .detail__media{ position:static }
  .searchbar__in{ flex-direction:column; border-radius:var(--r-lg) }
  .seg{ border-right:none; border-bottom:1px solid var(--line-soft); flex:0 0 auto }
  .searchbar__go{ margin:10px; border-radius:var(--r-sm) }
  .popover{ position:static; box-shadow:none; border:none; padding:4px 0 }
  .footer__in{ grid-template-columns:1fr; gap:24px }
}
@media (max-width:560px){
  .wrap,.nav__in,.hero__in,.footer__in{ padding-left:18px; padding-right:18px }
  .grid{ grid-template-columns:1fr }
  .section{ padding:60px 0 }
}

/* iOS: inputs >=16px pra não dar zoom automático */
input,select,textarea{ font-size:16px }
