/* ============ HERMANITO · Design System ============ */
:root{
  /* Brand palette */
  --navy:        #14294c;
  --navy-deep:   #0e1f3c;
  --navy-soft:   #20396b;
  --ink:         #1a2740;
  --celeste:     #6ea9d8;
  --celeste-2:   #4f8fc7;
  --celeste-soft:#cfe3f3;
  --gold:        #d99a3e;
  --gold-soft:   #ecc173;
  --brick:       #9c2b24;
  --brick-soft:  #c0463c;
  --green:       #4f6a2e;
  --cream:       #f1e6cf;
  --cream-2:     #e9dbbd;
  --paper:       #faf4e5;
  --paper-card:  #fffdf6;
  --muted:       #6f6552;
  --muted-2:     #938976;
  --line:        #e2d4b4;
  --wa:          #25d366;
  --wa-d:        #1da851;

  /* accent (tweakable) */
  --accent:      var(--celeste-2);
  --accent-2:    var(--gold);

  --maxw: 1180px;
  --radius: 16px;
  --shadow-sm: 0 2px 8px rgba(20,30,50,.08);
  --shadow-md: 0 14px 40px rgba(20,30,50,.16);
  --shadow-lg: 0 30px 70px rgba(14,31,60,.28);

  --font-display: 'Anton', 'Oswald', sans-serif;
  --font-ui: 'Oswald', sans-serif;
  --font-body: 'Mulish', system-ui, sans-serif;
  --font-script: 'Caveat', cursive;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* paper texture */
.paper-bg{
  background-color:var(--paper);
  background-image:
    radial-gradient(circle at 12% 18%, rgba(217,154,62,.05), transparent 38%),
    radial-gradient(circle at 88% 78%, rgba(110,169,216,.05), transparent 40%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.035'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.eyebrow{
  font-family:var(--font-script);
  color:var(--accent); font-size:1.5rem; font-weight:700;
  transform:rotate(-2deg); display:inline-block; line-height:1;
}
.kicker{
  font-family:var(--font-ui); font-weight:600; letter-spacing:.22em;
  text-transform:uppercase; font-size:.78rem; color:var(--gold);
}
h1,h2,h3{ margin:0; }
.display{
  font-family:var(--font-display); font-weight:400;
  letter-spacing:.01em; line-height:.94; text-transform:uppercase;
}
.section{ padding:96px 0; }
.section-head{ text-align:center; max-width:640px; margin:0 auto 56px; }
.section-head h2{
  font-family:var(--font-display); font-size:clamp(2.4rem,5vw,3.6rem);
  text-transform:uppercase; line-height:.95; color:var(--navy); margin-top:8px;
}
.section-head p{ color:var(--muted); font-size:1.06rem; margin-top:14px; line-height:1.6; }

/* ---------- Buttons ---------- */
.btn{
  font-family:var(--font-ui); font-weight:600; text-transform:uppercase;
  letter-spacing:.04em; font-size:1rem; padding:15px 28px; border-radius:999px;
  display:inline-flex; align-items:center; gap:10px; transition:.18s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--navy); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover{ background:var(--navy-deep); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-wa{ background:var(--wa); color:#fff; }
.btn-wa:hover{ background:var(--wa-d); transform:translateY(-2px); }
.btn-ghost{ background:transparent; border:2px solid var(--navy); color:var(--navy); }
.btn-ghost:hover{ background:var(--navy); color:#fff; }
.btn-gold{ background:var(--gold); color:var(--navy-deep); }
.btn-gold:hover{ background:var(--gold-soft); transform:translateY(-2px); }
.btn-block{ width:100%; justify-content:center; }
.btn:disabled{ opacity:.45; cursor:not-allowed; transform:none; }

/* ---------- Header ---------- */
.hdr{
  position:sticky; top:0; z-index:50;
  background:rgba(250,244,229,.86); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
  transition:background .3s ease, border-color .3s ease, box-shadow .3s ease;
}
.hdr-in{ display:flex; align-items:center; gap:24px; height:74px; }
.hdr-logo{ display:flex; align-items:center; gap:12px; transition:opacity .2s linear; }
.hdr-logo img{ height:46px; width:auto; filter:drop-shadow(0 2px 4px rgba(0,0,0,.12)); }
/* During the opening splash the header logo fades in as the big logo shrinks away */
html.intro-on .hdr-logo{ opacity:0; }
html.intro-on.scrolled .hdr-logo{ opacity:1; }
.hdr-nav{ display:flex; gap:30px; margin-left:8px; }
.hdr-nav a{
  font-family:var(--font-ui); font-weight:500; text-transform:uppercase;
  letter-spacing:.08em; font-size:.86rem; color:var(--ink); opacity:.78; transition:.15s;
  white-space:nowrap;
}
.hdr-nav a:hover{ opacity:1; color:var(--accent-2); }
.hdr-right{ margin-left:auto; display:flex; align-items:center; gap:14px; }
.status-pill{
  display:inline-flex; align-items:center; gap:7px; font-family:var(--font-ui);
  font-weight:500; font-size:.8rem; text-transform:uppercase; letter-spacing:.06em;
  padding:7px 13px; border-radius:999px; border:1.5px solid;
}
.status-pill .dot{ width:8px; height:8px; border-radius:50%; }
.status-open{ color:var(--green); border-color:rgba(79,106,46,.4); background:rgba(79,106,46,.08); }
.status-open .dot{ background:var(--green); box-shadow:0 0 0 3px rgba(79,106,46,.18); }
.status-closed{ color:var(--brick); border-color:rgba(156,43,36,.35); background:rgba(156,43,36,.07); }
.status-closed .dot{ background:var(--brick); }
.cart-btn{
  position:relative; display:inline-flex; align-items:center; gap:9px;
  background:var(--navy); color:#fff; padding:11px 18px; border-radius:999px;
  font-family:var(--font-ui); font-weight:600; letter-spacing:.03em; transition:.18s;
}
.cart-btn:hover{ background:var(--navy-deep); transform:translateY(-1px); }
.cart-count{
  background:var(--gold); color:var(--navy-deep); min-width:22px; height:22px;
  border-radius:999px; display:inline-flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:700; padding:0 6px;
}

/* ---------- Opening logo (in-flow, never traps content) ---------- */
.intro{ position:relative; height:88vh; min-height:500px; display:flex; flex-direction:column; align-items:center;
  justify-content:center; gap:14px; text-align:center; padding:0 24px; }
.intro-logo{ width:min(440px, 74vw); height:auto; filter:drop-shadow(0 16px 32px rgba(14,31,60,.22));
  transform: scale(calc(1 - 0.16 * var(--p, 0))); }
.intro-tag{ font-family:var(--font-script); color:var(--accent); font-size:clamp(1.5rem,3.2vw,2.1rem);
  line-height:1.1; transform:rotate(-2deg); margin-top:6px; white-space:nowrap; }
.intro-hint{ font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.2em; font-size:.74rem;
  color:var(--muted-2); display:flex; align-items:center; gap:8px; margin-top:10px; animation:introBounce 1.8s ease-in-out infinite; }
.intro-hint::after{ content:'↓'; font-size:1rem; }
@keyframes introBounce{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(6px); } }
@media (prefers-reduced-motion: reduce){ .intro-hint{ animation:none; } }

/* ---------- Hero (shared) ---------- */
.hero{ position:relative; overflow:hidden; }
.flag-stripe{ height:6px; background:linear-gradient(90deg,var(--celeste) 0 33%,#fff 33% 66%,var(--celeste) 66%); }

/* Variant: classic split */
.hero-classic{ display:block; padding:40px 0 78px; }
.hero-logo-big{ display:block; width:min(360px, 74vw); height:auto; margin:0 auto 30px;
  filter:drop-shadow(0 8px 20px rgba(14,31,60,.18)); }
.hero-row{ display:flex; align-items:center; gap:30px;
  padding-left: max(24px, calc((100vw - 1180px)/2 + 24px)); }
.hero-row .hero-text{ flex:0 0 512px; max-width:512px; min-width:0; }
.hero-row .hero-art{ flex:1 1 auto; }
.hero-classic .hero-h1{ font-size:clamp(2.5rem,4.4vw,4.1rem); }
.hero-brand{ display:block; width:min(290px, 80%); height:auto; margin:0 0 24px;
  filter:drop-shadow(0 6px 16px rgba(14,31,60,.16)); }
.hero-h1{ font-family:var(--font-display); color:var(--navy);
  font-size:clamp(3rem,6vw,5rem); line-height:.92; text-transform:uppercase;
  padding-bottom:.06em; margin-top:12px; }
.hero-h1 .blue{ color:var(--celeste-2); }
.hero-lead{ font-size:1.12rem; color:var(--muted); line-height:1.6; margin:26px 0 30px; max-width:34ch; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }
.hero-art{ position:relative; display:flex; align-items:center; justify-content:flex-end; min-width:0; }
.hero-disc{
  position:absolute; inset:auto; width:78%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 50% 40%, var(--celeste-soft), var(--celeste) 78%);
  bottom:6%; z-index:0; box-shadow:inset 0 0 0 14px rgba(255,255,255,.35);
}
.hero-classic .hero-disc{ inset:auto; width:98%; height:100%; aspect-ratio:auto; top:0; right:-10px;
  left:auto; bottom:auto; border-radius:30px; background:var(--celeste-soft); transform:rotate(-3deg);
  box-shadow:none; }
.hero-photo{ position:relative; z-index:2; width:100%; max-width:none; }
.hero-photo img{ width:100%; height:auto; display:block; }
.hero-price{ position:absolute; bottom:42px; right:24px; z-index:3; background:var(--navy);
  color:#fff; width:96px; height:96px; border-radius:50%; display:flex; flex-direction:column;
  align-items:center; justify-content:center; box-shadow:var(--shadow-md); border:3px solid var(--gold);
  transform:rotate(-7deg); }
.hero-price b{ font-family:var(--font-display); font-size:1.9rem; line-height:1; white-space:nowrap; }
.hero-price span{ font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.12em; font-size:.62rem; color:var(--gold-soft); margin-top:3px; white-space:nowrap; }
.hero-meta{ display:flex; gap:26px; margin-top:30px; flex-wrap:wrap; }
.hero-meta .m{ display:flex; flex-direction:column; }
.hero-meta .m b{ font-family:var(--font-display); font-size:1.5rem; color:var(--navy); white-space:nowrap; }
.hero-meta .m span{ font-size:.78rem; color:var(--muted); text-transform:uppercase; letter-spacing:.06em; white-space:nowrap; }

/* Variant: poster (centered) */
.hero-poster{ text-align:center; padding:62px 0 70px; }
.hero-poster .hero-h1{ font-size:clamp(2.6rem,6vw,4.6rem); padding-bottom:.16em; }
.hero-poster .hero-art{ margin-top:18px; }
.hero-foods{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; max-width:760px; margin:46px auto 0; }
.hero-food-card{ margin:0; }
.hero-food-card img{ width:100%; border-radius:18px; box-shadow:var(--shadow-md); display:block; }
.hero-food-card figcaption{ font-family:var(--font-display); text-transform:uppercase; color:var(--navy);
  font-size:1.2rem; margin-top:12px; letter-spacing:.02em; }
.hero-poster .hero-lead{ margin:30px auto 28px; }
.hero-poster .hero-cta{ justify-content:center; }

/* Variant: vitrine (dark, food-forward) */
.hero-vitrine{ background:var(--navy-deep); color:#fff; padding:0; }
.hero-vitrine .inner{ display:grid; grid-template-columns:1fr 1fr; min-height:560px; }
.hero-vitrine .left{ padding:74px 0 74px 0; display:flex; flex-direction:column; justify-content:center; }
.hero-vitrine .hero-h1{ color:#fff; }
.hero-vitrine .hero-h1 .blue{ color:var(--gold-soft); }
.hero-vitrine .hero-lead{ color:#d9d2c2; }
.hero-vitrine .right{ position:relative; display:flex; align-items:center; justify-content:center; }
.hero-vitrine .hero-photo{ max-width:520px; }
.hero-vitrine .vit-glow{ position:absolute; width:70%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle, rgba(217,154,62,.34), transparent 70%); }
.hero-vitrine .mini-mascot{ display:none; }

/* ---------- Selos strip ---------- */
.selos{ background:var(--navy); color:#fff; padding:42px 0; }
.selos-row{ display:grid; grid-template-columns:repeat(4,1fr); gap:28px; }
.selo{ display:flex; gap:14px; align-items:flex-start; }
.selo-ic{ width:46px; height:46px; flex:none; border-radius:12px; display:grid; place-items:center;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.16); }
.selo-ic svg{ width:24px; height:24px; stroke:var(--gold-soft); }
.selo b{ font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.04em;
  display:block; font-size:.98rem; }
.selo span{ font-size:.86rem; color:#c7cede; line-height:1.45; }

/* ---------- História ---------- */
.story{ position:relative; }
.story-grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:56px; align-items:center; }
.story-portrait{ position:relative; }
.story-portrait .frame{
  position:relative; background:var(--paper-card); border-radius:24px; padding:16px 16px 22px; box-shadow:var(--shadow-md);
  border:1px solid var(--line); text-align:center;
}
.story-illus{ width:100%; border-radius:16px; display:block;
  box-shadow:0 10px 24px rgba(14,31,60,.18); }
.story-portrait .cert{
  position:relative; z-index:2; font-family:var(--font-script); color:var(--navy); font-size:1.7rem; margin-top:16px; line-height:1;
}
.story-portrait .sub-cert{ position:relative; z-index:2; font-family:var(--font-ui); text-transform:uppercase;
  letter-spacing:.13em; font-size:.68rem; color:var(--muted-2); margin-top:9px; }
.story-portrait .tape{ position:absolute; top:-15px; left:50%; transform:translateX(-50%) rotate(-3deg);
  z-index:4;
  background:var(--gold); color:var(--navy-deep); font-family:var(--font-ui); font-weight:600;
  text-transform:uppercase; letter-spacing:.1em; font-size:.74rem; padding:6px 18px; border-radius:4px;
  box-shadow:var(--shadow-sm); white-space:nowrap; }
.story h2{ font-family:var(--font-display); font-size:clamp(2.2rem,4.6vw,3.4rem); color:var(--navy);
  text-transform:uppercase; line-height:.96; margin:10px 0 18px; }
.story p{ color:var(--muted); font-size:1.08rem; line-height:1.72; margin:0 0 16px; }
.story .sign{ font-family:var(--font-script); color:var(--accent); font-size:1.7rem; margin-top:6px; }

/* ---------- Cardápio ---------- */
.menu{ background:linear-gradient(180deg, var(--cream), var(--paper)); }
.promo-banner{
  display:flex; align-items:center; gap:18px; justify-content:center; flex-wrap:wrap;
  background:var(--gold); color:var(--navy-deep); border-radius:16px; padding:16px 26px;
  margin:0 auto 44px; max-width:760px; box-shadow:var(--shadow-sm);
}
.promo-banner b{ font-family:var(--font-ui); font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:1.05rem; }
.promo-banner span{ font-size:.95rem; }
.menu-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card{
  background:var(--paper-card); border-radius:20px; overflow:hidden; box-shadow:var(--shadow-sm);
  border:1px solid var(--line); display:flex; flex-direction:column; transition:.2s ease;
}
.card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.card-photo{ position:relative; aspect-ratio:16/11; overflow:hidden;
  background:radial-gradient(circle at 50% 60%, var(--cream-2), var(--cream)); }
.card-photo img{ width:100%; height:100%; object-fit:cover; transition:.4s ease; }
.card:hover .card-photo img{ transform:scale(1.05); }
.card-tag{ position:absolute; top:12px; left:12px; background:var(--brick); color:#fff;
  font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.06em;
  font-size:.72rem; padding:5px 11px; border-radius:999px; }
.card-tag.veg{ background:var(--green); }
.card-body{ padding:22px 22px 24px; display:flex; flex-direction:column; flex:1; }
.card-body h3{ font-family:var(--font-display); font-size:1.9rem; color:var(--navy); text-transform:uppercase; line-height:.92; }
.card-body .sub{ font-family:var(--font-ui); font-weight:500; text-transform:uppercase; letter-spacing:.1em;
  font-size:.74rem; color:var(--gold); margin-top:3px; }
.card-body .desc{ color:var(--muted); font-size:.96rem; line-height:1.55; margin:12px 0 14px; min-height:46px; }
.nutri{ display:flex; gap:8px; margin-bottom:18px; }
.nutri .chip{ display:inline-flex; align-items:center; gap:5px; background:var(--cream); color:var(--muted);
  border:1px solid var(--line); border-radius:999px; padding:5px 11px; font-size:.78rem; font-weight:600; white-space:nowrap; }
.card-foot{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; gap:12px; }
.price{ font-family:var(--font-display); font-size:1.9rem; color:var(--navy); }
.price small{ font-family:var(--font-body); font-size:.8rem; color:var(--muted-2); font-weight:600; }

/* stepper */
.stepper{ display:inline-flex; align-items:center; background:var(--navy); border-radius:999px; }
.stepper button{ width:40px; height:40px; color:#fff; font-size:1.3rem; display:grid; place-items:center; transition:.15s; }
.stepper button:hover{ color:var(--gold-soft); }
.stepper span{ min-width:30px; text-align:center; color:#fff; font-family:var(--font-ui); font-weight:600; font-size:1.05rem; }
.add-btn{ background:var(--gold); color:var(--navy-deep); border-radius:999px; padding:11px 20px;
  font-family:var(--font-ui); font-weight:600; text-transform:uppercase; letter-spacing:.04em; font-size:.9rem;
  display:inline-flex; align-items:center; gap:8px; transition:.16s; }
.add-btn:hover{ background:var(--gold-soft); transform:translateY(-1px); }

/* ---------- Entregas ---------- */
.entregas{ background:var(--navy); color:#fff; }
.entregas .section-head h2{ color:#fff; }
.entregas .section-head p{ color:#c2cadb; }
.days{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; max-width:920px; margin:0 auto; }
.day{ background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.12); border-radius:18px;
  padding:28px 26px; text-align:center; }
.day .moon{ width:44px; height:44px; margin:0 auto 12px; border-radius:50%; display:grid; place-items:center;
  background:rgba(255,255,255,.07); }
.day .moon svg{ width:24px; height:24px; }
.day h3{ font-family:var(--font-display); font-size:1.7rem; text-transform:uppercase; }
.day .line{ height:1px; background:rgba(255,255,255,.14); margin:16px 0; }
.day .lbl{ font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.08em; font-size:.74rem; color:var(--gold-soft); }
.day .big{ font-size:1.05rem; font-weight:700; margin-top:2px; }
.entregas .note{ text-align:center; margin-top:38px; }
.area-pill{ display:inline-flex; align-items:center; gap:10px; background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.16); border-radius:999px; padding:11px 22px; font-weight:600;
  font-family:var(--font-ui); letter-spacing:.04em; white-space:nowrap; }
.area-pill svg{ width:18px; height:18px; stroke:var(--celeste); }

/* ---------- Restaurante teaser ---------- */
.teaser{ background:linear-gradient(180deg,var(--paper),var(--cream)); text-align:center; }
.teaser .badge-soon{ display:inline-block; font-family:var(--font-ui); font-weight:600; text-transform:uppercase;
  letter-spacing:.18em; font-size:.78rem; color:var(--brick); border:1.5px dashed var(--brick-soft);
  padding:8px 18px; border-radius:999px; margin-bottom:20px; }
.teaser h2{ font-family:var(--font-display); font-size:clamp(2.2rem,5vw,3.4rem); color:var(--navy);
  text-transform:uppercase; line-height:.96; }
.teaser p{ color:var(--muted); font-size:1.1rem; max-width:560px; margin:18px auto 0; line-height:1.65; }

/* ---------- Footer ---------- */
.ftr{ background:var(--navy-deep); color:#cdd5e6; padding:60px 0 32px; }
.ftr-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; }
.ftr-logo img{ height:62px; margin-bottom:16px; }
.ftr p{ line-height:1.6; font-size:.95rem; color:#aeb8cf; }
.ftr h4{ font-family:var(--font-ui); text-transform:uppercase; letter-spacing:.1em; font-size:.84rem;
  color:#fff; margin:0 0 16px; }
.ftr a.l{ display:block; padding:5px 0; font-size:.95rem; color:#aeb8cf; transition:.15s; }
.ftr a.l:hover{ color:var(--gold-soft); }
.ftr .wa-line{ display:inline-flex; align-items:center; gap:9px; color:#fff; font-family:var(--font-ui);
  font-weight:600; font-size:1.15rem; margin-top:4px; white-space:nowrap; }
.ftr .wa-line svg{ width:22px; height:22px; }
.ftr-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:44px; padding-top:22px;
  display:flex; justify-content:space-between; gap:16px; flex-wrap:wrap; font-size:.84rem; color:#7e89a3; }

/* ---------- Floating cart (mobile) ---------- */
.fab-cart{ position:fixed; bottom:24px; left:24px; z-index:40; background:var(--navy); color:#fff;
  border-radius:999px; padding:14px 20px; font-family:var(--font-ui); font-weight:700; letter-spacing:.03em;
  display:none; align-items:center; gap:10px; box-shadow:var(--shadow-lg); }
.fab-cart .c{ background:var(--gold); color:var(--navy-deep); border-radius:999px; min-width:22px; height:22px;
  display:grid; place-items:center; font-size:.82rem; padding:0 6px; }

/* ---------- Floating WhatsApp (mascote) ---------- */
.fab-whats{ position:fixed; bottom:24px; right:24px; z-index:60; width:72px; height:72px;
  display:flex; align-items:center; justify-content:center; }
.fab-whats-av{ position:relative; z-index:2; width:72px; height:72px; border-radius:50%; overflow:hidden;
  background:radial-gradient(circle at 50% 32%, var(--celeste-soft), var(--celeste)); border:3px solid #fff;
  box-shadow:var(--shadow-lg); transition:transform .18s ease; }
.fab-whats-av img{ width:100%; height:100%; object-fit:cover; object-position:50% 12%; }
.fab-whats:hover .fab-whats-av{ transform:translateY(-3px) scale(1.05); }
.fab-whats-ring{ position:absolute; inset:0; border-radius:50%; z-index:1;
  box-shadow:0 0 0 0 rgba(37,211,102,.5); animation:waPulse 2.4s ease-out infinite; }
@keyframes waPulse{ 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.5); } 70%{ box-shadow:0 0 0 18px rgba(37,211,102,0); } 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0); } }
@media (prefers-reduced-motion: reduce){ .fab-whats-ring{ animation:none; } }
.fab-whats-badge{ position:absolute; bottom:-2px; right:-2px; z-index:3; width:28px; height:28px; border-radius:50%;
  background:var(--wa); display:grid; place-items:center; border:2.5px solid #fff; box-shadow:var(--shadow-sm); }
.fab-whats-badge svg{ width:16px; height:16px; color:#fff; }
.fab-whats-lbl{ position:absolute; right:86px; top:50%; transform:translateY(-50%) translateX(8px);
  background:var(--navy); color:#fff; padding:9px 15px; border-radius:999px; white-space:nowrap;
  font-family:var(--font-ui); font-weight:600; font-size:.86rem; letter-spacing:.02em; box-shadow:var(--shadow-md);
  opacity:0; pointer-events:none; transition:.2s ease; }
.fab-whats-lbl::after{ content:''; position:absolute; right:-5px; top:50%; transform:translateY(-50%) rotate(45deg);
  width:11px; height:11px; background:var(--navy); border-radius:2px; }
.fab-whats:hover .fab-whats-lbl{ opacity:1; transform:translateY(-50%) translateX(0); }

/* ---------- Checkout drawer ---------- */
.scrim{ position:fixed; inset:0; background:rgba(14,20,35,.55); backdrop-filter:blur(3px); z-index:90;
  opacity:0; pointer-events:none; transition:.25s; }
.scrim.on{ opacity:1; pointer-events:auto; }
.drawer{ position:fixed; top:0; right:0; height:100%; width:min(460px,100%); background:var(--paper);
  z-index:100; box-shadow:var(--shadow-lg); transform:translateX(100%); transition:.32s cubic-bezier(.22,1,.36,1);
  display:flex; flex-direction:column; }
.drawer.on{ transform:translateX(0); }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; padding:20px 24px;
  border-bottom:1px solid var(--line); background:var(--navy); color:#fff; }
.drawer-head h3{ font-family:var(--font-display); font-size:1.5rem; text-transform:uppercase; letter-spacing:.02em; white-space:nowrap; }
.drawer-head .x{ color:#fff; width:36px; height:36px; border-radius:50%; display:grid; place-items:center;
  font-size:1.4rem; transition:.15s; }
.drawer-head .x:hover{ background:rgba(255,255,255,.14); }
.drawer-body{ flex:1; overflow-y:auto; padding:22px 24px; }
.drawer-foot{ border-top:1px solid var(--line); padding:18px 24px; background:var(--paper-card); }

.empty{ text-align:center; padding:50px 10px; color:var(--muted); }
.empty img{ height:140px; margin:0 auto 18px; opacity:.9; }

.line-item{ display:flex; gap:13px; align-items:center; padding:14px 0; border-bottom:1px solid var(--line); }
.line-item img{ width:58px; height:58px; border-radius:12px; object-fit:cover; flex:none; background:var(--cream); }
.line-item .li-info{ flex:1; }
.line-item .li-info b{ font-family:var(--font-ui); font-weight:600; font-size:1.02rem; color:var(--navy); }
.line-item .li-info span{ display:block; color:var(--muted); font-size:.84rem; }
.line-item .mini-step{ display:inline-flex; align-items:center; background:var(--cream); border-radius:999px; border:1px solid var(--line); }
.line-item .mini-step button{ width:30px; height:30px; color:var(--navy); font-size:1.1rem; }
.line-item .mini-step span{ min-width:22px; text-align:center; font-weight:700; font-size:.92rem; }

.field{ margin-bottom:16px; }
.field label{ display:block; font-family:var(--font-ui); font-weight:500; text-transform:uppercase;
  letter-spacing:.06em; font-size:.74rem; color:var(--muted); margin-bottom:7px; }
.field label .req{ color:var(--brick); }
.field input, .field textarea, .field select{
  width:100%; padding:12px 14px; border:1.5px solid var(--line); border-radius:12px; background:var(--paper-card);
  font-family:var(--font-body); font-size:.98rem; color:var(--ink); transition:.15s;
}
.field input:focus, .field textarea:focus, .field select:focus{ outline:none; border-color:var(--celeste-2);
  box-shadow:0 0 0 3px rgba(79,143,199,.16); }
.field input.err, .field select.err{ border-color:var(--brick); }
.field .hint{ font-size:.8rem; color:var(--muted-2); margin-top:6px; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; }

.seg{ display:flex; gap:8px; }
.seg button{ flex:1; padding:11px; border:1.5px solid var(--line); border-radius:12px; background:var(--paper-card);
  font-family:var(--font-ui); font-weight:500; text-transform:uppercase; letter-spacing:.04em; font-size:.82rem;
  color:var(--muted); transition:.15s; }
.seg button.active{ background:var(--navy); color:#fff; border-color:var(--navy); }

.closed-note{ background:rgba(156,43,36,.07); border:1px solid rgba(156,43,36,.25); border-radius:14px;
  padding:14px 16px; margin-bottom:18px; }
.closed-note b{ color:var(--brick); display:flex; align-items:center; gap:8px; font-family:var(--font-ui);
  text-transform:uppercase; letter-spacing:.04em; font-size:.9rem; }
.closed-note p{ margin:6px 0 0; font-size:.9rem; color:var(--muted); line-height:1.5; }

.totals{ margin:6px 0 4px; }
.totals .row{ display:flex; justify-content:space-between; padding:5px 0; font-size:.96rem; color:var(--muted); }
.totals .row.grand{ border-top:1px dashed var(--line); margin-top:6px; padding-top:12px;
  font-family:var(--font-ui); font-weight:700; font-size:1.25rem; color:var(--navy); }
.totals .row.grand span{ white-space:nowrap; }
.totals .row.grand .v{ font-family:var(--font-display); }

/* divider */
.divider{ display:flex; align-items:center; gap:14px; margin:26px 0 18px; color:var(--gold); }
.divider::before, .divider::after{ content:''; flex:1; height:1px; background:var(--line); }
.divider svg{ width:20px; height:20px; }

/* ---------- responsive ---------- */
@media (max-width: 1000px){
  .hdr-nav{ display:none; }
  .hero-classic{ padding-left:24px; padding-right:24px; }
  .hero-logo-big{ width:min(280px, 64vw); margin-bottom:24px; }
  .hero-row{ flex-direction:column; text-align:center; padding-left:24px; padding-right:24px; gap:30px; }
  .hero-row .hero-text{ flex-basis:auto; max-width:100%; }
  .hero-row .hero-art{ width:100%; }
  .hero-classic .hero-lead{ margin-left:auto; margin-right:auto; }
  .hero-classic .hero-cta{ justify-content:center; }
  .hero-classic .hero-meta{ justify-content:center; }
  .hero-vitrine .inner{ grid-template-columns:1fr; }
  .hero-vitrine .right{ min-height:360px; }
  .story-grid{ grid-template-columns:1fr; gap:34px; }
  .selos-row{ grid-template-columns:repeat(2,1fr); gap:24px; }
  .menu-grid{ grid-template-columns:1fr; max-width:440px; margin:0 auto; }
  .days{ grid-template-columns:1fr; max-width:420px; }
  .ftr-grid{ grid-template-columns:1fr; gap:30px; }
  .fab-cart{ display:inline-flex; }
}
@media (max-width: 520px){
  .wrap{ padding:0 18px; }
  .section{ padding:64px 0; }
  .selos-row{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
}
