/* ===== Top Outlet Vitrina — brand styles ===== */
:root{
  --red:#e3221f;
  --red-dark:#b81813;
  --yellow:#ffce00;
  --yellow-dark:#e6b800;
  --black:#141414;
  --ink:#1c1c1c;
  --paper:#fafafa;
  --card:#ffffff;
  --line:#ececec;
  --muted:#6e6e6e;
  --green:#1faa59;
  --green-dark:#178347;
  --shadow:0 6px 22px rgba(0,0,0,.09);
  --shadow-lg:0 18px 50px rgba(0,0,0,.16);
  --radius:16px;
  --wa:#25d366;
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;font-family:var(--font);color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;line-height:1.5;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:0}
.container{max-width:1180px;margin:0 auto;padding:0 18px}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ---- header ---- */
.topbar{background:var(--black);color:#fff;font-size:.82rem;letter-spacing:.02em}
.topbar .container{display:flex;justify-content:space-between;align-items:center;height:36px;gap:12px}
.topbar a{color:var(--yellow);font-weight:600}
.topbar .tloc{opacity:.8}

header.site{position:sticky;top:0;z-index:40;background:#fff;border-bottom:1px solid var(--line);box-shadow:0 2px 10px rgba(0,0,0,.04)}
.headrow{display:flex;align-items:center;gap:16px;height:74px}
.brand{display:flex;align-items:center;gap:11px;font-weight:800}
.brand img{width:48px;height:48px}
.brand b{font-size:1.05rem;line-height:1}
.brand span{display:block;font-size:.66rem;color:var(--muted);font-weight:600;letter-spacing:.14em}
.searchwrap{flex:1;max-width:460px;position:relative}
.searchwrap input{
  width:100%;height:44px;border:1.5px solid var(--line);border-radius:999px;
  padding:0 16px 0 42px;font-size:.95rem;background:#f6f6f6;transition:.15s;
}
.searchwrap input:focus{outline:none;border-color:var(--red);background:#fff}
.searchwrap svg{position:absolute;left:15px;top:13px;width:18px;height:18px;color:var(--muted)}
.headcta{margin-left:auto;display:flex;gap:10px;align-items:center}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;border-radius:999px;padding:11px 18px;font-size:.9rem;transition:.15s;white-space:nowrap}
.btn-wa{background:var(--wa);color:#fff}
.btn-wa:hover{filter:brightness(.95)}
.btn-ghost{background:#f1f1f1;color:var(--ink)}
.btn-ghost:hover{background:#e7e7e7}
.btn-red{background:var(--red);color:#fff}
.btn-red:hover{background:var(--red-dark)}
.btn-yellow{background:var(--yellow);color:var(--black)}
.btn-yellow:hover{background:var(--yellow-dark)}
.btn-dark{background:var(--black);color:#fff}
.btn-block{width:100%;justify-content:center;padding:14px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ---- hero / deals strip ---- */
.hero{background:linear-gradient(120deg,var(--red) 0%,var(--red-dark) 60%,#7d0f0c 100%);color:#fff;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(255,206,0,.22),transparent 45%)}
.hero .container{position:relative;z-index:2;padding:30px 18px}
.heroflex{display:flex;gap:28px;align-items:center;flex-wrap:wrap}
.herotext{flex:1;min-width:280px}
.herotext .kick{display:inline-block;background:var(--yellow);color:var(--black);font-weight:800;font-size:.72rem;letter-spacing:.12em;padding:5px 12px;border-radius:999px;margin-bottom:14px}
.herotext h1{font-size:2.15rem;line-height:1.08;margin:0 0 10px;font-weight:800}
.herotext h1 em{color:var(--yellow);font-style:normal}
.herotext p{margin:0;opacity:.92;font-size:1rem;max-width:46ch}
.herobadges{display:flex;gap:14px;margin-top:18px;flex-wrap:wrap}
.herobadge{display:flex;flex-direction:column;background:rgba(0,0,0,.22);border:1px solid rgba(255,255,255,.16);border-radius:12px;padding:10px 14px}
.herobadge b{font-size:1.25rem;color:var(--yellow)}
.herobadge span{font-size:.72rem;opacity:.85}
.hb-btn{cursor:pointer;text-align:left;font-family:inherit;transition:.15s}
.hb-btn:hover{background:rgba(255,206,0,.22);border-color:var(--yellow)}

/* "nuevo hoy" ribbon on cards */
.pnew{position:absolute;top:10px;left:10px;background:var(--yellow);color:var(--black);font-weight:800;font-size:.66rem;letter-spacing:.04em;padding:4px 8px;border-radius:7px;text-transform:uppercase;z-index:2}
.pnew + .pstock{top:38px}

/* deals card */
.dealcard{background:#fff;color:var(--ink);border-radius:var(--radius);box-shadow:var(--shadow-lg);width:340px;max-width:100%;overflow:hidden}
.dealcard h3{margin:0;background:var(--black);color:var(--yellow);font-size:.82rem;letter-spacing:.1em;padding:11px 16px;text-transform:uppercase}
.dealgrid{display:grid;grid-template-columns:1fr auto auto;gap:0}
.dealgrid .dh{background:#f6f6f6;font-size:.66rem;font-weight:800;letter-spacing:.08em;color:var(--muted);padding:8px 14px;text-transform:uppercase}
.dealgrid .dc{padding:8px 14px;font-size:.86rem;border-top:1px solid var(--line)}
.dealgrid .dc.day{font-weight:700}
.dealgrid .dc.val{font-weight:800;text-align:right;color:var(--red)}
.dealgrid .today{background:#fff7d6}
.dealnote{font-size:.68rem;color:var(--muted);padding:9px 14px;background:#fafafa;border-top:1px solid var(--line)}

/* ---- brands / trust strip (scrolling marquee) ---- */
.brands{background:#fff;border-bottom:1px solid var(--line);overflow:hidden}
.brandsbar{display:flex;align-items:center;gap:14px;padding:13px 18px}
.brandlbl{font-size:.8rem;font-weight:700;color:var(--muted);white-space:nowrap;flex:none}
.marquee{flex:1;min-width:0;overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.mtrack{display:flex;gap:10px;width:max-content;animation:marq 26s linear infinite}
.brands:hover .mtrack{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mtrack span{font-weight:800;font-size:.9rem;color:#3a3a3a;background:#f4f4f4;border:1px solid var(--line);border-radius:8px;padding:6px 13px;white-space:nowrap}
.proof{flex:none;font-size:.82rem;font-weight:700;color:var(--ink);white-space:nowrap;display:flex;align-items:center;gap:6px}
.proof .star{color:#f5a623}
@media(max-width:760px){
  .brandsbar{flex-wrap:wrap;justify-content:center;gap:9px;padding:12px 14px}
  .brandlbl{display:none}
  .marquee{flex-basis:100%}
  .proof{flex-basis:100%;justify-content:center;font-size:.8rem}
}
@media(prefers-reduced-motion:reduce){.mtrack{animation:none}}

/* ---- category chips ---- */
.cats{background:#fff;border-bottom:1px solid var(--line);position:sticky;top:74px;z-index:30}
.catsrow{display:flex;gap:9px;overflow-x:auto;padding:13px 0;scrollbar-width:none}
.catsrow::-webkit-scrollbar{display:none}
.chip{flex:none;border:1.5px solid var(--line);background:#fff;border-radius:999px;padding:8px 15px;font-weight:600;font-size:.86rem;color:var(--ink);transition:.15s}
.chip:hover{border-color:var(--red)}
.chip.active{background:var(--black);border-color:var(--black);color:#fff}

/* ---- section head ---- */
.sechead{display:flex;align-items:flex-end;justify-content:space-between;margin:26px 0 16px;gap:12px;flex-wrap:wrap}
.sechead h2{margin:0;font-size:1.5rem;font-weight:800}
.sechead .count{color:var(--muted);font-size:.9rem;font-weight:600}

/* ---- product grid ---- */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;padding-bottom:40px}
.pcard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:.18s;display:flex;flex-direction:column;position:relative}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#ddd}
.pthumb{position:relative;aspect-ratio:1;background:#f3f3f3;overflow:hidden}
.pthumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.pcard:hover .pthumb img{transform:scale(1.05)}
.pfallback{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:3.4rem;background:linear-gradient(135deg,#fff7d6,#ffe9a8)}
.pstock{position:absolute;top:10px;left:10px;background:var(--black);color:var(--yellow);font-weight:800;font-size:.72rem;letter-spacing:.04em;padding:4px 9px;border-radius:7px}
.psource{position:absolute;top:10px;right:10px;background:rgba(255,255,255,.94);color:var(--ink);font-weight:700;font-size:.66rem;padding:4px 8px;border-radius:7px}
.pbody{padding:13px 14px 16px;display:flex;flex-direction:column;flex:1}
.pcat{font-size:.68rem;font-weight:700;letter-spacing:.08em;color:var(--red);text-transform:uppercase;margin-bottom:4px}
.ptitle{font-weight:700;font-size:.97rem;line-height:1.25;margin:0 0 4px}
.pcond{font-size:.74rem;color:var(--muted);margin-bottom:11px}
.pricerow{display:flex;align-items:baseline;gap:8px;margin-top:auto}
.price{font-size:1.32rem;font-weight:800;color:var(--ink)}
.pcard .btn{margin-top:12px}
.tag-apartado{position:absolute;inset:0;background:rgba(20,20,20,.55);display:flex;align-items:center;justify-content:center}
.tag-apartado span{background:var(--yellow);color:var(--black);font-weight:800;padding:8px 18px;border-radius:8px;transform:rotate(-7deg);font-size:1rem;letter-spacing:.05em;box-shadow:var(--shadow)}

/* empty */
.empty{text-align:center;padding:70px 20px;color:var(--muted)}
.empty .big{font-size:3rem;margin-bottom:10px}

/* ---- footer ---- */
footer.site{background:var(--black);color:#cfcfcf;margin-top:30px}
footer.site .container{padding:36px 18px;display:flex;gap:30px;flex-wrap:wrap;justify-content:space-between}
footer.site h4{color:#fff;margin:0 0 10px;font-size:.95rem}
footer.site a{color:#cfcfcf}footer.site a:hover{color:var(--yellow)}
footer.site .fcol{min-width:180px}
footer.site .fcol p{margin:5px 0;font-size:.88rem}
.credit{background:#000;color:#8a8a8a;text-align:center;padding:14px;font-size:.8rem}
.credit a{color:var(--yellow);font-weight:600}

/* ---- modal ---- */
.modal{position:fixed;inset:0;z-index:60;display:none;align-items:flex-end;justify-content:center}
.modal.open{display:flex}
.modal .backdrop{position:absolute;inset:0;background:rgba(0,0,0,.55)}
.sheet{position:relative;background:#fff;width:100%;max-width:460px;border-radius:20px 20px 0 0;padding:22px;box-shadow:var(--shadow-lg);max-height:92vh;overflow-y:auto;animation:slideup .25s ease}
@media(min-width:600px){.modal{align-items:center}.sheet{border-radius:20px}}
@keyframes slideup{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.sheet h3{margin:0 0 4px;font-size:1.25rem}
.sheet .sub{color:var(--muted);font-size:.88rem;margin:0 0 16px}
.steps{counter-reset:s;margin:0 0 16px;padding:0;list-style:none}
.steps li{position:relative;padding:0 0 14px 38px;font-size:.92rem}
.steps li::before{counter-increment:s;content:counter(s);position:absolute;left:0;top:-2px;width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;font-weight:800;font-size:.82rem;display:flex;align-items:center;justify-content:center}
.steps li b{display:block}
.sinpebox{background:#fff7d6;border:1.5px dashed var(--yellow-dark);border-radius:12px;padding:14px;text-align:center;margin-bottom:16px}
.sinpebox .lbl{font-size:.72rem;font-weight:700;letter-spacing:.1em;color:var(--muted);text-transform:uppercase}
.sinpebox .num{font-size:1.6rem;font-weight:800;letter-spacing:.04em}
.sinpebox .amt{color:var(--red);font-weight:800}
.uploadzone{border:2px dashed var(--line);border-radius:12px;padding:22px;text-align:center;color:var(--muted);cursor:pointer;transition:.15s;margin-bottom:14px}
.uploadzone:hover{border-color:var(--red);color:var(--ink)}
.uploadzone.has{border-color:var(--green);background:#f0fbf4;color:var(--green-dark)}
.field{margin-bottom:12px}
.field label{display:block;font-size:.8rem;font-weight:600;margin-bottom:5px}
.field input{width:100%;height:44px;border:1.5px solid var(--line);border-radius:10px;padding:0 13px;font-size:.95rem}
.field input:focus{outline:none;border-color:var(--red)}
.modal-close{position:absolute;top:14px;right:16px;background:#f1f1f1;width:34px;height:34px;border-radius:50%;font-size:1.1rem;color:var(--ink)}
.success{text-align:center;padding:10px 0}
.success .ok{width:66px;height:66px;border-radius:50%;background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2rem;margin:0 auto 14px}
.holdtimer{font-weight:800;color:var(--red)}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(120px);background:var(--black);color:#fff;padding:13px 20px;border-radius:12px;font-weight:600;font-size:.9rem;z-index:80;transition:.3s;box-shadow:var(--shadow-lg);display:flex;gap:9px;align-items:center}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast.ok{background:var(--green-dark)}

@media(max-width:640px){
  .headcta .lbl{display:none}
  .herotext h1{font-size:1.7rem}
  .searchwrap{order:3;flex-basis:100%;max-width:none}
  .headrow{height:auto;flex-wrap:wrap;padding:12px 0;gap:12px}
}
