/* ============================================================
   MAMA JULIA — STYLES
   Direction : naturel andin, chaleureux, éditorial.
   Mobile-first. Gros boutons, textes lisibles.
   ============================================================ */

:root{
  --cream:#e9f3f7;
  --cream-2:#d9e9f0;
  --surface:#fdfeff;
  --sky:#1a6589;
  --sky-dark:#10465f;
  --sky-soft:#dcecf2;
  --ochre:#e0a32e;
  --ochre-soft:#f6e6c4;
  --terra:#c0603a;
  --wa:#25d366;
  --wa-dark:#128c47;
  --ink:#1f2b31;
  --muted:#5d717b;
  --border:#cde0e8;
  --shadow:0 14px 34px -18px rgba(16,42,55,.42);
  --shadow-sm:0 6px 18px -10px rgba(16,42,55,.38);
  --radius:22px;
  --maxw:1180px;
  --font-display:"Fraunces",Georgia,serif;
  --font-body:"Mulish","Segoe UI",system-ui,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  font-size:17px;line-height:1.62;
  color:var(--ink);
  background:var(--cream);
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
h1,h2,h3{font-family:var(--font-display);font-weight:700;line-height:1.12;letter-spacing:-.01em}

.section-inner{max-width:var(--maxw);margin:0 auto;padding:0 20px}
section{padding:64px 0}

/* ---- En-têtes de section ---- */
.section-head{max-width:640px;margin:0 auto 38px;text-align:center}
.kicker{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--font-body);font-weight:700;
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--terra);margin-bottom:12px;
}
.kicker::before{content:"";width:26px;height:2px;background:var(--ochre);border-radius:2px}
.section-head h2{font-size:clamp(1.9rem,5vw,2.7rem);color:var(--sky)}
.section-head p{margin-top:12px;color:var(--muted)}
.muted{color:var(--muted)}

/* ---- Boutons ---- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  min-height:52px;padding:0 24px;border-radius:999px;
  font-weight:700;font-size:1rem;
  transition:transform .15s ease,box-shadow .2s ease,background .2s ease;
}
.btn:active{transform:scale(.97)}
.btn--primary{background:var(--sky);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--sky-dark)}
.btn--whatsapp{background:var(--wa);color:#0a3d1f;box-shadow:var(--shadow-sm)}
.btn--whatsapp:hover{background:#1ec25d}
.btn--ghost{background:var(--surface);color:var(--sky);border:2px solid var(--border)}
.btn--block{width:100%}

/* ============================================================
   EN-TÊTE
   ============================================================ */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(250,246,236,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
/* Largeur identique aux sections (section-inner) -> aucun décalage */
.site-header__inner{
  max-width:var(--maxw);margin:0 auto;
  padding:10px 20px;
  display:flex;align-items:center;gap:14px;
  position:relative;
}
.brand{
  display:flex;align-items:center;gap:11px;
  background:none;border:none;cursor:pointer;text-align:left;
  flex-shrink:0;min-width:0;order:1;
}
.brand__icon{border-radius:11px;flex-shrink:0}
.brand__text{display:flex;flex-direction:column;line-height:1.15}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:1.3rem;color:var(--sky)}
.brand__sub{font-size:.66rem;color:var(--muted);max-width:200px}

/* Panier — dans le flux, à droite sur desktop (centre = nav) */
.cart-btn{
  position:relative;
  width:46px;height:46px;border-radius:50%;
  background:var(--surface);border:2px solid var(--border);color:var(--sky);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  order:3;
}
.cart-btn:hover{border-color:var(--ochre)}
.cart-count{
  position:absolute;top:-5px;right:-5px;min-width:21px;height:21px;padding:0 5px;
  background:var(--terra);color:#fff;border-radius:999px;
  font-size:.72rem;font-weight:800;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--cream);
}

.header-actions{display:flex;align-items:center;gap:10px;flex:1;justify-content:flex-end;order:2}

.main-nav{display:flex;gap:4px;margin-right:auto;margin-left:20px}
.main-nav a{
  padding:9px 12px;border-radius:10px;font-weight:600;font-size:.92rem;
  color:var(--ink);transition:background .15s,color .15s;
}
.main-nav a:hover{background:var(--sky-soft);color:var(--sky)}

.lang-switch{display:flex;background:var(--cream-2);border-radius:999px;padding:3px;flex-shrink:0}
.lang-switch button{
  padding:7px 11px;border-radius:999px;font-weight:700;font-size:.82rem;color:var(--muted);
}
.lang-switch button.is-active{background:var(--sky);color:#fff}

.nav-toggle{display:none;width:46px;height:46px;border-radius:12px;
  background:var(--surface);border:2px solid var(--border);
  flex-direction:column;gap:5px;align-items:center;justify-content:center;flex-shrink:0}
.nav-toggle span{width:22px;height:2.5px;background:var(--sky);border-radius:2px;transition:.2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}


/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;padding:46px 0 0;background:
  radial-gradient(900px 460px at 78% 8%,var(--ochre-soft),transparent 60%),
  radial-gradient(700px 500px at 4% 92%,var(--sky-soft),transparent 62%),
  var(--cream);
  overflow:hidden}
.hero__deco{
  position:absolute;inset:0;pointer-events:none;opacity:.5;
  background-image:repeating-linear-gradient(115deg,transparent 0 38px,rgba(26,101,137,.05) 38px 39px);
}
.hero__inner{
  position:relative;max-width:var(--maxw);margin:0 auto;padding:0 20px 90px;
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
}
.hero__badge{
  display:inline-flex;align-items:center;gap:9px;
  background:var(--surface);border:1px solid var(--border);
  padding:8px 15px;border-radius:999px;font-size:.85rem;font-weight:600;color:var(--sky);
}
.hero__badge .dot{width:9px;height:9px;border-radius:50%;background:var(--wa);
  box-shadow:0 0 0 0 rgba(37,211,102,.6);animation:pulse 2.4s infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(37,211,102,.55)}
  70%{box-shadow:0 0 0 11px rgba(37,211,102,0)}
  100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}
}
.hero__title{
  margin:18px 0 14px;color:var(--sky);
  font-size:clamp(2.3rem,6.2vw,3.7rem);
}
.hero__title em{font-style:italic;color:var(--terra)}
.hero__lead{font-size:1.12rem;color:var(--muted);max-width:33ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:13px;margin-top:26px}

.hero__media{position:relative}
.hero__photo{
  border-radius:48% 52% 56% 44%/52% 46% 54% 48%;
  overflow:hidden;border:7px solid var(--surface);
  box-shadow:var(--shadow);position:relative;z-index:2;
  rotate:-2deg;
}
/* Ovale élargi (format paysage) : on voit davantage le tableau
   « el tiburón de la venta » derrière Mamita Julia. */
.hero__photo img{width:100%;aspect-ratio:1.25;object-fit:cover;display:block}
/* Halo jaune supprimé en v16-15 : la nouvelle photo du hero a déjà
   un fond jaune marqué, un halo derrière ferait doublon. Le galet
   garde sa bordure blanche + ombre douce, ça suffit. */
.hero__chip{
  position:absolute;left:-8px;bottom:18px;z-index:3;
  background:var(--surface);border-radius:16px;padding:12px 18px;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;line-height:1.3;
}
.hero__chip strong{font-family:var(--font-display);color:var(--sky);font-size:1.1rem}
.hero__chip span{font-size:.82rem;color:var(--muted)}

.ridge{position:absolute;left:0;right:0;bottom:-1px;line-height:0}
.ridge svg{width:100%;height:74px;display:block}
.ridge path{fill:var(--sky)}

/* ============================================================
   SOBRE MÍ
   ============================================================ */
.sobre{background:var(--sky);color:#fff}
.sobre__grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:center}
.sobre__text .kicker{color:var(--ochre)}
.sobre__text .kicker::before{background:var(--ochre)}
.sobre__text h2{font-size:clamp(1.9rem,5vw,2.6rem);color:#fff;margin-bottom:14px}
.sobre__text p{color:#d3e6ee;margin-bottom:12px}
.sobre__photos{
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;
  gap:14px;
}
.sobre__photos img{
  width:100%;border-radius:18px;box-shadow:var(--shadow);
  border:5px solid rgba(255,255,255,.9);object-fit:cover;
}
.sobre__photos img:nth-child(1){grid-row:span 2;aspect-ratio:3/4.4}
.sobre__photos img:nth-child(2){aspect-ratio:1}
.sobre__photos img:nth-child(3){aspect-ratio:1}

/* ============================================================
   CATÁLOGO
   ============================================================ */
.catalogo{background:var(--cream)}
.cat-block{margin-top:46px}
.cat-block:first-child{margin-top:8px}
.cat-block__head{margin-bottom:22px}
.cat-block__head h3{
  font-size:1.55rem;color:var(--sky);
  display:flex;align-items:center;gap:11px;
}
.cat-block__head h3::before{
  content:"";width:13px;height:13px;border-radius:4px;background:var(--ochre);
  transform:rotate(45deg);flex-shrink:0;
}
.cat-block__head p{color:var(--muted);margin-top:5px}

.grid{
  display:grid;gap:20px;
  grid-template-columns:repeat(auto-fill,minmax(248px,1fr));
}

/* ---- Carte produit ---- */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .18s ease,box-shadow .2s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.card__media{position:relative;background:var(--sky-dark)}
.card__media img{width:100%;aspect-ratio:1;object-fit:cover}
.card__flag{
  position:absolute;top:10px;left:10px;
  background:var(--ochre);color:#3a2a05;font-weight:800;
  font-size:.68rem;letter-spacing:.05em;text-transform:uppercase;
  padding:5px 10px;border-radius:999px;
}
.card__body{padding:16px 16px 18px;display:flex;flex-direction:column;flex:1}
.card__name{font-size:1.18rem;color:var(--sky)}
.card__chips{display:flex;flex-wrap:wrap;gap:6px;margin:9px 0 10px}
.chip{
  font-size:.74rem;font-weight:700;padding:4px 9px;border-radius:999px;
  background:var(--sky-soft);color:var(--sky);
}
.chip--flavour{background:var(--ochre-soft);color:#8a5e10}
.card__desc{font-size:.92rem;color:var(--muted);flex:1}
.card__ingr{
  margin-top:8px;font-size:.85rem;
}
.card__ingr summary{
  cursor:pointer;font-weight:700;color:var(--terra);
  list-style:none;display:inline-flex;align-items:center;gap:5px;
}
.card__ingr summary::-webkit-details-marker{display:none}
.card__ingr summary::after{content:"▾";font-size:.8em;transition:transform .2s}
.card__ingr[open] summary::after{transform:rotate(180deg)}
.card__ingr p{margin-top:7px;color:var(--muted);line-height:1.5}

.card__price{
  margin:13px 0 12px;display:flex;align-items:baseline;gap:8px;
  font-family:var(--font-display);
}
.card__price .amount{font-size:1.32rem;font-weight:600;color:var(--ink)}
.card__price .points{
  font-family:var(--font-body);font-size:.78rem;font-weight:700;
  background:var(--sky);color:#fff;padding:3px 8px;border-radius:999px;
}
.card__price .ask{font-size:1rem;font-weight:600;color:var(--terra)}

.card__actions{display:flex;flex-direction:column;gap:8px;align-items:stretch}
.stepper{
  display:flex;align-items:center;border:2px solid var(--border);
  border-radius:999px;overflow:hidden;flex-shrink:0;
}
.card__actions .stepper{width:100%;justify-content:space-between}
.stepper button{width:38px;height:44px;font-size:1.3rem;font-weight:700;color:var(--sky)}
.stepper button:active{background:var(--sky-soft)}
.stepper span{width:34px;text-align:center;font-weight:800;font-size:1rem}
.btn-add{
  width:100%;min-height:46px;border-radius:999px;
  background:var(--sky);color:#fff;font-weight:700;
  display:flex;align-items:center;justify-content:center;gap:7px;
  transition:background .15s,transform .12s;
}
.btn-add:active{transform:scale(.97)}
.btn-add.is-in{background:var(--wa-dark)}

/* ---- Sélecteur de présentation (Pote / Caja / Doypack) ---- */
.pres-select{display:flex;gap:6px;width:100%}
.pres-opt{
  flex:1;min-height:42px;padding:0 8px;border-radius:11px;
  border:2px solid var(--border);background:var(--cream);
  font-family:inherit;font-size:.84rem;font-weight:700;
  color:var(--muted);cursor:pointer;line-height:1.15;
  transition:border-color .12s,background .12s,color .12s;
}
.pres-opt:hover{border-color:var(--sky)}
.pres-opt.is-on{border-color:var(--sky);background:var(--sky-soft);color:var(--sky-dark,var(--sky))}

/* ---- Carte service ---- */
.service{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);overflow:hidden;
  display:grid;grid-template-columns:230px 1fr;
}
.service__media{background:var(--sky-soft)}
.service__media img{width:100%;height:100%;object-fit:cover;min-height:200px}
.service__body{padding:24px;display:flex;flex-direction:column;gap:9px}
.service__body h4{font-family:var(--font-display);font-size:1.4rem;color:var(--sky)}
.service__body p{color:var(--muted)}
.service__body .detalle{font-size:.9rem}
.service__body .btn{margin-top:8px;align-self:flex-start}

/* ============================================================
   PROMOCIONES
   ============================================================ */
.promos{background:var(--cream-2)}
.promo-list{display:block}
.promo{
  position:relative;background:var(--surface);
  border:2px dashed var(--ochre);border-radius:var(--radius);
  padding:24px 24px 24px 28px;overflow:hidden;
}
.promo::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:7px;background:var(--terra);
}
.promo__tag{
  display:inline-block;background:var(--terra);color:#fff;
  font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;margin-bottom:10px;
}
.promo h3{font-size:1.3rem;color:var(--sky);margin-bottom:7px}
.promo p{color:var(--muted)}
.promo__vig{margin-top:11px;font-size:.84rem;font-weight:700;color:var(--terra)}
.promos__empty{text-align:center;color:var(--muted);padding:20px}

/* ============================================================
   CÓMO PEDIR
   ============================================================ */
.pedir{background:var(--cream)}
.steps{
  list-style:none;display:grid;gap:18px;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
}
.step{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:26px 22px;position:relative;
}
.step__num{
  display:flex;align-items:center;justify-content:center;
  width:46px;height:46px;border-radius:50%;
  background:var(--ochre);color:#3a2a05;
  font-family:var(--font-display);font-weight:600;font-size:1.4rem;
  margin-bottom:14px;
}
.step h3{font-size:1.12rem;color:var(--sky);margin-bottom:6px}
.step p{font-size:.93rem;color:var(--muted)}

/* ============================================================
   CONTACTO
   ============================================================ */
.contacto{background:var(--sky);color:#fff}
.contacto .kicker{color:var(--ochre)}
.contacto .kicker::before{background:var(--ochre)}
.contacto .section-head h2{color:#fff}
.contacto .section-head p{color:#d3e6ee}
.contacto__grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(255px,1fr))}
.contacto__card{
  background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);
  border-radius:var(--radius);padding:26px 22px;text-align:center;
}
.contacto__card--wa{background:var(--surface);color:var(--ink)}
.contacto__icon{font-size:2rem;margin-bottom:8px}
.contacto__card h3{font-size:1.2rem;margin-bottom:8px;color:#fff}
.contacto__card--wa h3{color:var(--sky)}
.contacto__card p{margin-bottom:5px}
.contacto__card .muted{color:#bcd4de}
.contacto__card--wa .btn{margin-top:12px;width:100%}
.link-arrow{
  display:inline-block;margin-top:9px;font-weight:700;color:var(--ochre);
}
.link-arrow::after{content:" →"}

/* ============================================================
   PIED DE PAGE
   ============================================================ */
.site-footer{background:var(--sky-dark);color:#d3e6ee;padding-top:46px}
.footer__grid{display:flex;flex-direction:column;gap:12px;padding-bottom:26px;text-align:center}
.footer__brand{display:flex;flex-direction:column;align-items:center;gap:4px}
.footer__brand img{border-radius:12px}
.footer__brand strong{font-family:var(--font-display);font-size:1.3rem;color:#fff}
.footer__brand span{font-size:.85rem;color:#9fb9c5}
.footer__disclaimer,.footer__privacy,.footer__marca{
  font-size:.82rem;color:#92aeba;max-width:680px;margin:0 auto;
}
.footer__bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding:16px 20px;display:flex;flex-wrap:wrap;gap:8px;
  justify-content:center;font-size:.8rem;color:#83a0ac;
}
.footer__credits{
  color:var(--ochre);font-weight:700;
  text-decoration:none;
  transition:color .15s ease;
}
.footer__credits:hover,
.footer__credits:focus-visible{
  color:#fff;text-decoration:underline;
}
/* Lien discret vers la page de gestion (admin).
   Volontairement très sobre : visible pour qui le cherche,
   sans attirer l'œil d'un visiteur normal. */
.footer__gestion{
  color:#5e7884;
  font-size:.78rem;
  text-decoration:none;
  opacity:.7;
  transition:opacity .15s ease,color .15s ease;
}
.footer__gestion:hover,
.footer__gestion:focus-visible{
  opacity:1;color:#cdd9df;text-decoration:underline;
}

/* ============================================================
   PANIER (TIROIR)
   ============================================================ */
.drawer-overlay{
  position:fixed;inset:0;z-index:60;
  background:rgba(22,18,10,.5);backdrop-filter:blur(2px);
}
.cart-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:70;
  width:min(420px,92vw);background:var(--cream);
  display:flex;flex-direction:column;
  transform:translateX(105%);transition:transform .28s ease;
  box-shadow:-20px 0 50px -24px rgba(0,0,0,.5);
}
.cart-drawer.is-open{transform:translateX(0)}
.cart-drawer__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 20px;border-bottom:1px solid var(--border);background:var(--surface);
}
.cart-drawer__head h2{color:var(--sky);font-size:1.4rem}
.icon-btn{
  width:40px;height:40px;border-radius:50%;font-size:1.1rem;
  background:var(--cream-2);color:var(--ink);display:flex;
  align-items:center;justify-content:center;
}
.cart-drawer__body{flex:1;overflow-y:auto;padding:16px 18px}
.cart-empty{text-align:center;color:var(--muted);padding:48px 16px}
.cart-empty svg{opacity:.3;margin-bottom:10px}

.cart-item{
  display:grid;grid-template-columns:62px 1fr auto;gap:12px;
  padding:13px 0;border-bottom:1px solid var(--border);align-items:center;
}
.cart-item img{width:62px;height:62px;border-radius:12px;object-fit:cover;background:var(--sky-dark)}
.cart-item__name{font-weight:700;color:var(--sky);line-height:1.25}
.cart-item__meta{font-size:.8rem;color:var(--muted)}
.cart-item .stepper{margin-top:6px;border-width:1.5px}
.cart-item .stepper button{width:32px;height:36px;font-size:1.1rem}
.cart-item .stepper span{width:28px;font-size:.92rem}
.cart-item__remove{color:var(--terra);font-size:.8rem;font-weight:700;margin-top:4px;text-align:right}

.cart-drawer__foot{
  padding:16px 18px;border-top:1px solid var(--border);background:var(--surface);
}
.cart-drawer__foot.is-hidden{display:none}
.cart-field{margin-bottom:11px}
.cart-field label{display:block;font-size:.82rem;font-weight:700;color:var(--muted);margin-bottom:5px}
.cart-field input{
  width:100%;min-height:46px;padding:0 14px;border-radius:12px;
  border:2px solid var(--border);font-family:inherit;font-size:1rem;background:var(--cream);
}
.cart-field input:focus{outline:none;border-color:var(--ochre)}
.cart-turnstile{display:flex;justify-content:center;min-height:65px;margin:10px 0 4px}
#cartContinue[disabled]{opacity:.6;pointer-events:none}
.cart-aviso{font-size:.8rem;color:var(--muted);text-align:center;margin-top:9px}
.cart-clear{display:block;margin:10px auto 0;font-size:.84rem;font-weight:700;color:var(--terra)}

/* ---- Étape de paiement ---- */
.cart-volver{
  background:none;border:none;font-family:inherit;font-size:.9rem;font-weight:700;
  color:var(--muted);cursor:pointer;padding:0;margin-bottom:8px;
}
.cart-volver:hover{color:var(--terra)}
.pago-titulo{
  font-family:var(--font-display,inherit);font-size:1.15rem;font-weight:600;
  color:var(--terra);margin:2px 0 4px;
}
.pago-intro{font-size:.86rem;color:var(--muted);margin-bottom:12px}
.pago-opciones{display:flex;flex-direction:column;gap:9px;margin-bottom:12px}
.pago-opcion{
  display:flex;align-items:center;gap:10px;width:100%;min-height:52px;
  padding:0 16px;border-radius:13px;border:2px solid var(--border);
  background:var(--cream);font-family:inherit;font-size:1rem;font-weight:700;
  color:var(--ink,#1d2b33);cursor:pointer;text-align:left;
}
.pago-opcion:hover{border-color:var(--ochre)}
.pago-opcion.is-active{border-color:var(--wa);background:#e7f8ee}
.pago-opcion__ico{font-size:1.3rem;line-height:1}
.pago-panel{
  background:var(--cream);border-radius:13px;padding:14px;margin-bottom:12px;
  border:1px solid var(--border);text-align:center;
}
.pago-panel__titulo{font-size:1rem;font-weight:700;margin:0 0 4px;color:var(--terra)}
.pago-panel__txt{font-size:.85rem;color:var(--muted);margin:0 0 12px}
.yape-qr{
  display:block;width:200px;max-width:80%;height:auto;margin:0 auto 12px;
  border-radius:12px;border:1px solid var(--border);background:#fff;
}
.yape-qr--vacio{
  display:flex;align-items:center;justify-content:center;width:200px;height:200px;
  max-width:80%;font-size:.82rem;color:var(--muted);padding:16px;
}
.yape-num{
  display:flex;justify-content:space-between;align-items:center;gap:10px;
  padding:8px 4px;font-size:.92rem;border-top:1px solid var(--border);
}
.yape-num:first-of-type{border-top:none}
.yape-num__lbl{color:var(--muted);font-size:.82rem}
.yape-num strong{font-size:1.05rem;letter-spacing:.02em}
.cart-copiar{
  display:block;width:100%;min-height:42px;margin-top:10px;
  border-radius:11px;border:2px solid var(--ochre);background:var(--ochre-soft);
  font-family:inherit;font-size:.9rem;font-weight:700;color:#7a5410;cursor:pointer;
}
.cart-copiar:hover{background:var(--ochre);color:#fff}
.btn--whatsapp[disabled]{opacity:.45;pointer-events:none}

/* ============================================================
   WHATSAPP FLOTTANT
   ============================================================ */
.fab-wa{
  position:fixed;right:18px;bottom:18px;z-index:60;
  width:62px;height:62px;border-radius:50%;
  background:var(--wa);color:#0a3d1f;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 12px 28px -8px rgba(18,140,71,.7);
  animation:pulse 2.8s infinite;
}
.fab-wa:hover{background:#1ec25d}

/* ============================================================
   TOAST / BANDEAUX
   ============================================================ */
.toast{
  position:fixed;left:50%;bottom:96px;z-index:80;
  transform:translateX(-50%) translateY(28px);
  background:var(--sky-dark);color:#fff;
  padding:13px 22px;border-radius:999px;font-weight:700;font-size:.95rem;
  box-shadow:var(--shadow);opacity:0;pointer-events:none;
  transition:opacity .25s,transform .25s;max-width:90vw;text-align:center;
}
.toast.is-show{opacity:1;transform:translateX(-50%) translateY(0)}

.install-banner{
  position:fixed;left:14px;right:14px;bottom:14px;z-index:58;
  background:var(--sky-dark);color:#fff;
  display:flex;align-items:center;gap:12px;
  padding:12px 14px;border-radius:16px;box-shadow:var(--shadow);
  opacity:1;transform:translateY(0);
  transition:opacity .4s ease, transform .4s ease;
}
.install-banner.is-leaving{
  opacity:0;transform:translateY(20px);pointer-events:none;
}
.install-banner span{flex:1;font-weight:600;font-size:.92rem}
.install-banner button:first-of-type{
  background:var(--ochre);color:#3a2a05;font-weight:800;
  padding:9px 16px;border-radius:999px;
}
.install-banner .icon-btn{width:34px;height:34px;background:rgba(255,255,255,.15);color:#fff}

.offline-banner{
  position:fixed;left:0;right:0;top:0;z-index:90;
  background:var(--terra);color:#fff;text-align:center;
  padding:8px 14px;font-size:.86rem;font-weight:700;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:920px){
  .hero__inner{grid-template-columns:1fr;gap:30px;padding-bottom:80px}
  .hero__media{max-width:380px;margin:0 auto;width:100%}
  .sobre__grid{grid-template-columns:1fr;gap:30px}
  .sobre__photos{order:2;max-width:440px;margin:0 auto}
  .service{grid-template-columns:1fr}
  .service__media img{min-height:180px;max-height:240px}
}

@media (max-width:760px){
  body{font-size:16px}
  section{padding:50px 0}
  .site-header__inner{padding:9px 14px;gap:8px}
  /* Mobile : brand gauche | panier centre | lang+hamburger droite */
  .brand{order:1;flex:1 1 0}
  .cart-btn{order:2;position:absolute;left:50%;top:50%;
    transform:translate(-50%,-50%)}
  .header-actions{order:3;flex:1 1 0;justify-content:flex-end;margin:0}
  /* menu déroulant : attaché sous le header entier */
  .main-nav{
    position:absolute;top:100%;left:0;right:0;margin:0;
    flex-direction:column;gap:2px;padding:12px;
    background:var(--cream);border-bottom:1px solid var(--border);
    box-shadow:var(--shadow);
    display:none;
  }
  .main-nav.is-open{display:flex}
  .main-nav a{padding:13px 14px;font-size:1.05rem}
  .nav-toggle{display:flex}
  .brand__sub{display:none}
  .brand__name{font-size:1.15rem}
  .grid{grid-template-columns:1fr;gap:16px}
  .card__body{padding:13px}
  .card__name{font-size:1.05rem}
  .card__ingr,.card__desc{font-size:.85rem}
  .hero__chip{left:0}
}

@media (max-width:380px){
  .grid{grid-template-columns:1fr}
}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto}
}

/* ============================================================
   MODALE QR  +  LIEN INSTALL DU PIED DE PAGE
   ============================================================ */
.qr-modal{
  position:fixed;inset:0;z-index:95;
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.qr-modal[hidden]{display:none}
.qr-modal__overlay{
  position:absolute;inset:0;background:rgba(15,40,30,.62);
}
.qr-modal__box{
  position:relative;background:var(--surface);
  border-radius:20px;padding:26px 24px 22px;max-width:340px;width:100%;
  text-align:center;box-shadow:var(--shadow);
}
.qr-modal__close{
  position:absolute;top:10px;right:10px;width:34px;height:34px;
  border-radius:50%;background:var(--cream-2);color:var(--ink);
  font-size:1rem;font-weight:700;
}
.qr-modal__box h3{
  font-family:var(--font-display,inherit);font-size:1.2rem;
  color:var(--terra);margin-bottom:6px;
}
.qr-modal__box p{font-size:.9rem;color:var(--muted);margin-bottom:16px}
.qr-modal__img{
  width:210px;max-width:74%;height:auto;display:block;margin:0 auto;
  border-radius:12px;border:1.5px solid var(--border);background:#fff;padding:8px;
}
.qr-modal__url{
  margin-top:14px;display:inline-block;background:var(--sky);color:#fff;
  font-weight:700;font-size:.92rem;letter-spacing:.3px;
  padding:7px 18px;border-radius:999px;
}
.footer__install{
  display:inline-block;margin-top:10px;
  background:transparent;border:2px solid var(--ochre);
  color:var(--ochre);font-weight:700;font-size:.86rem;
  padding:8px 18px;border-radius:999px;cursor:pointer;
}
.footer__install:hover{background:var(--ochre);color:#3a2a05}

/* ============================================================
   v14 — SECTION SERVICIOS (2 services), catégorie destacada,
   chips TEOMA, prix de référence, avisos légaux.
   ============================================================ */
.servicios{background:var(--surface)}
.servicios__grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
  max-width:920px;margin:0 auto;
}
.servicio-card{
  display:flex;flex-direction:column;align-items:flex-start;
  gap:12px;padding:34px 30px;border-radius:var(--radius);
  background:var(--cream);border:2px solid var(--border);
  box-shadow:var(--shadow-sm);transition:transform .15s,box-shadow .15s;
}
.servicio-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.servicio-card:active{transform:scale(.99)}
.servicio-card--productos{background:linear-gradient(160deg,#eaf3f7,#dcecf2)}
.servicio-card--masajes{background:linear-gradient(160deg,#f6e6c4,#f3ddb0)}
.servicio-card__icon{
  width:74px;height:74px;border-radius:20px;display:grid;place-items:center;
  background:var(--surface);box-shadow:var(--shadow-sm);
}
.servicio-card--productos .servicio-card__icon{color:var(--sky)}
.servicio-card--masajes .servicio-card__icon{color:var(--terra)}
.servicio-card h3{font-size:1.5rem;color:var(--sky)}
.servicio-card--masajes h3{color:var(--terra)}
.servicio-card p{color:var(--muted);font-size:1rem}
.servicio-card__link{
  margin-top:auto;font-weight:700;color:var(--sky);
}
.servicio-card--masajes .servicio-card__link{color:var(--terra)}

/* ---- Catégorie mise en avant (Productos destacados) ---- */
.cat-block--destacada{
  background:linear-gradient(170deg,#fbf3dd,#f7e9c4);
  border:2px solid var(--ochre);border-radius:var(--radius);
  padding:30px 26px;margin-top:18px;
}
.cat-block__star{
  display:inline-block;color:var(--ochre);font-size:1.4rem;
  margin-right:8px;vertical-align:middle;
}
.cat-block--destacada .cat-block__head h3::before{background:var(--ochre)}

/* ---- Chip catégorie TEOMA d'origine ---- */
.chip--teoma{
  background:var(--sky-soft);color:var(--sky-dark);
  font-size:.72rem;font-weight:600;
}

/* ---- Prix de référence TEOMA ---- */
.ref-teoma{
  display:block;font-size:.78rem;color:var(--muted);margin-top:3px;
}

/* ---- Astérisque renvoi avisos ---- */
.aviso-ref{color:var(--ochre);font-weight:700;margin-left:1px}
.catalogo-avisos{
  margin-top:40px;padding:18px 22px;border-radius:14px;
  background:var(--sky-soft);
}
.catalogo-avisos p{
  font-size:.82rem;color:var(--sky-dark);margin:4px 0;line-height:1.5;
}

@media(max-width:640px){
  .servicios__grid{grid-template-columns:1fr;gap:18px}
  .servicio-card{padding:26px 22px}
  .cat-block--destacada{padding:22px 16px}
}

/* ============================================================
   v16 — ONGLETS-CARTES, FICHES DÉPLIABLES, PANIER CHIFFRÉ
   ============================================================ */

/* ---- Rangée d'onglets-cartes ---- */
.cat-tabs{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:12px;margin-bottom:30px;
}
.cat-tab{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:14px 12px;border-radius:16px;text-align:center;
  background:var(--surface);border:2px solid var(--border);
  transition:transform .14s,box-shadow .14s,border-color .14s;
}
.cat-tab:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}
.cat-tab:active{transform:scale(.98)}
.cat-tab.is-active{
  border-color:var(--sky);background:var(--sky-soft);
  box-shadow:var(--shadow-sm);
}
.cat-tab__ico{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;
  background:var(--sky-soft);color:var(--sky);
}
.cat-tab.is-active .cat-tab__ico{background:var(--surface)}
.cat-tab__foto{
  width:62px;height:62px;border-radius:50%;overflow:hidden;
  border:3px solid var(--ochre);box-shadow:var(--shadow-sm);
}
.cat-tab__foto img{width:100%;height:100%;object-fit:cover}
.cat-tab__txt{display:flex;flex-direction:column;gap:2px}
.cat-tab__title{
  font-family:var(--font-display);font-weight:600;font-size:.9rem;
  color:var(--sky);line-height:1.2;
}
.cat-tab__count{font-size:.72rem;color:var(--muted)}
.cat-tab--seleccion{
  border-color:var(--ochre);background:linear-gradient(160deg,#fbf3dd,#f7e9c4);
}
.cat-tab--seleccion.is-active{
  border-color:var(--ochre);background:linear-gradient(160deg,#f7e9c4,#f1dca8);
}
.cat-tab--seleccion .cat-tab__title{color:var(--terra)}

/* ---- Fiches : Description / Ingredients dépliables ---- */
.card__field{
  margin:8px 0;border-top:1px solid var(--border);padding-top:8px;
}
.card__toggle{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;font-family:var(--font-body);font-weight:700;
  font-size:.86rem;color:var(--sky);padding:2px 0;
}
.card__toggle-ico{transition:transform .18s}
.card__field.is-open .card__toggle-ico{transform:rotate(180deg)}
.card__collapse{
  max-height:0;overflow:hidden;transition:max-height .25s ease;
}
.card__field.is-open .card__collapse{max-height:600px}
.card__collapse p{
  font-size:.9rem;color:var(--muted);padding:6px 0 2px;line-height:1.55;
}

/* ---- Prix sur la fiche ---- */
.price-label{font-weight:600;color:var(--muted);font-size:.9rem}
.card__price .amount{font-size:1.15rem;font-weight:700;color:var(--sky)}

/* ---- Panier chiffré ---- */
.cart-item{
  display:flex;gap:12px;align-items:flex-start;
  padding:12px 0;border-bottom:1px solid var(--border);
}
.cart-item img{
  width:60px;height:60px;border-radius:10px;object-fit:cover;flex:none;
}
.cart-item__main{flex:1;min-width:0}
.cart-item__name{font-weight:700;font-size:.94rem;color:var(--ink)}
.cart-item__meta{font-size:.78rem;color:var(--muted);margin:2px 0}
.cart-item__row{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;margin-top:6px;flex-wrap:wrap;
}
.cart-item__precio{display:flex;flex-direction:column;align-items:flex-end}
.cart-item__unit{font-size:.76rem;color:var(--muted)}
.cart-item__sub{font-weight:700;color:var(--sky);font-size:.98rem}
.cart-item__remove{
  flex:none;width:26px;height:26px;border-radius:50%;
  background:var(--sky-soft);color:var(--sky);font-size:.8rem;
  display:grid;place-items:center;
}
.cart-item__remove:hover{background:var(--terra);color:#fff}

/* ---- Bloc total ---- */
.cart-total{
  margin-top:16px;padding:16px;border-radius:14px;background:var(--sky-soft);
}
.cart-total__row{
  display:flex;justify-content:space-between;align-items:center;
  font-size:.92rem;color:var(--sky-dark);padding:3px 0;
}
.cart-total__row--grand{
  margin-top:6px;padding-top:10px;border-top:2px solid var(--border);
  font-family:var(--font-display);font-weight:600;font-size:1.15rem;
  color:var(--sky);
}
.cart-total__monto{font-size:1.35rem}
.cart-total__nota{
  font-size:.76rem;color:var(--muted);margin-top:8px;line-height:1.45;
}

@media(max-width:640px){
  .cat-tabs{grid-template-columns:repeat(2,1fr);gap:9px}
  .cat-tab__foto{width:52px;height:52px}
}

/* ============================================================
   v16-3 — FICHES PROMO, BASCULE, MODALE PARTAGE, PAGE CATALOGUE
   ============================================================ */

/* ---- Header : logo et texte séparés ---- */
.brand__logo{
  background:none;border:none;cursor:pointer;padding:0;
  display:flex;align-items:center;flex-shrink:0;
}
.brand__text{
  background:none;border:none;cursor:pointer;text-align:left;
  display:flex;flex-direction:column;line-height:1.15;
}
.brand__text:hover .brand__name{color:var(--terra)}

/* ---- Grille de fiches promo ---- */
.promo-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:20px;
}
.promo-card{
  display:flex;flex-direction:column;border-radius:var(--radius);
  overflow:hidden;background:var(--surface);
  border:2px solid var(--ochre);box-shadow:var(--shadow-sm);
  transition:transform .15s,box-shadow .15s;
}
.promo-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.promo-card__media{background:#eef4ef;line-height:0}
.promo-card__media img{width:100%;height:auto;display:block}
.promo-card__body{
  display:flex;flex-direction:column;gap:8px;padding:16px;flex:1;
}
.promo-card__tag{
  align-self:flex-start;background:var(--terra);color:#fff;
  font-size:.7rem;font-weight:800;letter-spacing:.06em;
  text-transform:uppercase;padding:4px 10px;border-radius:999px;
}
.promo-card__title{
  font-family:var(--font-display);font-weight:600;font-size:1.15rem;
  color:var(--sky);line-height:1.25;
}
.promo-card__desc{font-size:.9rem;color:var(--muted);line-height:1.5}
.promo-card__precio{
  display:flex;align-items:baseline;gap:10px;margin-top:auto;padding-top:6px;
}
.promo-card__monto{
  font-family:var(--font-display);font-weight:600;
  font-size:1.6rem;color:var(--ochre-dark,#b9762a);
}
.promo-card__pts{
  font-size:.78rem;font-weight:700;color:var(--sky);
  background:var(--sky-soft);padding:3px 9px;border-radius:999px;
}
.promo-card__cta{width:100%;justify-content:center}

/* ---- Cartes-bascule (promos <-> sélection) ---- */
.basc-row{display:flex;justify-content:center;margin:22px 0}
.basc-row--top{margin-bottom:24px}
.basc-card{
  display:flex;align-items:center;gap:14px;
  padding:16px 22px;border-radius:18px;cursor:pointer;
  background:linear-gradient(160deg,#fbf3dd,#f7e9c4);
  border:2px solid var(--ochre);box-shadow:var(--shadow-sm);
  transition:transform .15s,box-shadow .15s;max-width:520px;width:100%;
}
.basc-card:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.basc-card--volver{
  background:var(--sky-soft);border-color:var(--sky);
}
.basc-card__foto{
  width:58px;height:58px;border-radius:50%;overflow:hidden;flex:none;
  border:3px solid var(--ochre);
}
.basc-card__foto img{width:100%;height:100%;object-fit:cover}
.basc-card__txt{display:flex;flex-direction:column;flex:1}
.basc-card__title{
  font-family:var(--font-display);font-weight:600;font-size:1.1rem;color:var(--terra);
}
.basc-card--volver .basc-card__title{color:var(--sky)}
.basc-card__sub{font-size:.82rem;color:var(--muted)}
.basc-card__arrow{font-size:1.5rem;color:var(--ochre);font-weight:700}
.basc-card--volver .basc-card__arrow{color:var(--sky)}

/* ---- Bouton vers le catalogue complet ---- */
.catalogo-cta{
  margin-top:34px;padding:26px;border-radius:var(--radius);
  background:var(--sky-soft);text-align:center;
}
.catalogo-cta p{margin-bottom:14px;color:var(--sky-dark);font-weight:600}

/* ---- Lien retour à l'accueil (page catalogue) ---- */
.volver-inicio{
  display:inline-block;margin-bottom:16px;font-weight:700;
  color:var(--sky);font-size:.95rem;
}
.volver-inicio:hover{color:var(--terra)}
.site-footer__home{
  display:inline-block;margin:8px 0;color:var(--cream);
  font-weight:700;text-decoration:underline;
}

/* ---- Modale partage WhatsApp ---- */
.modal{
  position:fixed;inset:0;z-index:120;
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.modal[hidden]{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(20,40,30,.55)}
.modal__box{
  position:relative;background:var(--surface);border-radius:var(--radius);
  padding:30px 26px;max-width:420px;width:100%;
  box-shadow:var(--shadow);text-align:center;
}
.modal__close{
  position:absolute;top:12px;right:12px;width:32px;height:32px;
  border-radius:50%;background:var(--sky-soft);color:var(--sky);
  display:grid;place-items:center;font-size:.9rem;
}
.modal__box h3{
  font-family:var(--font-display);font-weight:600;font-size:1.3rem;
  color:var(--sky);margin-bottom:10px;
}
.modal__box p{color:var(--muted);margin-bottom:20px;line-height:1.55}
.modal__actions{display:flex;flex-direction:column;gap:10px}
.btn--wa{
  background:var(--wa);color:#0a3d1f;font-weight:700;
  padding:12px 20px;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
}
.btn--wa:hover{background:#1ec25d}
.btn--ghost{
  background:transparent;border:2px solid var(--border);color:var(--muted);
  padding:10px 20px;border-radius:12px;font-weight:600;
}
.btn--ghost:hover{border-color:var(--sky);color:var(--sky)}

@media(max-width:640px){
  .promo-grid{grid-template-columns:1fr;gap:16px}
  .basc-card{padding:14px 16px}
}

/* ============================================================
   v16-4 — CARTE SÉLECTION PATCHWORK
   ============================================================ */
.seleccion-card{
  border:3px solid var(--ochre);
  background:linear-gradient(165deg,#fbf1d6,#f5e3b4);
  position:relative;
}
.seleccion-card:hover{
  transform:translateY(-4px);
  box-shadow:0 16px 34px -10px rgba(180,120,30,.45);
}
.seleccion-card__media{
  position:relative;background:var(--sky);padding:0;overflow:hidden;
}
/* patchwork 2x2 de photos produits */
.seleccion-card__grid{
  display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;
  gap:3px;aspect-ratio:1/1;
}
.seleccion-card__cell{background:#fff;overflow:hidden}
.seleccion-card__cell img{width:100%;height:100%;object-fit:cover}
/* photo ronde de Mamita Julia au centre du patchwork */
.seleccion-card__foto{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:38%;aspect-ratio:1/1;border-radius:50%;overflow:hidden;
  border:5px solid #fff;box-shadow:0 6px 18px -4px rgba(0,0,0,.5);
}
.seleccion-card__foto img{width:100%;height:100%;object-fit:cover}
.seleccion-card__tag{
  background:var(--ochre);color:#3a2a05;
}
.seleccion-card__cta{
  background:var(--ochre);color:#3a2a05;border:none;
}
.seleccion-card__cta:hover{background:var(--terra);color:#fff}

/* v16-4 — section Servicios à une seule carte */
.servicios__grid--solo{
  grid-template-columns:1fr;max-width:520px;
}

/* v16-7 — deuxième ligne centrée du header */
.site-header__tagline{
  text-align:center;
  font-size:.74rem;
  color:var(--muted);
  padding:5px 14px 7px;
  border-top:1px solid var(--border);
  background:rgba(250,246,236,.6);
}

/* ============================================================
   v16-11 — BANDEAU PRODUITS TEOMA + BANDEAU MERCADO
   ============================================================ */
/* la carte TEOMA reprend le format large de la fiche massage */
.servicios__banda{ margin-top:4px; }
.servicios__banda .service{ width:100%; }
/* différenciation couleur : carte TEOMA en bleu clair */
.service--teoma{
  background:linear-gradient(150deg,#eaf3f7,#dcebf2 130%);
  border:1px solid #cfe2ea;
}
.service--teoma .service__media{ background:#fff; display:flex; align-items:center; }
/* L'image TEOMA est une affiche verticale complète : on l'affiche
   EN ENTIER (pas de recadrage), pour que le visage de Mamita Julia
   reste toujours visible. */
.service--teoma .service__media img{
  height:auto; min-height:0; max-height:none;
}
.service--teoma .service__body h4{ color:var(--deep); }

/* bandeau pleine largeur du Mercado Modelo */
.mercado-banda{
  position:relative;
  background-image:url("../images/mercado-andahuaylas.webp");
  background-size:cover;
  background-position:center 60%;
  min-height:230px;
  display:flex; align-items:center;
}
.mercado-banda__overlay{
  width:100%;
  /* Voile JAUNE PÂLE et bien transparent : la photo du marché
     reste nettement visible derrière, le bandeau reste discret. */
  background:linear-gradient(90deg,
    rgba(246,226,156,.66) 0%,
    rgba(246,226,156,.42) 48%,
    rgba(246,226,156,.06) 100%);
  padding:34px 0;
}
.mercado-banda__txt{
  max-width:1180px; margin:0 auto; padding:0 22px;
  max-width:620px; margin-left:max(22px,calc((100% - 1180px)/2 + 22px));
}
/* Halo blanc net autour du texte : le rend lisible même sur la
   photo, sans avoir besoin d'un voile opaque. */
.mercado-banda__kicker{
  display:inline-block; color:#3d2204; font-size:.8rem;
  font-weight:800; letter-spacing:.13em; text-transform:uppercase;
  margin-bottom:7px;
  text-shadow:0 0 5px rgba(255,255,255,.95),0 1px 2px rgba(255,255,255,.9);
}
.mercado-banda__txt h2{
  color:var(--ink); font-size:1.62rem; line-height:1.2; margin-bottom:8px;
  font-weight:700;
  text-shadow:0 0 6px rgba(255,255,255,.95),0 1px 2px rgba(255,255,255,.9);
}
.mercado-banda__txt p{
  color:var(--ink); font-size:1rem; line-height:1.55; margin:0;
  font-weight:700;
  text-shadow:0 0 5px rgba(255,255,255,.95),0 1px 2px rgba(255,255,255,.9);
}
@media (max-width:680px){
  .mercado-banda{ min-height:300px; background-position:center; }
  .mercado-banda__overlay{
    background:linear-gradient(180deg,
      rgba(246,226,156,.34) 0%,
      rgba(246,226,156,.80) 60%);
    padding:26px 0;
  }
  .mercado-banda__txt{
    margin:0 auto; padding:0 18px; max-width:100%; text-align:center;
  }
  /* Sur mobile : texte nettement plus gros et plus gras, halo blanc
     renforcé — l'écriture reste bien lisible sur la photo. */
  .mercado-banda__kicker{
    font-size:.82rem; font-weight:800;
    text-shadow:0 0 7px #fff,0 0 4px #fff,0 1px 2px #fff;
  }
  .mercado-banda__txt h2{
    font-size:1.5rem; font-weight:700;
    text-shadow:0 0 8px #fff,0 0 4px #fff,0 1px 2px #fff;
  }
  .mercado-banda__txt p{
    font-size:1.04rem; font-weight:700;
    text-shadow:0 0 7px #fff,0 0 4px #fff,0 1px 2px #fff;
  }
}
