/* ============================================================
   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:600;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;
  display:flex;align-items:center;gap:16px;
  padding:10px 20px;
  background:rgba(250,246,236,.92);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.brand{display:flex;align-items:center;gap:11px;flex-shrink:0}
.brand__icon{border-radius:11px}
.brand__text{display:flex;flex-direction:column;line-height:1.15}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:1.32rem;color:var(--sky)}
.brand__sub{font-size:.66rem;color:var(--muted);max-width:200px}

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

.header-actions{display:flex;align-items:center;gap:10px;margin-left:auto}
.main-nav + .header-actions{margin-left:14px}

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

.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;
}
.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);
}

.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}
.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;
}
.hero__photo img{width:100%;aspect-ratio:1;object-fit:cover}
.hero__media::before{
  content:"";position:absolute;inset:-14px -10px 30px 30px;z-index:1;
  background:var(--ochre);opacity:.32;
  border-radius:46% 54% 50% 50%/56% 50% 50% 44%;
}
.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)}

/* ---- 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:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.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}

/* ============================================================
   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-name-field{margin-bottom:12px}
.cart-name-field label{display:block;font-size:.82rem;font-weight:700;color:var(--muted);margin-bottom:5px}
.cart-name-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-name-field input:focus{outline:none;border-color:var(--ochre)}
.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)}

/* ============================================================
   WHATSAPP FLOTTANT
   ============================================================ */
.fab-wa{
  position:fixed;right:18px;bottom:18px;z-index:55;
  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);
}
.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}
  .main-nav{
    position:absolute;top:100%;left:0;right: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}
  .header-actions{margin-left:auto}
  .main-nav + .header-actions{margin-left:auto}
  .grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:13px}
  .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 1fr}
}

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