:root{color-scheme:light;--bg:#FFFFFF;--white:#FFF;--ink:#0E0E0C;--ink2:#5a5a56;--ink3:#9a9a95;--line:rgba(0,0,0,0.08);--red:#E8200A;--blue:#0066FF;--green:#1aad49;--orange:#FF7A00;--wa:#25D366;--font:'Space Grotesk',system-ui,sans-serif;--annH:56px;--navH:64px}
@media(min-width:700px){:root{--annH:62px;--navH:78px}}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
/* El scroll interno de los modales NO arrastra el fondo (anti scroll-chaining) */
.pm-wrap,.pm-body,.csheet,.cbody,.catview,.apanel,.wm-card,.guia-wrap{overscroll-behavior:contain}
/* overflow-x:clip (no 'hidden') evita scroll horizontal SIN romper position:sticky del nav */
html,body{background:var(--bg)!important;color:var(--ink);font-family:var(--font);-webkit-font-smoothing:antialiased;overflow-x:clip}

/* CABECERA (barra de envío + nav) — estilo Adidas: sticky arriba, se OCULTA al bajar y REAPARECE
   al subir (clase .hide la sube con translateY). El JS de auto-hide alterna .hide según el scroll. */
.topbar{position:sticky;top:0;z-index:65;transition:transform .35s cubic-bezier(.4,0,.2,1)}
.topbar.hide{transform:translateY(-100%)}
/* BARRA DE ANUNCIO (envío gratis) — blanca, separada del nav por una línea gris fina. */
.annbar{position:relative;height:var(--annH);background:var(--white);color:var(--ink);display:flex;align-items:center;justify-content:center;gap:10px;text-align:center;padding:0 14px;line-height:1.08;border-bottom:1px solid var(--line)}
.annbar-ic{font-size:18px;flex:0 0 auto}
.annbar-tx{display:flex;flex-direction:column;align-items:center}
.annbar-tx strong{font-size:14px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}
.annbar-tx small{font-size:11px;font-weight:500;letter-spacing:.03em;color:var(--ink2);margin-top:1px}
@media(min-width:700px){.annbar-ic{font-size:20px}.annbar-tx strong{font-size:17px}.annbar-tx small{font-size:12.5px}}

/* NAV — dentro del header (.topbar). Móvil: ☰ izq · logo centro · carrito der.
   Escritorio: logo izq · menú centro · carrito der. */
nav{position:relative;z-index:60;height:var(--navH);display:flex;align-items:center;justify-content:center;padding:8px 58px;background:var(--bg);border-bottom:1px solid var(--line)}
.brand{text-align:center;line-height:1.04}
.logo{font-size:19px;font-weight:700;letter-spacing:.04em;color:var(--ink);text-transform:uppercase}
.brand-sub{font-size:11px;font-weight:600;color:var(--ink2);letter-spacing:.14em;text-transform:uppercase;margin-top:3px}
/* ☰ menú (solo móvil) */
.nav-burger{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--ink);cursor:pointer;padding:0}
.nav-burger svg{width:24px;height:24px;stroke:currentColor;stroke-width:2;stroke-linecap:round}
.nav-burger:active{transform:translateY(-50%) scale(.9)}
/* grupo derecho: carrito */
.nav-right{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:flex;align-items:center;gap:8px}
.nav-bag:active{transform:scale(.91)}
/* menú horizontal (solo escritorio) */
.nav-menu{display:none}
@media(min-width:700px){
  nav{display:grid;grid-template-columns:1fr auto 1fr;justify-content:initial;gap:18px;padding:8px 30px}
  .nav-burger{display:none}
  .brand{justify-self:start;text-align:left}
  .logo{font-size:22px}
  .nav-menu{display:flex;justify-self:center;align-items:center;gap:24px}
  .nav-menu button{background:none;border:none;font-family:var(--font);font-size:13px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--ink);cursor:pointer;padding:6px 0;position:relative;white-space:nowrap}
  .nav-menu button::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;background:var(--ink);transform:scaleX(0);transition:transform .18s}
  .nav-menu button:hover::after{transform:scaleX(1)}
  .nav-right{position:static;transform:none;justify-self:end}
}
/* PANEL LATERAL MÓVIL (menú ☰) */
.navdrawer{position:fixed;inset:0;z-index:600;display:none}
.navdrawer.on{display:block}
.nd-scrim{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(4px)}
.nd-panel{position:absolute;left:0;top:0;bottom:0;width:min(82vw,330px);background:var(--white);box-shadow:6px 0 40px rgba(0,0,0,.3);transform:translateX(-100%);transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;flex-direction:column;padding-bottom:max(12px,env(safe-area-inset-bottom));overflow-y:auto;-webkit-overflow-scrolling:touch}
.navdrawer.on .nd-panel{transform:translateX(0)}
.nd-head{display:flex;align-items:center;justify-content:space-between;padding:18px 18px 14px;border-bottom:1px solid var(--line)}
.nd-logo{font-size:15px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink)}
.nd-x{width:34px;height:34px;border:none;background:none;color:var(--ink2);font-size:18px;cursor:pointer;border-radius:50%}
.nd-links{display:flex;flex-direction:column;padding:6px 0}
.nd-links button{text-align:left;background:none;border:none;border-bottom:1px solid var(--line);font-family:var(--font);font-size:16px;font-weight:600;color:var(--ink);padding:15px 20px;cursor:pointer;transition:background .12s}
.nd-links button:active{background:var(--bg)}
@media(min-width:700px){.navdrawer{display:none!important}}

/* VENTANAS INFO (Mayoristas / Cambios) — ventana a PANTALLA COMPLETA con flecha ← de volver */
.info-modal{position:fixed;inset:0;z-index:660;display:none;background:var(--bg)}
.info-modal.on{display:block}
.info-page{position:absolute;inset:0;display:flex;flex-direction:column;background:var(--bg);animation:pmPage .3s cubic-bezier(.16,1,.3,1) both}
.info-head{flex:0 0 auto;position:relative;display:flex;align-items:center;justify-content:center;padding:15px 16px;background:var(--white);border-bottom:1px solid var(--line)}
.info-back{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--ink);font-size:25px;line-height:1;cursor:pointer}
.info-back:active{transform:translateY(-50%) scale(.9)}
.info-htitle{font-size:15px;font-weight:700;letter-spacing:.03em;color:var(--ink);text-transform:uppercase}
.info-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.info-body{max-width:640px;margin:0 auto;padding:26px 22px 44px}
.info-kicker{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink2);background:var(--bg);border:1px solid var(--line);border-radius:20px;padding:5px 12px;margin-bottom:12px}
.info-h1{font-size:24px;font-weight:700;line-height:1.12;letter-spacing:-.01em;color:var(--ink);text-transform:uppercase}
.info-h1 .big{color:var(--red)}
.info-lead{font-size:14px;color:var(--ink2);margin-top:10px;line-height:1.45}
.info-subt{font-size:13px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em;margin:20px 0 10px}
.info-benes{display:flex;flex-direction:column;gap:9px}
.info-bene{display:flex;align-items:flex-start;gap:9px;font-size:14.5px;font-weight:600;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:12px 14px}
.info-wa{margin-top:22px;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;background:var(--wa);color:#fff;border:none;border-radius:12px;padding:15px;font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer;transition:transform .12s,filter .15s}
.info-wa:hover{filter:brightness(1.05)}
.info-wa:active{transform:scale(.98)}
.info-sec{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}
.info-sec:first-of-type{border-top:none;padding-top:4px}
.info-sec h3{font-size:14.5px;font-weight:700;color:var(--ink);margin-bottom:6px;letter-spacing:.01em}
.info-sec p{font-size:13.5px;line-height:1.5;color:var(--ink2)}
.info-grid{display:block}
/* ── ESCRITORIO: ventanas Mayoristas/Cambios más profesionales (no estilo móvil estirado) ── */
@media(min-width:700px){
  .info-head{padding:18px}
  .info-htitle{font-size:18px}
  .info-back{left:18px;width:44px;height:44px;font-size:28px}
  .info-body{max-width:920px;padding:52px 40px 70px}
  .info-h1{font-size:40px;line-height:1.08}
  .info-lead{font-size:16.5px;margin-top:14px;max-width:620px}
  .info-subt{font-size:14px;margin:32px 0 16px}
  .info-benes{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .info-bene{font-size:16px;padding:18px 20px;border-radius:14px}
  .info-wa{max-width:420px;margin:34px auto 0;padding:17px 30px;font-size:16px}
  .info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:26px}
  .info-sec{margin-top:0;padding:22px;border-top:none;border:1px solid var(--line);border-radius:16px;background:var(--white)}
  .info-sec:first-of-type{padding-top:22px}
  .info-sec h3{font-size:16px;margin-bottom:8px}
  .info-sec p{font-size:14.5px}
}

.admin-pill{background:var(--white);border:1.5px solid var(--line);border-radius:20px;padding:7px 14px;font-family:var(--font);font-size:11px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .15s}
.admin-pill:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.bag-btn{position:relative;width:40px;height:40px;background:var(--ink);border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .14s}
.wa-fab{position:fixed;right:18px;bottom:max(18px,env(safe-area-inset-bottom));width:56px;height:56px;background:#25D366;border:none;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:565;box-shadow:0 4px 16px rgba(37,211,102,.45);transition:transform .15s}
.wa-fab svg{width:30px;height:30px}
.wa-fab:hover{transform:scale(1.08)}
.wa-fab:active{transform:scale(.95)}
/* Mini-anuncio sobre el FAB de WhatsApp ("Pregunta por los combos") */
.wa-bubble{position:fixed;right:18px;bottom:calc(max(18px,env(safe-area-inset-bottom)) + 66px);z-index:564;display:none;align-items:center;gap:8px;background:var(--white);color:var(--ink);border:1px solid var(--line);border-radius:14px;padding:10px 12px 10px 14px;font-family:var(--font);font-size:12.5px;font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.18);cursor:pointer;animation:pmIn .3s ease both}
.wa-bubble.show{display:inline-flex}
.wa-bubble::after{content:'';position:absolute;right:20px;bottom:-6px;width:12px;height:12px;background:var(--white);border-right:1px solid var(--line);border-bottom:1px solid var(--line);transform:rotate(45deg)}
.wa-bubble:active{transform:scale(.96)}
.wa-bubble-x{display:flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:var(--bg);color:var(--ink3);font-size:10px;font-weight:700;flex:0 0 auto}
@media(max-width:480px){.wa-bubble{font-size:11.5px;padding:9px 10px 9px 12px}}
.bag-btn:active{transform:scale(.91)}
.bag-btn svg{width:16px;height:16px;stroke:#fff;fill:none}
.bdot{position:absolute;top:-1px;right:-1px;min-width:16px;height:16px;background:var(--red);color:#fff;font-size:9px;font-weight:700;border-radius:8px;padding:0 4px;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);opacity:0;transform:scale(.5);transition:opacity .2s,transform .35s cubic-bezier(.34,1.56,.64,1)}
.bdot.show{opacity:1;transform:scale(1)}

/* HERO */
.hdr{padding:32px 16px 20px;display:flex;align-items:flex-end;justify-content:space-between;background:var(--bg)}
.hdr-tag{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.hdr-h{font-size:clamp(34px,9vw,56px);font-weight:700;letter-spacing:-.05em;line-height:.95;color:var(--ink)}
.hdr-h span{color:var(--ink3);font-weight:400}
.hdr-stat{text-align:right;flex-shrink:0}
.sn{font-size:28px;font-weight:700;letter-spacing:-.05em;color:var(--ink)}
.sl{font-size:10px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3)}

/* BANNER */
.banner{margin:0 10px 14px;padding:16px 18px;background:var(--ink);border-radius:16px;display:flex;align-items:center;justify-content:space-between}
.banner.off{display:none}
.ban-tag{font-size:9px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:4px}
.ban-txt{font-size:16px;font-weight:700;color:#fff;letter-spacing:-.03em}
.ban-sub{font-size:11px;color:rgba(255,255,255,.4);margin-top:2px}
.ban-val{font-size:28px;font-weight:700;color:#fff;letter-spacing:-.04em;line-height:1}
.ban-env{font-size:11px;color:var(--green);font-weight:600;margin-top:4px}

/* TABS */
/* Pestañas de género ocultas: se navega por el menú (Hombre/Mujer/Ofertas) + ← volver. Quedan solo
   las marcas (#brandbar). Los botones siguen en el DOM para que setG/openCatalog funcionen. */
.tabs{display:none}
.tabs.show{display:flex;gap:4px;padding:18px 10px 14px;background:var(--bg)}
.tab{flex:1;padding:10px 4px;background:var(--white);border:1.5px solid var(--line);border-radius:10px;font-family:var(--font);font-size:12px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .16s;text-align:center}
.tab.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.brandbar{display:flex;gap:6px;padding:16px 10px 12px;background:var(--bg);overflow-x:auto;scrollbar-width:none}
.brandbar::-webkit-scrollbar{display:none}
.brandbar:empty{display:none}
.bchip{flex:0 0 auto;padding:6px 13px;background:var(--white);border:1.5px solid var(--line);border-radius:20px;font-family:var(--font);font-size:11px;font-weight:600;color:var(--ink2);cursor:pointer;transition:all .16s;white-space:nowrap}
.bchip.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.secbar{display:flex;align-items:center;justify-content:space-between;padding:0 14px 10px;background:var(--bg)}
.secn{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3)}
.seccn{font-size:11px;color:var(--ink3)}
.secright{display:flex;align-items:center;gap:10px;min-width:0}
.catsort{flex:0 0 auto;max-width:180px;border:1px solid var(--line);background:var(--white);border-radius:10px;padding:7px 10px;font-family:var(--font);font-size:14px;color:var(--ink);cursor:pointer;outline:none}
.catsort:focus{border-color:var(--ink)}
@media(max-width:600px){.catsort{font-size:16px;max-width:150px;padding:8px 10px}}

/* GRID */
.catsearch{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--white);border-bottom:1px solid var(--line)}
.catsearch-ic{font-size:14px;opacity:.6;flex-shrink:0}
.catsearch input{flex:1;min-width:0;border:1px solid var(--line);background:var(--bg);border-radius:10px;padding:10px 12px;font-family:var(--font);font-size:16px;color:var(--ink);outline:none}
.catsearch input:focus{border-color:var(--ink)}
.catsearch-x{flex-shrink:0;width:30px;height:30px;border:none;background:var(--bg);border-radius:50%;font-size:13px;color:var(--ink2);cursor:pointer;display:flex;align-items:center;justify-content:center}
.grid-empty{grid-column:1/-1;text-align:center;padding:44px 16px;color:var(--ink2);font-size:14px;line-height:1.7}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 8px 24px;background:var(--bg);align-items:start}

/* CARD */
.cfoot-card{padding:8px 9px 10px;background:var(--white);cursor:pointer}
.card{background:var(--white);border-radius:13px;overflow:hidden;cursor:pointer;border:1.5px solid var(--line);box-shadow:0 1px 4px rgba(0,0,0,.06);transition:border-color .18s,box-shadow .18s,transform .15s;animation:cardUp .38s cubic-bezier(.16,1,.3,1) both;position:relative}
.card:active{transform:scale(.96)}
.card.picked{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,102,255,.1)}
.card.sold{opacity:.55;cursor:not-allowed}
@keyframes cardUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.cphoto{position:relative;width:100%;padding-bottom:100%;background:#EEECEA;overflow:hidden;display:block}
.cphoto img,.cphoto .noimg{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.cphoto .noimg{display:flex;align-items:center;justify-content:center;font-size:52px}
.card:not(.sold):hover .cphoto img{transform:scale(1.05)}
/* Bloquea la barra "Búsqueda visual" de Microsoft Edge sobre las fotos: el <img> no captura el
   cursor (Edge solo la muestra al hover directo sobre un img). El clic pasa a la tarjeta y los
   botones ♥/+ siguen funcionando; el zoom al hover también (depende del hover de la tarjeta). */
.cphoto img,.lphoto img,.pm-gal-track img,.hero-slide img,.cbanner img{pointer-events:none}
.bdsc{position:absolute;top:8px;left:8px;background:var(--red);color:#fff;font-size:12px;font-weight:800;padding:5px 10px;border-radius:14px}
.bsold{position:absolute;inset:0;background:rgba(255,255,255,.82);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink3);letter-spacing:.08em;text-transform:uppercase;pointer-events:none}
.bnew,.bviews{position:absolute;top:8px;right:8px;z-index:3;font-size:11.5px;font-weight:800;letter-spacing:.02em;padding:5px 10px;border-radius:20px;line-height:1;pointer-events:none}
.bnew{background:var(--ink);color:#fff;text-transform:uppercase}
.bviews{background:#137a3a;color:#fff}
.bchk{position:absolute;top:6px;right:6px;width:22px;height:22px;background:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;opacity:0;transform:scale(.2);transition:all .26s cubic-bezier(.34,1.56,.64,1)}
.card.picked .bchk{opacity:1;transform:scale(1)}
.cbrand{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3);margin-bottom:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cmodel{font-size:14px;font-weight:700;letter-spacing:-.01em;color:var(--ink);line-height:1.2;margin-bottom:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cprice{font-size:17px;font-weight:800;letter-spacing:-.04em;color:var(--ink);line-height:1}
.cprice.sale{color:var(--red)}
.cwas{font-size:11px;color:var(--ink3);text-decoration:line-through;margin-top:2px}

/* LIQUIDACIÓN */
.liq-sec{padding-bottom:140px;display:none}
.liq-hdr{margin:8px 10px 14px;background:linear-gradient(135deg,#E8200A,#c41a08);border-radius:16px;padding:18px 20px;display:flex;align-items:center;justify-content:space-between}
.liq-title{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.04em}
.liq-sub{font-size:11px;color:rgba(255,255,255,.6);margin-top:3px}
.liq-badge{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);border-radius:12px;padding:10px 16px;text-align:center}
.liq-badge-n{font-size:22px;font-weight:700;color:#fff;letter-spacing:-.04em}
.liq-badge-l{font-size:9px;color:rgba(255,255,255,.7);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.liq-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 8px;align-items:start}
.liq-card{background:var(--white);border-radius:13px;overflow:hidden;cursor:pointer;border:1.5px solid transparent;transition:border-color .18s,transform .15s;animation:cardUp .38s cubic-bezier(.16,1,.3,1) both;position:relative}
.liq-card:active{transform:scale(.96)}
.liq-card.picked{border-color:var(--red);box-shadow:0 0 0 3px rgba(232,32,10,.1)}
.liq-card.sold{opacity:.55;cursor:not-allowed}
.lphoto{position:relative;width:100%;padding-bottom:100%;background:#f5f0ee;overflow:hidden;display:block}
.lphoto img,.lphoto .noimg{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center center;display:block;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.lphoto .noimg{display:flex;align-items:center;justify-content:center;font-size:52px}
.liq-card:not(.sold):hover .lphoto img{transform:scale(1.05)}
.lbdsc{position:absolute;top:6px;left:6px;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:3px 7px;border-radius:12px}
.lbsold{position:absolute;inset:0;background:rgba(255,255,255,.82);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--ink3);letter-spacing:.08em;text-transform:uppercase;pointer-events:none}
.lbchk{position:absolute;top:6px;right:6px;width:22px;height:22px;background:var(--red);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:10px;opacity:0;transform:scale(.2);transition:all .26s cubic-bezier(.34,1.56,.64,1)}
.liq-card.picked .lbchk{opacity:1;transform:scale(1)}
.lfoot{padding:8px 9px 10px;background:var(--white);cursor:pointer}
.lpnow{font-size:15px;font-weight:700;letter-spacing:-.04em;color:var(--red);line-height:1}
.lpwas{font-size:10px;color:var(--ink3);text-decoration:line-through;margin-top:2px}
.lsave{display:inline-block;margin-top:3px;background:#fff5f5;color:var(--red);font-size:9px;font-weight:700;padding:2px 6px;border-radius:20px}
.liq-empty{padding:32px;text-align:center;color:var(--ink3);font-size:13px;grid-column:1/-1}

/* COMBOS MUNDIALISTAS: tarjetas de bundle en la sección Ofertas.
   1 col en móvil / 2 en escritorio: las fotos-tarjeta traen el diseño completo y necesitan ancho. */
.combos-grid{display:grid;grid-template-columns:1fr;gap:10px;padding:8px 10px 14px}
@media(min-width:700px){.combos-grid{grid-template-columns:repeat(2,1fr);gap:12px;max-width:1280px;margin:0 auto}}
/* Tarjeta con FOTO: la imagen ES la tarjeta (todo el diseño viene en ella) + franja CTA */
.combo-card.foto{padding:0;text-align:left}
.combo-card.foto picture,.combo-card.foto img{display:block;width:100%;height:auto}
.combo-cta-strip{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:11px}
.combo-card{position:relative;background:var(--white);border:1.5px solid var(--line);border-radius:16px;padding:16px 12px 14px;text-align:center;cursor:pointer;transition:transform .14s,box-shadow .15s,border-color .15s;overflow:hidden}
.combo-card:hover{transform:translateY(-3px);box-shadow:0 10px 26px rgba(0,0,0,.10);border-color:var(--ink)}
.combo-card:active{transform:scale(.97)}
.combo-flag{font-size:34px;line-height:1}
.combo-nom{font-size:13.5px;font-weight:800;color:var(--ink);margin-top:7px;letter-spacing:-.01em}
.combo-det{font-size:11px;font-weight:600;color:var(--ink2);margin-top:3px}
.combo-precio{font-size:17px;font-weight:800;color:var(--ink);margin-top:6px;letter-spacing:-.03em}
.combo-cami{display:inline-block;margin-top:7px;background:#eafaf0;color:#137a3a;border:1px solid #bfe9cd;font-size:9.5px;font-weight:800;padding:3px 9px;border-radius:12px}
.combo-cta{display:inline-block;margin-top:9px;background:var(--ink);color:#fff;font-size:11px;font-weight:700;padding:8px 16px;border-radius:9px}
/* Barra sticky de progreso del combo activo (dentro del catálogo) */
.combo-bar{position:sticky;top:59px;z-index:3;display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--ink);color:#fff;font-size:12.5px;font-weight:700;line-height:1.3}
.combo-bar.ok{background:#137a3a}
.combo-bar.exceso{background:#b3541e}
.combo-bar .cb-x{margin-left:auto;flex-shrink:0;background:rgba(255,255,255,.18);border:none;color:#fff;font-family:var(--font);font-size:10.5px;font-weight:700;padding:6px 10px;border-radius:8px;cursor:pointer}

/* BOTÓN CIRCULAR + en la foto */
.add-circle{
  position:absolute;
  bottom:8px; right:8px;
  width:30px; height:30px;
  background:var(--white);
  border:none;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:300; color:var(--ink);
  cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  transition:all .2s cubic-bezier(.34,1.56,.64,1);
  z-index:4;
  line-height:1;
}
.add-circle:active{transform:scale(.88)}
/* Cuando está en carrito → fondo azul con ✓ */
.card.picked .add-circle{
  background:var(--blue);
  color:#fff;
  font-size:13px;
}
.liq-card.picked .add-circle{
  background:var(--red);
  color:#fff;
  font-size:13px;
}
/* No mostrar cuando agotado */
.card.sold .add-circle,
.liq-card.sold .add-circle{display:none}

/* ── SELECTOR RÁPIDO DE TALLA ── overlay sobre la foto al tocar "+" (agrega de una) */
.qsize{position:absolute;inset:0;z-index:6;background:rgba(255,255,255,.96);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:8px;animation:fadeIn .12s}
.qsize-t{font-size:12px;font-weight:700;color:var(--ink)}
.qsize-row{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.qsize-chip{min-width:34px;padding:7px 9px;border:1.5px solid var(--line);background:var(--white);border-radius:9px;font-family:var(--font);font-size:13px;font-weight:700;color:var(--ink);cursor:pointer;transition:transform .1s}
.qsize-chip:active{transform:scale(.94)}
.qsize-chip:hover{border-color:var(--ink)}
.qsize-x{position:absolute;top:6px;right:6px;width:24px;height:24px;border:none;background:none;font-size:15px;color:var(--ink2);cursor:pointer;line-height:1}
.qsize-guia{margin-top:2px;border:none;background:none;font-family:var(--font);font-size:11px;font-weight:600;color:var(--ink2);text-decoration:underline;cursor:pointer;padding:2px 4px}
.qsize-guia:hover{color:var(--ink)}

/* ── FAVORITOS ❤️ ── corazón en la esquina LIBRE (abajo-izquierda) de cada tarjeta */
.fav-btn{
  position:absolute;
  left:7px; bottom:7px;
  width:30px; height:30px;
  background:rgba(255,255,255,.92);
  border:none;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:16px; line-height:1;
  color:#9aa0a6;
  cursor:pointer;
  box-shadow:0 2px 8px rgba(0,0,0,.18);
  transition:transform .2s cubic-bezier(.34,1.56,.64,1),color .18s;
  z-index:3;
  -webkit-backdrop-filter:blur(2px); backdrop-filter:blur(2px);
}
.fav-btn:active{transform:scale(.85)}
.fav-btn.on{color:var(--red)}
.card.sold .fav-btn{display:none}
.pm-gal .fav-btn{top:12px;right:12px;left:auto;bottom:auto;width:40px;height:40px;font-size:21px}   /* corazón de la ficha: arriba-derecha de la galería */

/* corazón del nav con contador (imita .nav-bag / .bdot) */
.fav-nav{
  position:relative;
  width:40px; height:40px;
  background:none;
  border:none;
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; line-height:1;
  color:var(--ink);
  cursor:pointer;
  transition:transform .14s;
}
.fav-nav:active{transform:scale(.91)}
.fav-dot{
  position:absolute; top:-1px; right:-1px;
  min-width:16px; height:16px;
  background:var(--red); color:#fff;
  font-size:9px; font-weight:700;
  border-radius:8px; padding:0 4px;
  display:flex; align-items:center; justify-content:center;
  border:2px solid var(--bg);
  opacity:0; transform:scale(.5);
  transition:opacity .2s,transform .35s cubic-bezier(.34,1.56,.64,1);
}
.fav-dot.show{opacity:1; transform:scale(1)}
@media(max-width:699px){.fav-nav{font-size:16px}.fav-dot{min-width:14px;height:14px;font-size:8px}}   /* móvil: corazón más pequeño + contador proporcional */

/* MODAL FOTO — display:none por defecto (fix del bug principal) */
.photo-modal{position:fixed;inset:0;z-index:620;display:none;background:rgba(0,0,0,.55)}
.photo-modal.on{display:block}
.pm-scrim{position:fixed;inset:0;cursor:pointer}
/* VENTANA del producto a pantalla completa (no tarjeta): barra fija arriba + contenido scrolleable */
.pm-wrap{position:absolute;inset:0;width:100%;height:100%;max-width:none;max-height:none;margin:0;background:var(--white);border-radius:0;display:flex;flex-direction:column;overflow:hidden;animation:pmPage .3s cubic-bezier(.16,1,.3,1) both}
@keyframes pmPage{from{transform:translateX(100%)}to{transform:translateX(0)}}
@keyframes pmUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
@keyframes pmIn{from{opacity:0;transform:scale(.9) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
/* Barra superior FIJA (← volver + marca) */
.pm-head{flex:0 0 auto;position:relative;z-index:4;background:var(--white);display:flex;align-items:center;justify-content:center;padding:14px 16px;border-bottom:1px solid var(--line)}
.pm-logo{font-size:15px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
.pm-back{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:36px;height:36px;background:var(--bg);border:none;border-radius:50%;color:var(--ink);font-size:19px;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.pm-back:active{transform:translateY(-50%) scale(.9)}
/* Área scrolleable (debajo de la barra fija) */
.pm-scroll{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.pm-img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;background:var(--bg)}
/* GALERÍA de la ficha: carrusel [foto principal, ...secundarias] con swipe + dots + flechas */
.pm-gal{position:relative;width:100%;aspect-ratio:1/1;background:var(--bg);overflow:hidden;touch-action:pan-y}
.pm-gal-track{display:flex;height:100%;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.pm-gal-track img{flex:0 0 100%;width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none;user-select:none}
.pm-gal-arr{display:none;position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border:none;border-radius:50%;background:rgba(255,255,255,.88);color:var(--ink);font-size:22px;line-height:1;cursor:pointer;z-index:3;box-shadow:0 2px 10px rgba(0,0,0,.15);align-items:center;justify-content:center}
.pm-gal-arr.prev{left:10px}.pm-gal-arr.next{right:10px}
.pm-gal-arr:active{transform:translateY(-50%) scale(.92)}
.pm-gal-dots{position:absolute;bottom:10px;left:0;right:0;display:flex;justify-content:center;gap:5px;z-index:3}
.pm-gal-dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.22);transition:width .2s,background .2s}
.pm-gal-dot.on{width:16px;border-radius:4px;background:var(--ink)}
.pm-360-btn{position:absolute;top:10px;right:10px;z-index:3;border:none;background:rgba(0,0,0,.62);color:#fff;font-family:var(--font);font-size:11px;font-weight:700;padding:7px 11px;border-radius:18px;cursor:pointer}
@media(min-width:700px){.pm-gal:hover .pm-gal-arr[data-multi="1"]{display:flex}}
.pm-body{padding:18px 18px 26px}
.pm-title{font-size:18px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.pm-stars{margin-top:6px;font-size:14px;color:#f5a623;letter-spacing:1px}
.pm-stars span{color:var(--ink2);font-size:12px;font-weight:600;letter-spacing:0;margin-left:5px}
.pm-price-row{display:flex;align-items:baseline;gap:10px;margin-top:12px}
.pm-price{font-size:27px;font-weight:700;color:var(--ink);letter-spacing:-.03em}
.pm-was{font-size:15px;color:var(--ink3);text-decoration:line-through}
.pm-save{font-size:12px;font-weight:700;color:var(--green);margin-top:4px}
.pm-desc{font-size:13px;color:var(--ink2);line-height:1.6;margin-top:12px}
.pm-finance{display:flex;gap:10px;margin-top:14px}
.pm-fin{flex:1;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:10px 8px;font-size:10.5px;font-weight:600;color:var(--ink2);text-align:center;line-height:1.35}
.pm-fin b{color:var(--ink);display:block;font-size:12px}
.pm-add{display:block;width:100%;margin-top:16px;background:var(--ink);color:#fff;border:none;padding:15px;border-radius:13px;font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer;transition:transform .12s,background .15s}
/* Barra sticky de compra (siempre visible, línea recta al checkout estilo Nike) */
.pm-foot{display:none;flex:0 0 auto;background:var(--white);border-top:1px solid var(--line);padding:7px 14px max(10px,env(safe-area-inset-bottom));box-shadow:0 -4px 16px rgba(0,0,0,.07);z-index:5}
.pm-foot-trust{display:block;width:100%;background:none;border:none;font-family:var(--font);font-size:11px;font-weight:600;color:var(--ink2);cursor:pointer;padding:3px 0 7px;text-align:center}
.pm-foot-bar{display:flex;align-items:center;gap:12px;max-width:880px;margin:0 auto}
.pm-foot-price{font-size:18px;font-weight:800;color:var(--ink);letter-spacing:-.02em;font-variant-numeric:tabular-nums;flex-shrink:0}
.pm-foot-add{flex:1;padding:13px;background:var(--ink);color:#fff;border:none;border-radius:12px;font-family:var(--font);font-size:14px;font-weight:800;cursor:pointer;transition:transform .12s,background .15s}
.pm-foot-add.in{background:var(--green)}
.pm-foot-add:active{transform:scale(.99)}
.pm-add:active{transform:scale(.98)}
.pm-add.in{background:var(--green)}
/* ── SELECTOR DE TALLAS (ficha) ── */
.pm-sizes{margin:18px 0 2px}
.pm-sizes-top{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:9px}
.pm-sizes-lbl{font-size:13px;font-weight:700;color:var(--ink);letter-spacing:.01em}
.pm-sizes-unit{font-weight:600;color:var(--ink3);font-size:12px}
.pm-sizes-err{font-size:12px;font-weight:600;color:var(--red);opacity:0;transition:opacity .2s}
.pm-sizes.err .pm-sizes-err{opacity:1}
.pm-sizes-row{display:flex;flex-wrap:wrap;gap:8px}
.pm-size{min-width:48px;height:46px;padding:0 13px;border:1.5px solid var(--line);border-radius:12px;background:var(--white);font-family:var(--font);font-size:14.5px;font-weight:700;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s,background .15s,color .15s}
.pm-size:hover{border-color:var(--ink2)}
.pm-size.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.pm-sizes.err .pm-sizes-row{animation:pmShake .4s}
@keyframes pmShake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
/* Guía de tallas (link colapsable + 2 fotos de marquilla) */
.pm-guia{margin-top:11px}
.pm-guia-toggle{background:none;border:none;font-family:var(--font);font-size:12.5px;font-weight:700;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:6px 0;text-decoration:underline;text-underline-offset:3px}
.pm-guia-box{margin-top:8px;background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:12px}
.pm-guia-tx{font-size:12px;line-height:1.5;color:var(--ink2);margin-bottom:10px}
.pm-guia-imgs{display:flex;justify-content:center}
.pm-guia-img{width:100%;max-width:280px;max-height:320px;object-fit:contain;border-radius:10px;border:1px solid var(--line);cursor:zoom-in;background:var(--white)}
#imgZoom{display:none;position:fixed;inset:0;z-index:700;background:rgba(0,0,0,.92);align-items:center;justify-content:center;padding:16px;cursor:zoom-out}
#imgZoom.on{display:flex}
#imgZoom img{max-width:100%;max-height:100%;object-fit:contain;border-radius:8px}
.pm-pay{margin-top:18px}
.pm-pay-t{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);text-align:center;margin-bottom:9px}
.pm-cod{display:flex;align-items:center;gap:10px;background:#eafaf0;border:1px solid #bfe9cd;color:#137a3a;border-radius:12px;padding:11px 13px;font-size:12.5px;font-weight:600;line-height:1.3;margin-bottom:14px}
.pm-cod b{font-weight:800}
.pm-cod-ic{font-size:20px;flex-shrink:0}
.pm-pay-strip{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px;background:var(--white);border:1px solid var(--line);border-radius:12px;padding:13px 14px}
.pm-pay-strip img{height:23px;width:auto;max-width:62px;object-fit:contain;display:block}
.pm-meta{margin-top:16px;display:flex;flex-direction:column;gap:9px}
.pm-chip{display:flex;align-items:center;gap:11px;font-size:12.5px;font-weight:600;line-height:1.3;border-radius:13px;padding:11px 13px;background:var(--white);border:1px solid var(--line);box-shadow:0 1px 2px rgba(0,0,0,.03);color:var(--ink2);transition:transform .16s,box-shadow .16s}
.pm-chip:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.07)}
.pm-chip-ic{flex-shrink:0;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;position:relative}
.pm-chip b{color:var(--ink);font-weight:800}
.pm-chip.social{color:var(--ink)}
.pm-chip.social .pm-chip-ic{background:#eef4ff}
.pm-chip.reserve{color:#c43a22;border-color:#ffd9d2;background:#fff6f4}
.pm-chip.reserve b{color:#c43a22;font-variant-numeric:tabular-nums}
.pm-chip.reserve .pm-chip-ic{background:#ffe2da}
.pm-chip.gift .pm-chip-ic{background:#fff3e0}
.pm-live{position:absolute;top:-1px;right:-1px;width:9px;height:9px;border-radius:50%;background:var(--green);border:2px solid var(--white);animation:pmLive 1.6s ease-in-out infinite}
@keyframes pmLive{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.6}}
.photo-modal.on .pm-chip{animation:trustIn .5s cubic-bezier(.16,1,.3,1) both}
.photo-modal.on .pm-chip:nth-child(2){animation-delay:.06s}
.photo-modal.on .pm-chip:nth-child(3){animation-delay:.12s}
.pm-trust{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pm-trust-item{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--white),var(--bg));border:1px solid var(--line);border-radius:14px;padding:11px 12px;font-size:12px;font-weight:700;color:var(--ink);box-shadow:0 1px 2px rgba(0,0,0,.03);transition:transform .16s,box-shadow .16s}
.pm-trust-item span{line-height:1.15}
.pm-trust-item:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.09)}
.pm-ti-ic{flex-shrink:0;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;background:#eef4ff}
.pm-trust-item:nth-child(2) .pm-ti-ic{background:#eafaf0}
.photo-modal.on .pm-trust-item{animation:trustIn .5s cubic-bezier(.16,1,.3,1) both}
.photo-modal.on .pm-trust-item:nth-child(2){animation-delay:.09s}
@keyframes trustIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
/* Financiación + medios de pago con logos reales (carpeta logos/, fallback a texto vía onerror) */
.pm-fin-cap{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-top:16px;margin-bottom:7px}
.pm-finance .pm-fin{display:flex;align-items:center;justify-content:center;min-height:52px}
.pm-fin-logo{max-height:30px;max-width:88%;object-fit:contain}
/* Reseñas de ejemplo en la ficha — bloque "Dejamos que nuestros clientes hablen" (estilo elena) */
.pm-reviews{margin-top:20px;border-top:1px solid var(--line);padding-top:18px}
.pm-rev-head{text-align:center;margin-bottom:14px}
.pm-rev-head h4{font-size:16px;font-weight:700;color:var(--ink);letter-spacing:-.02em;margin:0}
.pm-rev-bigstars{font-size:20px;color:#f5a623;letter-spacing:3px;margin-top:6px}
.pm-rev-count{font-size:12px;font-weight:600;color:var(--ink2);margin-top:3px}
.pm-rev{background:var(--bg);border:1px solid var(--line);border-radius:11px;padding:11px 12px;margin-bottom:8px}
.pm-rev-h{display:flex;align-items:center;justify-content:space-between;gap:8px}
.pm-rev-h b{font-size:12.5px;font-weight:700;color:var(--ink)}
.pm-rev-v{font-size:10px;font-weight:600;color:var(--green)}
.pm-rev-s{font-size:12px;color:#f5a623;letter-spacing:1px;margin-top:2px}
.pm-rev-x{font-size:12px;color:var(--ink2);line-height:1.5;margin-top:4px}
/* ESCRITORIO: misma VENTANA a pantalla completa, pero el área scrolleable es 2 columnas
   (foto izq + info der). La barra superior queda fija arriba. */
@media(min-width:700px){
  .pm-scroll{display:flex;flex-direction:row;overflow:hidden}
  .pm-img{width:44%;height:100%;aspect-ratio:auto;object-fit:contain;background:var(--white)}
  .pm-gal{width:44%;height:100%;aspect-ratio:auto;flex-shrink:0;background:var(--white)}
  .pm-gal-track img{object-fit:contain}
  .pm-body{width:56%;height:100%;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:26px 32px 34px}
  .pm-title{font-size:22px}
  .pm-price{font-size:32px}
}
.cart-line{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:600;line-height:1.3;border-radius:13px;padding:10px 12px;margin-top:8px;border:1px solid transparent}
.cart-line b{font-weight:800}
.cl-ic{flex-shrink:0;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px}
.cart-reserva{background:#fff6f4;color:#c43a22;border-color:#ffd9d2}
.cart-reserva b{font-variant-numeric:tabular-nums}
.cart-reserva .cl-ic{background:#ffe2da}
.cart-ahorro{background:#eafaf0;color:#137a3a;border-color:#bfe9cd}
.cart-ahorro .cl-ic{background:#cdeed8}
.cart-regalo{background:var(--bg);color:var(--ink2);border-color:var(--line)}
.cart-regalo .cl-ic{background:#fff3e0}
.cart-cupon{background:#eef4ff;color:#0052cc;border-color:#cfe0ff}
.cart-cupon .cl-ic{background:#dbe8ff}
.cup-box{display:flex;gap:7px;margin-top:8px}
.cup-box input{flex:1;min-width:0;padding:10px 12px;background:var(--bg);border:1.5px solid var(--line);border-radius:10px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--ink);outline:none;text-transform:uppercase}
.cup-box input::placeholder{text-transform:none;font-weight:500;color:var(--ink3)}
.cup-btn{padding:10px 16px;background:var(--ink);color:#fff;border:none;border-radius:10px;font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;flex-shrink:0}
.cup-err{font-size:11px;font-weight:600;color:var(--red);margin-top:5px;padding-left:2px}
/* (estilos pm-add/pm-scrim definidos arriba en el bloque mini-landing) */

/* ADMIN */
/* ADMIN "Shopify-lite": VENTANA a pantalla completa con sidebar (escritorio) / drawer ☰ (móvil) */
.apanel{position:fixed;inset:0;background:var(--bg);z-index:615;display:none;flex-direction:column;animation:pmPage .3s cubic-bezier(.16,1,.3,1) both}
.apanel.on{display:flex}
.av-top{flex:0 0 auto;display:flex;align-items:center;gap:10px;padding:max(12px,env(safe-area-inset-top)) 14px 12px;background:var(--white);border-bottom:1px solid var(--line)}
.av-burger{width:38px;height:38px;border:none;background:var(--bg);border-radius:9px;font-size:17px;color:var(--ink);cursor:pointer;flex-shrink:0}
.av-title{font-size:16px;font-weight:700;letter-spacing:-.02em;color:var(--ink)}
/* BÚSQUEDA GLOBAL del admin: productos + pedidos + clientes desde un solo campo (en memoria) */
.av-search{position:relative;flex:1;max-width:430px;margin:0 8px}
.av-search input{width:100%;padding:9px 13px;background:var(--bg);border:1.5px solid var(--line);border-radius:9px;font-family:var(--font);font-size:13px;color:var(--ink);outline:none;transition:border-color .15s}
.av-search input:focus{border-color:var(--ink)}
#avSearchRes{display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--white);border:1px solid var(--line);border-radius:12px;box-shadow:0 14px 40px rgba(0,0,0,.16);max-height:60vh;overflow-y:auto;z-index:30}
#avSearchRes.on{display:block}
.avs-h{font-size:9px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);padding:9px 12px 4px;border-top:1px solid var(--line)}
.avs-h:first-child{border-top:none}
.avs-item{display:flex;align-items:center;gap:9px;padding:8px 12px;cursor:pointer;font-size:12.5px;color:var(--ink);line-height:1.35}
.avs-item:hover{background:var(--bg)}
.avs-item img{width:30px;height:30px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--bg)}
@media(max-width:699px){.av-search{margin:0 4px}.av-search input{font-size:16px;padding:8px 11px}}
.av-body{flex:1;display:flex;min-height:0;position:relative}
.av-side{width:200px;flex-shrink:0;background:var(--white);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:2px;padding:12px 8px;overflow-y:auto}
.av-nav{display:flex;align-items:center;gap:10px;width:100%;text-align:left;border:none;background:none;border-radius:9px;padding:10px 12px;font-family:var(--font);font-size:13px;font-weight:600;color:var(--ink2);cursor:pointer;transition:background .12s}
.av-nav svg{flex-shrink:0;width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.av-nav:hover{background:var(--bg)}
.av-nav.on{background:var(--ink);color:#fff}
.av-scrim{display:none}
.av-main{flex:1;min-width:0;display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
#avMain [data-sec]{flex-shrink:0}
/* MÓVIL: sidebar = drawer lateral que abre el ☰ */
@media(max-width:699px){
  .av-side{position:absolute;left:0;top:0;bottom:0;z-index:6;transform:translateX(-105%);transition:transform .28s cubic-bezier(.32,.72,0,1);box-shadow:4px 0 30px rgba(0,0,0,.18)}
  .av-side.open{transform:translateX(0)}
  .av-scrim.on{display:block;position:absolute;inset:0;z-index:5;background:rgba(0,0,0,.4)}
}
@media(min-width:700px){.av-burger{display:none}.av-cards{grid-template-columns:repeat(3,1fr)!important}}
.adrag{width:36px;height:3px;background:var(--line);border-radius:2px;margin:10px auto 0;flex-shrink:0}
.ahead{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 10px;flex-shrink:0;border-bottom:1px solid var(--line)}
.atitle{font-size:17px;font-weight:700;letter-spacing:-.03em}
.ax{width:26px;height:26px;background:var(--bg);border:none;border-radius:50%;font-size:12px;color:var(--ink2);cursor:pointer;display:flex;align-items:center;justify-content:center}
.astats{display:flex;border-bottom:1px solid var(--line);flex-shrink:0}
.ast{flex:1;padding:10px 8px;text-align:center;border-right:1px solid var(--line)}
.ast:last-child{border-right:none}
.astn{font-size:18px;font-weight:700;letter-spacing:-.04em}
.astl{font-size:9px;color:var(--ink3);font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.trow{display:flex;align-items:center;justify-content:space-between;padding:11px 18px;border-bottom:1px solid var(--line);flex-shrink:0;background:var(--bg)}
.trow-lbl{font-size:13px;font-weight:700;letter-spacing:-.02em}
.trow-sub{font-size:11px;color:var(--ink3);margin-top:1px}
.sw{position:relative;width:44px;height:26px;cursor:pointer;flex-shrink:0}
.sw input{opacity:0;width:0;height:0;position:absolute}
.sw-tr{position:absolute;inset:0;background:#e0e0e0;border-radius:13px;transition:background .2s}
.sw input:checked~.sw-tr{background:var(--orange)}
.sw-th{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--white);border-radius:50%;box-shadow:0 1px 4px rgba(0,0,0,.2);transition:transform .2s;pointer-events:none}
.sw input:checked~.sw-tr~.sw-th{transform:translateX(18px)}
.atabs{display:flex;border-bottom:1px solid var(--line);flex-shrink:0}
.atab{flex:1;padding:10px;border:none;font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}
.uz{margin:14px 16px 0;border:2px dashed var(--line);border-radius:14px;padding:20px 16px;text-align:center;cursor:pointer;transition:all .18s;background:var(--bg);flex-shrink:0;position:relative}
.uz:hover,.uz.drag{border-color:var(--blue);background:#f0f4ff}
.uz input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.uz-ico{font-size:28px;margin-bottom:6px}
.uz-txt{font-size:13px;font-weight:600;color:var(--ink);margin-bottom:2px}
.uz-sub{font-size:11px;color:var(--ink3)}
.uqueue{display:flex;gap:8px;overflow-x:auto;padding:10px 16px 0;scrollbar-width:none;flex-shrink:0}
.uqueue::-webkit-scrollbar{display:none}
.qthumb{position:relative;flex-shrink:0;width:68px;height:68px;border-radius:10px;overflow:hidden;border:2px solid var(--line)}
.qthumb img{width:100%;height:100%;object-fit:cover}
.qdel{position:absolute;top:2px;right:2px;width:18px;height:18px;background:rgba(0,0,0,.6);border:none;border-radius:50%;color:#fff;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}
.qnum{position:absolute;bottom:3px;left:4px;background:rgba(0,0,0,.65);color:#fff;font-size:9px;font-weight:700;padding:1px 5px;border-radius:6px;pointer-events:none}
.prev360-btn{display:none;margin:6px 16px 0;padding:9px;border:1.5px dashed var(--blue);border-radius:9px;background:transparent;color:var(--blue);font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;align-items:center;justify-content:center;gap:6px;flex-shrink:0;transition:background .15s}
.prev360-btn:hover{background:rgba(0,102,255,.07)}
.q360-count{display:none;font-size:10px;color:var(--ink3);padding:4px 16px 0;flex-shrink:0}
.uopts{display:flex;gap:8px;padding:8px 16px 0;flex-shrink:0}
.uopt{display:flex;flex-direction:column;gap:3px;flex:1}
.uopt label{font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3)}
.uopt select,.uopt input{width:100%;padding:8px 10px;background:var(--bg);border:1.5px solid var(--line);border-radius:9px;font-family:var(--font);font-size:12px;font-weight:500;color:var(--ink);outline:none;transition:border-color .15s;-webkit-appearance:none}
.uopt select:focus,.uopt input:focus{border-color:var(--blue)}
.uadd{width:calc(100% - 32px);margin:10px 16px 0;padding:11px;background:var(--ink);color:#fff;border:none;border-radius:11px;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;flex-shrink:0}
.uadd:active{opacity:.8}
.uz-ai-btn{width:calc(100% - 32px);margin:6px 16px 0;padding:11px;background:linear-gradient(135deg,#7c3aed,#4f46e5);color:#fff;border:none;border-radius:11px;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;flex-shrink:0;text-align:center}
.uz-ai-btn:disabled{opacity:.55;cursor:not-allowed}
.alist-hdr{display:grid;grid-template-columns:46px 1fr 68px 58px 28px;gap:4px;padding:8px 14px;font-size:9px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink3);border-bottom:1px solid var(--line);background:var(--bg);position:sticky;top:0;z-index:2;flex-shrink:0}
.alist{overflow-y:auto;flex:1;min-height:0}
.arow{display:grid;grid-template-columns:46px 1fr 68px 58px 28px;gap:4px;padding:10px 14px;border-bottom:1px solid var(--line);align-items:center}
.arow:hover{background:#fafaf8}
.arow-img{width:42px;height:42px;border-radius:9px;overflow:hidden;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;position:relative}
.arow-img img{width:100%;height:100%;object-fit:cover}
.arow-sov{position:absolute;inset:0;background:rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:var(--ink3);text-transform:uppercase}
.arow-gen{font-size:11px;font-weight:600;color:var(--ink)}
.arow-st{font-size:10px;color:var(--ink3);margin-top:1px}
.arow-price{font-size:12px;font-weight:700;color:var(--ink)}
.arow-price.sale{color:var(--red)}
.epbtn{background:none;border:none;color:var(--blue);font-size:10px;font-weight:700;cursor:pointer;font-family:var(--font);padding:2px 0;text-decoration:underline;text-underline-offset:2px}
.ep-row{grid-column:1/-1;display:flex;flex-wrap:wrap;gap:6px;align-items:center;padding:6px 0 2px;animation:fadeIn .15s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}
.ep-row input{flex:1;min-width:0;padding:8px 10px;background:var(--bg);border:1.5px solid var(--blue);border-radius:9px;font-family:var(--font);font-size:13px;font-weight:700;color:var(--ink);outline:none}
.ep-brand{flex:1;min-width:0;padding:8px 6px;background:var(--bg);border:1.5px solid var(--blue);border-radius:9px;font-family:var(--font);font-size:12px;font-weight:700;color:var(--ink);outline:none;cursor:pointer}
.ep-save{padding:8px 14px;background:var(--ink);color:#fff;border:none;border-radius:9px;font-family:var(--font);font-size:12px;font-weight:700;cursor:pointer}
.ep-cancel{padding:8px 10px;background:none;color:var(--ink3);border:1px solid var(--line);border-radius:9px;font-family:var(--font);font-size:12px;cursor:pointer}
.sold-btn{padding:4px 6px;border-radius:8px;border:1.5px solid var(--line);background:var(--bg);font-family:var(--font);font-size:9px;font-weight:700;color:var(--ink2);cursor:pointer;transition:all .15s;white-space:nowrap;text-transform:uppercase}
.sold-btn.on{background:#111;border-color:#111;color:#fff}
.adel{width:24px;height:24px;background:none;border:1px solid var(--line);border-radius:50%;color:var(--ink3);font-size:11px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .14s}
.adel:hover{background:var(--red);border-color:var(--red);color:#fff}

/* CART */
.cscrim{position:fixed;inset:0;background:rgba(0,0,0,.3);backdrop-filter:blur(8px);z-index:600;display:none}
.cscrim.on{display:block}
/* CARRITO = ventana a pantalla completa en móvil (no tarjeta): barra "Tu pedido"+✕ fija arriba */
.csheet{position:fixed;inset:0;max-width:none;margin:0;background:var(--white);border-radius:0;z-index:610;transform:translateY(100%);transition:transform .34s cubic-bezier(.32,.72,0,1);height:100%;max-height:none;display:flex;flex-direction:column;padding-bottom:max(10px,env(safe-area-inset-bottom))}
.csheet.on{transform:translateY(0)}
/* ESCRITORIO: carrito como drawer lateral derecho (estilo Nike/Adidas). Móvil intacto. */
@media(min-width:700px){
  .csheet{left:auto;right:0;top:0;bottom:0;width:430px;max-width:430px;height:100vh;max-height:none;margin:0;border-radius:0;transform:translateX(100%)}
  .csheet.on{transform:translateX(0)}
  .cdrag{display:none}
  .ctop{padding-top:22px}
}
.cdrag{display:none}
.ctop{display:flex;align-items:center;justify-content:space-between;padding:max(16px,env(safe-area-inset-top)) 18px 8px;flex-shrink:0}
.cttl{font-size:19px;font-weight:700;letter-spacing:-.04em}
.cx{width:26px;height:26px;background:var(--bg);border:none;border-radius:50%;font-size:12px;color:var(--ink2);cursor:pointer;display:flex;align-items:center;justify-content:center}
.csteps{display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 18px 14px;flex-shrink:0}
.csd{width:6px;height:6px;border-radius:3px;background:var(--line);transition:all .25s}
.csd.active{width:20px;background:var(--ink)}
.csd.done{background:var(--blue)}
.cbody{overflow-y:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch;padding:0 18px}
.crow{display:flex;align-items:center;gap:10px;padding:12px 0;border-bottom:1px solid var(--line)}
.crimg{width:52px;height:52px;border-radius:10px;background:var(--bg);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden}
.crimg img{width:100%;height:100%;object-fit:cover}
.crinfo{flex:1;min-width:0}
.crname{font-size:13px;font-weight:600;letter-spacing:-.03em;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.crtalla{display:inline-block;font-size:10.5px;font-weight:700;color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:6px;padding:1px 7px;margin-top:3px}
.crprice{font-size:11px;color:var(--ink2);margin-top:2px}
.cqc{display:flex;align-items:center;gap:7px}
.cqb{width:24px;height:24px;background:var(--bg);border:1px solid var(--line);border-radius:50%;font-size:13px;display:flex;align-items:center;justify-content:center;cursor:pointer}
.cqv{font-size:12px;font-weight:700;min-width:12px;text-align:center}
.crm{background:none;border:none;font-size:12px;color:var(--ink3);cursor:pointer;padding:5px;transition:color .14s}
.crm:hover{color:var(--red)}
.cempty{padding:52px 20px;text-align:center}
.cempty-i{font-size:36px;margin-bottom:10px}
.cempty-t{font-size:12px;color:var(--ink3);line-height:1.6}
.csubb{display:flex;justify-content:space-between;align-items:center;padding:12px 0 0;margin-top:4px;border-top:1px solid var(--line)}
.csubl{font-size:12px;color:var(--ink2)}
.csubv{font-size:20px;font-weight:700;letter-spacing:-.04em}
.cenvio{font-size:11px;color:var(--green);font-weight:600;margin-top:4px;text-align:right}
/* ── Carrito estilo Adidas: mensajes + resumen + cupón colapsable ── */
.cart-msg{display:flex;align-items:flex-start;gap:9px;font-size:12px;font-weight:500;color:var(--ink2);line-height:1.45;padding:11px 0;border-bottom:1px solid var(--line)}
.cart-msg .cm-ic{flex-shrink:0;font-size:15px}
.cart-msg b{color:var(--ink);font-weight:700}
.cart-fin{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--line)}
.cart-fin-tx{flex:1;font-size:12px;font-weight:500;color:var(--ink2);line-height:1.45}
.cart-fin-tx b{color:var(--ink);font-weight:700}
.cart-fin-logos{display:flex;align-items:center;gap:9px;flex-shrink:0}
.cart-fin-logos img{height:17px;width:auto;max-width:62px;object-fit:contain}
/* ── Escalera de ahorro + cross-sell ("compra más, ahorra más") ── */
.esc-wrap{margin-top:14px;border:1px solid #bfe9cd;background:#f3fbf6;border-radius:14px;padding:13px 13px 6px}
.esc-head{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:800;letter-spacing:.04em;color:#137a3a;text-transform:uppercase}
.esc-sub{font-size:13px;color:var(--ink);margin-top:6px;line-height:1.45}
.esc-sub b{color:#137a3a;font-weight:800}
.esc-ladder{margin-top:10px;display:flex;flex-direction:column;gap:2px}
.esc-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink2);padding:6px 8px;border-radius:9px;font-variant-numeric:tabular-nums}
.esc-row .esc-dot{color:#bcd9c6;font-size:13px;width:12px;flex-shrink:0}
.esc-row .esc-pares{font-weight:700;color:var(--ink);min-width:58px}
.esc-row .esc-precio{font-weight:700;color:var(--ink);min-width:74px}
.esc-row .esc-ahorro{color:#137a3a;font-weight:600;font-size:11.5px;margin-left:auto;text-align:right}
.esc-row.done{opacity:.62}
.esc-row.done .esc-dot{color:#1ba94c}
.esc-row.next{background:#e3f7ea;border:1px solid #bfe9cd}
.esc-row.next .esc-dot{color:#137a3a}
.esc-apply{margin-top:10px;width:100%;padding:11px;background:#137a3a;color:#fff;border:none;border-radius:10px;font-family:var(--font);font-size:13px;font-weight:800;cursor:pointer}
.esc-apply:active{transform:scale(.99)}
/* "También te puede gustar" — cross-sell en la ficha (reusa las tarjetas .xs-card) */
.pmx{margin-top:18px;border-top:1px solid var(--line);padding-top:16px}
.pmx-t{font-size:14px;font-weight:800;color:var(--ink);margin-bottom:10px}
.pmx-row{display:flex;gap:9px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
.pmx-row::-webkit-scrollbar{height:4px}
.pmx-row::-webkit-scrollbar-thumb{background:var(--line);border-radius:4px}
.xs-wrap{margin-top:13px;border-top:1px dashed #cfe9d8;padding-top:11px}
.xs-title{font-size:12.5px;font-weight:800;color:var(--ink);margin-bottom:9px}
.xs-row{display:flex;gap:9px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px;scroll-snap-type:x proximity}
/* Cross-sell (carrito + ficha): carrusel horizontal con flechas ‹ › en ESCRITORIO (en móvil = swipe). */
.crsl{position:relative}
.crsl-a{position:absolute;top:42%;transform:translateY(-50%);z-index:2;width:32px;height:32px;border-radius:50%;border:1px solid var(--line);background:rgba(255,255,255,.96);color:var(--ink);font-size:18px;line-height:1;cursor:pointer;display:none;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.16)}
.crsl-a.prev{left:2px}
.crsl-a.next{right:2px}
.crsl-a:hover{background:#fff}
@media(min-width:700px){.crsl.crsl-on .crsl-a{display:flex}}
.xs-row::-webkit-scrollbar{height:4px}
.xs-row::-webkit-scrollbar-thumb{background:#cfe9d8;border-radius:4px}
.xs-card{flex:0 0 108px;scroll-snap-align:start;background:#fff;border:1px solid var(--line);border-radius:12px;padding:7px;font-family:var(--font);text-align:left;cursor:pointer;display:flex;flex-direction:column;gap:3px}
.xs-card:active{transform:scale(.98)}
.xs-img{width:100%;aspect-ratio:1/1;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;overflow:hidden}
.xs-img img{width:100%;height:100%;object-fit:cover}
.xs-nom{font-size:11px;font-weight:700;color:var(--ink);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.xs-precio{font-size:11.5px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums}
.xs-add{font-size:10px;font-weight:800;color:#137a3a;margin-top:1px}
.csum{margin-top:18px}
.csum-t{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--ink3);margin-bottom:8px}
.csum-row{display:flex;justify-content:space-between;align-items:baseline;font-size:13px;color:var(--ink2);padding:6px 0}
.csum-row .v{font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}
.csum-row.disc{color:var(--green)}
.csum-row.disc .v{color:var(--green)}
.csum-row .free{color:var(--green);font-weight:700}
.csum-total{display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding-top:13px;border-top:1px solid var(--line)}
.csum-total .l{font-size:15px;font-weight:700;color:var(--ink)}
.csum-total .v{font-size:23px;font-weight:700;letter-spacing:-.03em;color:var(--ink);font-variant-numeric:tabular-nums}
.cpromo{margin-top:14px}
.cpromo-toggle{background:none;border:none;font-family:var(--font);font-size:12.5px;font-weight:700;color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:6px 0;text-decoration:underline;text-underline-offset:3px}
.cpromo-box{margin-top:9px}
/* VER PEDIDO (un link con fotos para el vendedor) */
.ped-view{position:fixed;inset:0;z-index:700;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch}
.ped-bar{position:sticky;top:0;background:var(--white);border-bottom:1px solid var(--line);padding:14px 16px;text-align:center}
.ped-logo{display:block;font-size:15px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em}
.ped-sub{display:block;font-size:10px;font-weight:600;color:var(--ink3);letter-spacing:.12em;text-transform:uppercase;margin-top:2px}
.ped-body{max-width:600px;margin:0 auto;padding:16px}
.ped-head{font-size:16px;font-weight:700;color:var(--ink);margin-bottom:12px}
.ped-row{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:10px;margin-bottom:10px}
.ped-img{width:70px;height:70px;border-radius:11px;background:var(--bg);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:26px;overflow:hidden}
.ped-img img{width:100%;height:100%;object-fit:cover}
.ped-info{flex:1;min-width:0}
.ped-name{font-size:14px;font-weight:700;color:var(--ink)}
.ped-q{font-size:12px;color:var(--ink2);margin-top:3px}
.ped-pr{font-size:14px;font-weight:800;color:var(--ink);font-variant-numeric:tabular-nums}
.ped-total{display:flex;justify-content:space-between;align-items:center;margin-top:6px;padding:14px 4px 4px;border-top:1px solid var(--line);font-size:16px;font-weight:800;color:var(--ink)}
.ped-cta{display:block;text-align:center;margin-top:18px;background:var(--ink);color:var(--white);text-decoration:none;padding:14px;border-radius:13px;font-size:14px;font-weight:700}
.paysec{padding:4px 0 16px}
.paytit{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:12px}
/* Métodos de pago (paso 3): tarjetas pro con ícono, acento, sombra y hover */
.paychoice-list{display:flex;flex-direction:column;gap:11px;margin-top:18px}
/* Franja de confianza bajo los métodos de pago (Cambios/Garantía clicables a la política) */
.pay-trust{display:flex;flex-direction:column;gap:8px;margin-top:18px;padding:14px;background:var(--bg);border-radius:14px}
.pay-trust-i{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:0;font-family:var(--font);font-size:12.5px;font-weight:600;color:var(--ink);text-align:left}
.pay-trust button.pay-trust-i{cursor:pointer;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--line)}
.pay-trust-i span:first-child{font-size:15px;width:20px;text-align:center;flex:0 0 auto}
.paychoice{position:relative;width:100%;display:flex;align-items:center;gap:13px;text-align:left;background:var(--white);border:1px solid var(--line);border-radius:16px;padding:15px 16px;cursor:pointer;font-family:var(--font);box-shadow:0 1px 2px rgba(0,0,0,.04);transition:transform .15s,box-shadow .15s,border-color .15s}
.paychoice:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(0,0,0,.10);border-color:color-mix(in srgb,var(--acc) 40%,var(--line))}
.paychoice:active{transform:translateY(0) scale(.995)}
.pc-ic{flex-shrink:0;width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--acc)}
.pc-ic svg{width:23px;height:23px;display:block}
/* Logos reales de pasarela en el paso 3 (caja blanca con borde sutil) */
.pc-ic:has(.pc-logo){border:1px solid var(--line)}
.pc-ic .pc-logo{max-width:36px;max-height:28px;object-fit:contain;display:block}
.pc-logos2{display:flex;flex-direction:column;gap:3px;align-items:center;justify-content:center}
.pc-logos2 .pc-logo{max-width:34px;max-height:14px}
.pc-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px}
.pc-tit{font-size:14.5px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.pc-desc{font-size:11.5px;color:var(--ink2);line-height:1.4;margin-top:2px}
.pc-tot{font-size:12.5px;font-weight:800;color:var(--ink);margin-top:6px}
.pc-arrow{flex-shrink:0;align-self:center;color:var(--ink3);transition:transform .15s}
.pc-arrow svg{width:18px;height:18px;display:block}
.paychoice:hover .pc-arrow{transform:translateX(3px)}
/* Burbuja de info en una card de pago (ej. Contra entrega). Hover en escritorio, tap ⓘ en móvil. */
.pc-info{position:absolute;top:9px;right:40px;width:18px;height:18px;border-radius:50%;background:#e7e7e3;color:#6b6b67;font-size:12px;font-weight:800;font-style:italic;line-height:1;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:3}
.pc-info:hover{background:#d8d8d3}
.pc-tip{position:absolute;left:14px;right:14px;bottom:calc(100% - 4px);background:#1E1E1C;color:#fff;font-size:11.5px;font-weight:500;line-height:1.45;text-align:left;padding:11px 13px;border-radius:12px;box-shadow:0 8px 26px rgba(0,0,0,.24);opacity:0;visibility:hidden;transform:translateY(5px);transition:opacity .16s,transform .16s,visibility .16s;z-index:6;pointer-events:none}
.pc-tip b{color:#fff}
.pc-tip::after{content:'';position:absolute;top:100%;right:34px;border:7px solid transparent;border-top-color:#1E1E1C}
@media(hover:hover){.paychoice:hover .pc-tip{opacity:1;visibility:visible;transform:translateY(0)}}
.paychoice.tipon .pc-tip{opacity:1;visibility:visible;transform:translateY(0)}
.paygrid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}
.paycard{background:var(--white);border:1.5px solid var(--line);border-radius:14px;padding:13px 11px 11px;cursor:pointer;transition:all .2s;text-align:left;display:flex;flex-direction:column}
.paycard.on{border-color:var(--blue);box-shadow:0 0 0 3px rgba(0,102,255,.08);background:#fafcff}
.paylogo{height:30px;width:100%;display:flex;align-items:center;margin-bottom:9px;overflow:hidden}
.paylogo svg{height:100%;width:auto;max-width:100%;display:block}
.paynm{font-size:12px;font-weight:700;color:var(--ink)}
.paydesc{font-size:10px;color:var(--ink3);margin-top:2px;line-height:1.3}
.paybadge{display:inline-block;margin-top:5px;font-size:9px;font-weight:700;padding:2px 7px;border-radius:20px}
.bb{background:#EEF3FF;color:var(--blue)}
.bg{background:#EDFFF3;color:#00A63E}
.formsec{padding:4px 0 16px}
.formtit{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--ink3);margin-bottom:12px}
.fld{margin-bottom:10px}
.fld label{display:block;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink3);margin-bottom:4px}
.fld input{width:100%;padding:10px 12px;background:var(--bg);border:1.5px solid var(--line);border-radius:10px;font-family:var(--font);font-size:13px;font-weight:500;color:var(--ink);outline:none;transition:border-color .18s;-webkit-appearance:none}
.fld input:focus{border-color:var(--blue)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.cfoot{padding:12px 18px 2px;border-top:1px solid var(--line);flex-shrink:0}
.btnmain{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--ink);color:#fff;border:none;padding:15px 18px;border-radius:13px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .15s,transform .14s}
.btnmain:active{opacity:.87;transform:scale(.98)}
.btnmain:disabled{opacity:.35;cursor:not-allowed;transform:none}
.btnwa{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--wa);color:#fff;border:none;padding:15px 18px;border-radius:13px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;transition:opacity .15s,transform .14s;box-shadow:0 4px 16px rgba(37,211,102,.26)}
.btnwa:active{opacity:.87;transform:scale(.98)}
.btnback{background:none;border:none;color:var(--ink2);font-family:var(--font);font-size:12px;font-weight:500;cursor:pointer;padding:10px 0 0;display:flex;align-items:center;gap:4px}
.ferr{font-size:11px;color:var(--red);margin-top:5px;display:none}
.ferr.show{display:block}

/* BADGE 360° */
.b360{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.62);color:#fff;font-size:10px;font-weight:700;padding:4px 9px;border-radius:12px;letter-spacing:.06em}

/* MODE ROW (admin) */
.mode-row{display:flex;gap:6px;padding:10px 16px 0;flex-shrink:0}
.mode-btn{flex:1;padding:8px;border:1.5px solid var(--line);border-radius:9px;font-family:var(--font);font-size:11px;font-weight:700;cursor:pointer;background:var(--bg);color:var(--ink2);transition:all .15s}
.mode-btn.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* GUÍA DE CUIDADO */
.guia-modal{position:fixed;inset:0;z-index:520;display:none}
.guia-modal.on{display:block}
.guia-scrim{position:absolute;inset:0;background:rgba(0,0,0,.5);backdrop-filter:blur(6px)}
/* OJO: este modal se centra con translate(-50%,-50%); usa guiaIn (no pmIn) porque el estado
   final de pmIn pisaría el translate y dejaría la tarjeta descentrada (bug Fase 16). */
.guia-wrap{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(94vw,540px);max-height:92vh;overflow-y:auto;background:var(--white);border-radius:24px;box-shadow:0 24px 70px rgba(0,0,0,.35);animation:guiaIn .3s cubic-bezier(.16,1,.3,1) both;-webkit-overflow-scrolling:touch}
@keyframes guiaIn{from{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}
/* En móvil real, 92vh es MÁS alto que lo visible (la barra del navegador come pantalla) → los
   extremos de la tarjeta quedaban inalcanzables. dvh = altura visible dinámica. */
@supports (height:1dvh){.guia-wrap{max-height:calc(100dvh - 28px)}}
.guia-close{position:sticky;top:12px;float:right;margin:12px 12px 0 0;width:32px;height:32px;background:rgba(255,255,255,.85);border:1px solid var(--line);border-radius:50%;font-size:13px;cursor:pointer;z-index:3}
.guia-head{padding:28px 24px 22px;text-align:center;background:linear-gradient(160deg,#1a1a18,#2c2c28);color:#fff;border-radius:24px 24px 0 0}
.guia-logo{font-size:15px;font-weight:800;letter-spacing:-.02em;opacity:.9;margin-bottom:14px}
.guia-logo sup{font-size:8px}
.guia-kicker{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#1a1a18;background:#f2c94c;padding:4px 12px;border-radius:20px}
.guia-title{font-size:24px;font-weight:800;letter-spacing:-.03em;margin:12px 0 6px;line-height:1.15;color:#fff}
.guia-sub{font-size:13px;color:rgba(255,255,255,.7);line-height:1.5}
.guia-body{padding:20px 22px 8px}
.guia-step{display:flex;align-items:center;gap:10px;margin:22px 0 12px}
.guia-step:first-child{margin-top:4px}
.guia-num{width:26px;height:26px;flex-shrink:0;background:var(--ink);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800}
.guia-step-h{font-size:15px;font-weight:700;letter-spacing:-.02em}
.guia-mats{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.guia-mat{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:12px 10px;text-align:center}
.guia-mat-ico{font-size:26px;line-height:1}
.guia-mat-t{font-size:12px;font-weight:800;margin:6px 0 4px}
.guia-mat-d{font-size:10.5px;line-height:1.4;color:var(--ink2)}
.guia-card{background:var(--bg);border:1px solid var(--line);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:10px}
.guia-card-h{font-size:14px;font-weight:800;margin-bottom:2px}
.guia-row{display:flex;align-items:flex-start;gap:10px;font-size:13px;line-height:1.45;color:var(--ink)}
.guia-ic{font-size:18px;line-height:1.2;flex-shrink:0}
.guia-no{background:#fdecea;border-color:#f8d4cf}
.guia-no .guia-card-h{color:#d9492f}
.guia-pills{display:flex;flex-wrap:wrap;gap:7px}
.guia-pill{background:var(--white);border:1px solid #f3c7c0;color:#b53d28;font-size:11.5px;font-weight:600;padding:7px 11px;border-radius:20px}
.guia-tip{background:#eaf6ef;border-color:#cdebd8}
.guia-tip .guia-card-h{color:#1ba94c}
.guia-cupon{margin-top:14px;background:#eef4ff;border:1px dashed #9cc0ff;color:#0052cc;border-radius:12px;padding:12px 14px;font-size:12.5px;font-weight:600;text-align:center;line-height:1.5}
.guia-foot{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);text-align:center;font-size:13px;font-weight:600;color:var(--ink);line-height:1.7}
.guia-wa{display:inline-block;margin:8px 0;background:#25D366;color:#fff;text-decoration:none;font-size:13px;font-weight:700;padding:10px 20px;border-radius:30px}
.guia-foot span{display:block;font-size:12px;color:var(--ink3);font-weight:500;margin-top:8px}
.guia-actions{position:sticky;bottom:0;background:var(--white);border-top:1px solid var(--line);padding:14px 22px;border-radius:0 0 24px 24px}
.guia-dl{width:100%;background:var(--ink);color:#fff;border:none;border-radius:12px;padding:13px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer}
.guia-mats{grid-template-columns:1fr 1fr 1fr}
@media(max-width:400px){.guia-mats{grid-template-columns:1fr;gap:7px}.guia-mat{display:flex;align-items:center;gap:10px;text-align:left;padding:10px 12px}.guia-mat-ico{font-size:22px}.guia-mat-t{margin:0}.guia-mat-d{font-size:11px}}
/* Impresión / Descargar PDF: solo la guía, limpia */
@media print{
  body.printing-guia>*{display:none!important}
  body.printing-guia #guiaModal{display:block!important;position:static}
  body.printing-guia .guia-scrim,body.printing-guia .guia-close,body.printing-guia .guia-actions{display:none!important}
  body.printing-guia .guia-wrap{position:static;transform:none;max-height:none;width:100%;box-shadow:none;border-radius:0;overflow:visible}
  body.printing-guia .guia-head{border-radius:0;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  body.printing-guia .guia-mat,body.printing-guia .guia-card,body.printing-guia .guia-pill,body.printing-guia .guia-cupon,body.printing-guia .guia-wa{-webkit-print-color-adjust:exact;print-color-adjust:exact;break-inside:avoid}
}

/* VISOR 360° */
/* z-650: por encima de la ficha (620) — ahora el 360 se abre con un botón DENTRO de la ficha */
.viewer360{position:fixed;inset:0;z-index:650;display:none;flex-direction:column;align-items:center;justify-content:center;background:rgba(0,0,0,.93);padding:20px}
.viewer360.on{display:flex}
.v360-wrap{position:relative;max-width:min(92vw,480px);width:100%;animation:pmIn .3s cubic-bezier(.16,1,.3,1) both}
.v360-stage{position:relative;width:100%;user-select:none;cursor:grab;touch-action:pan-y}
.v360-stage:active{cursor:grabbing}
.v360-img{width:100%;display:block;border-radius:16px;box-shadow:0 24px 60px rgba(0,0,0,.4);pointer-events:none;-webkit-user-drag:none}
.v360-hint{position:absolute;bottom:12px;left:0;right:0;text-align:center;font-size:11px;color:rgba(255,255,255,.5);font-weight:600;transition:opacity .4s;pointer-events:none;letter-spacing:.04em}
.v360-counter{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.5);color:#fff;font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px}
.v360-close{position:absolute;top:-12px;right:-12px;width:30px;height:30px;background:rgba(255,255,255,.2);border:none;border-radius:50%;color:#fff;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.v360-close:hover{background:rgba(255,255,255,.35)}
.v360-scrim{position:absolute;inset:0;z-index:-1;cursor:pointer}

/* POPUP DE BIENVENIDA ($20.000 OFF) */
.wm{position:fixed;inset:0;z-index:600;display:none;align-items:center;justify-content:center;padding:18px;background:rgba(14,14,12,.62);backdrop-filter:blur(3px)}
.wm.on{display:flex}
.wm-card{position:relative;width:100%;max-width:360px;background:var(--white);border-radius:22px;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.45);animation:pmIn .34s cubic-bezier(.16,1,.3,1) both;max-height:94vh;overflow-y:auto;-webkit-overflow-scrolling:touch}
.wm-close{position:absolute;top:10px;right:10px;width:38px;height:38px;border:none;border-radius:50%;background:rgba(255,255,255,.18);color:#fff;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:2}
.wm-close:hover{background:rgba(255,255,255,.32)}
.wm-head{background:var(--ink);color:#fff;padding:22px 22px 22px;text-align:center}
.wm-brand{font-size:12px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;margin-bottom:12px}
.wm-brand span{color:var(--red)}
.wm-kick{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--orange);margin-bottom:8px}
.wm-off{font-size:46px;font-weight:700;line-height:1;letter-spacing:-.02em}
.wm-off span{color:var(--red)}
.wm-sub{font-size:13px;font-weight:600;opacity:.82;margin-top:7px}
.wm-body{padding:18px 20px 22px}
.wm-intro{font-size:12.5px;color:var(--ink2);line-height:1.5;text-align:center;margin-bottom:14px}
.wm-fld{margin-bottom:10px}
.wm-fld label{display:block;font-size:11px;font-weight:700;color:var(--ink2);margin-bottom:5px}
.wm-fld input{width:100%;padding:13px 14px;background:var(--bg);border:1.5px solid var(--line);border-radius:11px;font-family:var(--font);font-size:16px;font-weight:600;color:var(--ink);outline:none;-webkit-appearance:none}
.wm-fld input:focus{border-color:var(--ink)}
.wm-err{display:none;font-size:11.5px;color:var(--red);font-weight:600;margin:2px 0 8px}
.wm-err.show{display:block}
.wm-btn{width:100%;padding:14px;background:var(--red);color:#fff;border:none;border-radius:13px;font-family:var(--font);font-size:15px;font-weight:700;cursor:pointer;margin-top:4px;transition:transform .12s,opacity .12s}
.wm-btn:active{transform:scale(.98)}
.wm-btn[disabled]{opacity:.6;cursor:default}
.wm-fine{font-size:10px;color:var(--ink3);text-align:center;margin-top:10px;line-height:1.4}
.wm-ok{text-align:center;padding:6px 4px 4px}
.wm-ok-ico{font-size:40px}
.wm-ok-t{font-size:18px;font-weight:700;margin:6px 0 4px}
.wm-ok-d{font-size:12.5px;color:var(--ink2);line-height:1.5;margin-bottom:14px}
.wm-code{display:flex;align-items:center;justify-content:space-between;gap:10px;background:var(--bg);border:2px dashed var(--red);border-radius:13px;padding:12px 16px;margin-bottom:6px;animation:wmPop .4s cubic-bezier(.16,1,.3,1) .15s both}
.wm-code b{font-size:19px;font-weight:700;letter-spacing:.06em;color:var(--ink)}
.wm-copy{border:none;background:var(--ink);color:#fff;font-family:var(--font);font-size:12px;font-weight:700;padding:8px 13px;border-radius:9px;cursor:pointer}
@keyframes wmPop{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
/* Urgencia: el código vence a los 7 días */
.wm-badge{display:inline-block;background:#fff4ec;color:#b4530a;border:1px solid #f3ddc9;border-radius:999px;font-size:10.5px;font-weight:700;padding:5px 12px;margin:4px 0 2px}
/* Paso 2 (zero-party data): chips de talla y género — un clic, sin fricción */
.wm-q{font-size:11px;font-weight:700;color:var(--ink2);margin:13px 0 7px}
.wm-q small{font-weight:600;color:var(--ink3)}
.wm-chips{display:flex;flex-wrap:wrap;gap:6px;justify-content:center}
.wm-chip{border:1.5px solid var(--line);background:var(--bg);color:var(--ink);font-family:var(--font);font-size:12.5px;font-weight:700;padding:8px 13px;border-radius:999px;cursor:pointer;transition:all .12s}
.wm-chip.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.wm-chip:active{transform:scale(.94)}
/* Tag anclado para reabrir el popup de descuento (si lo cerró sin registrarse) */
.wm-reopen{position:fixed;left:14px;bottom:max(16px,env(safe-area-inset-bottom));z-index:55;display:none;align-items:center;gap:7px;background:var(--white);color:var(--ink);border:1px solid var(--line);border-radius:14px;padding:10px 14px;font-family:var(--font);font-size:12px;font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.16);cursor:pointer;animation:pmIn .3s ease both}
.wm-reopen.show{display:inline-flex}
.wm-reopen:active{transform:scale(.95)}
/* Popup más compacto en móvil */
@media(max-width:480px){
  .wm-card{max-width:300px}
  .wm-head{padding:14px 16px 14px}
  .wm-brand{font-size:10px;margin-bottom:8px}
  .wm-kick{font-size:10px;margin-bottom:5px}
  .wm-off{font-size:31px}
  .wm-sub{font-size:11.5px;margin-top:5px}
  .wm-body{padding:13px 15px 16px}
  .wm-intro{font-size:11.5px;margin-bottom:11px}
  .wm-fld{margin-bottom:7px}
  .wm-fld input{padding:11px 13px}
  .wm-btn{padding:12px}
  .wm-chip{font-size:11.5px;padding:7px 11px}
  .wm-q{margin:11px 0 6px}
}

/* HERO CARRUSEL */
.hero{position:relative;width:100%;height:calc(100vh - var(--annH) - var(--navH));overflow:hidden;background:var(--ink);display:none;touch-action:pan-y}
.hero.on{display:block}
.hero-track{display:flex;height:100%;transition:transform .5s cubic-bezier(.16,1,.3,1)}
.hero-slide{position:relative;min-width:100%;height:100%}
.hero-slide picture{display:block;width:100%;height:100%}
.hero-slide img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none;user-select:none}
.hero-ov{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;background:rgba(0,0,0,.30);color:#fff;text-align:center}
/* HERO: el botón va ABAJO — centrado en móvil, abajo a la DERECHA en escritorio (no tapa el
   arte de la imagen). Solo aplica al hero: los banners M/H/U conservan su propio layout. */
.hero .hero-ov{justify-content:flex-end;padding:0 24px 38px;background:linear-gradient(to top,rgba(0,0,0,.35) 0%,rgba(0,0,0,.08) 30%,transparent 55%)}
.hero-tit{font-size:24px;font-weight:700;line-height:1.1;letter-spacing:.02em;text-transform:uppercase;text-shadow:0 2px 16px rgba(0,0,0,.5)}
.hero-sub{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;opacity:.92;margin-top:8px;text-shadow:0 1px 10px rgba(0,0,0,.45)}
.hero-cta{margin-top:18px;display:inline-block;background:rgba(0,0,0,.14);color:#fff;border:1.5px solid #fff;border-radius:8px;padding:10px 24px;font-family:var(--font);font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:transform .12s,background .15s}
.hero-cta:hover{background:rgba(255,255,255,.15)}
.hero-cta:active{transform:scale(.97)}
.hero-dots{position:absolute;top:14px;left:0;right:0;display:flex;justify-content:center;gap:6px;z-index:2}
.hero-dot{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.45);transition:width .25s,background .25s}
.hero-dot.on{width:20px;border-radius:5px;background:var(--white)}
@media(min-width:700px){
  /* el alto del hero lo da calc(100vh - barras) con las vars de escritorio (no override aquí) */
  .hero .hero-ov{padding:0 24px 64px}   /* botón abajo-CENTRADO con margen del borde inferior */
  .hero .hero-cta{font-size:16px;padding:16px 52px;border-width:2px;border-radius:10px}   /* más grande en escritorio */
  .hero-tit{font-size:40px}
  .hero-sub{font-size:13px}
  .hero-cta{font-size:13px;padding:12px 30px}
  .hero-slide img{object-position:center var(--pos,50%)}   /* encuadre escritorio por slide */
}

/* ÚLTIMOS LANZAMIENTOS — carrusel con burbujas de rotación */
.lanz{padding:50px 0 50px;background:var(--bg);position:relative}
@media(min-width:700px){.lanz{padding:99px 0 99px}}
.lanz-hdr{padding:0 16px 12px}
.lanz-t{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.lanz-row{display:flex;gap:8px;overflow-x:auto;scroll-snap-type:x mandatory;padding:0 16px 6px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.lanz-row::-webkit-scrollbar{display:none}
.lanz-row.centered{justify-content:center}
/* Tarjetas IGUALES en las 3 filas (lanzamientos + colección Mujer/Hombre) = mismo tamaño que "Nuestros modelos": 2 por pantalla en móvil, 4 en escritorio. */
.lanz-row .card{flex:0 0 calc(50% - 4px);max-width:none;scroll-snap-align:start}
@media(min-width:700px){.lanz-row{gap:10px}.lanz-row .card{flex:0 0 calc(25% - 7.5px)}}
.lanz-nav{position:absolute;top:55%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;background:var(--white);border:1px solid var(--line);box-shadow:0 3px 12px rgba(0,0,0,.14);font-size:21px;font-weight:700;line-height:1;color:var(--ink);display:none;align-items:center;justify-content:center;cursor:pointer;z-index:5;padding:0 0 2px;font-family:var(--font);transition:transform .15s}
.lanz-nav:active{transform:translateY(-50%) scale(.9)}
.lanz-nav.prev{left:6px}
.lanz-nav.next{right:6px}
.lanz-nav.show{display:flex}
@media(max-width:699px){.lanz-nav,.lanz-nav.show{display:none}}   /* móvil: sin flechas, se desliza con el dedo */

/* BANNERS DE COLECCIÓN (Mujer/Hombre) — reusan .hero-ov/.hero-tit/.hero-sub/.hero-cta */
.cbanner{position:relative;width:100%;aspect-ratio:4/5;max-height:70vh;overflow:hidden;background:var(--ink)}
.cbanner picture{display:block;width:100%;height:100%}
.cbanner img{width:100%;height:100%;object-fit:cover;display:block;-webkit-user-drag:none}
@media(min-width:700px){.cbanner{aspect-ratio:auto;height:62vh;max-height:640px}.cbanner img{object-position:center var(--pos,50%)}}
/* Mujer, Hombre y Unisex: banner a PANTALLA COMPLETA en escritorio (los tres iguales) */
@media(min-width:700px){#bannerM,#bannerH,#bannerU{height:100vh;max-height:100vh}}
/* Banners de colección: título + botón ABAJO (no centrado como el hero) */
.cbanner .hero-ov{justify-content:flex-end;padding:0 22px 30px;background:linear-gradient(to top,rgba(0,0,0,.8) 6%,rgba(0,0,0,.32) 50%,transparent)}

/* PREVIEW (inicio): 2 columnas + "Ver todo" */
/* padding-top igual al de las filas de colección (50px móvil / 99px escritorio) → mismo espacio
   entre el banner Unisex y "Nuestros modelos" que entre los demás banners y sus filas. */
.preview{padding:50px 0 12px;background:var(--bg)}
@media(min-width:700px){.preview{padding-top:99px}}
.preview-hdr{display:flex;align-items:center;justify-content:space-between;padding:0 16px 12px}
.preview-t{font-size:18px;font-weight:700;letter-spacing:-.01em;color:var(--ink)}
.preview-all{border:none;background:none;color:var(--ink);font-family:var(--font);font-size:12.5px;font-weight:700;cursor:pointer;padding:6px 2px}
.preview-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;padding:0 16px}
@media(max-width:699px){#previewGrid .card:nth-child(n+7){display:none}}   /* móvil: "Nuestros modelos" solo 6 (escritorio 8); NO aplica a favoritos */
@media(min-width:700px){.preview-grid{grid-template-columns:repeat(4,1fr);gap:10px}}
/* Filas de variedad por género (inicio): mismo carrusel y tamaño que "Últimos lanzamientos"
   (heredan de .lanz-row). position:relative para que las flechas ‹ › se posicionen dentro. */
.genrow{padding:50px 0 50px;background:var(--bg);position:relative}
@media(min-width:700px){.genrow{padding:99px 0 99px}}
/* Ventana de favoritos (modal full-screen, lo abre el ♥ del nav) */
.favmodal{position:fixed;inset:0;z-index:600;background:var(--bg);display:none;flex-direction:column}
.favmodal.on{display:flex}
.favmodal-head{flex:0 0 auto;display:flex;align-items:center;gap:12px;padding:13px 14px;background:var(--white);border-bottom:1px solid var(--line)}
.favmodal-back{width:38px;height:38px;border:none;background:var(--bg);border-radius:50%;font-size:20px;line-height:1;cursor:pointer;color:var(--ink);display:flex;align-items:center;justify-content:center;font-family:var(--font)}
.favmodal-back:active{transform:scale(.92)}
.favmodal-ttl{font-size:17px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
.favmodal-body{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;padding:14px 0 28px}
.favmodal-empty{padding:54px 26px;text-align:center;color:var(--ink3);font-size:13px;line-height:1.8}

/* CATÁLOGO COMPLETO (vista a pantalla completa) */
.catview{position:fixed;inset:0;z-index:560;background:var(--bg);overflow-y:auto;-webkit-overflow-scrolling:touch;display:none}
.catview.on{display:block}
.catview-bar{position:sticky;top:0;z-index:3;display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--white);border-bottom:1px solid var(--line)}
.catview-back{width:34px;height:34px;border:none;border-radius:50%;background:var(--bg);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink);flex-shrink:0}
.catview-title{font-size:15px;font-weight:700;color:var(--ink)}

/* TOGGLE Móvil/Escritorio (admin banners) */
/* Subida de banner: las DOS versiones (móvil + escritorio) visibles a la vez, lado a lado.
   (Antes un toggle escondía la de escritorio → los banners quedaban sin esa versión.) */
.up2{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.upcell{background:var(--white);border:1.5px dashed var(--ink3);border-radius:10px;padding:9px;display:flex;flex-direction:column;gap:7px;cursor:pointer;min-width:0}
.upcell-t{font-size:11px;font-weight:800;color:var(--ink);line-height:1.25;text-align:center}
.upcell-s{font-size:9.5px;color:var(--ink3);font-weight:600;text-align:center;line-height:1.3}
/* La miniatura toma la FORMA de su dispositivo: vertical (9:16) en móvil, horizontal (2:1) en
   escritorio → se identifica de un vistazo cuál foto pertenece a cuál versión. */
.upcell img{display:none;border-radius:7px;border:1px solid var(--line);object-fit:cover}
.upcell.mov img{width:62%;max-width:110px;aspect-ratio:9/16;margin:0 auto}
.upcell.esc img{width:100%;aspect-ratio:2/1}
.upcell.mov{border-color:#7da7d9}.upcell.mov .upcell-t{color:#2563ab}
.upcell.esc{border-color:#b59ddf}.upcell.esc .upcell-t{color:#6b46c1}

/* TOAST */
.toast{position:fixed;left:50%;bottom:84px;transform:translateX(-50%) translateY(20px);background:var(--ink);color:#fff;padding:11px 18px;border-radius:24px;font-size:13px;font-weight:600;z-index:700;opacity:0;pointer-events:none;transition:opacity .25s,transform .25s;box-shadow:0 6px 24px rgba(0,0,0,.32);max-width:90vw;text-align:center}
.toast.on{opacity:1;transform:translateX(-50%) translateY(0)}

/* CLIENTES FELICES (testimonios) */
.testi{padding:24px 0 14px;background:var(--bg)}
.testi-hdr{padding:0 16px 14px;text-align:center}
.testi-t{font-size:19px;font-weight:700;color:var(--ink)}
.testi-stars{color:#f5a623;font-size:15px;letter-spacing:1px;margin-top:5px}
.testi-stars span{color:var(--ink2);font-size:12px;font-weight:600;letter-spacing:0;margin-left:5px}
.testi-row{columns:2;column-gap:10px;padding:0 14px 8px}
@media(min-width:700px){.testi-row{columns:4;column-gap:14px;max-width:1120px;margin:0 auto;padding:0 24px 10px}}
.testi-card{break-inside:avoid;-webkit-column-break-inside:avoid;display:inline-block;width:100%;margin:0 0 10px;background:var(--white);border:1px solid var(--line);border-radius:14px;padding:14px;cursor:pointer}
@media(min-width:700px){.testi-card{margin-bottom:14px}}
.testi-card-top{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.testi-card-foto{width:40px;height:40px;border-radius:50%;object-fit:cover;flex-shrink:0;background:var(--bg)}
/* Pantallazo/foto del pedido recibido — grande arriba de la tarjeta (estilo elena) */
.testi-card-cap{width:100%;height:auto;display:block;border-radius:10px;margin-bottom:10px;background:var(--bg)}
.tm-cap{width:100%;height:auto;display:block;border-radius:12px;margin-top:12px;background:var(--bg)}
.testi-card-name{font-size:13px;font-weight:700;color:var(--ink);display:flex;align-items:center;gap:4px}
.testi-card-verif{color:#1aad49;font-size:11px}
.testi-card-date{font-size:10px;color:var(--ink3)}
.testi-card-stars{color:#f5a623;font-size:12px;letter-spacing:1px}
.testi-card-text{font-size:12.5px;color:var(--ink2);line-height:1.5;margin-top:6px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.testi-card-prod{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:9px;border-top:1px solid var(--line)}
.testi-card-prod img{width:34px;height:34px;border-radius:7px;object-fit:cover}
.testi-card-prod span{font-size:10.5px;color:var(--ink2);font-weight:600}
.testi-modal{position:fixed;inset:0;z-index:640;display:none}
.testi-modal.on{display:flex;align-items:center;justify-content:center;padding:20px}
.tm-scrim{position:fixed;inset:0;background:rgba(0,0,0,.55);cursor:pointer}
.tm-card{position:relative;background:var(--white);border-radius:18px;max-width:380px;width:100%;padding:22px;animation:pmIn .3s both;max-height:90vh;overflow-y:auto}
.tm-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border:none;background:var(--bg);border-radius:50%;font-size:14px;cursor:pointer}
.tm-head{display:flex;align-items:center;gap:12px}
.tm-foto{width:52px;height:52px;border-radius:50%;object-fit:cover}
.tm-name{font-size:15px;font-weight:700;color:var(--ink)}
.tm-date{font-size:11px;color:var(--ink3)}
.tm-stars{color:#f5a623;font-size:16px;letter-spacing:2px;margin-top:12px}
.tm-text{font-size:14px;color:var(--ink);line-height:1.6;margin-top:10px}
.tm-prod{width:100%;margin-top:16px;background:var(--ink);color:#fff;border:none;padding:13px;border-radius:12px;font-family:var(--font);font-size:14px;font-weight:700;cursor:pointer}

/* FOOTER (redes + newsletter) */
.ftr{background:var(--bg);border-top:1px solid var(--line);margin-top:6px}
.ftr-top{display:flex;flex-direction:column;gap:24px;padding:28px 20px}
.ftr-h{font-size:11px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink2);margin-bottom:12px}
.ftr-icons{display:flex;gap:12px;flex-wrap:wrap}
.ftr-icons a{width:42px;height:42px;border-radius:50%;background:var(--white);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink);transition:transform .12s}
.ftr-icons a:active{transform:scale(.92)}
.ftr-icons svg{width:20px;height:20px;fill:currentColor}
.ftr-news-sub{font-size:12.5px;color:var(--ink2);margin-bottom:10px;line-height:1.5}
.ftr-news-row{display:flex;gap:8px}
.ftr-news-row input{flex:1;min-width:0;padding:12px 14px;background:var(--white);border:1.5px solid var(--line);border-radius:10px;font-family:var(--font);font-size:16px;color:var(--ink);outline:none}
.ftr-news-row input:focus{border-color:var(--ink)}
.ftr-news-row button{padding:12px 18px;background:var(--ink);color:#fff;border:none;border-radius:10px;font-family:var(--font);font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}
.ftr-news-msg{font-size:12px;font-weight:600;margin-top:8px;min-height:16px}
.ftr-bottom{background:var(--ink);color:#fff;text-align:center;padding:22px 20px}
.ftr-logo{font-size:20px;font-weight:700;letter-spacing:.02em}
.ftr-copy{font-size:11px;opacity:.7;margin-top:6px}
@media(min-width:700px){.ftr-top{flex-direction:row;justify-content:space-between;align-items:flex-start;max-width:1000px;margin:0 auto;padding:40px 24px}.ftr-news{max-width:430px;flex:1;margin-left:48px}}

/* RESPONSIVE */
@media(min-width:520px){.grid,.liq-grid{grid-template-columns:repeat(3,1fr);gap:9px}}
@media(min-width:700px){.grid{padding:0 12px 24px}.grid,.liq-grid{grid-template-columns:repeat(4,1fr);gap:10px}.liq-grid{padding:0 12px}}
@media(min-width:1000px){.grid,.liq-grid{grid-template-columns:repeat(5,1fr);gap:10px}}
@media(min-width:1200px){.grid,.liq-grid{grid-template-columns:repeat(5,1fr);gap:12px}}
