/* ===================================================================
   CALZADO BETAN — Hoja de estilos global
   Tokens basados en el Manual de Marca v1.0 (con ajustes de legibilidad).
   Parte 1: estilos de la landing (extraídos de index.html).
   Parte 2: componentes del ecommerce (catálogo, producto, carrito,
            checkout, confirmación, mini-cart, toasts).
   =================================================================== */
:root{
  --verde:#75FF00;        /* SOLO relleno (botones/badges) con texto oscuro */
  --verde-osc:#4AA500;    /* Texto/precios sobre blanco (legible) */
  --verde-claro:#A5FF42;
  --azul:#2457FF;
  --azul-osc:#1433A3;
  --bg:#FAFAFA; --bg-2:#F3F4F6; --borde:#E5E7EB;
  --texto:#111827; --texto-2:#6B7280; --blanco:#FFFFFF;
  --grad-cta:linear-gradient(135deg,#2457FF 0%,#75FF00 100%);
  --grad-verde:linear-gradient(180deg,#A5FF42 0%,#75FF00 100%);
  --r-btn:16px; --r-card:24px; --h-btn:52px;
  --sh-card:0 4px 20px rgba(17,24,39,.06);
  --sh-card-hover:0 18px 40px rgba(17,24,39,.12);
  --sh-cta:0 10px 30px rgba(117,255,0,.35);
  --maxw:1200px;
  --f-display:"Montserrat",-apple-system,"Segoe UI",system-ui,sans-serif;
  --f-body:"Inter",-apple-system,"Segoe UI",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--f-body);color:var(--texto);background:var(--bg);
  line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4{font-family:var(--f-display);line-height:1.1;letter-spacing:-.02em;font-weight:800}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.container{max-width:var(--maxw);margin:0 auto;padding:0 24px}
section{position:relative}
html.no-scroll{overflow:hidden}

/* Patrón de fondo sutil (huellas) — ~3.5% opacidad */
.bg-pattern{
  position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180' viewBox='0 0 180 180'%3E%3Cg fill='%23111827'%3E%3Cellipse cx='42' cy='52' rx='13' ry='18'/%3E%3Cellipse cx='49' cy='86' rx='9' ry='12'/%3E%3Ccircle cx='28' cy='34' r='3'/%3E%3Ccircle cx='37' cy='29' r='3'/%3E%3Ccircle cx='47' cy='30' r='3'/%3E%3Ccircle cx='56' cy='34' r='3'/%3E%3Cellipse cx='132' cy='128' rx='13' ry='18'/%3E%3Cellipse cx='139' cy='162' rx='9' ry='12'/%3E%3Ccircle cx='118' cy='110' r='3'/%3E%3Ccircle cx='127' cy='105' r='3'/%3E%3Ccircle cx='137' cy='106' r='3'/%3E%3Ccircle cx='146' cy='110' r='3'/%3E%3C/g%3E%3C/svg%3E");
  background-size:200px;
}

/* ============================ Botones ============================ */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:var(--h-btn);padding:0 26px;border-radius:var(--r-btn);
  font-family:var(--f-display);font-weight:700;font-size:15.5px;
  transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .2s,color .2s;
  white-space:nowrap;
}
.btn .ico{width:19px;height:19px}
.btn-primary{background:var(--verde);color:var(--texto)}
.btn-primary:hover{transform:scale(1.03);box-shadow:var(--sh-cta)}
.btn-secondary{background:var(--blanco);color:var(--azul);border:1.5px solid var(--azul)}
.btn-secondary:hover{transform:scale(1.03);background:rgba(36,87,255,.06)}
.btn-white{background:var(--blanco);color:var(--texto)}
.btn-white:hover{transform:scale(1.03);box-shadow:0 14px 36px rgba(0,0,0,.22)}
.btn-sm{height:42px;padding:0 18px;font-size:14px}

/* ============================ Navbar ============================ */
header{position:fixed;top:0;left:0;right:0;z-index:60;padding:16px 16px 0;transition:padding .35s ease}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;gap:18px;
  max-width:var(--maxw);margin:0 auto;padding:12px 20px;border-radius:0;
  background:rgba(250,250,250,0);border:1px solid transparent;
  transition:all .4s cubic-bezier(.2,.7,.2,1);
}
header.scrolled .nav-inner{
  max-width:880px;padding:9px 9px 9px 22px;border-radius:999px;
  background:rgba(255,255,255,.72);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--borde);box-shadow:0 12px 34px rgba(17,24,39,.10);
}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;gap:30px}
.nav-links a{font-family:var(--f-display);font-weight:600;font-size:15px;color:var(--texto);position:relative;padding:4px 0;transition:color .2s}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--azul);transition:width .25s}
.nav-links a:hover{color:var(--azul)}
.nav-links a:hover::after{width:100%}
.nav-actions{display:flex;align-items:center;gap:10px}
.nav-burger{display:none;width:42px;height:42px;border-radius:12px;align-items:center;justify-content:center;color:var(--texto)}
.nav-burger svg{width:24px;height:24px}
.nav-mobile{display:none}

/* ============================ Hero ============================ */
.hero{
  min-height:100vh;min-height:100svh;display:grid;align-items:center;align-content:center;
  grid-template-columns:1.05fr .95fr;gap:40px;
  padding:130px 24px 70px;max-width:var(--maxw);margin:0 auto;
}
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;font-family:var(--f-display);
  font-weight:700;font-size:13px;letter-spacing:.04em;text-transform:uppercase;
  color:var(--verde-osc);background:rgba(117,255,0,.12);padding:7px 14px;border-radius:999px;margin-bottom:22px;
}
.eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--verde-osc)}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);margin-bottom:20px}
.hero h1 .azul{color:var(--azul)}
.hero p.sub{font-size:clamp(1.05rem,1.6vw,1.3rem);color:var(--texto-2);max-width:30ch;margin-bottom:32px}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:34px}
.hero-trust{display:flex;flex-wrap:wrap;gap:14px 26px}
.trust-item{display:flex;align-items:center;gap:9px;font-size:14.5px;font-weight:500;color:var(--texto)}
.trust-item .chk{display:inline-flex;width:22px;height:22px;border-radius:50%;background:rgba(117,255,0,.18);align-items:center;justify-content:center;color:var(--verde-osc)}
.trust-item .chk svg{width:13px;height:13px;stroke-width:3}

/* Word-mask para el titular */
.split .word{display:inline-block;overflow:hidden;vertical-align:top;padding-bottom:.14em;margin-bottom:-.14em}
.split .w-in{display:inline-block}

/* Visual del hero: producto flotando */
.hero-visual{perspective:1100px;display:flex;justify-content:center;align-items:center}
.product-stage{transform-style:preserve-3d;will-change:transform;position:relative}
.product-tile{
  width:min(78vw,460px);aspect-ratio:4/3;border-radius:30px;overflow:hidden;
  background:var(--blanco);box-shadow:0 40px 80px -20px rgba(17,24,39,.35),0 0 0 1px rgba(17,24,39,.04);
}
.product-tile img{width:100%;height:100%;object-fit:cover}
.product-glow{position:absolute;inset:auto 6% -6% 6%;height:40px;border-radius:50%;
  background:radial-gradient(ellipse,rgba(17,24,39,.22),transparent 70%);filter:blur(8px);z-index:-1}
.product-badge{
  position:absolute;top:-14px;right:-10px;z-index:2;background:var(--azul);color:#fff;
  font-family:var(--f-display);font-weight:800;font-size:14px;padding:12px 16px;border-radius:16px;
  box-shadow:0 12px 24px rgba(36,87,255,.35);transform:rotate(4deg)}
.product-badge small{display:block;font-weight:600;font-size:10.5px;opacity:.85;letter-spacing:.03em}

/* ============================ Logo cloud ============================ */
.brands{padding:34px 0;border-top:1px solid var(--borde);border-bottom:1px solid var(--borde);background:rgba(255,255,255,.5)}
.brands .label{text-align:center;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--texto-2);margin-bottom:22px;font-weight:600}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.marquee-track{display:flex;align-items:center;gap:60px;width:max-content;animation:scrollx 30s linear infinite}
.marquee:hover .marquee-track{animation-play-state:paused}
.brand-logo{height:30px;width:auto;flex:none}
.brand-logo path{fill:#aab1bd;transition:fill .3s}
.brand-logo.brand-wide{height:23px}
.marquee:hover .brand-logo:hover path{fill:var(--texto-2)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ============================ Encabezado de sección ============================ */
.sec{padding:96px 0}
.sec-head{max-width:640px;margin:0 auto 56px;text-align:center}
.sec-head .tag{font-family:var(--f-display);font-weight:700;font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--azul);margin-bottom:14px;display:block}
.sec-head h2{font-size:clamp(2rem,4vw,2.9rem);margin-bottom:14px}
.sec-head p{color:var(--texto-2);font-size:1.08rem}

/* ============================ Bento grid ============================ */
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:18px}
.bento-item{position:relative;border-radius:var(--r-card);overflow:hidden;background:var(--bg-2);box-shadow:var(--sh-card);isolation:isolate}
.bento-item img{position:absolute;inset:0;width:100%;height:112%;top:-6%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.bento-item:hover img{transform:scale(1.06)}
.bento-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(17,24,39,.72));z-index:1}
.bento-text{position:absolute;left:0;bottom:0;z-index:2;padding:26px;color:#fff}
.bento-text h3{font-size:1.5rem;color:#fff;margin-bottom:4px}
.bento-text p{font-size:.95rem;opacity:.9}
.bento-item.big{grid-column:span 2;grid-row:span 2}
.bento-item.big .bento-text h3{font-size:2.1rem}
.bento-item.wide{grid-column:span 2}

/* ============================ Categorías ============================ */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cat-card{position:relative;border-radius:var(--r-card);overflow:hidden;aspect-ratio:3/2.3;box-shadow:var(--sh-card);isolation:isolate}
.cat-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1),filter .4s}
.cat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(17,24,39,.05),rgba(17,24,39,.6));z-index:1;transition:background .4s}
.cat-card:hover img{transform:scale(1.08);filter:brightness(1.08)}
.cat-card:hover::after{background:linear-gradient(180deg,rgba(36,87,255,.12),rgba(17,24,39,.62))}
.cat-label{position:absolute;left:0;bottom:0;z-index:2;padding:24px;width:100%;display:flex;align-items:center;justify-content:space-between}
.cat-label span{font-family:var(--f-display);font-weight:800;font-size:1.55rem;color:#fff}
.cat-label .arrow{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.18);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;color:#fff;transition:background .3s,transform .3s}
.cat-card:hover .cat-label .arrow{background:var(--verde);color:var(--texto);transform:translateX(2px)}
.cat-label .arrow svg{width:18px;height:18px}

/* ============================ Showcase (Apple) ============================ */
.showcase{background:var(--blanco);overflow:hidden}
.showcase-inner{display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px;min-height:80vh;max-width:var(--maxw);margin:0 auto;padding:80px 24px}
.showcase-visual{display:flex;justify-content:center;perspective:1300px}
.showcase-visual .product-tile{width:min(80vw,420px);aspect-ratio:1;box-shadow:0 50px 90px -30px rgba(17,24,39,.4),0 0 0 1px rgba(17,24,39,.04);will-change:transform}
.showcase-copy .tag{color:var(--verde-osc)}
.showcase-copy h2{font-size:clamp(2.2rem,4.5vw,3.4rem);margin-bottom:18px}
.showcase-copy .lead{color:var(--texto-2);font-size:1.15rem;margin-bottom:30px}
.spec-list{display:flex;flex-direction:column;gap:16px}
.spec{display:flex;align-items:center;gap:14px;font-weight:600;font-size:1.05rem}
.spec .si{width:44px;height:44px;border-radius:14px;background:var(--bg-2);display:flex;align-items:center;justify-content:center;color:var(--azul);flex:none}
.spec .si svg{width:22px;height:22px}

/* ============================ Productos (masonry / grid) ============================ */
.masonry{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.prod-card{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--sh-card);transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .3s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-6px);box-shadow:var(--sh-card-hover)}
.prod-media{position:relative;overflow:hidden;background:var(--bg-2)}
.prod-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.2,.7,.2,1)}
.prod-card:hover .prod-media img{transform:scale(1.04)}
.prod-card .prod-media{height:340px}
.prod-disc{position:absolute;top:14px;left:14px;background:var(--azul);color:#fff;font-family:var(--f-display);font-weight:800;font-size:13px;padding:6px 11px;border-radius:10px}
.prod-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:6px;flex:1}
.prod-cat{font-size:12.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--texto-2);font-weight:600}
.prod-name{font-family:var(--f-display);font-weight:800;font-size:1.25rem}
.prod-price{display:flex;align-items:baseline;gap:10px;margin-top:2px}
.prod-price .now{font-family:var(--f-display);font-weight:800;font-size:1.4rem;color:var(--verde-osc)}
.prod-price .was{font-size:.95rem;color:var(--texto-2);text-decoration:line-through}
.prod-card .btn{margin-top:14px;width:100%}
.prod-card.reversed{flex-direction:column-reverse}

/* ============================ Footer ============================ */
footer{background:var(--bg-2);padding:60px 0 30px;margin-top:0}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;padding-bottom:40px;border-bottom:1px solid var(--borde)}
.foot-brand img{height:40px;margin-bottom:16px}
.foot-brand p{color:var(--texto-2);font-size:.95rem;max-width:30ch}
.foot-col h4{font-family:var(--f-display);font-size:1rem;margin-bottom:16px}
.foot-col a{display:block;color:var(--texto-2);font-size:.95rem;padding:5px 0;transition:color .2s}
.foot-col a:hover{color:var(--azul)}
.foot-bottom{padding-top:24px;text-align:center;color:var(--texto-2);font-size:.88rem}

/* ============================ Reveal (estado inicial; GSAP anima) ============================ */
html.js .reveal{opacity:0;transform:translateY(28px)}
html.js .hero-fade{opacity:0;transform:translateY(24px)}
html.js .split .w-in{transform:translateY(115%)}

/* ============================ Responsive (landing) ============================ */
@media(max-width:980px){
  .nav-links,.nav-actions .btn{display:none}
  .nav-burger{display:flex}
  .hero{grid-template-columns:1fr;text-align:center;padding-top:120px;gap:30px}
  .hero p.sub{margin-left:auto;margin-right:auto}
  .hero-cta,.hero-trust{justify-content:center}
  .eyebrow{margin-left:auto;margin-right:auto}
  .hero-visual{order:-1}
  .showcase-inner{grid-template-columns:1fr;text-align:center;gap:30px}
  .showcase-copy .spec-list{align-items:center}
  .foot-grid{grid-template-columns:1fr 1fr}
  /* Menú móvil desplegable */
  header.menu-open .nav-mobile{display:flex}
  .nav-mobile{position:absolute;top:calc(100% + 8px);left:16px;right:16px;flex-direction:column;gap:4px;
    background:#fff;border:1px solid var(--borde);border-radius:20px;padding:14px;box-shadow:0 20px 40px rgba(17,24,39,.14)}
  .nav-mobile a{font-family:var(--f-display);font-weight:600;padding:12px 14px;border-radius:12px;font-size:1.05rem}
  .nav-mobile a:hover{background:var(--bg-2)}
  .nav-mobile .btn{display:flex;margin-top:6px}
}
@media(max-width:760px){
  .sec{padding:70px 0}
  .bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .bento-item.big{grid-column:span 2;grid-row:span 2}
  .bento-item.wide{grid-column:span 2}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .masonry{grid-template-columns:1fr}
  .prod-card .prod-media{height:300px}
  .hero-trust{display:none}
  .hero-cta .btn-secondary{display:none}
}
@media(max-width:460px){
  .cat-grid{grid-template-columns:1fr}
  .container{padding:0 18px}
}

/* Respeto a quien prefiere menos movimiento */
@media(prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
  html{scroll-behavior:auto}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}

/* ===================================================================
   PARTE 2 — COMPONENTES DEL ECOMMERCE
   =================================================================== */

/* ---------- Utilidades ---------- */
.btn-block{width:100%}
.btn-lg{height:58px;padding:0 34px;font-size:16.5px;border-radius:18px}
.btn-ghost{background:transparent;color:var(--texto-2)}
.btn-ghost:hover{background:var(--bg-2);color:var(--texto)}
.btn:disabled,.btn.is-disabled{opacity:.5;pointer-events:none;cursor:not-allowed}
.muted{color:var(--texto-2)}
.is-hidden{display:none!important}
.divider{height:1px;background:var(--borde);border:none;margin:18px 0}
.badge-pill{display:inline-flex;align-items:center;gap:6px;font-family:var(--f-display);font-weight:700;font-size:12px;letter-spacing:.03em;text-transform:uppercase;color:var(--verde-osc);background:rgba(117,255,0,.14);padding:5px 11px;border-radius:999px}
.stars{display:inline-flex;align-items:center;gap:2px;color:#f5b301}
.stars svg{width:16px;height:16px}
.stars .empty{color:var(--borde)}

/* ---------- Navbar sólida (páginas internas) ---------- */
header.solid{position:sticky;top:0;padding:0;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--borde)}
header.solid .nav-inner{max-width:var(--maxw);background:transparent;border:none;border-radius:0;padding:12px 24px}

/* Buscador en la navbar */
.nav-search{display:flex;align-items:center;gap:6px;background:var(--bg-2);border:1px solid var(--borde);border-radius:999px;padding:5px 6px 5px 16px;flex:1;max-width:330px}
.nav-search input{border:none;background:none;outline:none;font:inherit;font-size:14px;width:100%;color:var(--texto)}
.nav-search input::placeholder{color:var(--texto-2)}
.nav-search button{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--azul);color:#fff;flex:none;transition:background .2s}
.nav-search button:hover{background:var(--azul-osc)}
.nav-search button svg{width:17px;height:17px}
header.scrolled .nav-search{display:none}

/* Ícono de carrito + badge */
.nav-cart{position:relative;display:flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:14px;color:var(--texto);transition:background .2s}
.nav-cart:hover{background:var(--bg-2)}
.nav-cart svg{width:23px;height:23px}
.cart-badge{position:absolute;top:3px;right:3px;min-width:19px;height:19px;padding:0 5px;border-radius:999px;background:var(--azul);color:#fff;font-family:var(--f-display);font-weight:700;font-size:11px;display:flex;align-items:center;justify-content:center;line-height:1;box-shadow:0 0 0 2px var(--blanco)}
.cart-badge.is-empty{display:none}

/* ---------- Breadcrumbs ---------- */
.crumbs{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:13.5px;color:var(--texto-2);margin-bottom:18px}
.crumbs a{color:var(--texto-2);transition:color .2s}
.crumbs a:hover{color:var(--azul)}
.crumbs .sep{opacity:.5}
.crumbs .current{color:var(--texto);font-weight:600}

/* ---------- Cabecera de página ---------- */
.page-head{padding:38px 0 10px}
.page-head h1{font-size:clamp(1.9rem,4vw,2.7rem);margin-bottom:8px}
.page-head p{color:var(--texto-2);font-size:1.05rem}
main.page{min-height:60vh;padding-bottom:80px}

/* ---------- PLP: layout catálogo ---------- */
.plp{display:grid;grid-template-columns:262px 1fr;gap:34px;align-items:start}
.plp-side{position:sticky;top:90px}
.plp-bar{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:22px;flex-wrap:wrap}
.plp-bar .count{color:var(--texto-2);font-size:.95rem}
.plp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.plp-grid .prod-card .prod-media{height:260px}
.plp-grid .prod-name{font-size:1.1rem}
.plp-grid .prod-price .now{font-size:1.2rem}

/* Tarjeta de producto enlazable (PLP / relacionados) */
.prod-card .prod-media{display:block}
.prod-fav{position:absolute;top:12px;right:12px;z-index:2;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;color:var(--texto-2)}
.prod-meta-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.prod-rating{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;color:var(--texto-2);font-weight:600}
.prod-rating svg{width:13px;height:13px;color:#f5b301}

/* ---------- Filtros (sidebar) ---------- */
.filters{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-card);padding:8px 20px 18px;box-shadow:var(--sh-card)}
.filters-head{display:none;align-items:center;justify-content:space-between;padding:12px 0}
.filter-group{padding:16px 0;border-bottom:1px solid var(--borde)}
.filter-group:last-child{border-bottom:none}
.filter-group h4{font-size:.92rem;margin-bottom:12px;display:flex;align-items:center;justify-content:space-between}
.filter-opt{display:flex;align-items:center;gap:10px;padding:5px 0;font-size:14px;cursor:pointer;color:var(--texto)}
.filter-opt input{width:17px;height:17px;accent-color:var(--azul);cursor:pointer}
.filter-opt:hover{color:var(--azul)}
.filter-opt .opt-count{margin-left:auto;color:var(--texto-2);font-size:12.5px}
/* Tallas como chips */
.size-filter{display:flex;flex-wrap:wrap;gap:8px}
.size-chip{min-width:40px;height:36px;padding:0 8px;border:1.5px solid var(--borde);border-radius:10px;background:var(--blanco);font-weight:600;font-size:13.5px;color:var(--texto);display:flex;align-items:center;justify-content:center;transition:all .15s}
.size-chip:hover{border-color:var(--azul)}
.size-chip.active{background:var(--azul);border-color:var(--azul);color:#fff}
.filters-reset{margin-top:16px;width:100%}
.filters-toggle-btn{display:none}

/* Select de orden */
.sort-wrap{display:flex;align-items:center;gap:8px}
.sort-wrap label{font-size:13.5px;color:var(--texto-2);font-weight:600}
.select{height:42px;border:1.5px solid var(--borde);border-radius:12px;background:var(--blanco);padding:0 38px 0 14px;font:inherit;font-size:14px;font-weight:600;color:var(--texto);cursor:pointer;
  appearance:none;-webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center}
.select:focus{outline:none;border-color:var(--azul)}

/* Paginación */
.pagination{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:44px}
.pagination button,.pagination .page-num{min-width:42px;height:42px;padding:0 12px;border:1.5px solid var(--borde);border-radius:12px;background:var(--blanco);font-family:var(--f-display);font-weight:700;font-size:14px;color:var(--texto);display:inline-flex;align-items:center;justify-content:center;transition:all .15s}
.pagination button:hover:not(:disabled),.pagination .page-num:hover{border-color:var(--azul);color:var(--azul)}
.pagination .page-num.active{background:var(--azul);border-color:var(--azul);color:#fff}
.pagination button:disabled{opacity:.4;cursor:not-allowed}
.pagination svg{width:18px;height:18px}

/* Estado vacío */
.empty-state{text-align:center;padding:70px 20px;color:var(--texto-2)}
.empty-state .ico{width:84px;height:84px;border-radius:50%;background:var(--bg-2);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--texto-2)}
.empty-state .ico svg{width:40px;height:40px}
.empty-state h3{font-size:1.4rem;color:var(--texto);margin-bottom:8px}
.empty-state p{margin-bottom:22px}

/* ---------- PDP: página de producto ---------- */
.pdp{display:grid;grid-template-columns:1.05fr 1fr;gap:48px;align-items:start;padding-top:14px}
.pdp-gallery{position:sticky;top:90px}
.pdp-main{position:relative;border-radius:var(--r-card);overflow:hidden;background:var(--bg-2);aspect-ratio:1;box-shadow:var(--sh-card)}
.pdp-main img{width:100%;height:100%;object-fit:cover}
.pdp-main .prod-disc{font-size:14px;padding:7px 13px}
.pdp-thumbs{display:flex;gap:12px;margin-top:14px;flex-wrap:wrap}
.pdp-thumb{width:74px;height:74px;border-radius:14px;overflow:hidden;border:2px solid transparent;cursor:pointer;background:var(--bg-2);flex:none;transition:border-color .2s}
.pdp-thumb img{width:100%;height:100%;object-fit:cover}
.pdp-thumb.active{border-color:var(--azul)}

.pdp-info .pdp-brand{font-size:13px;letter-spacing:.05em;text-transform:uppercase;color:var(--azul);font-weight:700;margin-bottom:8px}
.pdp-info h1{font-size:clamp(1.7rem,3.4vw,2.4rem);margin-bottom:12px}
.pdp-rating{display:flex;align-items:center;gap:10px;margin-bottom:18px;font-size:14px;color:var(--texto-2)}
.pdp-price{display:flex;align-items:baseline;gap:14px;margin-bottom:8px}
.pdp-price .now{font-family:var(--f-display);font-weight:800;font-size:2rem;color:var(--verde-osc)}
.pdp-price .was{font-size:1.1rem;color:var(--texto-2);text-decoration:line-through}
.pdp-price .save{font-size:13px;font-weight:700;color:#fff;background:var(--azul);padding:4px 10px;border-radius:8px}
.pdp-tax{font-size:13px;color:var(--texto-2);margin-bottom:22px}
.pdp-desc{color:var(--texto-2);font-size:1rem;line-height:1.7;margin-bottom:26px}

.opt-block{margin-bottom:24px}
.opt-label{display:flex;align-items:center;justify-content:space-between;font-family:var(--f-display);font-weight:700;font-size:14px;margin-bottom:12px}
.opt-label .opt-current{color:var(--texto-2);font-weight:500}
.size-guide-link{font-size:13px;color:var(--azul);font-weight:600;cursor:pointer;background:none}
.size-guide-link:hover{text-decoration:underline}

/* Swatches de color */
.swatches{display:flex;flex-wrap:wrap;gap:12px}
.swatch{width:40px;height:40px;border-radius:50%;border:2px solid var(--borde);cursor:pointer;position:relative;transition:transform .15s;display:flex;align-items:center;justify-content:center}
.swatch:hover{transform:scale(1.08)}
.swatch.active{border-color:var(--azul);box-shadow:0 0 0 3px rgba(36,87,255,.18)}
.swatch .dot{width:30px;height:30px;border-radius:50%;border:1px solid rgba(17,24,39,.08)}

/* Tallas */
.sizes{display:flex;flex-wrap:wrap;gap:10px}
.size-btn{min-width:48px;height:46px;padding:0 10px;border:1.5px solid var(--borde);border-radius:12px;background:var(--blanco);font-family:var(--f-display);font-weight:700;font-size:14.5px;color:var(--texto);transition:all .15s}
.size-btn:hover:not(.is-disabled){border-color:var(--azul)}
.size-btn.active{background:var(--azul);border-color:var(--azul);color:#fff}
.size-btn.is-disabled{opacity:.35;text-decoration:line-through;cursor:not-allowed}

/* Stepper de cantidad */
.qty-stepper{display:inline-flex;align-items:center;border:1.5px solid var(--borde);border-radius:12px;overflow:hidden}
.qty-stepper button{width:42px;height:46px;font-size:20px;font-weight:600;color:var(--texto);display:flex;align-items:center;justify-content:center;transition:background .15s}
.qty-stepper button:hover:not(:disabled){background:var(--bg-2)}
.qty-stepper button:disabled{opacity:.4;cursor:not-allowed}
.qty-stepper .qty-val{min-width:46px;text-align:center;font-family:var(--f-display);font-weight:700;font-size:16px}

.pdp-actions{display:flex;gap:14px;align-items:stretch;margin:8px 0 20px;flex-wrap:wrap}
.pdp-actions .qty-block{flex:none}
.pdp-actions .btn{flex:1;min-width:200px}
.pdp-stock{font-size:13.5px;font-weight:600;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.pdp-stock .in{color:var(--verde-osc)}
.pdp-stock .low{color:#d97706}
.pdp-stock .out{color:#dc2626}
.pdp-stock .dot{width:8px;height:8px;border-radius:50%;background:currentColor}
.pdp-perks{display:grid;gap:12px;padding:20px;background:var(--bg-2);border-radius:18px}
.pdp-perk{display:flex;align-items:center;gap:12px;font-size:13.5px;color:var(--texto)}
.pdp-perk svg{width:20px;height:20px;color:var(--azul);flex:none}
.opt-error{color:#dc2626;font-size:13px;font-weight:600;margin-bottom:14px;display:none}
.opt-error.show{display:block}

/* Relacionados */
.related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.related-grid .prod-card .prod-media{height:230px}

/* ---------- Modal (guía de tallas) ---------- */
.modal-overlay{position:fixed;inset:0;z-index:120;background:rgba(17,24,39,.5);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
.modal-overlay.open{opacity:1;visibility:visible}
.modal{background:var(--blanco);border-radius:var(--r-card);max-width:520px;width:100%;max-height:86vh;overflow:auto;box-shadow:0 30px 80px rgba(17,24,39,.3);transform:translateY(16px) scale(.98);transition:transform .25s}
.modal-overlay.open .modal{transform:none}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:1px solid var(--borde)}
.modal-head h3{font-size:1.3rem}
.modal-close{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--texto-2)}
.modal-close:hover{background:var(--bg-2)}
.modal-body{padding:22px 24px}
.size-table{width:100%;border-collapse:collapse;font-size:14px}
.size-table th,.size-table td{padding:10px 12px;text-align:center;border-bottom:1px solid var(--borde)}
.size-table th{font-family:var(--f-display);font-weight:700;background:var(--bg-2)}

/* ---------- Mini-cart (drawer) + overlay ---------- */
.cart-overlay{position:fixed;inset:0;z-index:90;background:rgba(17,24,39,.5);backdrop-filter:blur(3px);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.cart-overlay.open{opacity:1;visibility:visible}
.cart-drawer{position:fixed;top:0;right:0;bottom:0;z-index:100;width:min(420px,92vw);background:var(--blanco);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.2,.7,.2,1);box-shadow:-20px 0 60px rgba(17,24,39,.18)}
.cart-drawer.open{transform:none}
.cart-drawer-head{display:flex;align-items:center;justify-content:space-between;padding:20px 22px;border-bottom:1px solid var(--borde)}
.cart-drawer-head h3{font-size:1.25rem}
.drawer-close{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--texto-2)}
.drawer-close:hover{background:var(--bg-2)}
.cart-drawer-body{flex:1;overflow-y:auto;padding:10px 22px}
.cart-drawer-foot{padding:18px 22px;border-top:1px solid var(--borde);display:flex;flex-direction:column;gap:10px}
.cart-drawer-foot .btn{margin:0}

.mini-line{display:flex;gap:14px;padding:16px 0;border-bottom:1px solid var(--borde)}
.mini-thumb{width:74px;height:74px;border-radius:14px;overflow:hidden;background:var(--bg-2);flex:none}
.mini-thumb img{width:100%;height:100%;object-fit:cover}
.mini-info{flex:1;min-width:0}
.mini-name{display:block;font-family:var(--f-display);font-weight:700;font-size:15px;color:var(--texto);margin-bottom:2px}
.mini-name:hover{color:var(--azul)}
.mini-meta{font-size:12.5px;color:var(--texto-2);margin-bottom:8px}
.mini-stepper{display:flex;align-items:center;gap:8px}
.mini-stepper button{width:28px;height:28px;border:1px solid var(--borde);border-radius:8px;font-size:16px;font-weight:700;color:var(--texto);display:flex;align-items:center;justify-content:center;transition:all .15s}
.mini-stepper button:hover{border-color:var(--azul);color:var(--azul)}
.mini-stepper span{font-weight:700;font-size:14px;min-width:18px;text-align:center}
.mini-stepper .mini-price{margin-left:auto;color:var(--verde-osc);font-family:var(--f-display);font-weight:800;font-size:14px;min-width:auto}
.mini-remove{align-self:flex-start;color:var(--texto-2);padding:4px;border-radius:8px}
.mini-remove:hover{color:#dc2626;background:rgba(220,38,38,.08)}
.cart-empty{text-align:center;padding:60px 16px;color:var(--texto-2)}
.cart-empty svg{margin:0 auto 16px;color:var(--borde)}
.cart-empty p{margin-bottom:18px;font-weight:600;color:var(--texto)}
.free-hint{font-size:13px;text-align:center;color:var(--texto-2);background:var(--bg-2);padding:8px;border-radius:10px}
.free-hint.ok{color:var(--verde-osc);background:rgba(117,255,0,.12);font-weight:600}
.summary-row{display:flex;align-items:center;justify-content:space-between;font-size:14.5px}

/* ---------- Toasts ---------- */
.toast-wrap{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{display:flex;align-items:center;gap:10px;background:var(--texto);color:#fff;padding:13px 20px;border-radius:14px;font-weight:600;font-size:14px;box-shadow:0 16px 40px rgba(17,24,39,.28);opacity:0;transform:translateY(16px);transition:opacity .3s,transform .3s;max-width:90vw}
.toast.show{opacity:1;transform:none}
.toast svg{flex:none;color:var(--verde)}
.toast-error{background:#dc2626}
.toast-error svg{color:#fff}

/* ---------- Carrito (página) ---------- */
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}
.cart-lines{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-card);box-shadow:var(--sh-card);padding:6px 24px}
.cart-line{display:grid;grid-template-columns:108px 1fr auto;gap:18px;padding:22px 0;border-bottom:1px solid var(--borde);align-items:center}
.cart-line:last-child{border-bottom:none}
.cart-line-img{width:108px;height:108px;border-radius:16px;overflow:hidden;background:var(--bg-2)}
.cart-line-img img{width:100%;height:100%;object-fit:cover}
.cart-line-name{font-family:var(--f-display);font-weight:800;font-size:1.1rem;margin-bottom:4px}
.cart-line-name a:hover{color:var(--azul)}
.cart-line-meta{font-size:13.5px;color:var(--texto-2);margin-bottom:12px}
.cart-line-bottom{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.cart-line-remove{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--texto-2);font-weight:600}
.cart-line-remove:hover{color:#dc2626}
.cart-line-remove svg{width:16px;height:16px}
.cart-line-price{text-align:right;font-family:var(--f-display);font-weight:800;font-size:1.15rem;color:var(--texto)}
.cart-line-price .unit{display:block;font-size:12px;color:var(--texto-2);font-weight:500}

/* Resumen de pedido (carrito + checkout) */
.cart-summary,.order-summary{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-card);box-shadow:var(--sh-card);padding:24px;position:sticky;top:90px}
.cart-summary h3,.order-summary h3{font-size:1.25rem;margin-bottom:18px}
.sum-rows{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}
.sum-row{display:flex;align-items:center;justify-content:space-between;font-size:14.5px;color:var(--texto)}
.sum-row .muted{color:var(--texto-2)}
.sum-row.discount{color:var(--verde-osc);font-weight:600}
.sum-total{display:flex;align-items:baseline;justify-content:space-between;padding-top:16px;border-top:1px solid var(--borde);margin-top:4px}
.sum-total .label{font-family:var(--f-display);font-weight:800;font-size:1.1rem}
.sum-total .val{font-family:var(--f-display);font-weight:800;font-size:1.6rem;color:var(--verde-osc)}

/* Cupón */
.coupon-form{display:flex;gap:8px;margin:18px 0}
.coupon-input{flex:1;height:46px;border:1.5px solid var(--borde);border-radius:12px;padding:0 14px;font:inherit;font-size:14px;text-transform:uppercase}
.coupon-input:focus{outline:none;border-color:var(--azul)}
.coupon-msg{font-size:13px;margin-top:-8px;margin-bottom:14px;min-height:18px}
.coupon-msg.ok{color:var(--verde-osc)}
.coupon-msg.err{color:#dc2626}
.coupon-applied{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(117,255,0,.12);border:1px dashed var(--verde-osc);border-radius:12px;padding:10px 14px;margin:18px 0;font-size:13.5px}
.coupon-applied strong{font-family:var(--f-display)}
.coupon-applied button{color:var(--texto-2);font-size:12px;font-weight:600;text-decoration:underline}
.coupon-applied button:hover{color:#dc2626}

/* ---------- Checkout ---------- */
.steps{display:flex;align-items:center;justify-content:center;gap:6px;margin:6px 0 30px;flex-wrap:wrap}
.step{display:flex;align-items:center;gap:10px;opacity:.5;transition:opacity .2s}
.step.active,.step.done{opacity:1}
.step-num{width:34px;height:34px;border-radius:50%;border:2px solid var(--borde);display:flex;align-items:center;justify-content:center;font-family:var(--f-display);font-weight:700;font-size:14px;color:var(--texto-2);flex:none}
.step.active .step-num{background:var(--azul);border-color:var(--azul);color:#fff}
.step.done .step-num{background:var(--verde-osc);border-color:var(--verde-osc);color:#fff}
.step.done .step-num svg{width:16px;height:16px}
.step-label{font-family:var(--f-display);font-weight:700;font-size:14px}
.step-sep{width:30px;height:2px;background:var(--borde)}
@media(max-width:620px){.step-label{display:none}.step-sep{width:18px}}

.checkout-layout{display:grid;grid-template-columns:1fr 360px;gap:34px;align-items:start}
.co-card{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-card);box-shadow:var(--sh-card);padding:28px}
.co-step{display:none}
.co-step.active{display:block;animation:co-in .35s ease}
@keyframes co-in{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.co-step h2{font-size:1.4rem;margin-bottom:6px}
.co-step .sub{color:var(--texto-2);font-size:.95rem;margin-bottom:22px}

/* Campos de formulario */
.field{margin-bottom:18px}
.field label{display:block;font-size:13.5px;font-weight:600;margin-bottom:7px}
.field .req{color:#dc2626}
.field input,.field select,.field textarea{width:100%;height:48px;border:1.5px solid var(--borde);border-radius:12px;padding:0 14px;font:inherit;font-size:15px;color:var(--texto);background:var(--blanco);transition:border-color .2s}
.field textarea{height:auto;padding:12px 14px;min-height:80px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--azul)}
.field.error input,.field.error select{border-color:#dc2626}
.field-error{display:none;color:#dc2626;font-size:12.5px;margin-top:6px}
.field.error .field-error{display:block}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field select.select{padding-right:38px}

/* Métodos de envío */
.ship-opt{display:flex;align-items:center;gap:14px;border:1.5px solid var(--borde);border-radius:14px;padding:16px 18px;margin-bottom:12px;cursor:pointer;transition:border-color .2s,background .2s}
.ship-opt:hover{border-color:var(--azul)}
.ship-opt.active{border-color:var(--azul);background:rgba(36,87,255,.04)}
.ship-opt input{width:18px;height:18px;accent-color:var(--azul)}
.ship-opt .ship-info{flex:1}
.ship-opt .ship-name{font-family:var(--f-display);font-weight:700;font-size:15px}
.ship-opt .ship-desc{font-size:13px;color:var(--texto-2)}
.ship-opt .ship-price{font-family:var(--f-display);font-weight:800;color:var(--verde-osc)}

/* Pago: tabs */
.pay-tabs{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:22px}
.pay-tab{display:flex;flex-direction:column;align-items:center;gap:7px;border:1.5px solid var(--borde);border-radius:14px;padding:14px 8px;font-family:var(--f-display);font-weight:700;font-size:12.5px;color:var(--texto);transition:all .2s;text-align:center}
.pay-tab:hover{border-color:var(--azul)}
.pay-tab.active{border-color:var(--azul);background:rgba(36,87,255,.05);color:var(--azul)}
.pay-tab svg{width:24px;height:24px}
.pay-panel{display:none}
.pay-panel.active{display:block}
.pay-note{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--texto-2);background:var(--bg-2);padding:14px 16px;border-radius:12px;margin-top:6px}
.pay-note svg{width:18px;height:18px;flex:none;color:var(--azul);margin-top:1px}
.card-brand{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-family:var(--f-display);font-weight:800;font-size:12px;color:var(--texto-2)}
.field.has-brand{position:relative}

/* Navegación entre pasos */
.co-nav{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:24px}
.co-nav .btn{min-width:150px}
.co-back{color:var(--texto-2);font-weight:600;display:inline-flex;align-items:center;gap:6px}
.co-back:hover{color:var(--texto)}
.co-back svg{width:18px;height:18px}

/* Mini items en el resumen */
.co-items{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:230px;overflow-y:auto}
.co-item{display:flex;gap:12px;align-items:center}
.co-item-thumb{position:relative;width:54px;height:54px;border-radius:10px;overflow:hidden;background:var(--bg-2);flex:none}
.co-item-thumb img{width:100%;height:100%;object-fit:cover}
.co-item-qty{position:absolute;top:-6px;right:-6px;min-width:20px;height:20px;border-radius:50%;background:var(--texto);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}
.co-item-info{flex:1;min-width:0}
.co-item-name{font-size:13.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.co-item-meta{font-size:12px;color:var(--texto-2)}
.co-item-price{font-weight:700;font-size:13.5px}

/* ---------- Confirmación ---------- */
.confirm{max-width:720px;margin:0 auto;text-align:center;padding-top:20px}
.confirm-icon{width:96px;height:96px;border-radius:50%;background:rgba(117,255,0,.16);display:flex;align-items:center;justify-content:center;margin:0 auto 22px;color:var(--verde-osc);animation:pop .5s cubic-bezier(.2,.9,.3,1.4)}
.confirm-icon svg{width:52px;height:52px}
@keyframes pop{0%{transform:scale(.4);opacity:0}100%{transform:scale(1);opacity:1}}
.confirm h1{font-size:clamp(1.9rem,4vw,2.6rem);margin-bottom:10px}
.confirm .lead{color:var(--texto-2);font-size:1.08rem;margin-bottom:6px}
.order-num{display:inline-block;font-family:var(--f-display);font-weight:800;font-size:1.1rem;color:var(--azul);background:rgba(36,87,255,.08);padding:8px 18px;border-radius:12px;margin:14px 0 30px;letter-spacing:.02em}
.confirm-card{background:var(--blanco);border:1px solid var(--borde);border-radius:var(--r-card);box-shadow:var(--sh-card);padding:28px;text-align:left;margin-bottom:26px}
.confirm-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.confirm-grid h4{font-size:.95rem;margin-bottom:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--texto-2)}
.confirm-section .line{font-size:14.5px;margin-bottom:4px}
.confirm-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.confirm-items{margin-top:8px}

/* ---------- Responsive (ecommerce) ---------- */
@media(max-width:980px){
  header.solid .nav-links{display:none}
  header.solid .nav-burger{display:flex}
  .nav-search{display:none}
  .nav-mobile .nav-search{display:flex;max-width:none;margin-top:8px}
  .plp{grid-template-columns:1fr;gap:0}
  .plp-side{position:static;margin-bottom:18px}
  .filters-toggle-btn{display:inline-flex}
  .filters{display:none}
  .filters.open{display:block}
  .cart-layout,.checkout-layout{grid-template-columns:1fr}
  .cart-summary,.order-summary{position:static}
  .pdp{grid-template-columns:1fr;gap:30px}
  .pdp-gallery{position:static}
  .related-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .plp-grid{grid-template-columns:repeat(2,1fr)}
  .plp-grid .prod-card .prod-media{height:200px}
  .confirm-grid{grid-template-columns:1fr;gap:20px}
  .pay-tabs{grid-template-columns:repeat(2,1fr)}
  .field-row{grid-template-columns:1fr}
}
@media(max-width:460px){
  .plp-grid{grid-template-columns:1fr}
  .related-grid{grid-template-columns:1fr}
  .cart-line{grid-template-columns:84px 1fr;grid-template-areas:"img main" "img price"}
  .cart-line-img{grid-area:img;width:84px;height:84px}
  .cart-line-price{grid-area:price;text-align:left;align-self:start}
  .pdp-actions .btn{min-width:100%}
}
