:root{
  --bg:#fff; --ink:#0e1b16; --muted:#54625c;
  --brand:#0F3E2E; --brand2:#4CA34D;
  --line:rgba(14,27,22,.12);
  --shadow:0 18px 45px rgba(14,27,22,.08);
  --radius:18px; --radius2:24px;
  --container:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--ink);line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(var(--container),calc(100% - 40px));margin:0 auto}
.skip{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip:focus{left:16px;top:16px;width:auto;height:auto;padding:10px 12px;background:#fff;border:1px solid var(--line);border-radius:12px;z-index:999}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* Header */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.84);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header__inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}

/* ✅ Logo un poquito más grande */
.brand__logo{
  height:100px;
  width:auto;
  object-fit:contain;
}

.nav{display:flex;align-items:center}
.nav__toggle{display:none;background:transparent;border:1px solid var(--line);border-radius:14px;width:44px;height:44px}
.nav__toggleLines{display:block;width:18px;height:2px;background:var(--ink);margin:0 auto;position:relative}
.nav__toggleLines::before,.nav__toggleLines::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.nav__toggleLines::before{top:-6px}.nav__toggleLines::after{top:6px}

.nav__menu{display:flex;align-items:center;gap:18px}
.nav__link{color:var(--muted);font-weight:500;padding:10px 10px;border-radius:12px}
.nav__link:hover{background:rgba(15,62,46,.06);color:var(--ink)}
.nav__cta{display:flex;align-items:center;gap:10px;margin-left:6px}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:10px 14px;border-radius:14px;border:1px solid transparent;font-weight:600;transition:transform .15s ease,box-shadow .15s ease,background .15s ease,border-color .15s ease;cursor:pointer}
.btn:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(14,27,22,.10)}
.btn--lg{padding:12px 18px;border-radius:16px}
.btn--primary{background:linear-gradient(135deg,var(--brand) 0%,#0b5a3c 52%,var(--brand2) 120%);color:#fff}
.btn--secondary{background:#fff;border-color:var(--line)}
.btn--ghost{background:rgba(15,62,46,.06);border-color:rgba(15,62,46,.12);color:var(--brand)}

/* Sections */
.section{padding:76px 0}
.section--alt{background:linear-gradient(180deg,#fbfcfb 0%,#f6f8f7 100%);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section__head{margin-bottom:22px}
.section__head h2{margin:0 0 8px;font-size:34px;letter-spacing:-.02em}
.muted{color:var(--muted)}
.tiny{font-size:12px}
.pill{display:inline-flex;padding:8px 12px;border:1px solid rgba(15,62,46,.16);background:rgba(15,62,46,.06);border-radius:999px;font-weight:600;color:var(--brand);margin:0 0 14px}

/* Hero */
.hero{padding-top:62px}
.hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:34px;align-items:center}
.hero h1{font-size:clamp(38px,4.2vw,56px);line-height:1.06;letter-spacing:-.03em;margin:0 0 14px}
.lead{font-size:16px;color:var(--muted);margin:0 0 18px;max-width:52ch}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin:8px 0 18px}
.trust{display:flex;gap:12px;flex-wrap:wrap}
.trust__item{background:rgba(255,255,255,.9);border:1px solid var(--line);border-radius:16px;padding:12px 14px;min-width:150px}
.trust__kpi{display:block;font-weight:800;color:var(--brand)}
.trust__label{display:block;font-size:12px;color:var(--muted)}

/* Visual */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);box-shadow:var(--shadow);overflow:hidden}
.card--photo{position:relative}
.card__badge{position:absolute;left:14px;top:14px;padding:8px 10px;background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:999px;font-size:12px;color:var(--muted)}

/* ✅ Flask: la imagen del CSS tiene que apuntar a /static/... */
.photo{
  height:360px;
  background-image:url("/static/assets/camioneta.png");
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  position:relative;
}
.photo::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(
    180deg,
    rgba(15,62,46,.15) 0%,
    rgba(15,62,46,.05) 40%,
    rgba(15,62,46,.15) 100%
  );
}

.miniStats{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
.miniStats__card{background:rgba(255,255,255,.95);border:1px solid var(--line);border-radius:var(--radius);padding:12px 14px}
.miniStats__title{display:block;font-weight:700}
.miniStats__text{display:block;font-size:12px;color:var(--muted);margin-top:4px}

/* Steps */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px}
.step__num{width:36px;height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:rgba(15,62,46,.08);border:1px solid rgba(15,62,46,.14);color:var(--brand);font-weight:800}
.step h3{margin:10px 0 6px}
.step p{margin:0;color:var(--muted)}
.ctaPanel{margin-top:16px;display:flex;justify-content:space-between;align-items:center;gap:16px;background:linear-gradient(135deg,rgba(15,62,46,.10),rgba(76,163,77,.10));border:1px solid rgba(15,62,46,.14);border-radius:var(--radius2);padding:18px}

/* Cards grid */
.gridCards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:16px}
.gcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px}
.gcard h3{margin:0 0 6px}
.gcard p{margin:0;color:var(--muted)}

/* Zones */
.zones{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;margin-top:16px}
.zones__highlights{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px;margin-bottom:32px;max-width:640px}
.zones__highlights .chip{display:flex;align-items:center;gap:10px;font-weight:600;padding:12px 18px;border-radius:14px;background:#f4f7f6;border:1px solid #e2e8e5;transition:all .18s ease}
.zones__highlights .chip:hover{transform:translateY(-2px);box-shadow:0 6px 14px rgba(0,0,0,.08)}
.chip__icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;background:#0F3E2E;color:#fff;font-size:14px;flex-shrink:0}
.zones__card{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
.chip{font-size:12px;padding:8px 10px;border-radius:999px;border:1px solid rgba(15,62,46,.14);background:rgba(15,62,46,.06);color:var(--brand);font-weight:600}
.schedule{display:grid;gap:10px;margin-top:10px}
.schedule__item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--line);border-radius:14px;background:#f6f8f7}
.schedule__day{width:40px;height:36px;display:inline-flex;align-items:center;justify-content:center;border-radius:12px;background:#fff;border:1px solid var(--line);font-weight:800;color:var(--brand)}
.schedule__text{color:var(--muted);font-size:13px}

/* Two columns */
.twoCol{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px}
.feature{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px;margin-bottom:14px}
.feature h3{margin:0 0 6px}.feature p{margin:0;color:var(--muted)}
.quote{background:linear-gradient(135deg,rgba(15,62,46,.10),rgba(76,163,77,.10));border:1px solid rgba(15,62,46,.14);border-radius:var(--radius2);padding:18px}
.quote p{margin:0;font-weight:600}
.quote__by{display:block;margin-top:10px;color:var(--muted);font-size:12px}
.ctaBox{margin-top:14px;background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px}

/* FAQ */
.faq{display:grid;gap:12px;margin-top:16px}
.faq__item{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:14px 16px}
.faq__item summary{cursor:pointer;font-weight:700}
.faq__item p{margin:10px 0 0;color:var(--muted)}

/* Contact */
.contact{display:grid;grid-template-columns:1.1fr .9fr;gap:14px;margin-top:16px}
.form{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px}
.form label{display:block;font-weight:600;font-size:13px}
.form input,.form textarea,.form select{width:100%;margin-top:6px;padding:12px;border-radius:14px;border:1px solid var(--line);font:inherit}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:rgba(15,62,46,.35);box-shadow:0 0 0 4px rgba(76,163,77,.12)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form__actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:12px}
.contact__side{display:grid;gap:12px}
.sideCard{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px}

/* Final CTA */
.section--final{padding:60px 0;background:
  radial-gradient(900px 400px at 20% 10%,rgba(76,163,77,.14),transparent 55%),
  radial-gradient(900px 400px at 80% 40%,rgba(15,62,46,.10),transparent 55%),
  linear-gradient(180deg,#fff,#fbfcfb);
  border-top:1px solid var(--line)
}
.finalCta{display:flex;justify-content:space-between;align-items:center;gap:16px;background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:18px;box-shadow:var(--shadow)}
.finalCta h2{margin:0 0 6px}

/* Footer */
.footer{padding:34px 0 18px;border-top:1px solid var(--line);background:#fff}
.footer__grid{display:flex;align-items:flex-start;justify-content:space-between;gap:18px}
.footer__logo{height:40px;width:auto}
.footer__cols{display:flex;gap:40px;flex-wrap:wrap}
.footer__col h4{margin:0 0 10px}
.footer__col a{display:block;color:var(--muted);padding:6px 0}
.footer__col a:hover{color:var(--ink)}
.footer__bottom{
  display:grid;
  grid-template-columns: 1fr auto 1fr;
  align-items:center;
  gap:12px;
  padding-top:18px;
  margin-top:18px;
  border-top:1px solid var(--line);
}

.footer__bottom > :first-child{ justify-self:start; }
.footer__bottom > .site-dev-signature{ justify-self:center; }
.footer__bottom > :last-child{ justify-self:end; }

/* Reveal */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .55s ease,transform .55s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* Responsive */
@media (max-width:920px){
  .hero__grid{grid-template-columns:1fr}
  .photo{height:300px}
  .steps{grid-template-columns:1fr}
  .gridCards{grid-template-columns:1fr}
  .zones{grid-template-columns:1fr}
  .twoCol{grid-template-columns:1fr}
  .contact{grid-template-columns:1fr}
  .form__row{grid-template-columns:1fr}
  .finalCta{flex-direction:column;align-items:flex-start}
  .footer__grid{flex-direction:column}
  .footer__cols{gap:18px}
}

@media (max-width:860px){
  .nav__toggle{display:inline-flex;align-items:center;justify-content:center}
  .nav__menu{
    position:absolute;right:20px;top:86px;width:min(360px,calc(100vw - 40px));
    flex-direction:column;align-items:stretch;gap:8px;
    background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:18px;
    padding:12px;box-shadow:var(--shadow);display:none
  }
  .nav__menu.is-open{display:flex}
  .nav__cta{margin-left:0;display:grid;grid-template-columns:1fr}
  .nav__link{padding:12px}
}


/* ---------- Shop (productos + carrito) ---------- */
.shopHead{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;margin:22px 0}
.shopHead h1{margin:0;font-size:34px;letter-spacing:-.02em}
.shopHead .muted{margin:6px 0 0}

.shopGrid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
@media (max-width:1100px){.shopGrid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:860px){.shopGrid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){.shopGrid{grid-template-columns:1fr}}

.pcard{background:#fff;border:1px solid var(--line);border-radius:var(--radius2);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;height:100%}
.pcard__body{padding:14px;display:flex;flex-direction:column}

/* Título */
.pcard__title{margin:0 0 6px;font-size:16px;line-height:1.2;font-weight:800}

/* ✅ Antes: min-height:30px generaba espacio cuando no había descripción */
.pcard__desc{
  margin:0 0 8px;
  color:var(--muted);
  font-size:12px;
  min-height:0;
}

/* Imagen del producto */
.pcard__img{
  background:#fff;
  border-bottom:1px solid var(--line);
  height:220px;
  padding:18px 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.pcard__img img{
  max-width:100%;
  max-height:100%;
  width:auto;
  height:auto;
  object-fit:contain;
  background:#fff;
  display:block;
}

/* Variantes (chips): ✅ compactas, sin aire fantasma */
.variantRow{
  display:flex;
  flex-wrap:wrap;
  gap:6px;               /* ✅ menos separación */
  margin:8px 0 10px;     /* ✅ elimina el hueco rojo */
  min-height:42px;       /* ✅ solo 1 fila “mínima” */
  max-height:92px;       /* ✅ si hay muchas, aparece scroll */
  overflow:auto;
  padding-right:4px;
}
.variantRow::-webkit-scrollbar{width:8px}
.variantRow::-webkit-scrollbar-thumb{background:rgba(15,62,46,.18);border-radius:999px}
.variantRow::-webkit-scrollbar-track{background:transparent}

.variantRow input{position:absolute;opacity:0;pointer-events:none}
.vbtn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:8px 10px;border-radius:999px;border:1px solid rgba(15,62,46,.16);
  background:rgba(15,62,46,.06);color:var(--brand);font-weight:700;font-size:12px;
  cursor:pointer;user-select:none;
}
.variantRow input:checked + .vbtn{
  background:linear-gradient(135deg,var(--brand) 0%,#0b5a3c 52%,var(--brand2) 120%);
  color:#fff;border-color:transparent;
}

/* Acciones: ✅ sin margin-top:auto para que no genere hueco rojo */
.pcard__actions{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:6px;        /* ✅ pegado pero con aire mínimo */
}

.qty{width:120px;max-width:100%;padding:10px 12px;border-radius:14px;border:1px solid var(--line);font:inherit}
.qty:focus{outline:none;border-color:rgba(15,62,46,.35);box-shadow:0 0 0 4px rgba(76,163,77,.12)}

/* Cart */
.cartList{display:grid;gap:10px;margin-top:14px}
.cartItem{display:flex;gap:12px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius2);padding:12px;box-shadow:var(--shadow)}
.cartItem__img{width:62px;height:62px;border-radius:16px;overflow:hidden;background:#f6f8f7;border:1px solid var(--line)}
.cartItem__img img{width:100%;height:100%;object-fit:contain}
.cartItem__main{flex:1}
.cartItem__name{margin:0;font-weight:900}
.cartItem__meta{margin:4px 0 0;color:var(--muted);font-size:12px}
.cartBar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-top:14px}

/* Top bar info */
.topRight{display:flex;align-items:center;gap:14px}
.userChip{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;border:1px solid var(--line);border-radius:999px;background:#fff;
  font-weight:800;
}
.badge{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:22px;height:22px;padding:0 6px;border-radius:999px;
  background:var(--brand2);color:#fff;font-weight:900;font-size:12px;
}

/* Fav button */
.favBtn{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:999px;
  border:1px solid var(--line);background:#fff;cursor:pointer;
}
.favBtn[data-on="1"]{border-color:rgba(76,163,77,.35);box-shadow:0 0 0 4px rgba(76,163,77,.12)}
.favBtn svg{width:18px;height:18px}

/* Toast / mensajes */
.toasts{position:fixed;top:18px;right:18px;z-index:9999;display:grid;gap:10px;max-width:360px}
.toast{
  background:#fff;border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:12px 14px;display:flex;gap:10px;align-items:flex-start;
  animation:toastIn .18s ease-out;
}
.toast__dot{width:10px;height:10px;border-radius:999px;margin-top:6px;background:var(--brand2)}
.toast--success .toast__dot{background:#21b36b}
.toast--info .toast__dot{background:#3b82f6}
.toast--error .toast__dot{background:#ef4444}
.toast__text{font-weight:700}
.toast__close{margin-left:auto;border:none;background:transparent;cursor:pointer;font-weight:900;opacity:.6}
.toast__close:hover{opacity:1}
@keyframes toastIn{from{transform:translateY(-6px);opacity:0}to{transform:translateY(0);opacity:1}}

/* Cantidad resaltada en carrito */
.qtyPill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 10px;border-radius:999px;
  background:rgba(15,62,46,.08);border:1px solid rgba(15,62,46,.14);
  font-weight:900;color:var(--brand);
}
.cartTopBar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin:12px 0 14px}
.itemsPill{
  display:inline-flex;gap:8px;align-items:center;
  padding:8px 12px;border-radius:999px;border:1px solid var(--line);background:#fff;font-weight:900;
}

/* Pill para variante (presentación) */
.varPill{
  display:inline-flex;align-items:center;justify-content:center;
  padding:4px 10px;border-radius:999px;
  background:rgba(76,163,77,.10);
  border:1px solid rgba(76,163,77,.22);
  font-weight:900;color:var(--brand);
  margin-left:8px;
}

/* ================= Footer ligero (pantallas internas) ================= */

.footer--lite{
  margin-top:60px;
  padding:14px 0;
  border-top:1px solid var(--line);
  background:#fff;
  font-size:13px;
}

.footer__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;

  /* 🔑 evita salto de línea */
  white-space:nowrap;
}

.footer__copy{
  color:var(--muted);
}

.footer__top{
  color:var(--brand);
  font-weight:600;
}

/* ------------------ LA Dev Labs signature (premium, minimal) ------------------ */
.site-dev-signature{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  vertical-align:middle;
  line-height:1;
  margin:0 6px;
}

.site-dev-signature__link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 8px;
  border-radius:10px;
  color:inherit;
  text-decoration:none;
  background:transparent;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,opacity .18s ease;
  -webkit-tap-highlight-color: transparent;
}

.site-dev-signature__link:focus-visible{outline:2px solid rgba(76,163,77,.18);outline-offset:3px;border-radius:10px}

.site-dev-signature__label{
  font-size:12px;
  color:var(--muted);
  font-weight:600;
  white-space:nowrap;
}

.site-dev-signature__text{
  font-size:13px;
  color:var(--ink);
  font-weight:700;
  white-space:nowrap;
}

.site-dev-signature__logo{
  display:inline-block;
  width:auto;
  height:18px; /* desktop default, scaled on mobile */
  object-fit:contain;
  flex:0 0 auto;
  transition:transform .18s ease,opacity .18s ease,filter .18s ease;
  filter:drop-shadow(0 2px 6px rgba(11,20,16,.04));
}

/* Desktop hover: subtle lift and faint background */
.site-dev-signature__link:hover{
  transform:translateY(-1px);
  box-shadow:0 8px 20px rgba(11,20,16,.06);
  background:rgba(15,62,46,.03);
}

/* Keep opacity/focus states subtle */
.site-dev-signature__link:active{transform:translateY(0)}

/* Mobile: compact — only logo visible and centered */
@media (max-width:640px){
  .footer__inner{white-space:normal}

  /* Force compact signature: only logo visible and centered */
  .site-dev-signature{
    display:flex !important;
    align-items:center;
    justify-content:center;
    margin:0;padding:0;
  }

  .site-dev-signature__link{
    display:flex !important;
    align-items:center;
    justify-content:center;
    gap:0 !important;
    padding:6px !important;
    min-width:44px;min-height:44px;
    white-space:nowrap !important;
    flex-wrap:nowrap !important;
  }

  /* hide label and text entirely on mobile */
  .site-dev-signature__label,
  .site-dev-signature__text{
    display:none !important;
    visibility:hidden !important;
    width:0 !important;
    height:0 !important;
    overflow:hidden !important;
    margin:0 !important;
    padding:0 !important;
  }

  /* logo a tamaño premium en mobile */
  .site-dev-signature__logo{
    width:26px !important;
    height:26px !important;
    max-width:none !important;
    object-fit:contain;
  }

  .site-dev-signature__link:active{transform:scale(.97)}
}

/* Ensure the signature doesn't force wrapping or push other footer items */
.footer__inner > .site-dev-signature{flex:0 0 auto}

/* End signature */

/* ------------------ FINAL MOBILE OVERRIDE (force logo-only signature) ------------------ */
@media (max-width: 640px) {
  .site-dev-signature__label,
  .site-dev-signature__text {
    display: none !important;
  }

  .site-dev-signature,
  .site-dev-signature__link {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 0 !important;
    white-space: nowrap !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .site-dev-signature__link {
    min-width: 32px !important;
    min-height: 32px !important;
  }

  .site-dev-signature__logo,
  .site-dev-signature__logo--footer {
    width: 26px !important;
    height: 26px !important;
    min-width: 26px !important;
    min-height: 26px !important;
    max-width: 26px !important;
    max-height: 26px !important;
    object-fit: contain !important;
  }

  /* Prevent stacking the public footer into a single column on mobile */
  .footer__bottom {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
    gap: 8px !important;
    text-align: center !important;
  }

  .footer__bottom > :first-child {
    justify-self: start !important;
  }

  .footer__bottom > .site-dev-signature {
    justify-self: center !important;
  }

  .footer__bottom > :last-child {
    justify-self: end !important;
  }

  /* Ensure internal footer (.footer__inner) uses the same centered layout */
  .footer__inner {
    display: grid !important;
    grid-template-columns: 1fr auto 1fr !important;
    align-items: center !important;
    gap: 8px !important;
  }

  .footer__left {
    justify-self: start !important;
  }

  .footer__top {
    justify-self: end !important;
  }

  /* Tap interaction premium */
  .site-dev-signature__link:active {
    transform: scale(.97);
  }
}

/* End final override */

.footer__top:hover{
  text-decoration:underline;
}

/* 📱 En pantallas muy chicas permitimos 2 líneas, pero alineadas */
@media (max-width:520px){
  .footer__inner{
    flex-direction:column;
    white-space:normal;
    gap:6px;
  }
}

/* Floating WhatsApp button */
.floating-wa{
  position:fixed;
  right:24px;
  bottom:calc(24px + env(safe-area-inset-bottom));
  width:64px;
  height:64px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(180deg,#17a65a 0%, #0f5b3b 100%);
  color:#fff;
  box-shadow:0 12px 30px rgba(6,40,27,0.18);
  z-index:1300;
  transition:opacity .36s cubic-bezier(.2,.8,.2,1), transform .36s cubic-bezier(.2,.8,.2,1), box-shadow .18s ease;
  opacity:0;
  transform:translateY(10px) scale(.96);
  visibility:hidden;
  pointer-events:none;
}
.floating-wa.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  visibility:visible;
  pointer-events:auto;
}
.floating-wa__icon svg{width:28px;height:28px;display:block}
.floating-wa:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 18px 36px rgba(6,40,27,0.22)}
.floating-wa:active{transform:translateY(0) scale(.98)}

@media (max-width:520px){
  .floating-wa{right:16px;bottom:calc(16px + env(safe-area-inset-bottom));width:52px;height:52px}
  .floating-wa__icon svg{width:22px;height:22px}
}

/* Breadcrumb */
.crumbs{
  display:flex;
  align-items:center;
  gap:10px;
  margin:12px 0 18px;
  color:var(--muted);
  font-weight:700;
}
.crumbs__link{
  color:var(--brand);
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(15,62,46,.14);
  background:rgba(15,62,46,.06);
}
.crumbs__link:hover{ text-decoration:underline; }
.crumbs__sep{ opacity:.6; }
.crumbs__current{
  color:var(--ink);
  font-weight:900;
}

/* Footer estado (chips) */
.footer__left{
  display:flex;
  align-items:center;
  gap:10px;
}
.footer__meta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:var(--muted);
}
.footerChip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(15,62,46,.12);
  background:rgba(15,62,46,.05);
  color:var(--brand);
  font-weight:800;
  font-size:12px;
}

.site-dev-signature{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap: 6px;
  opacity: .62;
  font-size: 11px;
  line-height: 1;
  white-space: nowrap !important;
  text-align: center;
  min-width: max-content !important;
  width: max-content !important;
  flex: 0 0 auto !important;
  max-width: 100%;
  transition: opacity .2s ease, transform .2s ease;
}

.site-dev-signature__label{
  color: var(--muted);
  font-weight: 600;
  font-size: 11px;
  line-height: 1;
  white-space: nowrap;
  flex: 0 0 auto;
}

.site-dev-signature__link{
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:6px !important;
  color: #2b4137;
  text-decoration: none;
  font-weight: 700;
  opacity: .82;
  line-height: 1;
  white-space:nowrap !important;
  min-width: 0;
  flex-wrap:nowrap !important;
  width: auto !important;
  max-width: none !important;
  flex: 0 0 auto;
  transition: opacity .2s ease, transform .2s ease, color .2s ease;
}

.site-dev-signature__logo{
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  display: block;
  object-fit: contain;
  object-position: center;
  flex: 0 0 auto;
}

.site-dev-signature__logo--footer{
  height: 18px !important;
  min-height: 18px !important;
  max-height: 18px !important;
}

.site-dev-signature__text{
  font-size: 11px;
  line-height: 1;
  letter-spacing: .01em;
  white-space:nowrap !important;
  flex: 0 0 auto;
}

.site-dev-signature__label{
  white-space:nowrap !important;
}

.site-dev-signature:hover,
.site-dev-signature:focus-within{
  opacity: .9;
}

.site-dev-signature__link:hover,
.site-dev-signature__link:focus-visible{
  opacity: 1;
  color: var(--brand);
  transform: translateY(-1px);
}

body.cart-page .site-dev-signature,
body.checkout-page .site-dev-signature{
  opacity: .5;
}

body.cart-page .site-dev-signature__link,
body.checkout-page .site-dev-signature__link{
  opacity: .7;
}

@media (max-width: 920px){
  .footer__bottom{
    grid-template-columns:1fr;
    justify-items:center;
    text-align:center;
  }

  .footer__bottom > :first-child,
  .footer__bottom > .site-dev-signature,
  .footer__bottom > :last-child{
    justify-self:center;
  }

  .site-dev-signature{
    gap: 5px;
    font-size: 10px;
    opacity: .56;
  }

  .site-dev-signature__label{
    font-size: 10px;
  }

  .site-dev-signature__logo{
    width: auto !important;
    max-width: none !important;
  }

  .site-dev-signature__logo--footer{
    height: 15px !important;
    min-height: 15px !important;
    max-height: 15px !important;
  }

  .site-dev-signature__text{
    font-size: 10px;
  }
}

@media (max-width: 640px){
  .site-dev-signature__logo--footer{
    height: 15px !important;
    min-height: 15px !important;
    max-height: 15px !important;
  }
}

/* Header de páginas internas (Mis pedidos / Carrito / etc) */
.pageHead{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:14px;
  margin:22px 0 10px;
}
.pageHead h1{
  margin:0;
  font-size:34px;
  letter-spacing:-.02em;
}
.pageHead .muted{
  margin:6px 0 0;
}
.pageHead__actions{
  display:flex;
  gap:10px;
  align-items:center;
}

/* Breadcrumb: siempre debajo del título */
.crumbs{
  display:flex;
  align-items:center;
  gap:10px;
  margin:8px 0 18px;   /* 👈 debajo del header */
  color:var(--muted);
  font-weight:700;
}

.emptyCard{
  background:#fff;
  border:1px solid var(--line);
  border-radius:var(--radius2);
  padding:16px 18px;
  color:var(--muted);
}

.productImage{
  height:160px;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:12px 0;
  background:#fff;
}

.productImage img{
  max-height:140px;
  max-width:100%;
  object-fit:contain;
}

/* ------------------ Carrito lateral tipo Amazon ------------------ */
.hasSideCart main.container{
  padding-right: 360px; /* espacio para que no tape contenido */
}
@media (max-width: 1100px){
  .hasSideCart main.container{ padding-right: 0; }
}

.sideCart{
  position: fixed;
  top: 94px; /* debajo del header sticky */
  right: 18px;
  width: 330px;
  max-height: calc(100vh - 120px);
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow);
  z-index: 60;
  overflow: hidden;
}

.sideCart--hidden{ display:none; }

.sideCart__head{
  padding: 12px 14px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  border-bottom: 1px solid var(--line);
  background: rgba(15,62,46,0.03);
}

.sideCart__title{ font-weight: 900; }
.sideCart__meta{ color: var(--muted); font-size: 12px; font-weight: 800; }

.sideCart__list{
  padding: 10px;
  overflow: auto;
  display: grid;
  gap: 10px;
}

.sideCartItem{
  display:flex;
  gap:10px;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 10px;
  background:#fff;
}

.sideCartItem__img{
  width: 54px;
  height: 54px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #f6f8f7;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.sideCartItem__img img{
  width:100%;
  height:100%;
  object-fit: contain;
}

.sideCartItem__mid{ flex:1; min-width:0; }
.sideCartItem__name{
  font-weight: 900;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sideCartItem__var{
  margin-top: 2px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 700;
}

.sideCartItem__qty{
  margin-top: 8px;
  display:flex;
  align-items:center;
  gap: 8px;
}

.qtyBtn{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: rgba(15,62,46,0.04);
  cursor:pointer;
  font-weight: 900;
}
.qtyBtn:hover{ background: rgba(15,62,46,0.08); }

.qtyNum{
  font-weight: 900;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(15,62,46,0.14);
  background: rgba(15,62,46,0.06);
  color: var(--brand);
}

.sideCartItem__rm{
  border:none;
  background: transparent;
  cursor:pointer;
  opacity: .8;
}
.sideCartItem__rm:hover{ opacity: 1; }

.sideCart__foot{
  padding: 12px;
  border-top: 1px solid var(--line);
  display:flex;
  gap:10px;
  background:#fff;
}
.sideCart__clear{ flex:1; }
.sideCart__go{ flex:1; }

/* Mobile: el carrito lateral no se muestra */
@media (max-width: 1100px){
  .sideCart{ display:none !important; }
}


/* =========================
   SideCart (carrito lateral)
========================= */
.sideCart{
  position: fixed;
  top: 84px;              /* ajustá según tu header */
  right: 18px;
  width: 360px;
  max-width: calc(100vw - 36px);
  height: calc(100vh - 110px);  /* deja aire arriba/abajo */
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 18px 45px rgba(0,0,0,.10);
  display: flex;               /* CLAVE */
  flex-direction: column;      /* CLAVE */
  overflow: hidden;            /* CLAVE: que no “escape” el footer */
  z-index: 999;
}

.sideCart.is-hidden{ display:none; }
.sideCart.is-open{ display:flex; }

.sideCart__header{
  flex: 0 0 auto;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 12px;
  border-bottom: 1px solid var(--line);
  background: #fff;
}

.sideCart__body{
  flex: 1 1 auto;            /* CLAVE: ocupa el alto disponible */
  overflow-y: auto;          /* CLAVE: scroll SOLO acá */
  padding: 12px;
}

.sideCart__footer{
  flex: 0 0 auto;            /* CLAVE */
  padding: 12px;
  border-top: 1px solid var(--line);
  background: #fff;
  display:flex;
  gap: 10px;
}

.sideCart__footer .w100{ width:100%; }

.sideCart__item{
  display:flex;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  margin-bottom: 10px;
}

.sideCart__img{
  width: 44px;
  height: 44px;
  border-radius: 10px;
  object-fit: cover;
  flex: 0 0 auto;
  background: #f4f6f6;
  border: 1px solid var(--line);
}

.sideCart__name{
  font-weight: 800;
  line-height: 1.1;
  margin-bottom: 2px;
  font-size: 14px;
}

.sideCart__sub{
  font-size: 12px;
}

.sideCart__qtyrow{
  margin-top: 8px;
  display:flex;
  align-items:center;
  gap: 8px;
}

.sideCart__qtypill{
  min-width: 42px;
  text-align:center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
  font-weight: 800;
  background: #eef6f1;
}

.sideCart__iconbtn{
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: #fff;
  cursor: pointer;
}

.sideCart__iconbtn:hover{
  background: #f5f7f7;
}


@keyframes sideCartPop{
  0%{ transform: translateX(0) scale(0.995); }
  40%{ transform: translateX(0) scale(1.01); }
  100%{ transform: translateX(0) scale(1); }
}

/* en pantallas chicas: que no tape todo */
@media (max-width: 980px){
  .sideCart{
    width: 320px;
    right: 10px;
  }
}

/* =========================================================
   ✅ Carrito lateral tipo Amazon (fix tamaño + scroll + control)
   Pegarlo al FINAL del styles.css
========================================================= */

.hasSideCart main.container{
  padding-right: 360px; /* deja espacio para el lateral */
}
@media (max-width: 1100px){
  .hasSideCart main.container{ padding-right: 0; }
}

/* panel */
.sideCart{
  position: fixed;
  top: 94px;
  right: 18px;
  width: 330px;
  max-height: calc(100vh - 120px);
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow);
  z-index: 60;
  overflow: hidden;
}
.sideCart--hidden{ display:none; }

/* header */
.sideCart__head{
  padding: 12px 14px;
  display:flex;
  justify-content: space-between;
  align-items:center;
  border-bottom: 1px solid var(--line);
  background:#fff;
}
.sideCart__left{ display:flex; align-items:center; gap:10px; }
.sideCart__x{
  border:none;
  background:transparent;
  cursor:pointer;
  font-weight:900;
  opacity:.65;
}
.sideCart__x:hover{ opacity:1; }

/* list scroll */
.sideCart__list{
  padding: 10px;
  overflow: auto;
  display: grid;
  gap: 10px;
  flex: 1;          /* ✅ para que el footer quede fijo y esto scrollee */
  min-height: 0;    /* ✅ importante para flex scroll */
}

/* item */
.sideCartItem{
  display:flex;
  gap:10px;
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 10px;
  background:#fff;
}
.sideCartItem__img{
  width: 54px;
  height: 54px;
  border-radius: 14px;
  border: 1px solid var(--line);
  background: #f6f8f7;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.sideCartItem__img img{
  width:100%;
  height:100%;
  object-fit: contain;   /* ✅ ya no se ve “gigante” */
  display:block;
}

.sideCartItem__mid{ flex:1; min-width:0; }
.sideCartItem__name{
  font-weight: 900;
  font-size: 13px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sideCartItem__var{
  margin-top: 2px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 700;
}

.sideCartItem__qty{
  margin-top: 8px;
  display:flex;
  align-items:center;
  gap: 8px;
}

.qtyBtn{
  width: 28px;
  height: 28px;
  border-radius: 10px;
  border: 1px solid var(--line);
  background: rgba(15,62,46,0.04);
  cursor:pointer;
  font-weight: 900;
}
.qtyBtn:hover{ background: rgba(15,62,46,0.08); }

.qtyNum{
  font-weight: 900;
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(15,62,46,0.14);
  background: rgba(15,62,46,0.06);
  color: var(--brand);
}

.sideCartItem__rm{
  border:none;
  background: transparent;
  cursor:pointer;
  opacity: .8;
}
.sideCartItem__rm:hover{ opacity: 1; }

/* footer fijo */
.sideCart__foot{
  padding: 12px;
  border-top: 1px solid var(--line);
  display:flex;
  gap:10px;
  background:#fff;
}
.sideCart__clear{ flex:1; }
.sideCart__go{ flex:1; }

/* animación al agregar */
.sideCart--pulse{
  animation: sideCartPulse .35s ease-out;
}
@keyframes sideCartPulse{
  0% { transform: translateY(0); box-shadow: var(--shadow); }
  45% { transform: translateY(-2px); box-shadow: 0 18px 40px rgba(14,27,22,0.18); }
  100% { transform: translateY(0); box-shadow: var(--shadow); }
}

/* Mobile: oculto */
@media (max-width: 1100px){
  .sideCart{ display:none !important; }
}

/* ✅ controles en carrito (pantalla) */
.cartQtyControls{
  display:flex;
  gap:8px;
  margin-top:10px;
}

/* =========================
   Fix: input cantidad en cards
   ========================= */
.pcard__actions .qty.qty--card{
  height: 40px;
  padding: 0 12px;
  border-radius: 14px;
  line-height: 40px;
}

/* Evita que el number haga saltos raros en algunos browsers */
.pcard__actions .qty.qty--card::-webkit-outer-spin-button,
.pcard__actions .qty.qty--card::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.pcard__actions .qty.qty--card {
  -moz-appearance: textfield;
}

/* =========================
   Side Cart (Amazon-like)
   ========================= */
.sideCart{
  position: fixed;
  top: 92px;          /* ajustá si tu header tiene otro alto */
  right: 18px;
  width: 320px;
  max-width: calc(100vw - 24px);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.08);
  z-index: 60;

  /* por defecto cerrado (pero existe) */
  transform: translateX(0);
}

.sideCart.is-hidden{ display:none; }

.sideCart.is-open{
  display:block;
}

.sideCart__header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 12px 12px;
  border-bottom: 1px solid var(--line);
}

.sideCart__close{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  cursor: pointer;
}

.sideCart__count{
  display:inline-flex;
  min-width: 24px;
  height: 24px;
  padding: 0 8px;
  border-radius: 999px;
  align-items:center;
  justify-content:center;
  background: rgba(31,115,65,.12);
  color: var(--brand);
  font-weight: 900;
  font-size: 12px;
}

/* ✅ Scroll interno: NO bloquea scroll del body */
.sideCart__body{
  padding: 10px 12px;
  overflow-y: auto;
  max-height: calc(100vh - 92px - 120px);
}

.sideCart__footer{
  display:flex;
  gap: 10px;
  padding: 12px;
  border-top: 1px solid var(--line);
}
.sideCart__footer .btn{
  flex: 1;
}

/* Items */
.sideCart__item{
  display:flex;
  gap: 10px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 16px;
  margin-bottom: 10px;
}

.sideCart__img{
  width: 54px;
  height: 54px;
  border-radius: 14px;
  object-fit: cover;
  border: 1px solid var(--line);
  background: #fff;
  flex: 0 0 auto;
}

.sideCart__meta{ flex: 1; min-width: 0; }
.sideCart__name{
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 4px;
}
.sideCart__sub{
  font-size: 12px;
  margin-bottom: 8px;
}

.sideCart__controls{
  display:flex;
  align-items:center;
  gap: 8px;
  flex-wrap: wrap;
}

.qtyBtn{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  cursor:pointer;
  font-weight: 900;
  font-size: 18px;
  line-height: 1;
}
.qtyBtn--sm{
  width: 34px;
  height: 34px;
  border-radius: 12px;
}

.sideCart__qtyPill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height: 34px;
  min-width: 54px;
  padding: 0 10px;
  border-radius: 999px;
  border: 1px solid rgba(31,115,65,.18);
  background: rgba(31,115,65,.08);
  font-weight: 900;
}

.trashBtn{
  width: 36px;
  height: 36px;
  border-radius: 12px;
  border: 1px solid var(--line);
  background: #fff;
  cursor:pointer;
}

/* mini highlight al agregar */
.sideCart.just-added{
  animation: sideCartPop .35s ease;
}
@keyframes sideCartPop{
  0%{ box-shadow: 0 0 0 rgba(0,0,0,0); }
  50%{ box-shadow: 0 0 0 6px rgba(31,115,65,.14); }
  100%{ box-shadow: 0 10px 30px rgba(0,0,0,.08); }
}

/* ✅ input cantidad mismo alto que botones */
.qty--same{
  height: 40px;
  padding: 0 12px;
  border-radius: 12px;
  line-height: 40px;
  box-sizing: border-box;
}

/* por si tu .qty no tiene altura fija */
.pcard__actions{
  display:flex;
  gap:10px;
  align-items:center;
}

/* =========================
   CARRITO LATERAL (FIX)
========================= */

.sideCart {
  position: fixed;
  top: 0;
  right: 0;
  width: 360px;
  height: 100vh;                 /* ⬅️ CLAVE */
  background: #fff;
  box-shadow: -10px 0 30px rgba(0,0,0,.12);
  display: flex;
  flex-direction: column;        /* ⬅️ CLAVE */
  z-index: 1200;
}

.sideCart.is-hidden {
  display: none;
}

.sideCart__header {
  flex: 0 0 auto;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.sideCart__body {
  flex: 1 1 auto;                /* ⬅️ ocupa el espacio */
  overflow-y: auto;              /* ⬅️ SCROLL ACÁ */
  padding: 12px;
}

.sideCart__footer {
  flex: 0 0 auto;
  padding: 12px;
  border-top: 1px solid var(--line);
  background: #fff;
  display: flex;
  gap: 10px;
}

.sideCart__footer .btn {
  width: 100%;
}

/* Items */
.sideCart__item {
  display: flex;
  gap: 10px;
  padding: 10px;
  border-radius: 12px;
  border: 1px solid var(--line);
  margin-bottom: 10px;
}

.sideCart__img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border-radius: 8px;
  background: #f7f7f7;
}

/* QTY */
.sideCart__qtyControls {
  display: flex;
  gap: 6px;
  margin-top: 6px;
}

.sideCart__qtyControls button {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: 1px solid var(--line);
  background: #fff;
  cursor: pointer;
}

/* =========================================================
   ✅ SideCart FIX (footer siempre visible + scroll interno)
   Pegar al FINAL del styles.css
========================================================= */

/* cuando el lateral existe, dejá espacio */
.has-sidecart main.container{
  padding-right: 360px;
}
@media (max-width: 1100px){
  .has-sidecart main.container{ padding-right: 0; }
}

/* panel */
.sideCart{
  position: fixed;
  right: 16px;
  top: 96px; /* debajo del header */
  width: 340px;
  max-width: calc(100vw - 32px);

  /* clave: altura fija “usable” para que el footer no se vaya */
  height: min(700px, calc(100vh - 120px));

  display: flex;
  flex-direction: column;

  background: #fff;
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow);
  z-index: 60;
  overflow: hidden;
}

.sideCart.is-hidden{
  display: none !important;
}

.sideCart__header{
  flex: 0 0 auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  background:#fff;
}

/* ✅ ESTE ES EL SCROLL */
.sideCart__body{
  flex: 1 1 auto;
  min-height: 0;          /* clave en flex */
  overflow-y: auto;       /* scroll interno */
  padding: 10px;
  display: grid;
  gap: 10px;
  background:#fff;
}

/* ✅ footer fijo siempre visible */
.sideCart__footer{
  flex: 0 0 auto;
  padding: 12px 14px;
  border-top: 1px solid var(--line);
  background:#fff;
  display:flex;
  gap: 10px;
}

/* botones al mismo ancho */
.sideCart__footer .btn{ flex: 1; }
.sideCart__footer .w100{ width:100%; }

/* Mobile: ocultar lateral */
@media (max-width: 1100px){
  .sideCart{ display:none !important; }
}


/* =========================
   SideCart (override final)
   - Mantiene footer visible
   - Scroll solo en el listado
   - Imágenes chicas tipo Amazon
   ========================= */
:root{
  --sidecart-top: 86px; /* ajustá si tu header es más alto/bajo */
  --sidecart-w: 360px;
}

.sideCart{
  position: fixed !important;
  top: var(--sidecart-top) !important;
  right: 18px !important;
  width: var(--sidecart-w) !important;
  height: calc(100vh - var(--sidecart-top) - 18px) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  z-index: 9999 !important;
}

.sideCart.is-hidden{ display:none !important; }
.sideCart.is-open{ transform: translateX(0) !important; }

.sideCart__header{
  flex: 0 0 auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content: space-between !important;
  gap: 10px !important;
  padding: 12px 12px !important;
  border-bottom: 1px solid var(--line) !important;
  background: #fff !important;
}

.sideCart__body{
  flex: 1 1 auto !important;
  min-height: 0 !important; /* CLAVE para que haga scroll bien */
  overflow: auto !important;
  padding: 12px !important;
  background: #fff !important;
}

.sideCart__footer{
  flex: 0 0 auto !important;
  position: sticky !important;
  bottom: 0 !important;
  background: #fff !important;
  border-top: 1px solid var(--line) !important;
  padding: 12px !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 10px !important;
}

.sideCart__item{
  display:flex !important;
  align-items:center !important;
  gap: 10px !important;
  padding: 10px !important;
  border: 1px solid var(--line) !important;
  border-radius: 14px !important;
  margin-bottom: 10px !important;
}

.sideCart__img{
  width: 44px !important;
  height: 44px !important;
  border-radius: 10px !important;
  border: 1px solid var(--line) !important;
  background:#fff !important;
  object-fit: contain !important;
  flex: 0 0 auto !important;
}

.sideCart__meta{ flex: 1 1 auto !important; min-width: 0 !important; }
.sideCart__name{
  font-weight: 900 !important;
  font-size: 14px !important;
  line-height: 1.2 !important;
  margin: 0 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.sideCart__sub{ font-size: 12px !important; margin-top: 2px !important; }
.sideCart__controls{
  display:flex !important;
  align-items:center !important;
  gap: 8px !important;
  margin-top: 8px !important;
}

.qtyBtn{
  width: 30px !important;
  height: 30px !important;
  border-radius: 10px !important;
  border: 1px solid var(--line) !important;
  background: #fff !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  cursor: pointer !important;
}

.sideCart__qtyPill{
  min-width: 34px !important;
  height: 30px !important;
  border-radius: 999px !important;
  border: 1px solid var(--line) !important;
  background: #eef5f1 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-weight: 900 !important;
  padding: 0 10px !important;
}

.trashBtn{
  width: 30px !important;
  height: 30px !important;
  border-radius: 10px !important;
  border: 1px solid var(--line) !important;
  background: #fff !important;
  cursor:pointer !important;
}

@media (max-width: 920px){
  :root{ --sidecart-top: 74px; --sidecart-w: min(92vw, 420px); }
  .sideCart{ right: 10px !important; left: auto !important; }
}

/* SIDE CART LAYOUT (evita placas gigantes) */
.sideCart{
  display: flex;
  flex-direction: column;
}

.sideCart__header{
  flex: 0 0 auto;
}

.sideCart__footer{
  flex: 0 0 auto;
}

.sideCart__body{
  flex: 1 1 auto;
  overflow: auto;
  min-height: 0; /* clave en flex para que el scroll funcione */
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-bottom: 10px;
}

/* cada item NO debe estirarse */
.sideCart__item{
  flex: 0 0 auto;
  height: auto;
  min-height: 0;
}

/* ---------- Checkout delivery badge & hint (scoped) ---------- */
.confirm-field-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.delivery-source-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;font-size:12px;font-weight:700;line-height:1;border:1px solid transparent;white-space:nowrap}
.delivery-source-badge.is-delivery{background:#edf8f1;color:#1f7a45;border-color:#cfe9d8}
.delivery-source-badge.is-home{background:#fff7e8;color:#9a6700;border-color:#f3ddb3}
.field-hint{margin-top:8px;font-size:13px;line-height:1.4;color:#5f6f67}

@media (max-width:520px){
  .confirm-field-head{align-items:flex-start;gap:8px}
  .delivery-source-badge{margin-top:6px}
}
