:root{
  --mata:#0B2419;
  --folha:#123528;
  --creme:#F4EBDA;
  --creme-60:rgba(244,235,218,.6);
  --dourado:#C9A24B;
  --rotulo:#101010;
  --fire:linear-gradient(150deg,#FFB347,#FF8A2A 35%,#E8323C 72%,#B0235C);
  --raio:20px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Sora',system-ui,sans-serif;
  background:var(--mata);color:var(--creme);
  overflow-x:hidden;line-height:1.5;
}
::selection{background:#FF8A2A;color:#101010}
img{display:block;max-width:100%}
a{color:inherit}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ===== FOCO VISÍVEL (teclado) ===== */
:focus{outline:none}
:focus-visible{outline:2px solid var(--creme);outline-offset:3px;border-radius:6px}
.skip-link{
  position:fixed;top:-100px;left:50%;transform:translateX(-50%);z-index:120;
  background:var(--rotulo);color:var(--creme);padding:12px 22px;border-radius:999px;
  font-weight:700;font-size:.85rem;text-decoration:none;border:1px solid #FF8A2A;
  transition:top .2s ease;
}
.skip-link:focus-visible{top:12px}
h1,h2,h3,.display{font-family:'Anton',sans-serif;font-weight:400;text-transform:uppercase;letter-spacing:.02em;line-height:.94}
.num{font-family:'Sora',sans-serif;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:0}
.script{font-family:'Caveat',cursive;text-transform:none;letter-spacing:0;font-weight:700}
.wrap{max-width:1120px;margin:0 auto;padding:0 22px}

.btn{
  display:inline-block;padding:15px 28px;border-radius:999px;
  font-weight:700;font-size:.95rem;text-decoration:none;text-align:center;
  transition:transform .15s ease, box-shadow .15s ease, background .2s ease;
}
.btn:active{transform:scale(.96)}
.btn--fire{background:var(--fire);color:#fff;box-shadow:0 10px 30px rgba(232,50,60,.4)}
.btn--fire:hover{transform:translateY(-2px);box-shadow:0 14px 38px rgba(232,50,60,.55)}
.btn--ghost{border:1.5px solid rgba(244,235,218,.4);color:var(--creme)}
.btn--ghost:hover{border-color:var(--creme)}
.btn--ghost-dark{border:1.5px solid rgba(244,235,218,.3);color:var(--creme)}
.btn--ghost-dark:hover{background:rgba(244,235,218,.08)}
.btn--leaf{background:#1E7A4F;color:#fff}
.btn--leaf:hover{background:#23925f}
.ic-bolt{display:inline-block;vertical-align:-2px;margin-left:4px;color:#FFD27A}

/* ===== TOPBAR ===== */
.topbar{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;
  background:linear-gradient(180deg,rgba(11,36,25,.9),transparent);
  transition:background .3s ease, padding .3s ease;
}
.topbar.solid{background:rgba(11,36,25,.92);backdrop-filter:blur(10px);padding:10px 22px;box-shadow:0 1px 0 rgba(244,235,218,.08)}
.brand{display:flex;align-items:center;gap:11px;text-decoration:none}
.brand .lotus{color:var(--creme);display:grid;place-items:center;opacity:.95}
.brand-txt b{font-family:'Anton',sans-serif;font-size:1rem;letter-spacing:.06em;display:block}
.brand-txt b i{color:var(--dourado);font-style:normal}
.brand-txt small{display:block;font-size:.6rem;letter-spacing:.16em;color:var(--creme-60);margin-top:1px;white-space:nowrap}
.cart-btn{
  position:relative;display:flex;align-items:center;gap:8px;
  background:var(--rotulo);color:var(--creme);
  padding:10px 16px 10px 14px;border-radius:999px;font-weight:700;font-size:.85rem;
  border:1px solid rgba(244,235,218,.18);transition:transform .15s ease;
}
.cart-btn:hover{transform:scale(1.04)}
.cart-count{
  min-width:22px;height:22px;padding:0 6px;border-radius:999px;
  background:var(--fire);color:#fff;display:grid;place-items:center;
  font-size:.74rem;font-weight:800;
}

/* ===== HERO ===== */
.hero{
  position:relative;min-height:100svh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:96px 20px 60px;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(820px 520px at 78% 8%, rgba(255,138,42,.26), transparent 62%),
    radial-gradient(720px 560px at 14% 100%, rgba(176,35,92,.3), transparent 60%),
    var(--mata);
  animation:heroPulse 12s ease-in-out infinite alternate;
}
@keyframes heroPulse{to{filter:hue-rotate(-12deg) brightness(1.05)}}
.bubbles{position:absolute;inset:0;z-index:1;pointer-events:none}
.bubbles span{
  position:absolute;bottom:-40px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(255,255,255,.5),rgba(255,255,255,.05) 60%);
  animation:rise linear infinite;
}
@keyframes rise{to{transform:translateY(-112vh)}}

/* coluna travada em 100%: título nowrap em fonte fallback não pode alargar o track (re-centraria o copo → CLS) */
.hero-stage{position:relative;z-index:2;display:grid;grid-template-columns:100%;place-items:center;width:min(92vw,560px)}
.hero-title{
  font-size:clamp(3.2rem,14vw,8.5rem);
  color:var(--creme);grid-area:1/1;pointer-events:none;white-space:nowrap;
}
.hero-title--back{
  align-self:start;transform:translateY(-12%);
  color:transparent;-webkit-text-stroke:1.5px rgba(244,235,218,.45);
  z-index:1;
}
.hero-title--front{align-self:end;transform:translateY(14%);z-index:3;text-shadow:0 12px 40px rgba(0,0,0,.5)}
.hero-title--front em{
  font-style:normal;
  background:var(--fire);-webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-bolt{width:.62em;height:.62em;display:inline-block;vertical-align:baseline;transform:rotate(6deg) translateY(.04em);filter:drop-shadow(0 6px 16px rgba(255,179,71,.5))}
/* largura + aspect-ratio do viewBox do copo (0 -20 200 300): reserva o espaço antes do JS injetar o SVG → zero CLS */
.hero-prod{grid-area:1/1;z-index:2;will-change:transform;width:clamp(220px,46vw,330px);aspect-ratio:200/300}
.hero-prod .svg-prod{
  width:100%;height:auto;display:block;
  filter:drop-shadow(0 30px 45px rgba(0,0,0,.55));
  animation:floaty 6s ease-in-out infinite;
}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.hero-sub{position:relative;z-index:2;margin-top:30px;max-width:430px;font-size:clamp(1rem,2.6vw,1.2rem);color:var(--creme-60)}
.hero-sub .script{color:#FFB347;font-size:1.35em}
.hero-ctas{position:relative;z-index:2;display:flex;gap:14px;margin-top:26px;flex-wrap:wrap;justify-content:center}
.scroll-hint{
  position:absolute;bottom:22px;left:50%;transform:translateX(-50%);z-index:2;
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--creme-60);
  display:flex;flex-direction:column;align-items:center;gap:8px;
}
.scroll-hint span{width:1px;height:30px;background:linear-gradient(var(--creme-60),transparent);animation:hintPulse 1.8s ease-in-out infinite}
@keyframes hintPulse{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ===== SHOWCASE =====
   track de 520vh: ~47vh de rolagem por sabor (9 sabores) — troca ágil
   no polegar sem perder a leitura; era 640vh/560vh e arrastava demais */
.showcase{position:relative;height:520vh}
.showcase-sticky{position:sticky;top:0;height:100svh;overflow:hidden;display:flex;align-items:center}
.sc-bg{
  position:absolute;inset:0;z-index:0;
  background:linear-gradient(160deg,var(--c1,#4FC3F7),var(--c2,#1565C0));
  transition:background .5s ease;
}
.sc-bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(100deg, rgba(0,0,0,.52) 0%, rgba(0,0,0,.28) 38%, transparent 62%),
  radial-gradient(120% 70% at 50% 118%, rgba(0,0,0,.4), transparent 60%)}
@media(max-width:760px){
  .sc-bg::after{background:
    linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.22) 42%, transparent 64%),
    radial-gradient(140% 60% at 50% 118%, rgba(0,0,0,.45), transparent 60%)}
}
.sc-inner{
  position:relative;z-index:2;width:100%;max-width:1120px;margin:0 auto;padding:0 32px;
  /* minmax(0,1fr): o min-content do palco quadrado não pode alargar a track
     e roubar largura da coluna do texto (quebrava o título no desktop) */
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);align-items:center;gap:20px;
}
.sc-copy{color:#fff}
.sc-eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;opacity:.95;text-shadow:0 2px 10px rgba(0,0,0,.4)}
.sc-name{
  font-size:clamp(2.8rem,8vw,6.2rem);margin:.1em 0 .15em;
  text-shadow:0 10px 40px rgba(0,0,0,.35);
  /* reserva sempre 2 linhas (1.88em = 2 × line-height .94) e ancora o nome
     embaixo: título de 1 ou 2 linhas não desloca preço/CTA/palco.
     align-content em bloco (sem display:grid — grid mudava a quebra de linha);
     navegador antigo ignora e o nome fica no topo da reserva, posições iguais */
  min-height:1.2em;align-content:end;
}
/* entrada do nome/descrição a cada troca de sabor */
.sc-name.swap{animation:scSwap .35s ease both}
.sc-desc.swap{animation:scSwap .35s ease .05s both}
@keyframes scSwap{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.sc-desc{font-size:clamp(1rem,2.4vw,1.25rem);max-width:26ch;opacity:.95;text-shadow:0 2px 12px rgba(0,0,0,.35)}
.sc-price{margin:22px 0 24px;font-size:.92rem;opacity:.95;text-shadow:0 2px 10px rgba(0,0,0,.35)}
.sc-price .num{font-size:1.25em}
.btn--dark{background:rgba(14,14,14,.92);color:#fff;border:1px solid rgba(255,255,255,.22)}
.btn--dark:hover{background:#0c0c0c;transform:translateY(-2px);box-shadow:0 12px 30px rgba(0,0,0,.35)}
.sc-cta{font-size:1rem;padding:16px 30px}

.sc-prod{position:relative;height:74svh;display:grid;place-items:center}
.sc-solo{height:64svh;display:grid;place-items:center}
/* palco 2D: copo na frente (direita), garrafa do sabor atrás (esquerda, menor).
   O box quadrado dá folga pros dois + o parallax sem depender do conteúdo. */
/* max-width:100% mantém o palco dentro da coluna: o aspect-ratio:1 derivava
   a largura da altura e estourava a track (texto/copo iam pras bolinhas) */
.sc-duo{position:relative;height:100%;aspect-ratio:1;max-width:100%;margin:0 auto}
.sc-copo{position:absolute;right:0;top:0;height:100%;z-index:2;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.45));will-change:transform}
.sc-garrafa{position:absolute;left:0;bottom:2%;height:64%;z-index:1;
  filter:drop-shadow(0 22px 36px rgba(0,0,0,.4));will-change:transform}
.sc-copo .svg-prod,.sc-garrafa .svg-prod{height:100%;width:auto}

/* dots: alvo de toque 44x44 (botão), miolo visual de 9px (::before) */
.sc-dots{
  position:absolute;right:2px;top:50%;transform:translateY(-50%);z-index:3;
  display:flex;flex-direction:column;gap:0;
}
.sc-dots button{
  width:44px;height:44px;border-radius:50%;
  display:grid;place-items:center;background:transparent;
}
.sc-dots button::before{
  content:"";width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);
  transition:transform .2s ease, background .2s ease;
}
.sc-dots button.on::before{background:#fff;transform:scale(1.5)}
@media(hover:hover){
  .sc-dots button:hover::before{background:rgba(255,255,255,.85);transform:scale(1.4)}
  .sc-dots button.on:hover::before{transform:scale(1.5)}
}

/* ===== CARDÁPIO ===== */
.cardapio{padding:80px 0;background:var(--mata)}
.sec-sub{color:var(--creme-60);margin-top:10px;font-size:.95rem}
.sec-sub b{color:#FFB347}
.menu-cards{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));margin-top:8px}
.menu-card{
  background:var(--folha);border-radius:var(--raio);padding:20px 20px 14px;
  border:1px solid rgba(244,235,218,.09);
  transition:border-color .3s ease, box-shadow .3s ease, transform .25s ease;
}
@media(hover:hover){
  .menu-card:hover{transform:translateY(-3px);border-color:rgba(244,235,218,.22);box-shadow:0 14px 32px rgba(0,0,0,.3)}
}
.menu-card.flash{border-color:var(--mc1);box-shadow:0 0 0 3px color-mix(in srgb, var(--mc1) 45%, transparent), 0 18px 40px rgba(0,0,0,.35);animation:cardFlash 1.6s ease}
@keyframes cardFlash{0%{transform:scale(1)}12%{transform:scale(1.025)}28%{transform:scale(1)}}
.mc-head{display:flex;align-items:center;gap:16px;margin-bottom:12px}
.mc-cup{flex:none;width:64px}
.mc-cup svg{display:block;width:100%;height:auto;filter:drop-shadow(0 8px 14px rgba(0,0,0,.35))}
.mc-tit h3{font-size:1.25rem;letter-spacing:.03em}
.mc-tit p{font-size:.82rem;color:var(--creme-60);margin-top:3px}

/* ===== ESCOLHA SUA COR ===== */
.cores{position:relative;background:var(--folha);padding:90px 22px;text-align:center}
.paleta{
  display:flex;gap:clamp(8px,2.4vw,26px);justify-content:center;align-items:flex-end;
  max-width:980px;margin:46px auto 0;flex-wrap:wrap;
}
.paleta-cup{width:clamp(86px,12vw,130px);animation:palFloat 5s ease-in-out infinite}
.paleta-cup:nth-child(even){width:clamp(72px,10vw,108px)}
.paleta-cup .svg-prod{width:100%;height:auto;filter:drop-shadow(0 18px 28px rgba(0,0,0,.4))}
@keyframes palFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.cores-txt .script{color:#FFB347;font-size:2rem}
.cores-txt h2{font-size:clamp(2.6rem,8vw,5rem);margin-bottom:.3em}
.cores-txt p:last-child{color:var(--creme-60);max-width:40ch;margin:14px auto 0}

/* ===== COMBO RESET (card único em destaque) ===== */
.detox{padding:80px 0;background:var(--mata)}
.combo-card{
  position:relative;max-width:920px;margin:0 auto;overflow:hidden;
  background:linear-gradient(150deg,#1a0f24,#2b1430);
  border:1px solid rgba(244,235,218,.1);border-radius:var(--raio);
  padding:44px 48px;display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;
}
.tag-leaf{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  color:#9FE0A8;background:rgba(30,122,79,.2);border:1px solid rgba(30,122,79,.4);
  padding:4px 10px;border-radius:999px;margin-bottom:12px}
.combo-body h3{font-size:2.6rem;margin-bottom:10px}
.combo-desc{color:var(--creme-60);font-size:.96rem;line-height:1.5;margin-bottom:20px;max-width:38ch}
.combo-seal{
  position:absolute;top:18px;right:18px;width:88px;height:88px;border-radius:50%;z-index:3;
  background:var(--fire);display:grid;place-content:center;text-align:center;
  font-family:'Anton',sans-serif;font-size:2.3rem;color:#fff;line-height:.8;
  box-shadow:0 10px 30px rgba(232,50,60,.4);transform:rotate(8deg);
}
.combo-seal small{font-size:.72rem;letter-spacing:.1em;line-height:1.2rem}
.combo-bottles{display:flex;gap:14px;align-items:flex-end;justify-content:center;margin:0}
.combo-bottles .cb{flex:1;max-width:104px;animation:cbFloat 4.5s ease-in-out infinite}
.combo-bottles .cb svg{display:block;width:100%;height:auto;filter:drop-shadow(0 14px 22px rgba(0,0,0,.5))}
@keyframes cbFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-7px)}}

/* logo customizado (painel) — substitui lótus + wordmark na topbar.
   O rótulo customizado das embalagens é uma <image> dentro do próprio SVG
   do copo/garrafa (ver svg.js), então não precisa de regra aqui. */
.brand-logo{display:block;height:38px;width:auto;max-width:44vw;object-fit:contain}
.combo-price{margin:6px 0 20px}
.combo-price b{font-family:'Sora',sans-serif;font-weight:800;font-size:2.1rem;display:block;font-variant-numeric:tabular-nums}
.combo-price small{color:var(--creme-60);font-size:.8rem}

/* ===== FEED ===== */
.feed{padding:70px 0 80px;background:var(--folha)}
.feed-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:26px;flex-wrap:wrap;gap:10px}
.feed-head h2{font-size:clamp(2rem,6vw,3.4rem)}
.feed-head em{font-style:normal;color:#FFB347}
.feed-link{font-weight:700;text-decoration:none;color:var(--dourado)}
/* embed do perfil: centralizado; min-height segura o espaço até o iframe
   chegar; o min-width:326px inline do IG estouraria telas de 360 (!important
   é o único jeito de vencer estilo inline) */
.feed-embed{display:flex;justify-content:center;min-height:430px}
.feed-embed .instagram-media{min-width:0!important}

/* ===== ONDE ===== */
.onde{padding:80px 0 90px;background:var(--mata)}
.sec-head{text-align:center;margin-bottom:40px}
.sec-head .script{color:#FFB347;font-size:1.7rem}
.sec-head h2{font-size:clamp(2.2rem,7vw,3.8rem)}
.onde-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}
.onde-card{background:var(--folha);border-radius:var(--raio);padding:28px;border:1px solid rgba(244,235,218,.08)}
.onde-card h3{font-size:1.2rem;color:#FFB347;margin-bottom:10px}
.onde-card p{font-size:.92rem;color:var(--creme-60);line-height:1.6;margin-bottom:8px}
.onde-card .muted{font-size:.8rem;opacity:.6}
.onde-ig{font-weight:700;color:var(--dourado);text-decoration:none;font-size:1rem}
.onde-card .btn{margin-top:6px}

/* ===== FOOTER ===== */
.foot{text-align:center;padding:50px 22px 100px;background:var(--mata);color:var(--creme-60)}
.foot .script{display:block;color:#FFB347;font-size:1.6rem;margin-bottom:8px}
.foot p{font-size:.8rem}

/* ===== REVEAL (só esconde quando o JS está ativo — anti-flash sem JS) ===== */
.reveal{transition:opacity .6s ease, transform .6s ease}
.js .reveal{opacity:0;transform:translateY(26px)}
.js .reveal.show{opacity:1;transform:none}

/* ===== mini add (cardápio + detox) ===== */
.mini-add{
  width:40px;height:40px;border-radius:12px;flex:none;
  background:#1E7A4F;color:#fff;font-size:1.15rem;font-weight:700;line-height:0;
  display:grid;place-items:center;transition:transform .15s ease, background .15s ease;
}
.mini-add:hover{transform:scale(1.12);background:#23925f}
.mini-add:active{transform:scale(.92)}
.mini-add.pop{animation:popAdd .25s cubic-bezier(.3,1.4,.4,1)}
@keyframes popAdd{0%{transform:scale(1)}40%{transform:scale(1.25)}100%{transform:scale(1)}}
.cart-count.pulse{animation:countPulse .3s ease}
@keyframes countPulse{0%{transform:scale(1)}45%{transform:scale(1.35)}100%{transform:scale(1)}}
.cafeina{margin-top:14px;font-size:.72rem;color:var(--creme-60);opacity:.8}

/* ===== COMO PEDIR ===== */
.passos{padding:80px 0;background:var(--folha)}
.passos-grid{list-style:none;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}
.passos-grid li{background:var(--mata);border-radius:var(--raio);padding:26px;border:1px solid rgba(244,235,218,.08)}
.passos-grid b{
  font-family:'Anton',sans-serif;font-size:2rem;display:inline-grid;place-items:center;
  width:52px;height:52px;border-radius:50%;background:var(--fire);color:#fff;margin-bottom:14px;
}
.passos-grid h3{font-size:1.05rem;margin-bottom:6px}
.passos-grid p{font-size:.85rem;color:var(--creme-60)}

/* ===== BARRA MOBILE ===== */
.mobile-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:70;
  display:none;align-items:center;justify-content:space-between;gap:14px;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:rgba(11,36,25,.96);backdrop-filter:blur(10px);
  border-top:1px solid rgba(244,235,218,.12);
}
/* "> span" = só o total (#mbTotal); o rótulo do botão (#mbLabel) fica dentro do .btn */
.mobile-bar > span{font-weight:700;font-size:.85rem;color:var(--creme);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mobile-bar .btn{padding:12px 22px;font-size:.9rem;flex:none}
.mobile-bar.empty > span{display:none}
.mobile-bar.empty .btn{flex:1}

/* ===== CARRINHO ===== */
.drawer-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:90;opacity:0;pointer-events:none;transition:opacity .25s ease}
.drawer-bg.on{opacity:1;pointer-events:auto}
.drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:91;width:min(410px,100%);
  background:var(--mata);border-left:1px solid rgba(244,235,218,.1);
  transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);
  display:flex;flex-direction:column;
}
.drawer.on{transform:none}
.drawer-head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 14px 22px;border-bottom:1px solid rgba(244,235,218,.1)}
.drawer-head h3{font-size:1.3rem}
.drawer-head button{
  font-size:1.8rem;line-height:1;color:var(--creme);
  width:44px;height:44px;display:grid;place-items:center;border-radius:12px;
  transition:background .15s ease;
}
.drawer-head button:hover{background:rgba(244,235,218,.08)}
.drawer-items{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:13px}
.cart-item{display:flex;gap:12px;align-items:center;background:var(--folha);border-radius:14px;padding:12px 14px}
.cart-item .swatch{width:14px;height:40px;border-radius:7px;flex:none}
.cart-item .ci-info{flex:1;min-width:0}
.cart-item .ci-info b{font-size:.92rem;display:block}
.cart-item .ci-info small{font-size:.74rem;color:var(--creme-60)}
.cart-item .ci-qtd{display:flex;align-items:center;gap:6px}
.cart-item .ci-qtd button{
  width:32px;height:32px;border-radius:9px;background:var(--mata);font-weight:700;font-size:1rem;
  display:grid;place-items:center;transition:background .15s ease;
}
.cart-item .ci-qtd button:hover{background:#0E2E20}
.cart-item .ci-qtd button.pop{animation:popAdd .25s cubic-bezier(.3,1.4,.4,1)}
.cart-empty{text-align:center;color:var(--creme-60);margin-top:50px;font-size:.95rem}
.nojs-menu{background:var(--folha);border-radius:var(--raio);padding:26px;border:1px solid rgba(244,235,218,.09)}
.nojs-menu p{margin-bottom:14px}
.nojs-menu ul{list-style:none;margin-bottom:20px;display:flex;flex-direction:column;gap:10px;color:var(--creme-60)}
.cart-empty .script{display:block;color:#FFB347;font-size:1.7rem;margin-bottom:6px}
.drawer-foot{padding:18px 22px 24px;border-top:1px solid rgba(244,235,218,.1)}
.drawer-total{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:14px}
.drawer-total b{font-family:'Sora',sans-serif;font-weight:800;font-size:1.4rem;font-variant-numeric:tabular-nums}
.drawer-cta{width:100%;padding:16px;border-radius:14px;font-weight:700;font-size:1rem}
.drawer-cta:disabled{opacity:.4;pointer-events:none}
.drawer-head{position:relative}
.drawer-back{position:static;font-size:1.7rem;line-height:1}

/* ===== CHECKOUT (fluxo em passos) ===== */
/* [hidden] não basta: o display:flex do .drawer-items/.checkout o sobrepõe */
.drawer-items[hidden],.checkout[hidden]{display:none}
.checkout{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:14px}
.co-hint{font-size:.82rem;color:var(--creme-60);margin:-2px 0 2px}
.co-field{display:flex;flex-direction:column;gap:6px;min-width:0}
.co-field>span{font-size:.8rem;color:var(--creme-60)}
.co-field input,.co-field textarea{
  width:100%;min-width:0;box-sizing:border-box;
  background:var(--folha);border:1.5px solid rgba(244,235,218,.14);border-radius:12px;
  padding:13px 14px;color:var(--creme);font:inherit;font-size:.95rem}
.co-field input:focus,.co-field textarea:focus{border-color:var(--dourado);outline:none}
.co-field textarea{resize:vertical;min-height:60px}
.co-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
/* entrega/retirada */
.co-tipos{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.co-tipo{display:flex;flex-direction:column;gap:3px;align-items:flex-start;text-align:left;
  background:var(--folha);border:1.5px solid rgba(244,235,218,.14);border-radius:14px;padding:16px;color:var(--creme)}
.co-tipo b{font-size:1.02rem}
.co-tipo small{font-size:.76rem;color:var(--creme-60)}
.co-tipo.on{border-color:var(--dourado);background:#10301F}
/* endereços salvos / radios */
.co-end{display:flex;gap:11px;align-items:flex-start;background:var(--folha);
  border:1.5px solid rgba(244,235,218,.14);border-radius:14px;padding:13px 15px;cursor:pointer}
.co-end.on{border-color:var(--dourado)}
.co-end input{margin-top:3px;accent-color:var(--dourado);width:17px;height:17px;flex:none}
.co-end span{display:flex;flex-direction:column;gap:2px;min-width:0}
.co-end b{font-size:.92rem}
.co-end small{font-size:.76rem;color:var(--creme-60)}
.co-novoend{display:flex;flex-direction:column;gap:12px;padding-top:2px}
/* pagamento */
.co-pags{display:flex;flex-direction:column;gap:10px}
.co-pag{display:flex;align-items:center;gap:11px;background:var(--folha);
  border:1.5px solid rgba(244,235,218,.14);border-radius:13px;padding:14px 15px;cursor:pointer}
.co-pag.on{border-color:var(--dourado)}
.co-pag input{accent-color:var(--dourado);width:17px;height:17px}
.co-pix{background:#10301F;border:1px solid rgba(201,162,75,.4);border-radius:12px;
  padding:12px 14px;font-size:.86rem;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.co-mini{background:var(--dourado);color:var(--preto);border-radius:8px;padding:4px 10px;font-size:.78rem;font-weight:700}
/* revisão */
.co-resumo{background:var(--folha);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:9px}
.co-lin{display:flex;justify-content:space-between;gap:10px;font-size:.9rem}
.co-lin small{color:var(--creme-60)}
.co-lin.tot{color:var(--creme-60);font-size:.86rem}
.co-lin.grand{border-top:1px solid rgba(244,235,218,.14);padding-top:9px;margin-top:2px;font-size:1.05rem}
.co-lin.grand b{font-family:'Sora',sans-serif;font-weight:800}
.co-rev{display:flex;flex-direction:column;gap:8px}
.co-rev-l{display:flex;justify-content:space-between;gap:14px;font-size:.85rem}
.co-rev-l span{color:var(--creme-60);flex:none}
.co-rev-l b{text-align:right;font-weight:600}
/* enviado */
.co-enviado{text-align:center;padding:24px 10px;display:flex;flex-direction:column;align-items:center;gap:12px}
.co-check{width:64px;height:64px;border-radius:50%;background:#1FAF5A;color:#fff;
  display:grid;place-items:center;font-size:2rem;font-weight:800}
.co-enviado h4{font-family:'Anton',sans-serif;font-size:1.5rem;font-weight:400}
.co-enviado p{font-size:.9rem;color:var(--creme-60);max-width:280px}
.co-enviado .btn{margin-top:6px}

/* ===== TOAST ===== */
.toast{position:fixed;left:50%;bottom:26px;transform:translate(-50%,200px);z-index:99;
  background:var(--rotulo);color:var(--creme);padding:13px 22px;border-radius:999px;
  font-size:.85rem;font-weight:600;border:1px solid #FF8A2A;pointer-events:none;white-space:nowrap;
  box-shadow:0 12px 32px rgba(0,0,0,.45);
  transition:transform .3s cubic-bezier(.5,1.6,.5,1)}
.toast.on{transform:translate(-50%,0)}

/* ===== MOBILE ===== */
@media(max-width:760px){
  .combo-seal{width:70px;height:70px;font-size:1.8rem;top:12px;right:12px}
}
@media(prefers-reduced-motion:reduce){
  .combo-bottles .cb{animation:none}
}
@media(max-width:400px){
  .brand-txt small{letter-spacing:.08em}
  .topbar{padding:12px 14px}
  .cart-btn{padding:9px 13px;font-size:.8rem}
}
@media(max-width:760px){
  .mobile-bar{display:flex}
  .foot{padding-bottom:150px}
  .toast{bottom:calc(88px + env(safe-area-inset-bottom))}
  .hero{padding:84px 16px 120px}
  .scroll-hint{display:none}
  .hero-prod{width:clamp(180px,46vw,250px)}
  .hero-sub{margin-top:18px;font-size:.95rem}
  .hero-ctas{margin-top:20px;gap:10px}
  .hero-ctas .btn{padding:13px 20px;font-size:.88rem}
  .sc-cta{width:100%;max-width:240px}
  /* altura 100svh + palco flexível: em tela baixa o produto encolhe
     (até 150px) em vez de cortar copo/canudo no overflow do sticky.
     align-items:stretch (anula o center do desktop): sem ele a row 1fr
     não estica o .sc-prod e a cadeia de height:100% colapsa no min. */
  /* minmax(0,1fr): a coluna NÃO pode inflar pro min-content do palco (.sc-duo
     com aspect-ratio:1 fica largo e empurrava o texto pra baixo das bolinhas).
     padding maior à direita (48px) é onde mora a coluna dos dots. */
  .sc-inner{grid-template-columns:minmax(0,1fr);text-align:center;gap:6px;padding:80px 48px 30px 22px;
    grid-template-rows:auto 1fr;height:100svh;align-items:stretch}
  .sc-copy{order:1}
  .sc-prod{order:2;height:50svh;min-height:0}
  .sc-solo{height:100%;max-height:42svh;min-height:150px;width:100%}
  /* no mobile o palco é dimensionado pela LARGURA (preenche a coluna): o
     aspect-ratio:1 derivava largura da altura e o copo (right:0) vazava
     pras bolinhas. width:100% + aspect-ratio:auto trava na coluna. */
  .sc-duo{width:100%;aspect-ratio:auto;margin:0}
  .sc-price{justify-content:center}
  .sc-desc{margin:0 auto}
  .sc-dots{right:0}
  .combo-card{grid-template-columns:1fr;gap:24px;padding:34px 24px;text-align:center}
  .combo-body h3{font-size:2.2rem}
  .combo-desc{margin-left:auto;margin-right:auto}
  /* padding à direita pra fileira limpar o selo "5 dias" do canto */
  .combo-bottles{max-width:none;margin:0;padding-right:84px;box-sizing:border-box}
  .combo-bottles .cb{max-width:66px}
}

/* tela curta no mobile: aperta tipografia e respiros do showcase só o
   suficiente pro copo + garrafa caberem inteiros (sem cortar embaixo) */
@media(max-width:760px) and (max-height:760px){
  .sc-inner{padding:80px 48px 12px 22px;gap:2px}
  .sc-eyebrow{font-size:.68rem}
  .sc-name{font-size:clamp(1.9rem,9.5vw,2.6rem)}
  .sc-desc{font-size:.88rem}
  .sc-price{margin:8px 0 12px;font-size:.84rem}
  .sc-cta{padding:12px 22px;font-size:.88rem}
  .sc-solo{max-height:48svh}
}

/* ===== REDUCED MOTION ===== */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation:none!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
  .showcase{height:auto}
  .showcase-sticky{position:static;height:auto;display:block}
  .sc-bg{display:none}
  .sc-inner{background:var(--folha)}
}
