/* ============================================================
   CHINELÊ BY MADUZZI — Boutique de calçados femininos · Brasília
   Sistema visual: serifa de alto contraste + sans refinada
   ============================================================ */

:root{
  /* Paleta da marca */
  --off-white:#FDFCF8;
  --ivory:#F3F0E9;
  --nude:#E3DBCC;
  --obsidian:#101010;
  --graphite:#262320;
  --ink-60:rgba(16,16,16,.60);
  --ink-45:rgba(16,16,16,.45);
  --line:rgba(16,16,16,.12);
  --line-light:rgba(253,252,248,.18);
  /* Prata metálica */
  --silver-1:#E8E8E6;
  --silver-2:#B9B7B0;
  --silver-3:#8C8A83;
  --champagne:#D8C7A6;
  --metal:linear-gradient(135deg,#E9E7E2 0%,#C2BFB6 38%,#8E8B82 64%,#CFCCC3 100%);

  --font-display:"Cormorant Garamond",Georgia,serif;
  --font-ui:"Jost","Century Gothic",system-ui,sans-serif;

  --maxw:1280px;
  --gut:clamp(20px,5vw,72px);
  --header-h:76px;
}

*{box-sizing:border-box;margin:0;padding:0}
:focus-visible{outline:2px solid var(--obsidian);outline-offset:3px}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-ui);
  background:var(--off-white);
  color:var(--obsidian);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:500;line-height:1.06;letter-spacing:-.01em}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gut)}
.eyebrow{
  font-family:var(--font-ui);font-size:12px;font-weight:500;
  letter-spacing:.34em;text-transform:uppercase;color:var(--silver-3);
}
.eyebrow.on-dark{color:var(--silver-2)}

/* ---------- Wordmark ---------- */
.wordmark{display:inline-flex;flex-direction:column;align-items:flex-start;line-height:.82}
.wordmark .name{
  font-family:var(--font-display);font-weight:500;letter-spacing:.01em;
  font-size:30px;display:inline-flex;align-items:center;gap:.12em;
}
.wordmark .name .star{font-size:.5em;transform:translateY(-.55em);opacity:.9}
.wordmark .by{
  font-family:var(--font-display);font-style:italic;font-weight:400;
  font-size:14px;letter-spacing:.06em;align-self:flex-end;opacity:.85;margin-top:2px;
}

/* ---------- Botões ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.6em;
  font-family:var(--font-ui);font-size:12.5px;font-weight:500;letter-spacing:.18em;
  text-transform:uppercase;padding:15px 30px;border:1px solid var(--obsidian);
  background:var(--obsidian);color:var(--off-white);
  transition:.35s cubic-bezier(.4,0,.2,1);white-space:nowrap;
}
.btn:hover{background:transparent;color:var(--obsidian)}
.btn--ghost{background:transparent;color:var(--obsidian)}
.btn--ghost:hover{background:var(--obsidian);color:var(--off-white)}
.btn--on-dark{border-color:var(--off-white);background:transparent;color:var(--off-white)}
.btn--on-dark:hover{background:var(--off-white);color:var(--obsidian)}
.btn--wa{border-color:var(--obsidian);background:var(--obsidian);color:var(--off-white)}
.btn--wa svg{width:17px;height:17px}
.btn--sm{padding:11px 20px;font-size:11px;letter-spacing:.16em}
.btn--block{width:100%}

.link-underline{
  font-size:12px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;
  position:relative;padding-bottom:4px;display:inline-block;
}
.link-underline::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:currentColor;transform:scaleX(.4);transform-origin:left;opacity:.5;
  transition:.4s;
}
.link-underline:hover::after{transform:scaleX(1);opacity:1}

/* ---------- Placeholder de imagem (estado vazio elegante) ---------- */
.ph{
  position:relative;overflow:hidden;
  background:linear-gradient(135deg,var(--ivory) 0%,var(--nude) 100%);
  display:grid;place-items:center;
}
.ph::after{
  content:"Chinelê ✦";
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(20px,3.4vw,38px);letter-spacing:.01em;line-height:1;
  color:var(--obsidian);opacity:.12;text-align:center;padding:0 12px;
}
.ph--dark{background:linear-gradient(135deg,var(--ivory) 0%,var(--nude) 100%)}
.ph--dark::after{color:var(--obsidian);opacity:.12}
/* Foto real cadastrada pelo Admin (substitui o estado vazio) */
.ph.has-img{
  background-size:cover;background-position:center;background-repeat:no-repeat;
  background-image:none; /* sobrescrito inline pela url da foto */
}
.ph.has-img::after{display:none}
/* Miniaturas (galeria de até 5 fotos no card) */
.ph-thumbs{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  display:flex;gap:6px;padding:8px;justify-content:center;flex-wrap:wrap;
  background:linear-gradient(to top,rgba(16,16,16,.32),transparent);
}
.ph-thumb{
  width:30px;height:30px;flex:none;border-radius:3px;cursor:pointer;
  background-size:cover;background-position:center;
  border:1.5px solid rgba(253,252,248,.7);opacity:.78;transition:.2s;
}
.ph-thumb:hover{opacity:1}
.ph-thumb.on{opacity:1;border-color:var(--off-white);box-shadow:0 0 0 1px var(--obsidian)}

/* ============================================================
   HEADER
   ============================================================ */
.header{
  position:fixed;top:0;left:0;right:0;z-index:60;height:var(--header-h);
  display:flex;align-items:center;
  background:rgba(253,252,248,.82);backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);transition:.4s;
}
.header .wrap{display:flex;align-items:center;justify-content:space-between;width:100%}
.header .wordmark .name{font-size:24px}
.header .wordmark .by{font-size:11px}
.nav{display:flex;gap:34px}
.nav a{
  font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;white-space:nowrap;
  color:var(--ink-60);transition:.25s;position:relative;padding:4px 0;
}
.nav a:hover{color:var(--obsidian)}
.nav a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--obsidian);
  transform:scaleX(0);transform-origin:left;transition:transform .3s;
}
.nav a:hover::after,.nav a.active::after{transform:scaleX(1)}
.nav a.active{color:var(--obsidian)}
.header-actions{display:flex;align-items:center;gap:14px}
.icon-btn{
  position:relative;width:42px;height:42px;display:grid;place-items:center;
  border:1px solid var(--line);border-radius:50%;transition:.3s;
}
.icon-btn:hover{border-color:var(--obsidian)}
.icon-btn svg{width:18px;height:18px}
.cart-count{
  position:absolute;top:-4px;right:-4px;min-width:19px;height:19px;padding:0 5px;
  background:var(--obsidian);color:var(--off-white);border-radius:10px;
  font-size:10px;font-weight:600;display:grid;place-items:center;
  transform:scale(0);transition:.3s cubic-bezier(.34,1.56,.64,1);
}
.cart-count.show{transform:scale(1)}
.menu-toggle{display:none;width:42px;height:42px;flex-direction:column;gap:5px;
  align-items:center;justify-content:center}
.menu-toggle span{width:20px;height:1.5px;background:var(--obsidian);transition:.3s}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:var(--obsidian);color:var(--off-white);
  padding:var(--header-h) 0 0;position:relative;overflow:hidden;
}
/* Split de tela cheia: texto na metade esquerda, foto na metade direita (ponta a ponta) */
.hero .wrap{max-width:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.hero-copy{
  max-width:none;display:flex;flex-direction:column;justify-content:center;
  padding-block:clamp(44px,6vw,96px);
  padding-left:max(var(--gut),calc((100vw - var(--maxw))/2));
  padding-right:clamp(28px,4vw,64px);
}
.hero-copy .eyebrow{margin-bottom:26px}
.hero h1{
  font-size:clamp(44px,6.6vw,94px);line-height:.98;letter-spacing:-.02em;margin-bottom:26px;
}
.hero h1 em{font-style:italic;color:var(--nude)}
.hero p.lead{
  font-size:clamp(15px,1.7vw,18px);color:rgba(253,252,248,.72);
  max-width:480px;margin-bottom:38px;line-height:1.7;
}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap}
/* Visual do topo no formato quadrado (igual a um post de feed do Instagram) */
.hero-visual{position:relative;width:100%;height:100%;min-height:clamp(480px,52vw,700px)}

/* ---------- Carrossel do hero (fotos rotativas) ---------- */
.hero-carousel{
  position:absolute;inset:0;overflow:hidden;border:1px solid var(--line-light);
  background:#1b1916;
}
.hc-track{display:flex;height:100%;transition:transform .7s cubic-bezier(.65,0,.35,1)}
.hc-slide{
  flex:0 0 100%;height:100%;position:relative;display:flex;align-items:flex-end;overflow:hidden;
  background-color:#15130f;
  background-image:var(--img);background-size:cover;background-position:center;background-repeat:no-repeat;
}
.hc-slide.hc-placeholder{
  background:linear-gradient(135deg,var(--ivory) 0%,var(--nude) 100%);
  display:grid;place-items:center;align-items:center;
}
.hc-slide.hc-placeholder::after{
  content:"Chinelê ✦";
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(26px,4vw,54px);letter-spacing:.01em;
  color:var(--obsidian);opacity:.12;padding:0;text-transform:none;
}
.hc-cap{
  position:relative;z-index:3;padding:26px 28px;width:100%;
  background:linear-gradient(to top,rgba(16,16,16,.7),transparent);
  display:flex;flex-direction:column;gap:4px;
}
.hc-cap strong{font-family:var(--font-display);font-weight:500;font-size:clamp(22px,2.4vw,30px);color:var(--off-white);line-height:1.05}
.hc-cap span{font-size:13px;letter-spacing:.04em;color:rgba(253,252,248,.82)}
/* Setas de navegação manual (anterior/próximo) */
.hc-arrow{
  position:absolute;top:50%;transform:translateY(-50%);z-index:4;
  width:44px;height:44px;border-radius:50%;border:1px solid rgba(253,252,248,.55);
  background:rgba(20,18,15,.42);color:var(--off-white);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px);
  opacity:0;transition:opacity .3s,background .25s,transform .25s;
}
.hero-carousel:hover .hc-arrow,.bq-carousel:hover .hc-arrow{opacity:1}
.hc-arrow:hover{background:rgba(20,18,15,.7);border-color:var(--off-white)}
.hc-arrow:active{transform:translateY(-50%) scale(.92)}
.hc-prev{left:14px}
.hc-next{right:14px}
.hc-track{touch-action:pan-y;cursor:grab}
.hc-track.dragging{cursor:grabbing;transition:none}
/* No celular as setas ficam sempre visíveis (não tem hover) */
@media(hover:none){
  .hc-arrow{opacity:.92;width:40px;height:40px}
}
.hc-dots{position:absolute;bottom:16px;right:18px;z-index:3;display:flex;gap:8px}
.hc-dot{width:8px;height:8px;border-radius:50%;background:rgba(253,252,248,.45);transition:.25s}
.hc-dot.on{background:var(--off-white);transform:scale(1.25)}
.hc-dot:hover{background:rgba(253,252,248,.8)}

/* ---------- Carrossel de fotos da loja (seção "A boutique") ---------- */
.split-media{position:relative;height:100%;min-height:clamp(460px,46vw,620px)}
#sobre{padding-block:0}
.bq-carousel{
  position:relative;height:100%;min-height:clamp(440px,44vw,580px);overflow:hidden;
  background:#1b1916;border:1px solid var(--line);
}
.bq-carousel .hc-dots{bottom:14px;right:16px}

/* ---------- Mapa do Google (seção de localização) ---------- */
.local-map{
  position:relative;aspect-ratio:16/11;overflow:hidden;
  background:#1b1916;border:1px solid rgba(253,252,248,.12);
}
.local-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.map-ph{
  position:absolute;inset:0;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--ivory) 0%,var(--nude) 100%);
}
.map-ph::after{
  content:"Chinelê ✦";
  font-family:var(--font-display);font-style:italic;font-weight:500;
  font-size:clamp(24px,3.6vw,46px);letter-spacing:.01em;
  color:var(--obsidian);opacity:.12;padding:0;
}

.grid-empty{grid-column:1/-1;text-align:center;color:var(--ink-45);padding:50px 0;font-size:15px}

/* ============================================================
   SECTION shell
   ============================================================ */
.section{padding-block:clamp(64px,9vw,130px)}
.section--ivory{background:var(--ivory)}
.section--nude{background:var(--nude)}
.section--dark{background:var(--obsidian);color:var(--off-white)}
.section-head{max-width:680px;margin-bottom:clamp(40px,5vw,64px)}
.section-head.center{margin-inline:auto;text-align:center}
.section-head .eyebrow{display:block;margin-bottom:18px}
.section-head h2{font-size:clamp(32px,4.4vw,58px);margin-bottom:18px}
.section-head p{font-size:clamp(15px,1.5vw,17px);color:var(--ink-60);max-width:560px}
.section--dark .section-head p{color:rgba(253,252,248,.66)}
.center.section-head p{margin-inline:auto}

/* ============================================================
   CATEGORIAS
   ============================================================ */
.cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px)}
.cat-card{position:relative;overflow:hidden;background:var(--off-white);
  border:1px solid var(--line);transition:.45s}
.cat-card:hover{transform:translateY(-4px)}
.cat-card .ph{aspect-ratio:3/4}
.cat-card .cat-body{padding:20px 22px 24px}
.cat-card h3{font-size:24px;margin-bottom:6px}
.cat-card p{font-size:13px;color:var(--ink-60);line-height:1.5;margin-bottom:14px;min-height:38px}
.cat-card .link-underline{font-size:11px}

/* ============================================================
   VITRINE / PRODUTOS
   ============================================================ */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:48px}
.filter-bar button{
  font-size:11.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;
  padding:10px 20px;border:1px solid var(--line);color:var(--ink-60);
  border-radius:999px;transition:.3s;
}
.filter-bar button:hover{border-color:var(--obsidian);color:var(--obsidian)}
.filter-bar button.active{background:var(--obsidian);color:var(--off-white);border-color:var(--obsidian)}

.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(22px,2.6vw,44px)}
.product{display:flex;flex-direction:column}
.product .ph{aspect-ratio:4/5;margin-bottom:18px;cursor:pointer}
.product .product-tag{
  position:absolute;top:14px;left:14px;z-index:2;background:var(--off-white);
  font-family:var(--font-ui);font-size:10px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;padding:6px 11px;color:var(--obsidian);
}
.product .product-tag.dark{background:var(--obsidian);color:var(--off-white)}
.product .brand{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-3);margin-bottom:5px}
.product h3{font-size:21px;font-weight:500;margin-bottom:6px}
.product .price{font-family:var(--font-display);font-size:21px;margin-bottom:16px}
.product .price s{color:var(--ink-45);font-size:.8em;margin-right:8px}

.opt-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.opt-row .opt-label{flex-basis:100%;font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-45);margin-bottom:3px}
.chip{
  min-width:34px;height:32px;padding:0 10px;display:grid;place-items:center;
  border:1px solid var(--line);font-size:12.5px;font-weight:500;transition:.2s;color:var(--ink-60);
}
.chip:hover{border-color:var(--obsidian)}
.chip.sel{background:var(--obsidian);color:var(--off-white);border-color:var(--obsidian)}
.swatch{width:30px;height:30px;border-radius:50%;border:1px solid var(--line);position:relative;transition:.2s}
.swatch.sel{box-shadow:0 0 0 2px var(--off-white),0 0 0 3.5px var(--obsidian)}

.qty{display:inline-flex;align-items:center;border:1px solid var(--line)}
.qty button{width:34px;height:34px;display:grid;place-items:center;font-size:16px;color:var(--ink-60)}
.qty button:hover{color:var(--obsidian)}
.qty span{min-width:34px;text-align:center;font-size:13px;font-weight:500}

/* ---------- Card clicável + setinhas de foto ---------- */
.product{cursor:pointer;transition:transform .4s cubic-bezier(.2,0,.2,1)}
.product .ph{position:relative;overflow:hidden;transition:box-shadow .4s}
.product:hover{transform:translateY(-5px)}
.product:hover .ph.has-img{box-shadow:0 18px 44px rgba(16,16,16,.15)}
.product:hover h3{color:var(--nude)}
/* zoom suave da foto no hover (camada interna, recortada pelo .ph) */
.product .ph-zoom{
  position:absolute;inset:0;z-index:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  transition:transform .6s cubic-bezier(.2,0,.2,1);
}
.product:hover .ph-zoom{transform:scale(1.03)}
/* Ícone de sacola no canto do card (adição rápida) */
.card-bag{
  position:absolute;top:10px;right:12px;z-index:5;
  width:36px;height:36px;display:grid;place-items:center;
  background:none;border:0;cursor:pointer;color:var(--obsidian);
  filter:drop-shadow(0 1px 2px rgba(253,252,248,.85));
  opacity:0;transform:translateY(-4px);transition:opacity .25s,transform .25s;
}
.product:hover .card-bag{opacity:.9;transform:none}
.card-bag:hover{opacity:1;transform:scale(1.1)}
.card-bag:active{transform:scale(.9)}
/* No celular (sem hover) o ícone fica sempre visível */
@media(hover:none){
  .card-bag{opacity:.92;transform:none;width:34px;height:34px}
}
.pc-arrow{
  position:absolute;top:42%;transform:translateY(-50%);z-index:4;
  width:36px;height:36px;border-radius:50%;display:grid;place-items:center;
  background:rgba(253,252,248,.9);color:var(--obsidian);font-size:20px;line-height:1;
  box-shadow:0 2px 10px rgba(16,16,16,.18);opacity:.92;transition:.2s;
}
.pc-arrow:hover{background:var(--off-white);opacity:1;transform:translateY(-50%) scale(1.06)}
.pc-arrow.prev{left:10px}
.pc-arrow.next{right:10px}
.pc-dots{position:absolute;bottom:12px;left:0;right:0;z-index:4;display:flex;gap:6px;justify-content:center}
.pc-dot{width:6px;height:6px;border-radius:50%;background:rgba(253,252,248,.55);transition:.2s}
.pc-dot.on{background:var(--off-white);transform:scale(1.3)}

/* ---------- Modal de detalhe do produto ---------- */
.pd-overlay{position:fixed;inset:0;background:rgba(16,16,16,.55);opacity:0;visibility:hidden;
  transition:.35s;z-index:110;backdrop-filter:blur(2px)}
.pd-overlay.open{opacity:1;visibility:visible}
.pd-modal{
  position:fixed;z-index:120;top:50%;left:50%;transform:translate(-50%,-46%);
  width:min(940px,94vw);max-height:92vh;background:var(--off-white);overflow:hidden;
  opacity:0;visibility:hidden;transition:.35s cubic-bezier(.4,0,.2,1);
  box-shadow:0 40px 100px rgba(0,0,0,.4);
}
.pd-modal.open{opacity:1;visibility:visible;transform:translate(-50%,-50%)}
.pd-close{
  position:absolute;top:14px;right:14px;z-index:6;width:40px;height:40px;border-radius:50%;
  background:rgba(253,252,248,.92);color:var(--obsidian);font-size:24px;display:grid;place-items:center;
  box-shadow:0 2px 10px rgba(16,16,16,.18);transition:.2s;
}
.pd-close:hover{background:var(--off-white);transform:rotate(90deg)}
.pd-content{display:grid;grid-template-columns:1fr 1fr;max-height:92vh;overflow-y:auto}
.pd-gallery{position:relative;background:var(--ivory)}
.pd-main{aspect-ratio:4/5;background:var(--nude);background-size:cover;background-position:center;position:relative;cursor:zoom-in;overflow:hidden}
.pd-main::after{
  content:"Ampliar +";position:absolute;bottom:12px;left:12px;z-index:3;pointer-events:none;
  font-family:var(--font-ui);font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  background:rgba(253,252,248,.92);color:var(--obsidian);padding:6px 10px;transition:opacity .2s;
}
.pd-main.zoomed::after{opacity:0}
.pd-thumbs{display:flex;gap:8px;padding:12px;flex-wrap:wrap;background:var(--off-white)}
.pd-thumb{width:54px;height:66px;flex:none;background-size:cover;background-position:center;
  border:1px solid var(--line);opacity:.6;transition:.2s}
.pd-thumb:hover{opacity:.85}
.pd-thumb.on{opacity:1;border-color:var(--obsidian)}
.pd-info{padding:clamp(26px,3vw,44px);display:flex;flex-direction:column}
.pd-info .brand{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver-3);margin-bottom:8px}
.pd-info h2{font-size:clamp(26px,3vw,40px);font-weight:500;line-height:1.05;margin-bottom:12px}
.pd-price{font-family:var(--font-display);font-size:28px;margin-bottom:28px}
.pd-price s{color:var(--ink-45);font-size:.78em;margin-right:10px}
.pd-info .opt-row{margin-bottom:18px}
.pd-code{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-45);margin:-4px 0 16px}
.pd-add{margin-top:auto}
/* Sanfonas (Descrição / Características) — só aparecem quando preenchidas no admin */
.pd-accordions{margin-top:30px}
.pd-acc{border-top:1px solid var(--line)}
.pd-acc:last-child{border-bottom:1px solid var(--line)}
.pd-acc-head{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:18px 2px;background:none;border:0;cursor:pointer;text-align:left;
  font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.14em;
  text-transform:uppercase;color:var(--obsidian);transition:opacity .2s;
}
.pd-acc-head:hover{opacity:.65}
.pd-acc-ico{flex:none;color:var(--ink-60);transition:transform .35s cubic-bezier(.4,0,.2,1)}
.pd-acc.open .pd-acc-ico{transform:rotate(180deg)}
.pd-acc-body{display:grid;grid-template-rows:0fr;transition:grid-template-rows .35s cubic-bezier(.4,0,.2,1)}
.pd-acc.open .pd-acc-body{grid-template-rows:1fr}
.pd-acc-inner{overflow:hidden}
.pd-acc-inner > *{margin-bottom:0}
.pd-acc.open .pd-acc-inner{padding-bottom:20px}
.pd-acc-inner p{font-size:14.5px;line-height:1.7;color:var(--ink-60);white-space:pre-line}
.pd-feat-list{list-style:none;display:flex;flex-direction:column;gap:9px}
.pd-feat-list li{position:relative;padding-left:20px;font-size:14px;line-height:1.5;color:var(--ink-60)}
.pd-feat-list li::before{content:"✦";position:absolute;left:0;top:1px;color:var(--silver-3);font-size:12px}
@media(max-width:760px){
  .pd-modal{top:0;left:0;transform:none;width:100vw;height:100%;max-height:100%}
  .pd-modal.open{transform:none}
  .pd-content{grid-template-columns:1fr;max-height:100vh}
  .pd-main{aspect-ratio:4/5}
}

.product-actions{display:flex;gap:10px;margin-top:14px;align-items:stretch}
.product-actions .add{flex:1}

/* ============================================================
   INSTITUCIONAL (split)
   ============================================================ */
/* Boutique: split de tela cheia (foto à esquerda ponta a ponta, texto à direita) */
.split{max-width:none;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:0;align-items:stretch}
.split-copy{
  display:flex;flex-direction:column;justify-content:center;
  padding-block:clamp(40px,6vw,90px);
  padding-right:max(var(--gut),calc((100vw - var(--maxw))/2));
  padding-left:clamp(28px,4vw,64px);
}
.split .ph{aspect-ratio:4/5}
.split-copy h2{font-size:clamp(30px,3.8vw,52px);margin-bottom:24px}
.split-copy p{color:var(--ink-60);margin-bottom:18px;font-size:16px}
.section--dark .split-copy p{color:rgba(253,252,248,.7)}

/* ============================================================
   COMO COMPRAR (passos)
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,52px)}
.step{position:relative;padding-top:30px;border-top:1px solid var(--line-light)}
.section:not(.section--dark) .step{border-top-color:var(--line)}
.step .num{font-family:var(--font-display);font-size:54px;line-height:1;margin-bottom:18px;opacity:.32}
.step h3{font-size:22px;margin-bottom:10px}
.step p{font-size:14.5px;color:var(--ink-60)}
.section--dark .step p{color:rgba(253,252,248,.66)}

/* ============================================================
   BENEFÍCIOS
   ============================================================ */
.bene-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.bene{background:var(--ivory);padding:34px 30px}
.bene .b-ico{width:30px;height:30px;margin-bottom:16px;color:var(--silver-3)}
.bene h3{font-size:18px;margin-bottom:8px;font-family:var(--font-ui);font-weight:500;letter-spacing:0}
.bene p{font-size:13.5px;color:var(--ink-60);line-height:1.55}

/* ============================================================
   SEO LOCAL / LOCALIZAÇÃO
   ============================================================ */
.local{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(32px,5vw,72px);align-items:center}
.local .ph{aspect-ratio:16/11}
.local-chips{display:flex;flex-wrap:wrap;gap:8px;margin:24px 0 32px}
.local-chips span{
  font-size:11.5px;letter-spacing:.08em;padding:7px 14px;border:1px solid var(--line-light);
  color:rgba(253,252,248,.8);border-radius:999px;
}

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-final{text-align:center}
.cta-final h2{font-size:clamp(34px,5vw,68px);margin-bottom:22px;max-width:14ch;margin-inline:auto}
.cta-final p{max-width:520px;margin:0 auto 38px;color:var(--ink-60);font-size:16px}
.cta-final .hero-actions{justify-content:center}

/* ============================================================
   RODAPÉ
   ============================================================ */
.footer{background:var(--obsidian);color:var(--off-white);padding-block:clamp(56px,7vw,90px) 36px}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(28px,4vw,56px);margin-bottom:56px}
.footer .wordmark .name{font-size:32px}
.footer-brand p{font-size:14px;color:rgba(253,252,248,.6);margin-top:20px;max-width:280px;line-height:1.6}
.footer-col h4{font-family:var(--font-ui);font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--silver-2);margin-bottom:20px}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px}
.footer-col a,.footer-col li{font-size:14px;color:rgba(253,252,248,.66);transition:.25s}
.footer-col a:hover{color:var(--off-white)}
.footer-note{font-size:12.5px;color:rgba(253,252,248,.5);line-height:1.6;border-top:1px solid var(--line-light);padding-top:28px;display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-seo{max-width:640px}

/* ============================================================
   CARRINHO LATERAL
   ============================================================ */
.overlay{position:fixed;inset:0;background:rgba(16,16,16,.5);opacity:0;visibility:hidden;
  transition:.4s;z-index:90;backdrop-filter:blur(2px)}
.overlay.open{opacity:1;visibility:visible}
.cart{
  position:fixed;top:0;right:0;height:100%;width:min(440px,100%);z-index:100;
  background:var(--off-white);display:flex;flex-direction:column;
  transform:translateX(100%);transition:.45s cubic-bezier(.4,0,.2,1);box-shadow:-20px 0 60px rgba(16,16,16,.18);
}
.cart.open{transform:translateX(0)}
.cart-head{display:flex;align-items:center;justify-content:space-between;padding:26px 28px;border-bottom:1px solid var(--line)}
.cart-head h3{font-size:24px}
.cart-head .count-lbl{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--silver-3)}
.cart-close{font-size:22px;width:38px;height:38px;display:grid;place-items:center;color:var(--ink-60)}
.cart-body{flex:1;overflow-y:auto;padding:8px 28px}
.cart-empty{text-align:center;padding:80px 20px;color:var(--ink-45)}
.cart-empty .ph-ico{width:54px;height:54px;margin:0 auto 20px;opacity:.4}
.cart-empty p{font-size:14px;margin-bottom:6px}
.cart-item{display:grid;grid-template-columns:72px 1fr auto;gap:16px;padding:22px 0;border-bottom:1px solid var(--line)}
.cart-item .ci-img{width:72px;height:90px}
.cart-item .ci-name{font-family:var(--font-display);font-size:18px;line-height:1.1;margin-bottom:4px}
.cart-item .ci-meta{font-size:12px;color:var(--ink-60);letter-spacing:.04em;margin-bottom:10px}
.cart-item .ci-price{font-family:var(--font-display);font-size:17px}
.cart-item .ci-remove{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-45);text-decoration:underline;text-underline-offset:3px}
.cart-item .ci-remove:hover{color:var(--obsidian)}
.cart-item .ci-qty{display:inline-flex;align-items:center;border:1px solid var(--line)}
.cart-item .ci-qty button{width:28px;height:28px;display:grid;place-items:center;color:var(--ink-60)}
.cart-item .ci-qty span{min-width:26px;text-align:center;font-size:12px}
.cart-foot{padding:24px 28px;border-top:1px solid var(--line);background:var(--ivory);display:none}
.cart-line{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-60);margin-bottom:8px}
.cart-total{display:flex;justify-content:space-between;align-items:baseline;margin:14px 0 6px}
.cart-total .t-lbl{font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.cart-total .t-val{font-family:var(--font-display);font-size:28px}
.cart-foot .disclaimer{font-size:11px;color:var(--ink-45);margin-top:14px;text-align:center;line-height:1.5}

/* Toast */
.toast{
  position:fixed;bottom:28px;left:50%;transform:translate(-50%,120%);z-index:120;
  background:var(--obsidian);color:var(--off-white);padding:15px 26px;
  font-size:13px;letter-spacing:.04em;display:flex;align-items:center;gap:12px;
  transition:.45s cubic-bezier(.34,1.56,.64,1);box-shadow:0 12px 40px rgba(16,16,16,.3);
}
.toast.show{transform:translate(-50%,0)}
.toast svg{width:18px;height:18px;color:var(--champagne)}

/* Conteúdo sempre visível (sem animação de entrada para máxima confiabilidade) */
.reveal{opacity:1}

/* ============================================================
   RESPONSIVO
   ============================================================ */
@media(max-width:1080px){
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .product-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}
/* Botão flutuante de WhatsApp */
.wa-float{
  position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:70;
  width:56px;height:56px;border-radius:50%;display:grid;place-items:center;
  background:var(--obsidian);color:var(--off-white);
  box-shadow:0 10px 30px rgba(16,16,16,.28);transition:transform .3s,background .3s;
}
.wa-float:hover{transform:translateY(-3px) scale(1.05);background:var(--graphite)}
.wa-float svg{width:28px;height:28px}
@media(max-width:560px){.wa-float{width:52px;height:52px}.wa-float svg{width:26px;height:26px}}

/* Menu recolhe para ☰ mais cedo, para nunca encostar na marca */
@media(max-width:1024px){
  .nav{display:none}
  .menu-toggle{display:flex}
}
@media(max-width:860px){
  .hero .wrap{grid-template-columns:1fr;align-items:center}
  .hero-copy{padding:clamp(28px,7vw,48px) var(--gut)}
  .hero-visual{order:-1;width:100%;max-width:none;height:auto;min-height:0;aspect-ratio:4/5;margin-inline:0}
  .split,.local{grid-template-columns:1fr;align-items:center}
  .split-copy{padding:clamp(28px,7vw,48px) var(--gut)}
  .split-media{height:auto;min-height:0}
  .bq-carousel{height:auto;min-height:0;aspect-ratio:4/5}
  #sobre{padding-block:clamp(40px,9vw,80px)}
  .local .ph,.local-map{order:-1}
  .steps{grid-template-columns:1fr}
  .bene-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  :root{--header-h:64px}
  .header .wordmark .name{font-size:20px}
  /* Vitrine em 2 colunas no celular (estilo boutique) */
  .product-grid{grid-template-columns:repeat(2,1fr);gap:30px 14px}
  .product .ph{margin-bottom:12px}
  .product .brand{display:none}
  .product h3{
    font-size:12.5px;font-weight:400;letter-spacing:.05em;text-transform:uppercase;
    color:var(--ink-60);line-height:1.5;margin-bottom:7px;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:2.95em;
  }
  .product:hover h3{color:var(--ink-60)}
  .product .price{font-family:var(--font-ui);font-size:15px;font-weight:500;letter-spacing:.01em;margin-bottom:6px}
  .product .price s{font-size:.82em}
  .cat-grid{grid-template-columns:1fr 1fr}
  .bene-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr}
  .hero-actions .btn{flex:1}
  .filter-bar{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
}

/* Mobile menu drawer */
.mobile-menu{
  position:fixed;inset:0;z-index:80;background:var(--obsidian);color:var(--off-white);
  padding:calc(var(--header-h) + 16px) var(--gut) 32px;
  display:flex;flex-direction:column;gap:2px;
  overflow-y:auto;-webkit-overflow-scrolling:touch;
  transform:translateY(-100%);transition:.5s cubic-bezier(.4,0,.2,1);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu a{font-family:var(--font-display);font-size:24px;padding:10px 0;border-bottom:1px solid var(--line-light)}
.mobile-menu .btn{margin-top:20px}
.mobile-close{position:absolute;top:18px;right:var(--gut);font-size:30px;color:var(--off-white)}
/* Categorias no menu mobile (acordeão com seta) */
.mm-cat-group{display:flex;flex-direction:column;border-bottom:1px solid var(--line-light);padding-bottom:4px}
.mm-cat-toggle,.mm-subcat-toggle{
  display:flex;align-items:center;justify-content:space-between;width:100%;
  background:none;border:none;cursor:pointer;color:var(--off-white);text-align:left;
  font-family:var(--font-display);
}
.mm-cat-toggle{font-size:24px;padding:10px 0 4px}
.mm-subcat-toggle{font-size:18px;padding:7px 0;color:rgba(253,252,248,.85)}
.mm-arrow{transition:transform .3s ease;flex:0 0 auto;margin-left:10px}
.mm-cat-toggle[aria-expanded="true"] .mm-arrow,
.mm-subcat-toggle[aria-expanded="true"] .mm-arrow{transform:rotate(180deg)}
.mm-cat-list,.mm-subcat-list{
  display:flex;flex-direction:column;overflow:hidden;
  max-height:0;opacity:0;transition:max-height .4s ease,opacity .3s ease;
}
.mm-cat-list.open{max-height:900px;opacity:1}
.mm-subcat-list.open{max-height:400px;opacity:1}
.mm-cat-group a{font-size:18px;padding:7px 0 7px 16px;border-bottom:1px solid rgba(253,252,248,.07);color:rgba(253,252,248,.85)}
.mm-cat-list>a:last-child{border-bottom:none}
.mm-subcat-group{border-bottom:1px solid rgba(253,252,248,.07)}
.mm-subcat-list a{padding-left:32px;font-size:16px;color:rgba(253,252,248,.7)}
