/* ============================================================
   TRÓPICO — Tienda virtual
   Estilos. Los colores se controlan con variables y el panel
   de administrador puede cambiarlos (--primary / --dark).
   ============================================================ */
:root{
  --primary:#E21F21;
  --primary-d:#b81618;
  --dark:#3C3C3B;
  --ink:#1f1f1f;
  --muted:#6b7280;
  --line:#e7e7e9;
  --bg:#f4f5f7;
  --white:#fff;
  --wa:#25D366;
  --radius:14px;
  --shadow:0 6px 22px rgba(0,0,0,.08);
  --shadow-h:0 14px 32px rgba(0,0,0,.14);
  --wrap:1200px;
  --font:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,Arial,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:var(--font);color:var(--ink);background:var(--bg);line-height:1.45}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 18px}
.hidden{display:none !important}

/* ---------- Top bar ---------- */
.topbar{background:var(--dark);color:#fff;font-size:13px}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:36px;gap:14px}
.topbar a{opacity:.9}
.topbar .tb-r{display:flex;gap:18px;align-items:center}
.topbar .tb-r span{display:inline-flex;align-items:center;gap:6px}
@media(max-width:680px){.topbar .tb-l{display:none}}

/* ---------- Header ---------- */
.header{background:#fff;position:sticky;top:0;z-index:40;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.header .wrap{display:flex;align-items:center;gap:20px;height:78px}
.brand{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.brand img{height:46px;width:auto}
.search{flex:1;display:flex;max-width:620px;border:2px solid var(--line);border-radius:999px;overflow:hidden;transition:.15s}
.search:focus-within{border-color:var(--primary)}
.search input{flex:1;border:none;outline:none;padding:11px 18px;font-size:15px;background:transparent}
.search button{background:var(--primary);color:#fff;padding:0 20px;font-size:18px}
.header-actions{display:flex;align-items:center;gap:10px;flex:0 0 auto}
.btn-wa{background:var(--wa);color:#fff;border-radius:999px;padding:10px 16px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.btn-wa:hover{filter:brightness(.95)}
.icon-link{color:var(--dark);font-size:13px;display:flex;flex-direction:column;align-items:center;gap:2px;padding:4px 6px}
.icon-link b{font-size:18px}
@media(max-width:860px){
  .header .wrap{flex-wrap:wrap;height:auto;padding-top:12px;padding-bottom:12px;gap:12px}
  .search{order:3;flex-basis:100%;max-width:none}
  .btn-wa span.lbl{display:none}
}

/* ---------- Category nav ---------- */
.catnav{background:var(--primary);position:sticky;top:78px;z-index:30}
.catnav .wrap{display:flex;gap:4px;align-items:center;overflow-x:auto;scrollbar-width:none}
.catnav .wrap::-webkit-scrollbar{display:none}
.catnav a{color:#fff;font-size:14px;font-weight:500;padding:13px 14px;white-space:nowrap;border-bottom:3px solid transparent;display:inline-flex;gap:7px;align-items:center}
.catnav a:hover,.catnav a.active{background:rgba(0,0,0,.12);border-bottom-color:#fff}
@media(max-width:860px){.catnav{top:auto;position:static}}

/* ---------- Hero ---------- */
.hero{position:relative;background:linear-gradient(120deg,var(--primary) 0%,var(--primary-d) 60%,#7d0f11 100%);color:#fff;overflow:hidden}
.hero::after{content:"";position:absolute;right:-80px;top:-80px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.07)}
.hero .wrap{position:relative;display:grid;grid-template-columns:1.1fr .9fr;gap:30px;align-items:center;padding:46px 18px;z-index:1}
.hero h1{font-size:38px;line-height:1.1;margin:0 0 14px;font-weight:800}
.hero p{font-size:17px;opacity:.95;margin:0 0 22px;max-width:520px}
.hero .cta{background:#fff;color:var(--primary);font-weight:700;padding:13px 26px;border-radius:999px;display:inline-flex;align-items:center;gap:9px;font-size:16px;box-shadow:var(--shadow)}
.hero .cta:hover{transform:translateY(-1px)}
.hero-badge{display:inline-block;background:rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.35);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;margin-bottom:16px;letter-spacing:.5px;text-transform:uppercase}
.hero-media{border-radius:18px;overflow:hidden;box-shadow:var(--shadow-h);aspect-ratio:16/10;background:rgba(0,0,0,.25);display:flex;align-items:center;justify-content:center}
.hero-media iframe,.hero-media video,.hero-media img{width:100%;height:100%;object-fit:cover;border:0}
.hero-media.placeholder{font-size:14px;color:rgba(255,255,255,.8);text-align:center;padding:20px;flex-direction:column;gap:8px}
.hero-media.placeholder b{font-size:34px}
@media(max-width:860px){.hero .wrap{grid-template-columns:1fr;padding:30px 18px}.hero h1{font-size:28px}.hero-media{order:-1}}

/* ---------- Benefits ---------- */
.benefits{background:#fff;border-bottom:1px solid var(--line)}
.benefits .wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:18px}
.benefit{display:flex;gap:12px;align-items:center;justify-content:center;text-align:left}
.benefit .bi{font-size:26px;background:#fff0f0;width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.benefit b{display:block;font-size:14px}
.benefit small{color:var(--muted);font-size:12.5px}
@media(max-width:760px){.benefits .wrap{grid-template-columns:1fr;gap:12px}.benefit{justify-content:flex-start}}

/* ---------- Sections ---------- */
.section{padding:34px 0}
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px}
.section-head h2{font-size:23px;margin:0;font-weight:700;position:relative;padding-left:14px}
.section-head h2::before{content:"";position:absolute;left:0;top:3px;bottom:3px;width:5px;border-radius:3px;background:var(--primary)}
.section-head a{color:var(--primary);font-weight:600;font-size:14px}

/* ---------- Category tiles ---------- */
.cat-tiles{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}
.cat-tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px 10px;text-align:center;transition:.15s}
.cat-tile:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateY(-2px)}
.cat-tile .ic{font-size:32px;margin-bottom:8px}
.cat-tile b{font-size:13px;display:block;line-height:1.2}
.cat-tile small{color:var(--muted);font-size:11.5px}
@media(max-width:980px){.cat-tiles{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.cat-tiles{grid-template-columns:repeat(2,1fr)}}

/* ---------- Product grid & cards ---------- */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
@media(max-width:980px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:720px){.grid{grid-template-columns:repeat(2,1fr);gap:12px}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.16s;position:relative}
.card:hover{box-shadow:var(--shadow-h);transform:translateY(-3px)}
.card .ph{aspect-ratio:1/1;background:#fff;display:flex;align-items:center;justify-content:center;padding:14px;cursor:pointer}
.card .ph img{max-height:100%;width:auto;object-fit:contain;mix-blend-mode:multiply}
.card .tag{position:absolute;top:10px;left:10px;background:var(--dark);color:#fff;font-size:11px;font-weight:600;padding:4px 9px;border-radius:999px;letter-spacing:.4px}
.card .warr{position:absolute;top:10px;right:10px;background:#fff7e6;color:#a86b00;font-size:10.5px;font-weight:700;padding:4px 8px;border-radius:999px;border:1px solid #ffe2a8}
.card .body{padding:12px 14px 14px;display:flex;flex-direction:column;gap:7px;flex:1}
.card .brand{font-size:11px;color:var(--muted);font-weight:600;letter-spacing:.6px;text-transform:uppercase}
.card .name{font-size:14px;font-weight:600;line-height:1.25;cursor:pointer;min-height:35px}
.card .name:hover{color:var(--primary)}
.card .price{font-size:21px;font-weight:800;color:var(--primary);margin-top:auto}
.card .price small{font-size:11px;color:var(--muted);font-weight:500;display:block;text-transform:none}
.card .buy{background:var(--wa);color:#fff;border-radius:10px;padding:10px;font-weight:600;font-size:13.5px;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.card .buy:hover{filter:brightness(.95)}

/* ---------- Breadcrumb ---------- */
.crumb{font-size:13px;color:var(--muted);padding:16px 0 4px}
.crumb a:hover{color:var(--primary)}

/* ---------- Category page toolbar ---------- */
.toolbar{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.toolbar h1{font-size:24px;margin:0}
.toolbar .count{color:var(--muted);font-size:13px;font-weight:400}
.toolbar select{border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:14px;background:#fff}

/* ---------- Product detail ---------- */
.pd{display:grid;grid-template-columns:1fr 1fr;gap:34px;padding:18px 0 10px}
.pd-gallery .main{background:#fff;border:1px solid var(--line);border-radius:var(--radius);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;padding:24px}
.pd-gallery .main img{max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.pd-thumbs{display:flex;gap:10px;margin-top:10px;flex-wrap:wrap}
.pd-thumbs img{width:66px;height:66px;object-fit:contain;border:2px solid var(--line);border-radius:10px;padding:5px;background:#fff;cursor:pointer}
.pd-thumbs img.active{border-color:var(--primary)}
.pd-info h1{font-size:27px;margin:6px 0 4px;line-height:1.2}
.pd-brand{font-size:12px;color:var(--muted);font-weight:700;letter-spacing:.6px;text-transform:uppercase}
.pd-code{font-size:12.5px;color:var(--muted);margin-top:2px}
.pd-price{font-size:36px;font-weight:800;color:var(--primary);margin:14px 0 2px}
.pd-price small{font-size:13px;color:var(--muted);font-weight:500}
.pd-note{font-size:12.5px;color:var(--muted);margin-bottom:14px}
.pd-specs{margin:8px 0 16px}
.pd-specs h3{font-size:14px;margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px;color:var(--dark)}
.pd-specs ul{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr 1fr;gap:7px 16px}
.pd-specs li{font-size:13.5px;display:flex;gap:8px;align-items:flex-start}
.pd-specs li::before{content:"✓";color:var(--primary);font-weight:800}
.gift{background:#fff7e6;border:1px solid #ffe2a8;color:#8a5a00;border-radius:12px;padding:10px 14px;font-size:13px;display:flex;gap:9px;align-items:center;margin-bottom:16px}
.qty{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.qty button{width:38px;height:38px;border:1px solid var(--line);border-radius:10px;font-size:20px;background:#fff}
.qty input{width:56px;height:38px;text-align:center;border:1px solid var(--line);border-radius:10px;font-size:16px}
.pd-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-buy-lg{background:var(--wa);color:#fff;font-weight:700;font-size:17px;padding:15px 26px;border-radius:12px;display:inline-flex;align-items:center;gap:11px;box-shadow:var(--shadow);flex:1;justify-content:center}
.btn-buy-lg:hover{filter:brightness(.96)}
.pd-meta{display:flex;gap:20px;margin-top:18px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:16px}
.pd-meta div{font-size:12.5px;color:var(--muted);display:flex;gap:8px;align-items:center}
.pd-meta b{color:var(--ink)}
@media(max-width:820px){.pd{grid-template-columns:1fr;gap:18px}.pd-specs ul{grid-template-columns:1fr}}

/* ---------- Footer ---------- */
.footer{background:var(--dark);color:#cfcfcf;margin-top:40px}
.footer .wrap{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:26px;padding:40px 18px 26px}
.footer img{height:40px;margin-bottom:12px}
.footer h4{color:#fff;font-size:15px;margin:0 0 12px}
.footer a,.footer p{font-size:13.5px;color:#cfcfcf;margin:7px 0;display:block}
.footer a:hover{color:#fff}
.footer .wa-cta{background:var(--wa);color:#fff;border-radius:12px;padding:12px 16px;font-weight:600;display:inline-flex;gap:9px;align-items:center;margin-top:6px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);text-align:center;font-size:12.5px;color:#9a9a9a;padding:14px}
@media(max-width:820px){.footer .wrap{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer .wrap{grid-template-columns:1fr}}

/* ---------- Floating WhatsApp ---------- */
.wa-float{position:fixed;right:18px;bottom:18px;z-index:60;background:var(--wa);color:#fff;width:58px;height:58px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;box-shadow:0 8px 24px rgba(37,211,102,.5);animation:waPulse 2.4s infinite}
.wa-float:hover{transform:scale(1.06)}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ---------- Empty / misc ---------- */
.empty{text-align:center;padding:60px 20px;color:var(--muted)}
.empty .ic{font-size:46px;margin-bottom:10px}

/* ============================================================
   PANEL DE ADMINISTRADOR
   ============================================================ */
.admin-shell{min-height:100vh;background:var(--bg)}
.admin-top{background:var(--dark);color:#fff;position:sticky;top:0;z-index:20}
.admin-top .wrap{display:flex;align-items:center;justify-content:space-between;height:62px;gap:14px}
.admin-top .at-l{display:flex;align-items:center;gap:12px;font-weight:700}
.admin-top .at-l .dot{background:var(--primary);color:#fff;padding:3px 9px;border-radius:7px;font-size:12px;letter-spacing:1px}
.admin-top .at-r{display:flex;gap:10px;align-items:center}
.admin-top a,.admin-top button{color:#fff;font-size:13.5px;padding:8px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.25)}
.admin-top a:hover,.admin-top button:hover{background:rgba(255,255,255,.12)}
.admin-layout{display:grid;grid-template-columns:220px 1fr;gap:22px;max-width:1100px;margin:0 auto;padding:22px 18px}
.admin-tabs{display:flex;flex-direction:column;gap:4px;position:sticky;top:84px;align-self:start}
.admin-tabs button{text-align:left;padding:11px 14px;border-radius:10px;font-size:14px;font-weight:500;color:var(--dark);display:flex;gap:10px;align-items:center}
.admin-tabs button:hover{background:#ececef}
.admin-tabs button.active{background:var(--primary);color:#fff}
.admin-main{min-width:0}
.panel{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:18px}
.panel h2{margin:0 0 4px;font-size:20px}
.panel .sub{color:var(--muted);font-size:13.5px;margin-bottom:18px}
@media(max-width:820px){.admin-layout{grid-template-columns:1fr}.admin-tabs{flex-direction:row;overflow-x:auto;position:static}}

/* form elements */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:5px;color:var(--dark)}
.field .hint{font-weight:400;color:var(--muted);font-size:12px}
.field input[type=text],.field input[type=number],.field input[type=password],.field textarea,.field select{
  width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;font-family:inherit;background:#fff}
.field textarea{min-height:90px;resize:vertical}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--primary)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media(max-width:620px){.row2,.row3{grid-template-columns:1fr}}
.check{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:500}
.check input{width:18px;height:18px}

.btn{background:var(--primary);color:#fff;border-radius:10px;padding:11px 18px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:8px}
.btn:hover{background:var(--primary-d)}
.btn.ghost{background:#fff;color:var(--dark);border:1px solid var(--line)}
.btn.ghost:hover{background:#f3f3f5}
.btn.green{background:var(--wa)}
.btn.danger{background:#fff;color:#c0392b;border:1px solid #f0c4bf}
.btn.danger:hover{background:#fff3f1}
.btn.sm{padding:7px 12px;font-size:13px}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}

/* admin product table */
.atable{width:100%;border-collapse:collapse;font-size:13.5px}
.atable th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px;padding:8px 10px;border-bottom:2px solid var(--line)}
.atable td{padding:9px 10px;border-bottom:1px solid var(--line);vertical-align:middle}
.atable tr:hover td{background:#fafafa}
.atable .pimg{width:46px;height:46px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:8px}
.atable .nm{font-weight:600}
.atable .muted{color:var(--muted);font-size:12px}
.pill{display:inline-block;font-size:11px;font-weight:700;padding:3px 8px;border-radius:999px}
.pill.on{background:#e7f7ec;color:#1a7f3c}
.pill.off{background:#f1f1f1;color:#888}
.pill.star{background:#fff3d6;color:#a8740a}

/* image manager */
.imgman{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.imgman .it{position:relative;width:84px;height:84px;border:1px solid var(--line);border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;padding:5px}
.imgman .it img{max-width:100%;max-height:100%;object-fit:contain}
.imgman .it button{position:absolute;top:-7px;right:-7px;background:var(--primary);color:#fff;width:22px;height:22px;border-radius:50%;font-size:13px;line-height:1;box-shadow:var(--shadow)}
.dropzone{border:2px dashed #d4d4d8;border-radius:12px;padding:18px;text-align:center;color:var(--muted);font-size:13.5px;cursor:pointer;transition:.15s}
.dropzone:hover{border-color:var(--primary);color:var(--primary);background:#fff7f7}

/* modal */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:80;display:flex;align-items:flex-start;justify-content:center;padding:30px 16px;overflow:auto}
.modal{background:#fff;border-radius:16px;max-width:720px;width:100%;padding:24px;box-shadow:var(--shadow-h)}
.modal h3{margin:0 0 16px;font-size:19px;display:flex;justify-content:space-between;align-items:center}
.modal h3 button{font-size:24px;color:var(--muted)}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--dark),#1c1c1c);padding:20px}
.login-card{background:#fff;border-radius:18px;padding:34px;max-width:380px;width:100%;text-align:center;box-shadow:var(--shadow-h)}
.login-card img{height:50px;margin:0 auto 18px}
.login-card h2{margin:0 0 4px;font-size:20px}
.login-card p{color:var(--muted);font-size:13.5px;margin:0 0 18px}
.login-card .field{text-align:left}
.login-card .btn{width:100%;justify-content:center}
.login-err{color:var(--primary);font-size:13px;margin-top:10px;min-height:18px}

/* toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);background:var(--dark);color:#fff;padding:12px 22px;border-radius:999px;font-size:14px;z-index:100;box-shadow:var(--shadow-h);opacity:0;transition:.25s;pointer-events:none}
.toast.show{opacity:1;bottom:34px}
.storage-bar{height:8px;background:#eee;border-radius:999px;overflow:hidden;margin:8px 0}
.storage-bar i{display:block;height:100%;background:var(--wa)}
.storage-bar i.warn{background:#e8a33d}
.storage-bar i.full{background:var(--primary)}

/* ===== Ofertas ===== */
.tag.oferta{background:var(--primary)}
.price .was{color:var(--muted);text-decoration:line-through;font-size:13px;font-weight:600;margin-right:2px}
.card-actions{display:flex;gap:8px;margin-top:4px}
.card-actions .buy{flex:1;margin-top:0}
.addcart{background:#fff;border:1.5px solid var(--wa);color:var(--wa);border-radius:10px;width:44px;font-size:17px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.addcart:hover{background:var(--wa);color:#fff}
.off-badge{background:var(--primary);color:#fff;font-size:13px;font-weight:700;padding:2px 8px;border-radius:7px;vertical-align:middle}
.pd-price .was{font-size:18px}
.save-note{color:#1a7f3c;font-weight:700;font-size:14px;margin:2px 0 8px}
.btn-addcart-lg{background:#fff;border:2px solid var(--wa);color:var(--wa);font-weight:700;font-size:16px;padding:14px 22px;border-radius:12px;display:inline-flex;align-items:center;gap:9px;justify-content:center;cursor:pointer}
.btn-addcart-lg:hover{background:#eafaf0}

/* ===== Carrito ===== */
.cart-btn{position:relative;background:#fff;border:1.5px solid var(--line);border-radius:12px;width:46px;height:46px;font-size:21px;display:flex;align-items:center;justify-content:center}
.cart-btn:hover{border-color:var(--primary)}
.cart-badge{position:absolute;top:-6px;right:-6px;background:var(--primary);color:#fff;font-size:11px;font-weight:700;min-width:19px;height:19px;border-radius:999px;display:none;align-items:center;justify-content:center;padding:0 5px}
.cart-modal{max-width:520px}
.cart-list{display:flex;flex-direction:column;gap:10px;max-height:52vh;overflow:auto}
.cart-it{display:flex;gap:12px;align-items:center;border:1px solid var(--line);border-radius:12px;padding:8px}
.cart-it img{width:54px;height:54px;object-fit:contain;background:#fff;border-radius:8px;flex:0 0 auto}
.ci-main{flex:1;min-width:0}
.ci-name{font-size:13.5px;font-weight:600;line-height:1.25}
.ci-price{font-size:12.5px;color:var(--primary);font-weight:700}
.ci-qty{display:flex;align-items:center;gap:8px}
.ci-qty button{width:30px;height:30px;border:1px solid var(--line);border-radius:8px;font-size:17px;background:#fff}
.ci-qty span{min-width:20px;text-align:center;font-weight:600}
.ci-rm{color:var(--muted);font-size:16px;padding:6px}
.ci-rm:hover{color:var(--primary)}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-top:14px;padding-top:14px;border-top:2px solid var(--line);font-size:16px}
.cart-total b{font-size:22px;color:var(--primary)}
@media(max-width:560px){.cart-it img{width:44px;height:44px}.ci-name{font-size:12.5px}.btn-addcart-lg{width:100%}}

/* ===== Filtros categoría ===== */
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filters select{border:1px solid var(--line);border-radius:10px;padding:9px 12px;font-size:14px;background:#fff}

/* ===== Agotado ===== */
.card .ph .sold-out{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-12deg);background:rgba(60,60,59,.9);color:#fff;font-weight:800;font-size:15px;letter-spacing:1px;padding:6px 16px;border-radius:8px;z-index:2}
.agotado-lbl{flex:1;text-align:center;background:#f1f1f1;color:#888;font-weight:700;font-size:13px;padding:10px;border-radius:10px}
.sold-note{background:#fff3f1;border:1px solid #f0c4bf;color:#b23b2e;border-radius:12px;padding:12px 14px;font-size:14px;flex:1}
.sold-note a{color:var(--primary);font-weight:700;text-decoration:underline}

/* ===== Compartir ===== */
.share-row{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:14px;color:var(--muted)}
.share-row a,.share-row button{font-size:18px;border:1px solid var(--line);border-radius:9px;padding:7px 10px;background:#fff;color:var(--dark);display:inline-flex;align-items:center;gap:6px}
.share-row button{font-size:13px;font-weight:600;cursor:pointer}
.share-row a:hover,.share-row button:hover{border-color:var(--primary);color:var(--primary)}

/* ===== Medios de pago ===== */
.pay-sec{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pays{display:flex;flex-wrap:wrap;gap:10px}
.pay{background:#f4f5f7;border:1px solid var(--line);border-radius:999px;padding:9px 16px;font-size:14px;font-weight:600;color:var(--dark)}
.fin{margin-top:14px;font-size:14.5px;color:var(--dark);font-weight:600}

/* ===== Reseñas ===== */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px}
.review p{font-size:14px;line-height:1.5;margin:8px 0}
.review span{font-size:13px;color:var(--muted);font-weight:600}
.stars{color:#f5b50a;letter-spacing:2px;font-size:15px}
.rating-big{display:flex;align-items:center;gap:10px;margin-bottom:16px;font-size:18px}
.rating-big .stars{font-size:22px}
.rating-big b{font-size:22px}
@media(max-width:820px){.reviews{grid-template-columns:1fr}}

/* ===== Sucursales ===== */
.branches{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.branch{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.branch-map{aspect-ratio:16/11;background:#eee}
.branch-map iframe{width:100%;height:100%;border:0;display:block}
.branch-info{padding:14px}
.branch-info b{font-size:15px}
.branch-info p{margin:5px 0;font-size:13px;color:var(--muted)}
.branch-info a{color:var(--primary);font-weight:600;font-size:13.5px}
@media(max-width:820px){.branches{grid-template-columns:1fr}}

/* ===== Admin subcard ===== */
.subcard{border:1px solid var(--line);border-radius:12px;padding:14px;margin-bottom:12px;background:#fafafa}

/* ============================================================
   ICONOS VECTORIALES
   ============================================================ */
.svg-ic{width:1em;height:1em;display:inline-block;vertical-align:-0.14em;flex:0 0 auto}
.svg-ic .ln{fill:none;stroke:var(--dark);stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.svg-ic .ac{fill:none;stroke:var(--primary);stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.svg-ic .cu{fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.svg-ic .fac{fill:var(--primary);stroke:none}
.svg-ic .fcu{fill:currentColor;stroke:none}
/* categoría sobre fondo rojo (nav) -> blanco */
.catnav .svg-ic .ln,.catnav .svg-ic .ac{stroke:#fff}
.catnav a .svg-ic{width:1.15em;height:1.15em;vertical-align:-0.22em}
/* tamaños por contexto */
.cat-tile .ic{font-size:42px;line-height:0;margin-bottom:10px}
.cat-tile .ic .svg-ic{vertical-align:middle}
.benefit .bi .svg-ic{width:26px;height:26px}
.section-head h2 .svg-ic{width:0.95em;height:0.95em;vertical-align:-0.12em;margin-right:2px}
.toolbar h1 .svg-ic{width:0.9em;height:0.9em;vertical-align:-0.1em;margin-right:2px}
.btn-wa .svg-ic,.buy .svg-ic,.btn-buy-lg .svg-ic,.btn-addcart-lg .svg-ic,.wa-cta .svg-ic{width:1.25em;height:1.25em;vertical-align:-0.28em}
.addcart .svg-ic{width:20px;height:20px}
.wa-float .svg-ic{width:30px;height:30px}
.cart-btn .svg-ic{width:24px;height:24px}
.search button .svg-ic{width:20px;height:20px}
.topbar .svg-ic{width:1em;height:1em;vertical-align:-0.15em;margin-right:3px}
.pay .svg-ic{color:#1a7f3c;width:1.05em;height:1.05em;vertical-align:-0.16em;margin-right:4px}
.footer p .svg-ic,.footer a .svg-ic{width:1.05em;height:1.05em;vertical-align:-0.16em;margin-right:3px}
.pd-meta .svg-ic{width:1.2em;height:1.2em;vertical-align:-0.25em;margin-right:2px}
.gift .svg-ic{width:1.25em;height:1.25em;vertical-align:-0.2em}
.share-row a .svg-ic,.share-row button .svg-ic{width:18px;height:18px;vertical-align:-0.22em}

/* selector de iconos (admin) */
.icon-pick{display:flex;flex-wrap:wrap;gap:8px}
.icon-pick .ip{width:48px;height:48px;border:1.5px solid var(--line);border-radius:10px;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer}
.icon-pick .ip .svg-ic{width:26px;height:26px}
.icon-pick .ip:hover{border-color:var(--primary)}
.icon-pick .ip.sel{border-color:var(--primary);background:#fff0f0;box-shadow:0 0 0 2px rgba(226,31,33,.15)}

/* ===== Atención técnica (franja) ===== */
.tech-sec{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.tech-band{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.tech-ic{flex:0 0 auto;width:60px;height:60px;border-radius:14px;background:#fff0f0;display:flex;align-items:center;justify-content:center}
.tech-ic .svg-ic{width:34px;height:34px}
.tech-txt{flex:1;min-width:200px}
.tech-txt b{font-size:17px;display:block}
.tech-txt p{margin:3px 0 0;color:var(--muted);font-size:14px}
.tech-phones{display:flex;gap:10px;flex-wrap:wrap}
.tech-phones a{background:var(--wa);color:#fff;border-radius:10px;padding:10px 16px;font-weight:600;font-size:14px;display:inline-flex;align-items:center;gap:7px}
.tech-phones a:hover{filter:brightness(.95)}
.tech-phones a .svg-ic{width:1.1em;height:1.1em}
@media(max-width:600px){.tech-band{justify-content:center;text-align:center}.tech-txt{text-align:center}}

/* iconos de encabezados de sección en rojo de marca */
.section-head h2 .svg-ic{color:var(--primary)}
.empty .ic .svg-ic{width:46px;height:46px;color:var(--muted)}
.branch-info p .svg-ic{width:1em;height:1em;vertical-align:-0.14em;margin-right:3px;color:var(--primary)}
.fin .svg-ic{color:#1a7f3c;margin-right:4px;vertical-align:-0.14em}

/* ===== Marcas ===== */
.marcas-sec{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.marcas{display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center}
.marcas>span{color:var(--muted);font-size:14px;font-weight:600}
.marcas-logos{display:flex;align-items:center;gap:34px;flex-wrap:wrap;justify-content:center}
.marcas-logos img{height:32px;width:auto;opacity:.9}
.marcas-logos img:hover{opacity:1}
.cardbrand{height:15px;width:auto;align-self:flex-start}
.pd-brandlogo{height:28px;width:auto;margin:2px 0 4px}

/* ===== Video facade ===== */
.ytfacade{position:relative;width:100%;height:100%;background-size:cover;background-position:center;cursor:pointer;display:flex;align-items:center;justify-content:center}
.ytfacade::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.18)}
.ytplay{position:relative;z-index:1;display:flex;filter:drop-shadow(0 4px 10px rgba(0,0,0,.45));transition:.15s}
.ytplay .svg-ic{width:66px;height:66px}
.ytfacade:hover .ytplay{transform:scale(1.08)}

/* ===== Garantía ===== */
.warr-hero{display:flex;gap:20px;align-items:center;background:linear-gradient(120deg,var(--primary),var(--primary-d));color:#fff;border-radius:18px;padding:28px;margin:14px 0 22px}
.warr-hero .svg-ic{width:62px;height:62px;flex:0 0 auto}
.warr-hero .svg-ic .ln,.warr-hero .svg-ic .ac{stroke:#fff}
.warr-hero h1{margin:0 0 6px;font-size:28px}
.warr-hero p{margin:0;opacity:.95;font-size:15px;max-width:680px}
.warr-cols{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
.warr-card{border:1px solid var(--line);border-radius:14px;padding:20px;background:#fff}
.warr-card h3{margin:0 0 12px;font-size:17px;display:flex;align-items:center;gap:8px}
.warr-card.cover{border-top:4px solid var(--wa)}
.warr-card.excl{border-top:4px solid var(--primary)}
.warr-card .svg-ic{color:var(--wa);width:1.1em;height:1.1em}
.warr-card ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.warr-card li{font-size:14px;padding-left:24px;position:relative;line-height:1.4}
.warr-card.cover li::before{content:"✓";position:absolute;left:0;color:var(--wa);font-weight:800}
.warr-card.excl li::before{content:"✕";position:absolute;left:0;color:var(--primary);font-weight:800}
.warr-how{background:#fff;border:1px solid var(--line);border-radius:14px;padding:22px}
.warr-how h3{margin:0 0 8px;font-size:18px}
.warr-how p{margin:0 0 16px;font-size:14.5px;color:#444;max-width:760px}
.warr-badge{display:inline-flex;align-items:center;gap:7px;background:#fff7e6;border:1px solid #ffe2a8;color:#8a5a00;border-radius:10px;padding:9px 13px;font-size:13px;font-weight:600;margin:6px 0 14px}
.warr-badge:hover{background:#fff0d6}
@media(max-width:760px){.warr-cols{grid-template-columns:1fr}.warr-hero{flex-direction:column;text-align:center}}

/* ===== Carrusel del hero ===== */
.hero-carousel{position:relative;width:100%;height:100%;background:#fff;overflow:hidden}
.hc-track{position:absolute;inset:0}
.hc-slide{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;background:#fff;cursor:pointer}
.hc-slide.active{opacity:1;pointer-events:auto;z-index:1}
.hc-slide img{max-width:80%;max-height:82%;object-fit:contain;mix-blend-mode:multiply}
.hc-cap{position:absolute;left:0;right:0;bottom:0;padding:16px 18px;background:linear-gradient(transparent,rgba(0,0,0,.62));color:#fff;display:flex;flex-direction:column;gap:1px;text-align:left}
.hc-cap span{font-size:11px;opacity:.9;text-transform:uppercase;letter-spacing:.6px;font-weight:600}
.hc-cap b{font-size:15px;line-height:1.25;font-weight:600}
.hc-cap em{font-style:normal;font-weight:800;font-size:19px}
.hc-arrow{position:absolute;top:46%;transform:translateY(-50%);z-index:3;background:rgba(255,255,255,.9);border-radius:50%;width:38px;height:38px;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);color:var(--dark)}
.hc-arrow.prev{left:10px}.hc-arrow.next{right:10px}
.hc-arrow:hover{background:#fff;color:var(--primary)}
.hc-arrow .svg-ic{width:20px;height:20px}
.hc-dots{position:absolute;top:12px;left:0;right:0;display:flex;gap:6px;z-index:3;justify-content:center}
.hc-dot{width:8px;height:8px;border-radius:50%;background:rgba(0,0,0,.18);border:1px solid rgba(0,0,0,.08);padding:0;transition:.2s}
.hc-dot.active{background:var(--primary);width:22px;border-radius:5px}
.hc-slide.active.anim-fade{animation:hcFade .7s ease}
.hc-slide.active.anim-slide{animation:hcSlide .65s cubic-bezier(.2,.7,.2,1)}
.hc-slide.active.anim-zoom img{animation:hcKen 4.2s ease forwards}
@keyframes hcFade{from{opacity:0}to{opacity:1}}
@keyframes hcSlide{from{opacity:0;transform:translateX(46px)}to{opacity:1;transform:translateX(0)}}
@keyframes hcKen{from{transform:scale(1)}to{transform:scale(1.12)}}

/* ===== Barra de promoción ===== */
.promobar{background:var(--dark);color:#fff;font-size:13.5px}
.promobar .wrap{display:flex;align-items:center;justify-content:center;gap:14px;min-height:38px;position:relative;padding:6px 40px}
.promobar span{display:inline-flex;align-items:center;gap:8px;text-align:center}
.promobar b{color:#ffd2d2;font-weight:700}
.promobar .svg-ic{color:#ff6b6b;width:1.05em;height:1.05em}
.promobar [data-promo-x]{position:absolute;right:14px;color:#fff;font-size:20px;opacity:.8;line-height:1}
.promobar [data-promo-x]:hover{opacity:1}

/* ===== Vista rápida (botón en card) ===== */
.card .ph{position:relative}
.quickbtn{position:absolute;left:50%;bottom:10px;transform:translateX(-50%) translateY(8px);background:rgba(255,255,255,.96);color:var(--dark);border:1px solid var(--line);border-radius:999px;padding:7px 14px;font-size:12.5px;font-weight:600;display:inline-flex;align-items:center;gap:6px;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.18s;white-space:nowrap;z-index:2}
.card:hover .quickbtn{opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.quickbtn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}
.quickbtn .svg-ic{width:15px;height:15px}
@media(max-width:760px){.quickbtn{opacity:1;pointer-events:auto;transform:translateX(-50%);bottom:8px;padding:6px 11px;font-size:11.5px}}

/* ===== Modal Vista rápida ===== */
.qv-modal{max-width:840px;padding:0;overflow:hidden;position:relative}
.qv-x{position:absolute;top:10px;right:12px;font-size:24px;color:var(--dark);z-index:3;background:rgba(255,255,255,.9);border-radius:50%;width:34px;height:34px;line-height:1;box-shadow:var(--shadow)}
.qv{display:grid;grid-template-columns:1fr 1fr}
.qv-gallery{background:#fff;padding:24px;display:flex;flex-direction:column;gap:10px;border-right:1px solid var(--line)}
.qv-main{aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.qv-main img{max-width:100%;max-height:100%;object-fit:contain;mix-blend-mode:multiply}
.qv-thumbs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.qv-thumbs img{width:52px;height:52px;object-fit:contain;border:2px solid var(--line);border-radius:8px;padding:4px;cursor:pointer;background:#fff}
.qv-thumbs img.active{border-color:var(--primary)}
.qv-info{padding:26px 24px}
.qv-info h3{margin:4px 0 8px;font-size:20px;line-height:1.2}
.qv-specs{margin:10px 0 0;padding:0;list-style:none;display:grid;gap:6px}
.qv-specs li{font-size:13px;padding-left:20px;position:relative;line-height:1.35}
.qv-specs li::before{content:"✓";position:absolute;left:0;color:var(--primary);font-weight:800}
.qv-actions{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}
.qv-actions .btn-buy-lg,.qv-actions .btn-addcart-lg{flex:1;font-size:14px;padding:12px 14px}
.qv-full{display:inline-block;margin-top:14px;color:var(--primary);font-weight:600;font-size:14px}
@media(max-width:680px){.qv{grid-template-columns:1fr}.qv-gallery{border-right:none;border-bottom:1px solid var(--line);padding:18px}.qv-main{aspect-ratio:16/11}}

/* ===== Carrito: ciudad ===== */
.cart-city{margin-top:12px}
.cart-city label{display:block;font-size:12.5px;font-weight:600;margin-bottom:5px;color:var(--dark)}
.cart-city select{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;background:#fff}

/* ===== Checkout carrito (nombre/pago) ===== */
.cart-city input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;font-size:14px;background:#fff}
.cart-row2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}
@media(max-width:520px){.cart-row2{grid-template-columns:1fr}}

/* ===== Pulido mobile ===== */
@media(max-width:620px){
  .hero h1{font-size:24px}
  .hero p{font-size:15px}
  .section{padding:24px 0}
  .section-head h2{font-size:19px}
  .pd-price{font-size:30px}
  .cart-modal,.qv-modal{max-width:100%}
  .modal{padding:18px}
  .btn-buy-lg{font-size:15px;padding:13px 18px}
  .card .name{font-size:13px}
  .card .price{font-size:18px}
}
@media(max-width:380px){
  .grid{grid-template-columns:1fr 1fr;gap:10px}
  .catnav a{font-size:13px;padding:11px 10px}
}

/* ===== Ficha técnica ===== */
.spec-table{width:100%;border-collapse:collapse;margin:4px 0 16px;font-size:13.5px}
.spec-table th{text-align:left;width:38%;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line);vertical-align:top}
.spec-table td{padding:8px 10px;border-bottom:1px solid var(--line);font-weight:500}

/* ===== Zoom / Lightbox ===== */
.pd-gallery .main img.zoomable{cursor:zoom-in}
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.9);z-index:120;display:flex;align-items:center;justify-content:center;padding:24px;cursor:zoom-out}
.lightbox img{max-width:96%;max-height:92%;object-fit:contain;border-radius:6px;background:#fff}
.lb-x{position:absolute;top:16px;right:22px;color:#fff;font-size:36px;line-height:1;background:none}

/* ===== Comparador ===== */
.cmp-toggle{margin-top:8px;width:100%;border:1px dashed var(--line);border-radius:9px;padding:6px;font-size:12px;font-weight:600;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#fff}
.cmp-toggle .svg-ic{width:15px;height:15px}
.cmp-toggle:hover{border-color:var(--primary);color:var(--primary)}
.cmp-toggle.on{background:var(--primary);color:#fff;border-style:solid;border-color:var(--primary)}
.compare-bar{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);z-index:65;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-h);border-radius:14px;padding:10px 14px;display:flex;align-items:center;gap:14px;max-width:94vw}
.cb-items{display:flex;gap:8px}
.cb-it{position:relative;width:46px;height:46px;border:1px solid var(--line);border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;padding:3px}
.cb-it img{max-width:100%;max-height:100%;object-fit:contain}
.cb-it button{position:absolute;top:-7px;right:-7px;background:var(--primary);color:#fff;width:20px;height:20px;border-radius:50%;font-size:12px;line-height:1}
.cb-act{display:flex;gap:8px;align-items:center}
.btn.sm{padding:8px 12px;font-size:13px}
.cmp-modal{max-width:920px}
.cmp-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
.cmp-table{border-collapse:collapse;width:100%;font-size:13px}
.cmp-table th{position:sticky;left:0;background:#fafafa;text-align:left;color:var(--muted);font-weight:600;padding:10px;border:1px solid var(--line);white-space:nowrap;width:108px;z-index:1}
.cmp-table td{padding:10px;border:1px solid var(--line);vertical-align:top;min-width:150px}
.cmp-img{width:88px;height:88px;object-fit:contain;mix-blend-mode:multiply}
@media(max-width:560px){.compare-bar{left:10px;right:10px;transform:none;max-width:none;bottom:80px}.cb-items{overflow-x:auto}}

/* ===== Atención técnica (página) ===== */
.tech-more{display:inline-flex;align-items:center;color:var(--primary)!important;background:none!important;font-weight:700;padding:8px 4px!important}
.att-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin:6px 0 22px}
.att-card{background:#fff;border:1px solid var(--line);border-top:4px solid var(--wa);border-radius:14px;padding:22px;text-align:center}
.att-num{font-size:20px;font-weight:800;color:var(--dark);display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:14px}
.att-num .svg-ic{width:1.1em;height:1.1em;color:var(--wa)}
.att-card .btn-buy-lg{width:100%;justify-content:center}
.att-call{display:inline-block;margin-top:10px;color:var(--muted);font-size:13.5px;text-decoration:underline}
.att-call:hover{color:var(--primary)}
