*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
/* ── SCREEN READER ONLY & SKIP LINK ── */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link:focus{position:fixed;top:8px;left:8px;width:auto;height:auto;padding:8px 16px;background:var(--primary);color:#fff;border-radius:var(--radius-md);font-weight:700;z-index:10000;clip:auto;white-space:normal;overflow:visible;margin:0;}
/* ── PAGE LOADER ── */
.page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg-main,#fff);display:flex;align-items:center;justify-content:center;transition:opacity .5s ease,visibility .5s ease}
.page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.page-loader-inner{display:flex;flex-direction:column;align-items:center;gap:12px}
.page-loader-logo{display:none}
.page-loader-brand{font-family:'Baloo 2',sans-serif;font-weight:800;font-size:28px;color:#fff;letter-spacing:-2px}
.page-loader-brand span{color:#fff}
.page-loader-dots{display:flex;gap:6px;margin-top:4px}
.page-loader-dots span{width:7px;height:7px;border-radius:50%;background:#F15200;animation:loader-bounce 1.2s ease-in-out infinite}
.page-loader-dots span:nth-child(2){animation-delay:.2s}
.page-loader-dots span:nth-child(3){animation-delay:.4s}
@keyframes loader-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.92);opacity:.7}}
@keyframes loader-bounce{0%,80%,100%{transform:translateY(0);opacity:.4}40%{transform:translateY(-8px);opacity:1}}

:root{
  --primary:#F15200;--primary-dark:#CC4500;--primary-light:#FFF1EA;
  --secondary:#00A651;--accent:#FFB800;--accent-dark:#D49A00;
  --bg:#F7F8FA;--bg-card:#FFFFFF;--bg-header:#FFFFFF;
  --text-primary:#111827;--text-secondary:#4B5563;--text-muted:#767676;
  --border:#E5E7EB;--border-light:#F3F4F6;
  --shadow-sm:0 1px 3px rgba(0,0,0,.08),0 1px 2px rgba(0,0,0,.04);
  --shadow-md:0 4px 16px rgba(0,0,0,.1);
  --shadow-lg:0 12px 32px rgba(0,0,0,.12);
  --shadow-xl:0 24px 48px rgba(0,0,0,.15);
  --radius-sm:12px;--radius-md:12px;--radius-lg:12px;--radius-xl:12px;--radius-full:9999px;
  --font-head:'Plus Jakarta Sans',sans-serif;--font-body:'DM Sans',sans-serif;
  --transition:all .2s cubic-bezier(.4,0,.2,1);--whatsapp:#25D366;
}
[data-theme="dark"]{
  --bg:#0F1117;--bg-card:#1A1D27;--bg-header:#13151F;
  --text-primary:#F9FAFB;--text-secondary:#9CA3AF;--text-muted:#9399A5;
  --border:#2D3142;--border-light:#252838;
  --shadow-sm:0 1px 3px rgba(0,0,0,.3);--shadow-md:0 4px 16px rgba(0,0,0,.35);--shadow-lg:0 12px 32px rgba(0,0,0,.4);
}
html{scroll-behavior:smooth;-webkit-tap-highlight-color:transparent}
body{font-family:var(--font-body);background:var(--bg);color:var(--text-primary);min-height:100vh;transition:background .3s,color .3s;overflow-x:hidden;}
::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}
h1,h2,h3,h4,h5{font-family:var(--font-head);font-weight:700;line-height:1.2}

/* HEADER */
.header{position:sticky;top:0;z-index:100;background:var(--primary);box-shadow:var(--shadow-sm);}

.header-top{max-width:1400px;margin:0 auto;padding:12px 16px;display:flex;align-items:center;gap:12px;}
.logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0;gap:6px;background:none;padding:4px 2px;}
.logo-img{display:none;}
.logo-text{font-family:'Baloo 2',sans-serif;font-weight:800;font-size:26px;letter-spacing:-0.5px;}
.logo-text .logo-full,.logo-text .logo-short{color:#fff}
.logo-text .logo-full>span,.logo-text .logo-short>span{color:#fff}
.logo-text .logo-full{display:none}
.logo-text .logo-short{display:inline}
@media(min-width:480px){.logo-text .logo-full{display:inline}.logo-text .logo-short{display:none}}
@media(max-width:767px){.logo-text{display:none}}
.search-wrap{flex:1;position:relative;}
.search-input{width:100%;padding:10px 16px 10px 40px;background:#fff;border:2px solid #fff;border-radius:var(--radius-md);font-family:var(--font-body);font-size:14px;color:var(--text-primary);outline:none;transition:var(--transition);}
.search-input::placeholder{color:var(--text-muted)}
.search-input:focus{border-color:rgba(0,0,0,.2);background:#fff}
/* Prevent iOS auto-zoom on ALL inputs/selects/textareas */
@media(max-width:767px){input:not([type=checkbox]):not([type=radio]),textarea,select{font-size:16px!important;}}
.search-btn{position:absolute;left:4px;right:auto;top:50%;transform:translateY(-50%);background:transparent;border:none;cursor:pointer;width:34px;height:34px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;color:#9CA3AF;transition:var(--transition);}
.search-btn:hover{color:#6B7280;transform:translateY(-50%) scale(1.05)}
.search-btn svg{width:16px;height:16px}
.header-actions{display:flex;align-items:center;gap:6px;}
.btn-icon{position:relative;background:none;border:none;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;transition:var(--transition);}
.btn-icon:hover{background:rgba(0,0,0,.12);color:#fff}
.btn-icon svg{width:22px;height:22px}
/* MORE MENU DROPDOWN */
.more-menu{position:relative;}
.more-menu-trigger{transition:var(--transition);}
.more-menu-trigger.active{background:rgba(0,0,0,.15);color:#fff;}
.more-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:210px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);z-index:300;padding:6px;display:none;flex-direction:column;gap:2px;animation:dropIn .15s ease;}
.more-menu-dropdown.open{display:flex;}
@keyframes dropIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.more-menu-item{width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-secondary);text-align:left;display:flex;align-items:center;gap:10px;border-radius:var(--radius-md);transition:var(--transition);}
.more-menu-item:hover{background:var(--primary-light);color:var(--primary);}
.more-menu-item svg{width:20px;height:20px;flex-shrink:0;}
.more-menu-item-wa{color:#128C7E;}
.more-menu-item-wa:hover{background:rgba(37,211,102,.1)!important;color:#075E54!important;}
.more-menu-divider{height:1px;background:var(--border);margin:4px 6px;}
.ham-action-btn-wa{color:#25D366!important;font-weight:600;}
.ham-action-btn-wa:hover{background:rgba(37,211,102,.1)!important;color:#25D366!important;}
.cart-badge{position:absolute;top:2px;right:2px;background:#fff;color:var(--primary);font-family:var(--font-head);font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;padding:0 4px;transition:transform .3s cubic-bezier(.34,1.56,.64,1);}
.cart-badge.bump{transform:scale(1.4)}
.wish-badge{position:absolute;top:2px;right:2px;background:#fff;color:var(--primary);font-family:var(--font-head);font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:var(--radius-full);display:none;align-items:center;justify-content:center;padding:0 4px;}
.wish-badge.visible{display:flex}

/* WISH PANEL */
.wish-panel{position:fixed;top:0;right:0;bottom:0;width:min(420px,100vw);background:var(--bg-card);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px rgba(0,0,0,.15);}
.wish-panel.open{transform:translateX(0)}
.wish-header{padding:15px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.wish-title{font-family:var(--font-head);font-size:16px;font-weight:800;display:flex;align-items:center;gap:7px;flex:1;min-width:0;}
.wish-count-pill{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0;}
.btn-clear-wish{background:none;border:1.5px solid var(--border);cursor:pointer;padding:5px 10px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;color:var(--text-muted);transition:var(--transition);display:none;align-items:center;gap:4px;white-space:nowrap;flex-shrink:0;}
.btn-clear-wish:hover{border-color:#EF4444;color:#EF4444;}
.btn-clear-wish svg{width:11px;height:11px;}
.wish-body{flex:1;overflow-y:auto;padding:14px;}
.wish-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:10px;color:var(--text-muted);}
.wish-empty-icon{font-size:56px;opacity:.5}
.wish-item{display:flex;align-items:flex-start;gap:10px;padding:10px;background:var(--bg);border-radius:var(--radius-md);margin-bottom:8px;}
.wish-item-img{width:64px;height:64px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;cursor:pointer;transition:var(--transition);}
.wish-item-img:hover{opacity:.85;}
.wish-item-info{flex:1;min-width:0;}
.wish-item-name{font-size:12px;font-weight:600;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:4px;cursor:pointer;}
.wish-item-name:hover{color:var(--primary);}
.wish-item-price{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--primary);}
.wish-item-old{font-size:11px;color:var(--text-muted);text-decoration:line-through;margin-left:4px;}
.wish-item-actions{display:flex;align-items:center;gap:7px;margin-top:6px;}
.wish-btn-cart{background:var(--primary-light);color:var(--primary);border:1.5px solid rgba(241,82,0,.2);padding:5px 11px;border-radius:var(--radius-md);font-family:var(--font-head);font-size:11px;font-weight:700;cursor:pointer;transition:var(--transition);}
.wish-btn-cart:hover{background:var(--primary);color:#fff;}
.wish-btn-cart.added{background:var(--primary);color:#fff;}
.wish-btn-buy{background:var(--accent);color:#111;border:1.5px solid var(--accent);padding:5px 11px;border-radius:var(--radius-md);font-family:var(--font-head);font-size:11px;font-weight:800;cursor:pointer;transition:var(--transition);}
.wish-btn-buy:hover{background:var(--accent-dark);border-color:var(--accent-dark);}
.wish-btn-remove{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:18px;line-height:1;padding:2px;transition:var(--transition);}
.wish-btn-remove:hover{color:#EF4444;transform:scale(1.2);}

/* ORDERS HISTORY PANEL */
.orders-panel{position:fixed;top:0;right:0;bottom:0;width:min(480px,100vw);background:var(--bg-card);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px rgba(0,0,0,.15);}
.orders-panel.open{transform:translateX(0)}
.orders-ph{padding:15px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.orders-ph-title{font-family:var(--font-head);font-size:16px;font-weight:800;display:flex;align-items:center;gap:7px;flex:1;min-width:0;}
.orders-ph-count{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0;}
.btn-clear-orders{background:none;border:1.5px solid var(--border);cursor:pointer;padding:5px 10px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;color:var(--text-muted);transition:var(--transition);display:none;align-items:center;gap:4px;white-space:nowrap;flex-shrink:0;}
.btn-clear-orders:hover{border-color:#EF4444;color:#EF4444;}
.btn-clear-orders svg{width:11px;height:11px;}
.orders-body{flex:1;min-height:0;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:12px;align-content:flex-start;}
.orders-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:10px;color:var(--text-muted);}
.orders-empty-icon{font-size:56px;opacity:.5}
.ord-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);flex-shrink:0;}
.ord-card-head{padding:10px 13px;display:flex;align-items:flex-start;justify-content:space-between;gap:8px;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;}
.ord-card-ref{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--text-primary);}
.ord-card-date{font-size:11px;color:var(--text-muted);margin-top:2px;}
.ord-status-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:var(--radius-full);font-size:10px;font-weight:700;flex-shrink:0;white-space:nowrap;}
.osc-approved{background:rgba(0,166,81,.12);color:#00A651;}
.osc-pending{background:rgba(241,82,0,.12);color:var(--primary);}
.osc-declined{background:rgba(239,68,68,.12);color:#EF4444;}
.osc-wa{background:rgba(37,211,102,.12);color:#25D366;}
.osc-unknown{background:var(--border-light);color:var(--text-muted);}
/* Order card collapsible toggle */
.ord-toggle-btn{background:none;border:none;cursor:pointer;width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:var(--transition);flex-shrink:0;margin-left:auto;pointer-events:none;}
.ord-toggle-btn:hover{background:var(--bg-card);color:var(--text-primary);}
.ord-toggle-btn svg{width:16px;height:16px;transition:transform .25s;}
.ord-toggle-btn.open svg{transform:rotate(180deg);}
.ord-card-collapsible{display:none;}
.ord-card-items{padding:10px 13px;display:flex;flex-direction:column;gap:4px;border-bottom:1px solid var(--border);}
.ord-item-row{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--text-secondary);}
.ord-item-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:8px;}
.ord-item-price{font-weight:600;flex-shrink:0;color:var(--text-primary);}
.ord-total-row{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--font-head);font-size:14px;font-weight:800;color:var(--text-primary);margin-top:6px;padding-top:7px;border-top:1px solid var(--border);}
.ord-card-info{padding:10px 13px;display:flex;flex-direction:column;gap:5px;}
.ord-card-actions{padding:10px 13px 13px;border-top:1px solid var(--border);}
.btn-repeat-order{display:flex;align-items:center;gap:7px;width:100%;padding:9px 14px;border:1.5px solid var(--primary);background:transparent;color:var(--primary);border-radius:8px;font-size:.83rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s;}
.btn-repeat-order:hover{background:var(--primary);color:#fff;}
.btn-repeat-order svg{width:15px;height:15px;flex-shrink:0;}
/* ── Order detail modal ── */
.ord-detail-overlay{position:fixed;inset:0;z-index:3200;background:rgba(0,0,0,.6);display:flex;align-items:flex-end;justify-content:center;padding:0;opacity:0;pointer-events:none;transition:opacity .28s ease;}
.ord-detail-overlay.open{opacity:1;pointer-events:all;}
@media(min-width:560px){.ord-detail-overlay{align-items:center;padding:20px;}}
.ord-detail-box{background:var(--bg-card);width:100%;max-width:520px;border-radius:20px 20px 0 0;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-xl);transform:translateY(40px);transition:transform .32s cubic-bezier(.34,1.1,.64,1);overflow:hidden;}
.ord-detail-overlay.open .ord-detail-box{transform:translateY(0);}
@media(min-width:560px){.ord-detail-box{border-radius:20px;transform:translateY(0) scale(.94);}.ord-detail-overlay.open .ord-detail-box{transform:scale(1);}}
.ord-detail-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:18px 20px 14px;border-bottom:1px solid var(--border);flex-shrink:0;}
.ord-detail-title{font-family:var(--font-head);font-size:16px;font-weight:800;color:var(--text-primary);}
.ord-detail-ref{font-size:11px;color:var(--text-muted);margin-top:3px;font-family:monospace;}
.ord-detail-body{overflow-y:auto;flex:1;padding:0;}
.ord-detail-section{padding:14px 20px;border-bottom:1px solid var(--border-light);}
.ord-detail-section:last-child{border-bottom:none;}
.ord-detail-section-title{font-family:var(--font-head);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:10px;}
.ord-detail-item-row{display:flex;align-items:center;gap:10px;padding:5px 0;}
.ord-detail-item-img{width:40px;height:40px;border-radius:8px;object-fit:cover;flex-shrink:0;border:1px solid var(--border);background:var(--bg);}
.ord-detail-item-name{flex:1;font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.35;}
.ord-detail-item-qty{font-size:12px;color:var(--text-muted);flex-shrink:0;}
.ord-detail-item-price{font-size:13px;font-weight:700;color:var(--text-primary);flex-shrink:0;}
.ord-detail-total-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0 2px;border-top:1px solid var(--border);margin-top:6px;font-family:var(--font-head);font-size:15px;font-weight:800;color:var(--primary);}
.ord-detail-info-row{display:flex;align-items:flex-start;gap:10px;padding:5px 0;font-size:13px;color:var(--text-secondary);line-height:1.4;}
.ord-detail-info-icon{font-size:15px;flex-shrink:0;margin-top:1px;}
.ord-detail-status-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0;}
.ord-detail-footer{padding:14px 20px 20px;border-top:1px solid var(--border);flex-shrink:0;display:flex;flex-direction:column;gap:8px;}
.btn-ord-detail-repeat{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:12px;border:1.5px solid var(--primary);background:transparent;color:var(--primary);border-radius:var(--radius-md);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;transition:background .15s,color .15s;}
.btn-ord-detail-repeat:hover{background:var(--primary);color:#fff;}
.btn-ord-detail-repeat svg{width:15px;height:15px;flex-shrink:0;}
/* ── Guest register error popup ── */
.reg-err-overlay{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:3100;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .22s;}
.reg-err-overlay.open{opacity:1;pointer-events:all;}
.reg-err-box{background:var(--bg-card,#fff);border-radius:14px;padding:28px 24px 24px;max-width:420px;width:100%;box-shadow:0 8px 40px rgba(0,0,0,.22);}
.reg-err-title{font-size:1.1rem;font-weight:700;margin-bottom:12px;color:var(--text-primary,#1a1a1a);}
.reg-err-body{font-size:.88rem;line-height:1.65;color:var(--text-secondary,#555);margin-bottom:20px;}
.reg-err-actions{display:flex;flex-direction:column;gap:10px;}
.btn-reg-err-wa{display:flex;align-items:center;justify-content:center;gap:8px;padding:11px 18px;background:#25D366;color:#fff;border-radius:9px;font-size:.9rem;font-weight:700;text-decoration:none;text-align:center;}
.btn-reg-err-wa:hover{opacity:.88;}
.btn-reg-err-close{padding:9px 18px;background:transparent;border:1.5px solid var(--border,#e0e0e0);border-radius:9px;font-size:.85rem;cursor:pointer;color:var(--text-secondary,#555);}
.btn-reg-err-close:hover{border-color:var(--primary);color:var(--primary);}
.ord-info-row{display:flex;align-items:flex-start;gap:7px;font-size:12px;color:var(--text-secondary);}
.ord-info-icon{flex-shrink:0;font-size:13px;margin-top:1px;}
.ord-info-mono{font-family:monospace;font-size:11px;word-break:break-all;color:var(--text-muted);}

/* Flat theme toggle */
.theme-toggle{background:none;border:none;cursor:pointer;width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:var(--transition);}
.theme-toggle:hover{background:var(--bg);color:var(--text-primary)}
.theme-toggle svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.75;}

/* HAMBURGER MENU */
.ham-btn{display:none;background:none;border:none;cursor:pointer;width:40px;height:40px;border-radius:var(--radius-md);align-items:center;justify-content:center;color:#fff;transition:var(--transition);flex-shrink:0;position:relative;}
.ham-btn:hover{background:rgba(0,0,0,.12);color:#fff}
.ham-btn svg{width:22px;height:22px;}
.ham-badge{position:absolute;top:2px;right:2px;background:#fff;color:var(--primary);font-family:var(--font-head);font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:var(--radius-full);display:none;align-items:center;justify-content:center;padding:0 4px;}
.ham-badge.visible{display:flex}
@media(max-width:767px){
  .ham-btn{display:flex;}
  .header-top{flex-wrap:wrap;padding:10px 12px 0;gap:6px;justify-content:space-between;}
  .header-top .logo{display:flex;padding:4px;background:none;border-radius:0;flex:1;justify-content:center;}
  .header-top .logo .logo-img{filter:brightness(0) invert(1);}
  .header-top .logo .logo-text{display:block;color:#fff;}
  .header-top .logo .logo-text .logo-full,.header-top .logo .logo-text .logo-short{color:#fff;}
  .header-top .logo .logo-text .logo-full>span,.header-top .logo .logo-text .logo-short>span{color:#fff;}
  .header-top .logo .logo-text .logo-full{display:inline;}
  .header-top .logo .logo-text .logo-short{display:none;}
  .header-actions{flex-shrink:0;}
  .search-wrap{order:10;width:100%;flex:none;padding-bottom:10px;}
  .search-btn{left:4px;right:auto;top:0;bottom:10px;transform:none;margin:auto 0;}
  .header-wish-desktop,.header-theme-desktop,.header-orders-desktop,.header-more-desktop{display:none!important;}
}
.ham-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:150;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px);}
.ham-overlay.open{opacity:1;pointer-events:all}
.ham-drawer{position:fixed;top:0;left:0;bottom:0;width:min(300px,85vw);background:var(--bg-card);z-index:151;display:flex;flex-direction:column;transform:translateX(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:8px 0 32px rgba(0,0,0,.15);}
.ham-drawer.open{transform:translateX(0)}
.ham-drawer-head{padding:16px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.ham-drawer-logo{font-family:'Baloo 2',sans-serif;font-size:26px;font-weight:800;color:#111827;letter-spacing:-0.5px;}
.ham-drawer-logo span{color:var(--primary);}
.ham-drawer-close{background:none;border:none;cursor:pointer;width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:var(--transition);}
.ham-drawer-close:hover{background:var(--bg)}
.ham-drawer-close svg{width:18px;height:18px}
.ham-drawer-body{flex:1;overflow-y:auto;padding:12px 0;}
.ham-section-label{padding:8px 18px 4px;font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;}
.ham-cat-btn{width:100%;padding:11px 18px;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-secondary);text-align:left;display:flex;align-items:center;gap:10px;transition:var(--transition);border-left:3px solid transparent;}
.ham-cat-btn:hover{color:var(--primary);background:var(--primary-light);}
.ham-cat-btn.active{color:var(--primary);background:var(--primary-light);border-left-color:var(--primary);font-weight:600;}
.ham-divider{height:1px;background:var(--border);margin:10px 18px;}
.ham-action-btn{width:100%;padding:11px 18px;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-secondary);text-align:left;display:flex;align-items:center;gap:10px;transition:var(--transition);}
.ham-action-btn:hover{color:var(--primary);background:var(--primary-light);}
.ham-action-btn svg{width:20px;height:20px;flex-shrink:0;}
.ham-wish-count{margin-left:auto;background:var(--primary);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:var(--radius-full);display:none;align-items:center;justify-content:center;padding:0 4px;}
.ham-wish-count.visible{display:flex}

/* CATEGORIES */
.categories-nav{border-top:1px solid var(--border);background:var(--bg-header);box-shadow:0 2px 4px rgba(0,0,0,.06);}
.categories-inner{max-width:1400px;margin:0 auto;padding:0 16px;display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;}
.categories-inner::-webkit-scrollbar{display:none}
.cat-btn{flex-shrink:0;padding:10px 14px;background:none;border:none;cursor:pointer;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);border-bottom:2px solid transparent;transition:var(--transition);white-space:nowrap;display:flex;align-items:center;gap:6px;}
.cat-btn:hover{color:var(--primary)}
.cat-btn.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}
@media(max-width:767px){.categories-nav{display:none;}}

/* BANNER */
.hero{max-width:1400px;margin:16px auto 0;padding:0 16px;}
.banner-slider{border-radius:var(--radius-xl);overflow:hidden;position:relative;height:190px;}
@media(min-width:600px){.banner-slider{height:240px}}
@media(min-width:768px){.banner-slider{height:300px}}
.banner-slide{position:absolute;inset:0;display:flex;align-items:center;padding:24px 28px;opacity:0;pointer-events:none;transition:opacity .7s ease;}
@media(min-width:768px){.banner-slide{padding:24px 100px}}
.banner-slide.active{opacity:1;pointer-events:auto}
.banner-content{max-width:360px;color:#fff}
.banner-tag{display:inline-block;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);padding:3px 10px;border-radius:var(--radius-full);font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin-bottom:8px;}
.banner-title{font-family:var(--font-head);font-size:clamp(16px,3.5vw,30px);font-weight:800;line-height:1.15;margin-bottom:6px;}
.banner-sub{font-size:12px;opacity:.85;margin-bottom:14px}
.banner-cta{display:inline-flex;align-items:center;gap:6px;background:#fff;color:var(--primary);padding:7px 16px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;text-decoration:none;transition:var(--transition);cursor:pointer;border:none;}
.banner-cta:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.2)}
.banner-image{position:absolute;right:4px;bottom:0;font-size:90px;opacity:.15;transform:rotate(-15deg);pointer-events:none;}
@media(min-width:600px){.banner-image{opacity:.25;font-size:150px}}
@media(min-width:768px){.banner-image{opacity:.3;font-size:200px;right:20px}}
.banner-dots{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:5;}
.banner-dot{width:9px;height:9px;border-radius:5px;background:rgba(255,255,255,.45);transition:all .3s;cursor:pointer;border:none;}
.banner-dot.active{background:#fff;width:26px}
.banner-arrow{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(255,255,255,.22);backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.4);color:#fff;width:46px;height:46px;border-radius:50%;cursor:pointer;align-items:center;justify-content:center;transition:var(--transition);padding:0;}
.banner-arrow svg{width:22px;height:22px;flex-shrink:0}
.banner-arrow:hover{background:rgba(255,255,255,.42);transform:translateY(-50%) scale(1.08);}
.banner-arrow-prev{left:14px;}.banner-arrow-next{right:14px;}
@media(min-width:768px){.banner-arrow{display:flex;}}

/* SECTION */
.section{max-width:1400px;margin:0 auto;padding:22px 16px 0;}

/* DEALS ZONE */
.deals-zone{background:var(--bg-card);margin:22px 0 0;padding:20px 16px 22px;position:relative;border-top:1px solid var(--border);border-bottom:1px solid var(--border);}
.deals-zone::before{display:none;}
.deals-zone::after{display:none;}
.deals-zone-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;max-width:1400px;margin-left:auto;margin-right:auto;}
.deals-zone-title{font-family:var(--font-head);font-size:clamp(15px,3vw,18px);font-weight:800;color:var(--text-primary);display:flex;align-items:center;gap:7px;}
.deals-zone-title svg{flex-shrink:0;}
.deals-zone-badge{background:var(--primary-light);color:var(--primary);font-family:var(--font-head);font-size:11px;font-weight:700;padding:4px 10px;border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;border:1px solid rgba(241,82,0,.15);}
.deals-zone .carousel-arrow{background:var(--bg);border-color:var(--border);color:var(--text-secondary);}
.deals-zone .carousel-arrow:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
.deals-zone .carousel-scroll .product-card{min-width:165px;max-width:165px;}
@media(min-width:400px){.deals-zone .carousel-scroll .product-card{min-width:180px;max-width:180px;}}
@media(min-width:600px){.deals-zone .carousel-scroll .product-card{min-width:195px;max-width:195px;}}
@media(min-width:900px){.deals-zone .carousel-scroll .product-card{min-width:210px;max-width:210px;}}
@media(max-width:767px){.deals-zone{margin-top:16px;}}
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.section-title{font-family:var(--font-head);font-size:clamp(15px,2.5vw,19px);font-weight:800;color:var(--text-primary);display:flex;align-items:center;gap:7px;}
.section-title-dot{width:7px;height:7px;border-radius:50%;background:var(--primary);display:inline-block;}
.section-link{font-size:12px;font-weight:600;color:var(--primary);text-decoration:none;}
.section-link:hover{text-decoration:underline}

/* CAROUSEL */
.carousel-wrap{position:relative;}
.carousel-arrow{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:var(--bg-card);border:1.5px solid var(--border);border-radius:50%;width:36px;height:36px;align-items:center;justify-content:center;cursor:pointer;box-shadow:var(--shadow-md);transition:var(--transition);color:var(--text-primary);}
.carousel-arrow svg{width:16px;height:16px;flex-shrink:0;}
.carousel-arrow.prev{left:-14px;}.carousel-arrow.next{right:-14px;}
.carousel-arrow:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-50%) scale(1.1);}
@media(min-width:768px){.carousel-arrow{display:flex;}}
.carousel-scroll{display:flex;align-items:stretch;gap:10px;overflow-x:auto;padding-bottom:4px;scroll-behavior:smooth;scrollbar-width:none;}
.carousel-scroll::-webkit-scrollbar{display:none}
.carousel-scroll .product-card{min-width:140px;max-width:140px;flex-shrink:0;}
@media(min-width:400px){.carousel-scroll .product-card{min-width:155px;max-width:155px;}}
@media(min-width:600px){.carousel-scroll .product-card{min-width:170px;max-width:170px;}}
@media(min-width:900px){.carousel-scroll .product-card{min-width:185px;max-width:185px;}}
.carousel-scroll .card-body{padding:9px;gap:4px;}
.carousel-scroll .card-name{font-size:11.5px;}
.carousel-scroll .card-price{font-size:13px;}
.carousel-scroll .card-old-price{font-size:10px;}
.carousel-scroll .card-discount{font-size:9px;}
.carousel-scroll .card-seller,.carousel-scroll .card-stars{font-size:10px;}
.carousel-scroll .low-stock{font-size:9.5px;}
.carousel-scroll .btn{padding:7px 8px;font-size:11px;gap:3px;border-radius:8px;}
.carousel-scroll .btn svg{width:12px;height:12px;}
.carousel-scroll .card-actions{gap:5px;padding-top:6px;}

/* MAIN GRID */
.products-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
@media(min-width:600px){.products-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:900px){.products-grid{grid-template-columns:repeat(4,1fr)}}
@media(min-width:1200px){.products-grid{grid-template-columns:repeat(5,1fr)}}

/* PRODUCT CARD */
.product-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:var(--transition);cursor:pointer;position:relative;display:flex;flex-direction:column;}
.product-card:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);}
.card-img-wrap{position:relative;aspect-ratio:1;overflow:hidden;background:var(--bg);contain-intrinsic-size:1px 200px;content-visibility:auto;}
.card-img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;}
.card-img.img-loaded{opacity:1}
.card-wishlist{position:absolute;top:7px;right:7px;background:var(--bg-card);border:none;cursor:pointer;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm);opacity:1;transition:var(--transition);z-index:2;}
.card-wishlist svg{width:15px;height:15px;transition:var(--transition);}
.card-wishlist.active{opacity:1;}
.badge-wrap{position:absolute;top:7px;left:7px;display:flex;flex-direction:column;gap:3px;z-index:2;}
.badge-wrap-right{position:absolute;top:7px;right:7px;z-index:2;}
.badge{display:inline-flex;align-items:center;gap:2px;padding:2px 6px;border-radius:6px;font-family:var(--font-head);font-size:9px;font-weight:700;line-height:1.4;letter-spacing:.2px;}
.badge-top{background:var(--accent);color:#111}.badge-offer{background:var(--primary);color:#fff}.badge-new{background:var(--secondary);color:#fff}
.card-body{padding:11px;flex:1;display:flex;flex-direction:column;gap:5px;}
.card-seller{font-size:11px;color:var(--text-muted);font-weight:500;}
.card-name{font-family:var(--font-head);font-size:13px;font-weight:600;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4;}
.card-prices{display:flex;align-items:baseline;gap:5px;flex-wrap:wrap;}
.card-price{font-family:var(--font-head);font-size:15px;font-weight:800;color:var(--text-primary);}
.card-old-price{font-size:11px;color:var(--text-muted);text-decoration:line-through;}
.card-discount{font-size:10px;font-weight:700;color:#0A6B35;background:rgba(0,166,81,.1);padding:1px 4px;border-radius:4px;}
.low-stock{font-size:10px;font-weight:600;color:#B45309;display:flex;align-items:center;gap:3px;}
.low-stock::before{content:'';width:5px;height:5px;border-radius:50%;background:#F59E0B;flex-shrink:0;animation:pulse 1.5s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
.card-actions{display:flex;flex-direction:column;gap:5px;margin-top:auto;padding-top:7px;}
.btn{display:flex;align-items:center;justify-content:center;gap:5px;padding:8px 10px;border-radius:var(--radius-md);font-family:var(--font-head);font-size:12px;font-weight:700;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;line-height:1;}
.btn-cart{background:var(--primary-light);color:var(--primary);border:1.5px solid rgba(241,82,0,.2);width:100%;height:34px;box-sizing:border-box;}
.btn-cart:hover{background:var(--primary);color:#fff}
.btn-cart svg{width:13px;height:13px}
.btn-cart.added{background:var(--secondary);color:#fff;border-color:var(--secondary);}
.btn-wa{background:var(--primary);color:#fff;}
.btn-wa:hover{background:var(--primary-dark);}
.btn-wa svg{width:16px;height:16px}
.btn-buy-now{background:var(--accent);color:#111;width:100%;height:34px;box-sizing:border-box;font-weight:800;}
.btn-buy-now:hover{background:var(--accent-dark);color:#111;}
.btn-buy-now svg{width:13px;height:13px}
.card-stars{display:flex;align-items:center;gap:3px;font-size:11px;color:#A16207;}
.star-count{color:var(--text-muted);margin-left:2px}

/* FILTERS */
.filters-bar{max-width:1400px;margin:18px auto 0;padding:0 16px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.filter-chip{display:flex;align-items:center;padding:6px 13px;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-full);font-family:var(--font-body);font-size:12px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:var(--transition);white-space:nowrap;}
.filter-chip:hover{border-color:var(--primary);color:var(--primary)}
.filter-chip.active{border-color:var(--primary);background:var(--primary);color:#fff;}
.sort-select{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-full);padding:6px 13px;font-family:var(--font-body);font-size:12px;color:var(--text-secondary);cursor:pointer;outline:none;margin-left:auto;}
.sort-select:focus{border-color:var(--primary)}

/* CART PANEL */
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(4px);}
.cart-overlay.open{opacity:1;pointer-events:all}
.cart-panel{position:fixed;top:0;right:0;bottom:0;width:min(440px,100vw);background:var(--bg-card);z-index:201;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:-8px 0 32px rgba(0,0,0,.15);}
.cart-panel.open{transform:translateX(0)}
.cart-header{padding:15px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
.cart-title{font-family:var(--font-head);font-size:16px;font-weight:800;display:flex;align-items:center;gap:7px;flex:1;min-width:0;}
.cart-count-pill{background:var(--primary);color:#fff;font-size:11px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0;}
.btn-clear-cart{background:none;border:1.5px solid var(--border);cursor:pointer;padding:5px 10px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;color:var(--text-muted);transition:var(--transition);display:none;align-items:center;gap:4px;white-space:nowrap;flex-shrink:0;}
.btn-clear-cart:hover{border-color:#EF4444;color:#EF4444;}
.btn-clear-cart svg{width:11px;height:11px;}
.btn-close{background:var(--bg);border:none;cursor:pointer;width:34px;height:34px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:var(--transition);flex-shrink:0;}
.btn-close:hover{background:var(--border)}
.btn-close svg{width:18px;height:18px}
.cart-body{flex:1;overflow-y:auto;padding:14px}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:10px;color:var(--text-muted);}
.cart-empty-icon{font-size:56px;opacity:.5}

/* SELLER GROUP */
.seller-group{margin-bottom:14px}
.seller-group-header{display:flex;align-items:center;gap:8px;padding:9px 11px;background:var(--bg);border-radius:var(--radius-md);margin-bottom:7px;}
.seller-avatar{width:26px;height:26px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;}
.seller-name{font-size:12px;font-weight:600}
.seller-subtotal{font-size:11px;color:var(--text-muted);margin-left:auto}

/* CART ITEM */
.cart-item{display:flex;align-items:flex-start;gap:9px;padding:9px;background:var(--bg);border-radius:var(--radius-md);margin-bottom:7px;transition:opacity .2s;}
.cart-item.unchecked{opacity:.4;}
.cart-item--unavailable{opacity:.7;filter:grayscale(.6);}
.cart-item-unavailable-badge{font-size:11px;font-weight:600;color:#dc2626;background:#fee2e2;border:1px solid #fca5a5;border-radius:6px;padding:2px 8px;margin:4px 0;display:inline-block;}
.cart-item-zone-badge{font-size:11px;font-weight:600;color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:6px;padding:2px 8px;margin:4px 0;display:inline-block;}
.cart-item--zone-unavail{opacity:.8;}
.wish-item--zone-unavail{opacity:.82;}
.wish-item-zone-badge{font-size:11px;font-weight:600;color:#92400e;background:#fef3c7;border:1px solid #fcd34d;border-radius:6px;padding:2px 7px;display:inline-block;margin:3px 0 5px;}
.cart-item-check{padding-top:3px;flex-shrink:0;}
.cart-item-check input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--primary);}
.cart-select-all{padding:4px 14px 8px;display:none;align-items:center;border-bottom:1px solid var(--border-light);margin-bottom:4px;}
.cart-select-all-label{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--text-secondary);cursor:pointer;user-select:none;}
.cart-select-all-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;}
.cart-item-img{width:58px;height:58px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:12px;font-weight:600;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:3px;}
.cart-item-price{font-family:var(--font-head);font-size:13px;font-weight:700;color:var(--primary)}
.cart-item-controls{display:flex;align-items:center;gap:7px;margin-top:5px;}
.qty-btn{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-secondary);transition:var(--transition);}
.qty-btn:hover{border-color:var(--primary);color:var(--primary)}
.qty-num{font-family:var(--font-head);font-size:12px;font-weight:700;min-width:18px;text-align:center;}
.btn-remove{margin-left:auto;background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:10px;display:flex;align-items:center;gap:3px;padding:2px;transition:var(--transition);}
.btn-remove:hover{color:#EF4444}
.btn-remove svg{width:11px;height:11px}

/* CART FOOTER */
.cart-footer{padding:14px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:10px;}
.cart-totals{display:flex;flex-direction:column;gap:5px}
.cart-total-row{display:flex;justify-content:space-between;font-size:12px;color:var(--text-secondary)}
.cart-total-row.grand{font-family:var(--font-head);font-size:17px;font-weight:800;color:var(--text-primary)}
.btn-checkout{display:flex;align-items:center;justify-content:center;gap:8px;padding:13px;border-radius:var(--radius-lg);background:var(--primary);color:#fff;font-family:var(--font-head);font-size:14px;font-weight:700;border:none;cursor:pointer;transition:var(--transition);}
.btn-checkout:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(241,82,0,.3)}
.btn-checkout svg{width:20px;height:20px}

/* ORDER POPUP */
.order-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:400;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(6px);}
.order-overlay.open{opacity:1;pointer-events:all}
@media(min-width:600px){.order-overlay{align-items:center}}
.order-box{background:var(--bg-card);width:100%;max-width:460px;border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;transform:translateY(60px);transition:transform .35s cubic-bezier(.4,0,.2,1);max-height:90vh;display:flex;flex-direction:column;}
@media(min-width:600px){.order-box{border-radius:var(--radius-xl);transform:scale(.94) translateY(10px)}}
.order-overlay.open .order-box{transform:translateY(0)}
@media(min-width:600px){.order-overlay.open .order-box{transform:scale(1) translateY(0)}}
@media(max-width:599px){
  .order-overlay{background:var(--bg-card);backdrop-filter:none;}
  .order-box{max-width:100%;height:100%;max-height:100%;border-radius:0;overflow:visible;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
  .order-overlay.open .order-box{transform:translateX(0);}
  .order-header{position:sticky;top:0;background:var(--bg-card);z-index:2;}
  .order-scroll{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;}
  .order-footer{position:sticky;bottom:0;background:var(--bg-card);border-top:1px solid var(--border);}
}
.order-header{padding:16px 18px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.order-title{font-family:var(--font-head);font-size:16px;font-weight:800;display:flex;align-items:center;gap:8px;}
.order-scroll{overflow-y:auto;flex:1;}

/* MAP CONFIRM */
.map-view-link{display:inline-flex;align-items:center;gap:4px;font-size:12px;color:var(--text-muted);text-decoration:none;margin-top:5px;padding:3px 0;transition:color .2s;}
.map-view-link:hover{color:var(--primary);}
.map-confirm-wrap{overflow:hidden;max-height:0;transition:max-height .4s cubic-bezier(.4,0,.2,1);margin-top:6px;}
.map-confirm-wrap.visible{max-height:380px;}
#mapEl{width:100%;height:190px;display:none;background:var(--bg);}
.map-confirm-bar{padding:10px 13px;display:flex;flex-direction:column;gap:8px;background:var(--bg-card);border-top:1px solid var(--border);transition:background .3s;}
.map-confirm-question{font-size:13px;font-weight:600;color:var(--text-primary);}
.map-confirm-btns{display:flex;gap:8px;}
.btn-map-yes{flex:1;padding:9px;background:var(--secondary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);}
.btn-map-yes:hover{filter:brightness(1.1);}
.btn-map-move{flex:1;padding:9px;background:var(--bg);color:var(--text-primary);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);}
.btn-map-move:hover{border-color:var(--primary);color:var(--primary);}
.map-confirm-hint{font-size:11.5px;color:var(--text-muted);display:none;padding:2px 0;}
.map-confirm-hint.visible{display:block;}
.btn-map-confirm{width:100%;padding:9px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:13px;font-weight:700;cursor:pointer;display:none;transition:var(--transition);}
.btn-map-confirm:hover{background:var(--primary-dark);}
.btn-map-confirm.visible{display:block;}
.map-confirmed-badge{padding:8px 10px;background:#dcfce7;border-radius:var(--radius-sm);font-size:12.5px;color:#166534;font-weight:600;align-items:center;gap:6px;display:none;}
.map-confirmed-badge.visible{display:flex;}
[data-theme="dark"] .map-confirmed-badge{background:#14532d;color:#86efac;}
.map-loading{height:190px;display:flex;align-items:center;justify-content:center;gap:10px;font-size:12px;color:var(--text-muted);background:var(--bg);}
.map-loading .spin{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;}
.map-wrap-inner{border:1.5px solid var(--border);border-radius:var(--radius-md);overflow:hidden;margin-top:8px;}
.order-body{padding:16px 18px;display:flex;flex-direction:column;gap:13px;}
.order-field{display:flex;flex-direction:column;gap:5px;}
.order-label{font-size:12px;font-weight:600;color:var(--text-secondary);}
.order-label .req{color:#EF4444}
.order-input{padding:10px 13px;background:var(--bg);border:2px solid var(--border);border-radius:var(--radius-md);font-family:var(--font-body);font-size:14px;color:var(--text-primary);outline:none;transition:var(--transition);width:100%;}
.order-input:focus{border-color:var(--primary);background:var(--bg-card)}
.order-input::placeholder{color:var(--text-muted)}
select.order-input option{background:var(--bg-card);color:var(--text-primary);}
.input-prefix-wrap{position:relative;display:flex;align-items:center;}
.input-prefix{position:absolute;left:13px;font-size:13px;font-weight:600;color:var(--text-secondary);pointer-events:none;z-index:1;white-space:nowrap;display:flex;align-items:center;gap:5px;}
.flag-co{width:20px;height:14px;border-radius:2px;flex-shrink:0;}
.order-input-prefixed{padding-left:26px;}
#inputCelular.order-input-prefixed{padding-left:76px;}
.order-summary-panel{border-radius:var(--radius-md);overflow:hidden;background:var(--bg);}
.order-summary-panel>summary{display:flex;align-items:center;justify-content:space-between;padding:10px 13px;cursor:pointer;list-style:none;font-size:13px;font-weight:700;color:var(--text-primary);gap:8px;user-select:none;}
.order-summary-panel>summary::-webkit-details-marker{display:none;}
.order-summary-panel>summary .osh-detail-hint{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:400;color:var(--text-muted);}
.order-summary-panel>summary .osh-chevron{width:14px;height:14px;flex-shrink:0;transition:transform .2s;color:var(--text-muted);stroke:var(--text-muted);}
.order-summary-panel[open]>summary .osh-chevron{transform:rotate(180deg);}
.order-summary-panel[open] .osh-detail-hint::before{content:'Ocultar ';}
.order-summary{background:var(--bg);border-top:1px solid var(--border);border-radius:0;padding:10px 13px;font-size:12px;color:var(--text-secondary);line-height:1.7;}
.order-summary strong{color:var(--text-primary);}
.osp-table{width:100%;border-collapse:collapse;table-layout:fixed;border-radius:6px;overflow:hidden;}
.osp-th-name{width:56%;text-align:left;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:0 6px 7px 0;border-bottom:2px solid var(--border);}
.osp-th-qty{width:14%;text-align:center;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:0 4px 7px;border-bottom:2px solid var(--border);}
.osp-th-sub{width:30%;text-align:right;font-size:9px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;padding:0 0 7px 4px;border-bottom:2px solid var(--border);}
.osp-table tbody tr{border-bottom:1px solid var(--border-light);}
.osp-table tbody tr:last-child{border-bottom:none;}
.osp-table td{padding:7px 4px;font-size:12px;color:var(--text-primary);vertical-align:middle;word-break:break-word;}
.osp-alt td{background:var(--bg-card);}
.osp-name{font-weight:500;padding-right:6px !important;display:flex;align-items:center;gap:8px;}
.osp-thumb{width:32px;height:32px;border-radius:6px;object-fit:cover;flex-shrink:0;border:1px solid var(--border);background:var(--border-light);}
.osp-qty{text-align:center;color:var(--text-muted);font-size:11px;font-weight:600;}
.osp-sub{text-align:right;font-weight:700;white-space:nowrap;color:var(--primary);}
.osp-seller-row td{padding:10px 4px 4px;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:transparent !important;border-bottom:none !important;}
.cupon-toggle-row{padding-top:2px!important;padding-bottom:6px!important;}
.cupon-toggle-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13px;color:var(--text-secondary);}
.cupon-toggle-label input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer;flex-shrink:0;}
.order-footer{padding:12px 18px 18px;flex-shrink:0;}
.btn-send-order{width:100%;padding:14px;background:var(--primary);color:#fff;font-family:var(--font-head);font-size:15px;font-weight:700;border:none;cursor:pointer;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition);}
.btn-send-order:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 8px 24px rgba(241,82,0,.3)}
.btn-send-order svg{width:20px;height:20px}

/* WOMPI RESULT OVERLAY */
.wompi-result-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:450;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(8px);}
.wompi-result-overlay.open{opacity:1;pointer-events:all}
@media(min-width:600px){.wompi-result-overlay{align-items:center}}
.wompi-result-box{background:var(--bg-card);width:100%;max-width:460px;border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;transform:translateY(60px);transition:transform .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;max-height:92vh;}
@media(min-width:600px){.wompi-result-box{border-radius:var(--radius-xl);transform:scale(.94) translateY(10px)}}
.wompi-result-overlay.open .wompi-result-box{transform:translateY(0)}
@media(min-width:600px){.wompi-result-overlay.open .wompi-result-box{transform:scale(1) translateY(0)}}
@media(max-width:599px){
  .wompi-result-overlay{background:var(--bg-card);backdrop-filter:none;}
  .wompi-result-box{max-width:100%;height:100%;max-height:100%;border-radius:0;overflow:visible;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
  .wompi-result-overlay.open .wompi-result-box{transform:translateX(0);}
  .wompi-result-body{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;}
  .wompi-result-footer{position:sticky;bottom:0;background:var(--bg-card);}
}
.wompi-result-body{padding:30px 24px 14px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;overflow-y:auto;flex:1;}
.wompi-result-icon{font-size:58px;line-height:1;margin-bottom:2px;}
.wompi-result-title{font-family:var(--font-head);font-size:21px;font-weight:800;color:var(--text-primary);}
.wompi-result-sub{font-size:13px;color:var(--text-secondary);line-height:1.6;max-width:320px;}
.wompi-result-ref{font-family:monospace;font-size:11px;background:var(--bg);border:1px solid var(--border);padding:4px 10px;border-radius:6px;color:var(--text-muted);}
.wompi-result-summary{width:100%;background:var(--bg);border-radius:var(--radius-md);padding:12px 14px;font-size:13px;color:var(--text-secondary);line-height:1.7;text-align:left;max-height:130px;overflow-y:auto;}
.wompi-result-name{font-size:12px;color:var(--text-muted);text-align:center;}
.wompi-result-footer{padding:14px 18px 20px;display:flex;flex-direction:column;gap:8px;flex-shrink:0;border-top:1px solid var(--border);}
.btn-wompi-confirm{width:100%;padding:14px;background:#25D366;color:#fff;font-family:var(--font-head);font-size:15px;font-weight:700;border:none;cursor:pointer;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;gap:8px;transition:var(--transition);}
.btn-wompi-confirm:hover{background:#1ebe5a;transform:translateY(-1px);box-shadow:0 6px 20px rgba(37,211,102,.3);}
.btn-wompi-confirm svg{width:20px;height:20px;}
.btn-wompi-retry{width:100%;padding:11px;background:transparent;color:var(--text-muted);font-size:13px;font-weight:600;border:1.5px solid var(--border);cursor:pointer;border-radius:var(--radius-lg);transition:var(--transition);}
.btn-wompi-retry:hover{border-color:#EF4444;color:#EF4444;}
#cambioWrap{display:none;}

/* PRODUCT MODAL */
/* PRODUCT MODAL — mobile: full-screen page slide; desktop: centred modal */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:300;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(6px);}
.modal-overlay.open{opacity:1;pointer-events:all}
@media(min-width:768px){.modal-overlay{align-items:center}}
.modal-box{background:var(--bg-card);width:100%;max-width:800px;max-height:92vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);position:relative;}
@media(min-width:768px){.modal-box{border-radius:var(--radius-xl);max-height:85vh;transform:scale(.95) translateY(20px)}}
.modal-overlay.open .modal-box{transform:translateY(0)}
@media(min-width:768px){.modal-overlay.open .modal-box{transform:scale(1) translateY(0)}}
.modal-header{padding:14px 18px;display:flex;align-items:center;justify-content:flex-end;position:absolute;top:0;right:0;z-index:2;}
.modal-body{overflow-y:auto;flex:1}
/* Mobile overrides — full screen page, slides in from right */
@media(max-width:767px){
  .modal-overlay{background:var(--bg-card);backdrop-filter:none;}
  .modal-box{max-width:100%;height:100%;max-height:100%;border-radius:0;overflow:visible;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
  .modal-overlay.open .modal-box{transform:translateX(0);}
  .modal-header{position:sticky;top:0;left:0;right:0;width:100%;background:var(--bg-card);border-bottom:1px solid var(--border);padding:10px 16px;justify-content:flex-start;box-sizing:border-box;z-index:2;}
  .modal-body{overflow-y:auto;height:100%;}
}
.modal-grid{display:grid;grid-template-columns:1fr;}
@media(min-width:768px){.modal-grid{grid-template-columns:1fr 1fr}}
.modal-gallery{position:relative;background:var(--bg);padding:12px;}
.modal-main-img{width:100%;aspect-ratio:1;object-fit:contain;border-radius:var(--radius-md);transition:opacity .18s ease;contain-intrinsic-size:1px 400px;}
.modal-thumbs{display:flex;gap:8px;padding:12px;overflow-x:auto;scrollbar-width:none;}
.modal-thumbs::-webkit-scrollbar{display:none}
.modal-thumb{width:52px;height:52px;border-radius:var(--radius-sm);object-fit:cover;cursor:pointer;border:2px solid transparent;transition:var(--transition);flex-shrink:0;opacity:.5;}
.modal-thumb.active{border-color:var(--primary);opacity:1;transform:scale(1.08);box-shadow:0 0 0 3px rgba(var(--primary-rgb),.25);}
.modal-info{padding:18px;display:flex;flex-direction:column;gap:10px}
.modal-seller{font-size:12px;color:var(--text-muted)}
.modal-name{font-family:var(--font-head);font-size:19px;font-weight:800;line-height:1.2}
.modal-price-wrap{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.modal-price{font-family:var(--font-head);font-size:26px;font-weight:800;}
.modal-old{font-size:15px;color:var(--text-muted);text-decoration:line-through}
.modal-off{font-size:13px;font-weight:700;color:var(--secondary);background:rgba(0,166,81,.1);padding:2px 7px;border-radius:5px}
.modal-desc{font-size:14px;color:var(--text-secondary);line-height:1.7;overflow:hidden;max-height:2000px;transition:max-height .4s ease}
.modal-desc-collapsed{max-height:5.6em;-webkit-mask-image:linear-gradient(to bottom,#000 60%,transparent 100%);mask-image:linear-gradient(to bottom,#000 60%,transparent 100%)}
.btn-modal-desc-more{background:none;border:none;color:var(--primary);font-size:13px;font-weight:600;cursor:pointer;padding:2px 0 8px;display:block;transition:opacity .2s}
.modal-actions{display:flex;flex-direction:column;gap:9px;margin-top:auto;padding-top:14px;border-top:1px solid var(--border)}
.modal-actions .btn{padding:12px;font-size:14px}
.btn-wish{background:var(--primary-light);color:var(--primary);border:1.5px solid rgba(241,82,0,.2);}
.btn-wish:hover{background:var(--primary);color:#fff;}
.btn-wish.active{background:var(--primary);color:#fff;border-color:var(--primary);}
.btn-wish svg{width:16px;height:16px;}

/* IMAGE HOVER ZOOM (desktop only) */
.modal-gallery{overflow:hidden;cursor:zoom-in;}
.modal-gallery.zooming{cursor:crosshair;}
.modal-main-img{transition:transform .18s ease;transform-origin:50% 50%;will-change:transform;pointer-events:none;}
.modal-gallery.zooming .modal-main-img{transition:none;}

/* 429 ALERT */
#alert429{position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(4px);animation:alert429In .25s ease both;}
#alert429Box{background:#fff;border-radius:var(--radius-xl);padding:32px 28px;max-width:360px;width:100%;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 16px 48px rgba(0,0,0,.22);text-align:center;}
@keyframes alert429In{from{opacity:0}to{opacity:1}}

/* REQUEST PRODUCT MODAL */
.req-overlay{z-index:310;}
.req-box{max-width:460px;}
@media(min-width:768px){.req-box{border-radius:var(--radius-xl);transform:scale(.95) translateY(20px);}}
@media(max-width:767px){.req-box{max-width:100%;height:100%;max-height:100%;}}
.req-body{padding:12px 24px 32px;display:flex;flex-direction:column;align-items:center;gap:10px;}
.req-icon{font-size:52px;line-height:1;margin-top:4px;}
.req-title{font-family:var(--font-head);font-size:20px;font-weight:800;color:var(--text-primary);text-align:center;line-height:1.25;}
.req-subtitle{font-size:14px;color:var(--text-secondary);text-align:center;line-height:1.5;margin-top:-4px;}
.req-form{width:100%;display:flex;flex-direction:column;gap:8px;margin-top:4px;}
.req-form-label{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:-2px;}
.req-form textarea,.req-form input{width:100%;padding:10px 13px;border-radius:var(--radius-md);border:1.5px solid var(--border);background:var(--bg);color:var(--text-primary);font-size:14px;font-family:var(--font-body);outline:none;transition:border-color .2s;box-sizing:border-box;}
.req-form textarea{min-height:88px;resize:vertical;}
.req-form textarea:focus,.req-form input:focus{border-color:var(--primary);}
.req-form textarea.req-error,.req-form input.req-error{border-color:#e53935;animation:reqShake .3s;}
@keyframes reqShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}
.btn-req-send{width:100%;padding:14px;border-radius:var(--radius-md);background:#25D366;color:#fff;border:none;font-size:15px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:9px;margin-top:6px;transition:var(--transition);line-height:1;}
.btn-req-send:hover{background:#1ebe5a;transform:translateY(-1px);box-shadow:0 4px 14px rgba(37,211,102,.3);}
.btn-req-send svg{width:20px;height:20px;flex-shrink:0;}
.similar-title{font-family:var(--font-head);font-size:15px;font-weight:700;padding:18px 18px 10px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.similar-more{font-size:12px;font-weight:600;color:var(--primary);display:flex;align-items:center;gap:3px;cursor:pointer;flex-shrink:0;opacity:.9;user-select:none;}
.similar-more svg{width:14px;height:14px;flex-shrink:0;}
.similar-nav{position:relative;display:flex;align-items:center;}
.similar-nav-btn{display:none;position:absolute;top:50%;transform:translateY(-50%);z-index:3;background:var(--bg-card);border:1.5px solid var(--border);border-radius:50%;width:34px;height:34px;flex-shrink:0;cursor:pointer;box-shadow:var(--shadow-md);align-items:center;justify-content:center;color:var(--text-primary);transition:var(--transition);}
.similar-nav-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);}
.similar-nav-btn svg{width:16px;height:16px;}
.similar-nav-prev{left:-10px;}
.similar-nav-next{right:-10px;}
@media(min-width:768px){.similar-nav-btn{display:flex;}}
.similar-scroll{flex:1;display:flex;gap:10px;padding:0 18px 18px;overflow-x:auto;scrollbar-width:none;}
.similar-scroll::-webkit-scrollbar{display:none}
.similar-scroll .product-card{min-width:155px;flex-shrink:0}
.modal-ref{font-size:11px;color:var(--text-muted);margin-top:-4px;font-family:monospace;letter-spacing:.02em;}
.mini-card{width:118px;flex-shrink:0;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;background:var(--bg);border:1.5px solid var(--border);transition:var(--transition);}
.mini-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--primary);}
.mini-card-img{width:100%;aspect-ratio:1;object-fit:cover;contain-intrinsic-size:1px 118px;}
.mini-card-body{padding:7px 8px 9px;}
.mini-card-name{font-size:11px;font-weight:600;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;margin-bottom:5px;}
.mini-card-price{font-family:var(--font-head);font-size:13px;font-weight:800;color:var(--primary);}
.mini-card-old{font-size:10px;color:var(--text-muted);text-decoration:line-through;margin-left:3px;}

/* SEARCH DROPDOWN */
.search-dropdown{position:absolute;top:calc(100% + 5px);left:0;right:0;background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:201;overflow:hidden;display:none;}
.search-dropdown.open{display:block}
.search-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:99;display:none;backdrop-filter:blur(2px);}
.search-backdrop.open{display:block}
.search-drop-item{display:flex;align-items:center;gap:10px;padding:9px 12px;cursor:pointer;transition:var(--transition);border-bottom:1px solid var(--border-light);}
.search-drop-item:last-child{border-bottom:none}
.search-drop-item:hover{background:var(--bg)}
.search-drop-img{width:42px;height:42px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0;}
.search-drop-info{flex:1;min-width:0}
.search-drop-name{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.search-drop-price{font-family:var(--font-head);font-size:12px;font-weight:700;color:var(--primary);margin-top:1px;}
.search-drop-empty{padding:14px 16px;display:flex;align-items:flex-start;gap:10px;color:var(--text-muted);font-size:13px;}
.search-drop-empty-icon{font-size:22px;flex-shrink:0;opacity:.7;margin-top:1px;}
.search-drop-empty-text{display:flex;flex-direction:column;gap:5px;}
.search-drop-request-btn{background:none;border:none;padding:0;color:var(--primary);font-size:12px;font-weight:700;cursor:pointer;text-align:left;text-decoration:underline;text-underline-offset:2px;}
.search-drop-request-btn:hover{opacity:.8;}

/* BANNER POPUP */
.bnr-popup-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:350;display:flex;align-items:flex-end;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;backdrop-filter:blur(6px);}
.bnr-popup-overlay.open{opacity:1;pointer-events:all}
@media(min-width:600px){.bnr-popup-overlay{align-items:center}}
.bnr-popup-box{background:var(--bg-card);width:100%;max-width:880px;max-height:90vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;overflow:hidden;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .4s cubic-bezier(.4,0,.2,1);}
@media(min-width:600px){.bnr-popup-box{border-radius:var(--radius-xl);max-height:82vh;transform:scale(.95) translateY(16px)}}
.bnr-popup-overlay.open .bnr-popup-box{transform:translateY(0)}
@media(min-width:600px){.bnr-popup-overlay.open .bnr-popup-box{transform:scale(1) translateY(0)}}
@media(max-width:599px){
  .bnr-popup-overlay{background:var(--bg-card);backdrop-filter:none;}
  .bnr-popup-box{max-width:100%;height:100%;max-height:100%;border-radius:0;overflow:visible;transform:translateX(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);}
  .bnr-popup-overlay.open .bnr-popup-box{transform:translateX(0);}
  .bnr-popup-header{position:sticky;top:0;background:var(--bg-card);z-index:2;}
  .bnr-popup-body{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch;}
}
.bnr-popup-header{padding:16px 18px 13px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.bnr-popup-title{font-family:var(--font-head);font-size:17px;font-weight:800;}
.bnr-popup-body{overflow-y:auto;flex:1;padding:16px 16px 24px;}
.bnr-popup-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;}
@media(min-width:500px){.bnr-popup-grid{grid-template-columns:repeat(3,1fr)}}
@media(min-width:768px){.bnr-popup-grid{grid-template-columns:repeat(4,1fr)}}

/* TOAST */
.toast-container{position:fixed;bottom:88px;left:50%;transform:translateX(-50%);z-index:500;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none;}
.toast{background:var(--text-primary);color:var(--bg-card);padding:9px 16px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;display:flex;align-items:center;gap:7px;box-shadow:var(--shadow-lg);animation:toastIn .3s cubic-bezier(.34,1.56,.64,1);max-width:260px;text-align:center;}
.toast.removing{animation:toastOut .3s ease forwards}
@keyframes toastIn{from{opacity:0;transform:translateY(10px) scale(.95)}to{opacity:1;transform:none}}
@keyframes toastOut{to{opacity:0;transform:translateY(-8px) scale(.95)}}

/* FAB */
.btn-scroll-top{position:fixed;bottom:24px;left:20px;width:48px;height:48px;border-radius:50%;background:var(--primary);border:2px solid var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(241,82,0,.4);z-index:99;opacity:0;pointer-events:none;transform:translateY(10px);transition:opacity .25s,transform .25s,background .18s;}
.btn-scroll-top.visible{opacity:1;pointer-events:auto;transform:none;}
.btn-scroll-top:hover{background:var(--primary-dark);border-color:var(--primary-dark);box-shadow:0 4px 20px rgba(241,82,0,.55);}
.fab-cart{position:fixed;bottom:20px;right:20px;background:var(--primary);color:#fff;border:none;cursor:pointer;padding:13px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:700;display:flex;align-items:center;gap:7px;box-shadow:var(--shadow-xl);z-index:100;transition:opacity .3s,transform .3s,background .2s;opacity:0;pointer-events:none;}
.fab-cart:hover{transform:translateY(-3px);background:var(--primary-dark)}
.fab-cart svg{width:18px;height:18px}
.fab-cart.visible{opacity:1;pointer-events:auto;}
@media(min-width:601px){.fab-cart{bottom:24px;}}

/* FOOTER */
.footer{max-width:1400px;margin:40px auto 0;padding:24px 16px;border-top:1px solid var(--border);text-align:center;color:var(--text-muted);font-size:12px;}
.footer strong{color:var(--primary)}

/* NO RESULTS */
.no-results{grid-column:1/-1;padding:50px 20px;text-align:center;color:var(--text-muted);}
.no-results-icon{font-size:44px;margin-bottom:10px}
.no-results h3{font-family:var(--font-head);font-size:17px;margin-bottom:5px;color:var(--text-secondary)}

@keyframes slideIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.product-card.new-in{animation:slideIn .35s ease}

/* PROMOTED CARD */
.promoted-card{border-color:rgba(255,184,0,.35);}
.promoted-card:hover{border-color:var(--accent);box-shadow:0 4px 20px rgba(35, 7, 71, 0.18);}
.promo-label{position:absolute;bottom:6px;right:6px;background:rgba(0,0,0,.52);color:#fff;font-size:11px;font-weight:700;padding:3px 8px;border-radius:5px;letter-spacing:.3px;pointer-events:none;z-index:2;backdrop-filter:blur(2px);}
.promo-seller-name{color:var(--primary);font-weight:600;}
.promo-badge-modal{display:inline-block;background:rgba(255,184,0,.15);color:#7A5500;font-size:10px;font-weight:700;padding:2px 8px;border-radius:4px;letter-spacing:.3px;border:1px solid rgba(255,184,0,.4);}
[data-theme="dark"] .promo-badge-modal{background:rgba(255,184,0,.12);color:#d4a017;}
.btn-promo-wa{background:#25D366;color:#fff;width:100%;height:34px;box-sizing:border-box;text-decoration:none;}
.btn-promo-wa:hover{background:#1EA855;}
.btn-promo-wa svg{width:13px;height:13px}

/* POPUP: BANNER */
.ppb-overlay,.ppp-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:600;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .35s;}
.ppb-overlay.open,.ppp-overlay.open{opacity:1;pointer-events:all;overscroll-behavior:none;touch-action:none;}
.ppb-box,.ppp-box{touch-action:auto;}
.ppb-box{background:var(--bg-card);border-radius:28px;overflow:hidden;max-width:440px;width:100%;position:relative;box-shadow:0 32px 80px rgba(0,0,0,.35);animation:ppbIn .42s cubic-bezier(.34,1.56,.64,1);}
@keyframes ppbIn{from{opacity:0;transform:translateY(36px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}
.ppb-close{position:absolute;top:12px;right:12px;z-index:10;background:rgba(0,0,0,.5);border:none;cursor:pointer;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:var(--transition);backdrop-filter:blur(4px);}
.ppb-close:hover{background:rgba(0,0,0,.75);transform:scale(1.1) rotate(90deg);}
.ppb-close svg{width:15px;height:15px;}
.ppb-hero{position:relative;height:230px;overflow:hidden;background:var(--bg);}
.ppb-img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;}
.ppb-box:hover .ppb-img{transform:scale(1.05);}
.ppb-grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.8) 0%,rgba(0,0,0,.1) 55%,transparent 100%);}
.ppb-badge{position:absolute;top:16px;left:16px;background:linear-gradient(135deg,var(--primary),#FF6B35);color:#fff;font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:1px;padding:6px 14px;border-radius:999px;box-shadow:0 4px 20px rgba(241,82,0,.55);animation:ppbBadgePulse 2.8s ease-in-out infinite;}
@keyframes ppbBadgePulse{0%,100%{box-shadow:0 4px 20px rgba(241,82,0,.5)}50%{box-shadow:0 4px 32px rgba(241,82,0,.85),0 0 0 4px rgba(241,82,0,.15)}}
.ppb-body{padding:22px 22px 26px;display:flex;flex-direction:column;gap:12px;}
.ppb-title{font-family:var(--font-head);font-size:clamp(19px,5vw,25px);font-weight:800;line-height:1.2;background:linear-gradient(135deg,var(--primary) 0%,#FF8C42 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.ppb-sub{font-size:13.5px;color:var(--text-secondary);line-height:1.55;}
.ppb-cta{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--primary) 0%,#FF6B35 100%);color:#fff;border:none;padding:15px 24px;border-radius:999px;font-family:var(--font-head);font-size:14px;font-weight:700;cursor:pointer;transition:all .25s;align-self:stretch;letter-spacing:.4px;box-shadow:0 6px 28px rgba(241,82,0,.4);}
.ppb-cta::after{content:'';position:absolute;inset:0;left:-110%;width:50%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transform:skewX(-20deg);transition:left .55s ease;}
.ppb-cta:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(241,82,0,.55);}
.ppb-cta:hover::after{left:160%;}
.ppb-dismiss{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;align-self:center;padding:0;text-decoration:underline;}
.ppb-dismiss:hover{color:var(--text-secondary);}
/* POPUP: PRODUCT */
.ppp-box{background:var(--bg-card);border-radius:28px;overflow:hidden;max-width:390px;width:100%;position:relative;box-shadow:0 32px 80px rgba(0,0,0,.35);animation:pppIn .42s cubic-bezier(.34,1.56,.64,1);}
@keyframes pppIn{from{opacity:0;transform:scale(.88) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}
.ppp-close{position:absolute;top:12px;right:12px;z-index:10;background:rgba(0,0,0,.5);border:none;cursor:pointer;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;transition:var(--transition);backdrop-filter:blur(4px);}
.ppp-close:hover{background:rgba(0,0,0,.75);transform:scale(1.1) rotate(90deg);}
.ppp-close svg{width:15px;height:15px;}
.ppp-img-wrap{position:relative;aspect-ratio:4/3;overflow:hidden;background:var(--bg);contain-intrinsic-size:1px 300px;}
.ppp-img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease;}
.ppp-box:hover .ppp-img{transform:scale(1.05);}
.ppp-ribbon{position:absolute;top:22px;left:-30px;background:linear-gradient(135deg,#FF3B3B,#FF6B00);color:#fff;font-family:var(--font-head);font-size:10px;font-weight:800;letter-spacing:1.5px;padding:6px 40px;transform:rotate(-42deg);box-shadow:0 4px 14px rgba(255,59,59,.45);text-transform:uppercase;}
.ppp-disc-chip{position:absolute;bottom:12px;left:12px;background:linear-gradient(135deg,var(--primary),#FF6B35);color:#fff;font-family:var(--font-head);font-size:14px;font-weight:800;padding:5px 13px;border-radius:999px;box-shadow:0 4px 18px rgba(241,82,0,.55);display:none;}
.ppp-body{padding:18px 20px 24px;display:flex;flex-direction:column;gap:10px;}
.ppp-badge-row{display:flex;align-items:center;}
.ppp-badge{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--primary);background:var(--primary-light);padding:4px 11px;border-radius:999px;}
.ppp-name{font-family:var(--font-head);font-size:clamp(15px,4vw,19px);font-weight:800;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.ppp-desc{font-size:12.5px;color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
.ppp-price-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;}
.ppp-price{font-family:var(--font-head);font-size:28px;font-weight:800;color:var(--secondary);}
.ppp-old{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--text-muted);text-decoration:line-through;}
.ppp-seller{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:5px;}
.ppp-seller::before{content:'\1F6D2';}
.ppp-wa{display:flex;align-items:center;justify-content:center;gap:10px;padding:15px 20px;border-radius:999px;font-family:var(--font-head);font-size:14px;font-weight:700;color:#fff;background:linear-gradient(135deg,#25D366 0%,#128C7E 100%);text-decoration:none;box-shadow:0 6px 28px rgba(37,211,102,.45);transition:all .25s;animation:waPulse 2.8s ease-in-out infinite;}
@keyframes waPulse{0%,100%{box-shadow:0 6px 28px rgba(37,211,102,.45)}50%{box-shadow:0 8px 40px rgba(37,211,102,.75),0 0 0 4px rgba(37,211,102,.12)}}
.ppp-wa:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(37,211,102,.65);animation:none;}
.ppp-wa svg{width:22px;height:22px;flex-shrink:0;}
.ppp-dismiss{background:none;border:none;color:var(--text-muted);font-size:11px;cursor:pointer;align-self:center;padding:0;text-decoration:underline;}
.ppp-dismiss:hover{color:var(--text-secondary);}

/* RECENTLY VIEWED */
.recent-section{padding-top:0;margin-top:24px;}
/* Horizontal card — only for recently viewed */
.recent-item-wrap{position:relative;flex-shrink:0;width:250px;display:flex;flex-direction:column;}
@media(min-width:480px){.recent-item-wrap{width:270px;}}
@media(min-width:768px){.recent-item-wrap{width:290px;}}
.recent-hcard{display:flex;flex-direction:row;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden;cursor:pointer;position:relative;transition:var(--transition);flex:1;}
.recent-hcard:hover{box-shadow:var(--shadow-lg);border-color:var(--primary);}
.recent-hcard-img-wrap{position:relative;flex-shrink:0;width:60px;align-self:stretch;background:var(--bg);}
.recent-hcard-img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;display:block;}
.recent-hcard-img.img-loaded{opacity:1;}
.recent-hcard-disc{position:absolute;bottom:5px;left:5px;background:var(--primary);color:#fff;font-family:var(--font-head);font-size:9px;font-weight:700;padding:2px 5px;border-radius:4px;}
.recent-hcard-body{flex:1;min-width:0;padding:8px 8px 8px 10px;display:flex;flex-direction:column;gap:3px;}
.recent-hcard-name{font-family:var(--font-head);font-size:11px;font-weight:600;color:var(--text-primary);display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35;}
.recent-hcard-prices{display:flex;align-items:baseline;gap:5px;flex-wrap:wrap;}
.recent-hcard-actions{display:flex;flex-direction:column;gap:4px;margin-top:auto;padding-top:6px;}
.btn-clear-recent{background:none;border:1.5px solid var(--border);cursor:pointer;padding:5px 10px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:11px;color:var(--text-muted);transition:var(--transition);display:flex;align-items:center;gap:4px;white-space:nowrap;flex-shrink:0;}
.btn-clear-recent:hover{border-color:#EF4444;color:#EF4444;}
.btn-clear-recent svg{width:11px;height:11px;}
.btn-remove-recent{position:absolute;top:4px;right:4px;z-index:2;width:20px;height:20px;border-radius:50%;background:rgba(0,0,0,.45);border:none;color:#fff;font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;}
.recent-item-wrap:hover .btn-remove-recent{opacity:1;}
.recent-cta-card{flex-shrink:0;width:120px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;border-radius:var(--radius-lg);border:2px dashed var(--border);background:var(--bg);cursor:pointer;padding:16px 10px;transition:var(--transition);text-align:center;align-self:stretch;}
.recent-cta-card:hover{border-color:var(--primary);background:var(--primary-light);}
.recent-cta-icon{font-size:24px;}
.recent-cta-text{font-family:var(--font-head);font-size:11px;font-weight:700;color:var(--text-secondary);line-height:1.3;}
.recent-cta-card:hover .recent-cta-text{color:var(--primary);}
.recent-cta-arrow{font-size:18px;color:var(--text-muted);transition:var(--transition);}
.recent-cta-card:hover .recent-cta-arrow{color:var(--primary);transform:translateX(3px);}

/* COUPON */
.cupon-row{display:flex;gap:8px;}
.cupon-row .order-input{flex:1;}
.btn-apply-cupon{background:var(--primary);color:#fff;border:none;padding:0 16px;border-radius:var(--radius-md);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:var(--transition);}
.btn-apply-cupon:hover{background:var(--primary-dark);}
.cupon-feedback{font-size:12px;font-weight:600;min-height:16px;margin-top:2px;}
.cupon-feedback.ok{color:var(--secondary);}
.cupon-feedback.err{color:#ef4444;}

/* SKELETON */
@keyframes shimmer{0%{background-position:-600px 0}100%{background-position:600px 0}}
.skel-card{background:var(--bg-card);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);}
.skel-img,.skel-line,.skel-btn{background:linear-gradient(90deg,var(--border) 25%,var(--bg-card) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.4s ease-in-out infinite;}
.skel-img{aspect-ratio:1;width:100%;}
.skel-body{padding:11px;display:flex;flex-direction:column;gap:8px;}
.skel-line{height:11px;border-radius:4px;}
.skel-line.w40{width:40%}.skel-line.w60{width:60%}.skel-line.w80{width:80%}
.skel-btn{height:30px;border-radius:var(--radius-md);}
#gridSectionHeader{scroll-margin-top:110px}

/* BANNER ALTERNATIVO 2 */
.bnr2{max-width:1400px;margin:16px auto 0;padding:0 16px;}
.bnr2-inner{border-radius:var(--radius-xl);overflow:hidden;display:grid;grid-template-columns:1fr 1fr;min-height:190px;}
@media(min-width:600px){.bnr2-inner{min-height:240px}}
@media(min-width:768px){.bnr2-inner{min-height:300px}}
.bnr2-left{background:#0F172A;padding:28px 30px;display:flex;flex-direction:column;justify-content:center;gap:10px;position:relative;}
.bnr2-right{background:linear-gradient(160deg,#F15200,#FF8C00);display:flex;align-items:center;justify-content:center;font-size:100px;position:relative;overflow:hidden;}
@media(min-width:600px){.bnr2-right{font-size:160px}}
.bnr2-badge{position:absolute;top:14px;left:14px;background:var(--accent);color:#111;font-family:var(--font-head);font-size:10px;font-weight:800;padding:4px 10px;border-radius:var(--radius-full);letter-spacing:.5px;text-transform:uppercase;}
.bnr2-eyebrow{font-size:11px;font-weight:600;color:rgba(255,255,255,.5);letter-spacing:1px;text-transform:uppercase;}
.bnr2-title{font-family:var(--font-head);font-size:clamp(15px,3vw,28px);font-weight:800;color:#fff;line-height:1.15;}
.bnr2-title span{color:var(--accent);}
.bnr2-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.bnr2-pill{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:11px;font-weight:600;padding:4px 12px;border-radius:var(--radius-full);white-space:nowrap;}
.bnr2-cta{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;border:none;transition:var(--transition);}
.bnr2-cta:hover{background:var(--primary-dark);transform:translateY(-2px)}
.bnr2-deco{position:absolute;bottom:-10px;right:-10px;font-size:120px;opacity:.12;transform:rotate(20deg);pointer-events:none;}

/* BANNER ALTERNATIVO 3 */
.bnr3{max-width:1400px;margin:16px auto 0;padding:0 16px;}
.bnr3-inner{border-radius:var(--radius-xl);background:#0A0A0A;min-height:190px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:32px 24px;position:relative;overflow:hidden;}
@media(min-width:600px){.bnr3-inner{min-height:240px}}
@media(min-width:768px){.bnr3-inner{min-height:300px;padding:40px 32px}}
.bnr3-glow{position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(241,82,0,.35) 0%,transparent 70%);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.bnr3-label{font-family:var(--font-head);font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--primary);margin-bottom:10px;position:relative;}
.bnr3-title{font-family:var(--font-head);font-size:clamp(20px,5vw,46px);font-weight:800;color:#fff;line-height:1.05;margin-bottom:8px;position:relative;}
.bnr3-title em{font-style:normal;color:var(--primary);}
.bnr3-sub{font-size:13px;color:rgba(255,255,255,.5);margin-bottom:18px;position:relative;}
.bnr3-btns{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;position:relative;}
.bnr3-btn-main{background:var(--primary);color:#fff;border:none;padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);}
.bnr3-btn-main:hover{background:var(--primary-dark);transform:translateY(-2px)}
.bnr3-btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3);padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);}
.bnr3-btn-ghost:hover{border-color:#fff;}

/* BANNER ALTERNATIVO 4 */
.bnr4{max-width:1400px;margin:16px auto 0;padding:0 16px;}
.bnr4-inner{display:grid;grid-template-columns:1fr 1fr;gap:10px;min-height:190px;}
@media(min-width:600px){.bnr4-inner{grid-template-columns:2fr 1fr 1fr;min-height:230px}}
@media(min-width:768px){.bnr4-inner{min-height:280px}}
.bnr4-main{border-radius:var(--radius-xl);background:linear-gradient(140deg,#1A1A2E,#16213E);padding:28px 24px;display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden;grid-column:1/-1;}
@media(min-width:600px){.bnr4-main{grid-column:1/2;grid-row:1}}
.bnr4-main-emoji{position:absolute;top:-10px;right:10px;font-size:130px;opacity:.18;transform:rotate(-10deg);pointer-events:none;}
.bnr4-kicker{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:6px;}
.bnr4-main-title{font-family:var(--font-head);font-size:clamp(14px,3vw,24px);font-weight:800;color:#fff;line-height:1.2;margin-bottom:14px;}
.bnr4-main-title b{color:#FFD700;}
.bnr4-main-cta{align-self:flex-start;background:#fff;color:#1A1A2E;border:none;padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:800;cursor:pointer;transition:var(--transition);}
.bnr4-main-cta:hover{background:var(--accent);transform:translateY(-2px)}
.bnr4-mini{border-radius:var(--radius-xl);padding:20px 18px;display:flex;flex-direction:column;justify-content:space-between;overflow:hidden;position:relative;cursor:pointer;transition:var(--transition);}
.bnr4-mini:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.bnr4-mini-emoji{font-size:48px;margin-bottom:6px;}
.bnr4-mini-label{font-family:var(--font-head);font-size:13px;font-weight:800;color:#fff;}
.bnr4-mini-sub{font-size:11px;color:rgba(255,255,255,.7);margin-top:2px;}
.bnr4-mini-arrow{font-size:18px;color:rgba(255,255,255,.6);margin-top:8px;}

/* CONTROL DE CANTIDAD EN TARJETA */
.card-qty-ctrl{display:flex;align-items:center;background:var(--primary);border-radius:var(--radius-md);overflow:hidden;height:34px;}
.card-qty-btn{background:transparent;border:none;color:#fff;font-size:20px;font-weight:300;cursor:pointer;width:36px;height:100%;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0;padding:0;line-height:1;}
.card-qty-btn:hover{background:rgba(0,0,0,.2)}
.card-qty-num{color:#fff;font-family:var(--font-head);font-size:14px;font-weight:800;flex:1;text-align:center;pointer-events:none;user-select:none;}
.fly-add{position:fixed;z-index:9999;pointer-events:none;width:38px;height:38px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(241,82,0,.5);}
@keyframes fab-catch{0%{transform:scale(1)}30%{transform:scale(1.28)}60%{transform:scale(.93)}80%{transform:scale(1.1)}100%{transform:scale(1)}}
.fab-catch{animation:fab-catch .42s cubic-bezier(.36,.07,.19,.97);}

/* BANNERS — estructura base y carrusel */
.sbnr{max-width:1400px;margin:16px auto 0;padding:0 16px;}
.sbnr-carousel{max-width:1400px;margin:16px auto 0;padding:0 16px;position:relative;}
.sbnr-carousel-viewport{overflow:hidden;border-radius:var(--radius-xl);height:196px;}
@media(min-width:600px){.sbnr-carousel-viewport{height:240px;}}
@media(min-width:768px){.sbnr-carousel-viewport{height:295px;}}
.sbnr-track{display:flex;transition:transform .45s cubic-bezier(.4,0,.2,1);will-change:transform;}
.sbnr-carousel .sbnr{margin:0;padding:0;flex:0 0 100%;min-width:100%;}
.sbnr-carousel .sbnr-glow{margin:0;}
.sbnr-dots{display:flex;justify-content:center;gap:6px;margin-top:10px;}
.sbnr-dot{width:8px;height:8px;border-radius:50%;border:none;background:var(--border);cursor:pointer;padding:0;transition:background .2s,transform .2s;}
.sbnr-dot.active{background:var(--primary);transform:scale(1.25);}
.sbnr-arrow{position:absolute;top:calc(50% - 11px);transform:translateY(-50%);background:rgba(0,0,0,.35);border:none;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:background .2s;z-index:2;}
.sbnr-arrow:hover{background:rgba(0,0,0,.55);}
.sbnr-arrow svg{width:18px;height:18px;}
.sbnr-arrow-prev{left:24px;}
.sbnr-arrow-next{right:24px;}
@media(max-width:480px){.sbnr-arrow{display:none;}}
/* GLOW — diseño de producción */
.sbnr-deco{position:absolute;right:18px;bottom:8px;font-size:clamp(70px,10vw,110px);opacity:.07;pointer-events:none;transform:rotate(-15deg);line-height:1;}
.sbnr-glow{height:196px;position:relative;display:flex;align-items:center;justify-content:center;padding:36px 24px;overflow:hidden;}
@media(min-width:600px){.sbnr-glow{height:240px;}}
@media(min-width:768px){.sbnr-glow{height:295px;padding:40px 32px;}}
.sbnr-glow-spot{position:absolute;width:320px;height:320px;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.sbnr-glow-ring{position:absolute;width:210px;height:210px;border-radius:50%;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.sbnr-glow-ring2{position:absolute;width:340px;height:340px;border-radius:50%;border:1px solid rgba(255,255,255,.06);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.sbnr-glow-content{position:relative;z-index:1;text-align:center;max-width:520px;}
.sbnr-glow-tag{display:inline-block;padding:3px 14px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;border:1px solid;}
.sbnr-glow-title{font-family:var(--font-head);font-size:clamp(18px,4vw,34px);font-weight:900;color:#fff;line-height:1.05;margin-bottom:4px;}
.sbnr-glow-title em{font-style:normal;}
.sbnr-glow-sub{font-size:12px;color:rgba(255,255,255,.55);margin-bottom:12px;}
.sbnr-glow-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.sbnr-glow-btn{border:none;padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:0 4px 22px rgba(0,0,0,.25);}
.sbnr-glow-btn:hover{transform:translateY(-2px);filter:brightness(1.12);box-shadow:0 8px 30px rgba(0,0,0,.35);}
.sbnr-ghost{background:rgba(255,255,255,.07);color:rgba(255,255,255,.7);border:1.5px solid rgba(255,255,255,.18);padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-ghost:hover{background:rgba(255,255,255,.14);color:#fff;}
/* ===== NUEVAS OPCIONES DE BANNER (preview) ===== */
.sbnr-opts-wrap{max-width:1400px;margin:20px auto 0;padding:0 16px;}
.sbnr-opts-label{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:2.5px;margin-bottom:14px;display:flex;align-items:center;gap:10px;}
.sbnr-opts-label::before,.sbnr-opts-label::after{content:'';flex:1;height:1px;background:var(--border);}
.sbnr-opts-item-label{font-family:var(--font-head);font-size:10px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:6px;}
.sbnr-opts-items{display:flex;flex-direction:column;gap:20px;}
/* OPT 4 — NEON DARK */
.sbnr-o4{overflow:hidden;height:196px;display:flex;align-items:center;padding:28px 32px;background:#080808;position:relative;}
@media(min-width:600px){.sbnr-o4{height:240px;}}
@media(min-width:768px){.sbnr-o4{height:295px;}}
.sbnr-o4-line{position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent 0%,var(--primary) 30%,#ff9d6e 60%,transparent 100%);}
.sbnr-o4-line2{position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.08) 50%,transparent 100%);}
.sbnr-o4-content{position:relative;z-index:1;flex:1;}
.sbnr-o4-tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--primary);margin-bottom:10px;}
.sbnr-o4-tag::before{content:'';display:inline-block;width:18px;height:1.5px;background:var(--primary);}
.sbnr-o4-title{font-family:var(--font-head);font-size:clamp(19px,4vw,38px);font-weight:900;color:#fff;line-height:1.0;margin-bottom:4px;letter-spacing:-1px;}
.sbnr-o4-title em{font-style:normal;-webkit-text-stroke:1.5px var(--primary);color:transparent;}
.sbnr-o4-sub{font-size:12px;color:rgba(255,255,255,.4);margin-bottom:14px;max-width:340px;}
.sbnr-o4-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-o4-btn{background:var(--primary);color:#fff;border:none;padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-o4-btn:hover{background:var(--primary-dark);transform:translateY(-2px);}
.sbnr-o4-ghost{background:transparent;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.14);padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-o4-ghost:hover{border-color:rgba(255,255,255,.4);color:#fff;}
.sbnr-o4-emoji{flex-shrink:0;font-size:clamp(70px,10vw,120px);line-height:1;opacity:.85;margin-left:20px;position:relative;z-index:1;}
@media(max-width:480px){.sbnr-o4-emoji{display:none;}}
/* OPT 5 — FROSTED LIGHT */
.sbnr-o5{overflow:hidden;height:196px;position:relative;display:flex;align-items:center;justify-content:center;padding:32px 24px;}
@media(min-width:600px){.sbnr-o5{height:240px;}}
@media(min-width:768px){.sbnr-o5{height:295px;}}
.sbnr-o5-bg{position:absolute;inset:0;background:linear-gradient(135deg,#fff8f4 0%,#ffeee4 40%,#ffe0cc 100%);}
.sbnr-o5-blob{position:absolute;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(241,82,0,.18) 0%,transparent 70%);bottom:-80px;right:-40px;pointer-events:none;}
.sbnr-o5-blob2{position:absolute;width:160px;height:160px;border-radius:50%;background:radial-gradient(circle,rgba(255,184,0,.2) 0%,transparent 70%);top:-40px;left:20px;pointer-events:none;}
.sbnr-o5-card{position:relative;z-index:1;background:rgba(255,255,255,.72);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.95);border-radius:20px;padding:24px 28px;max-width:420px;text-align:center;box-shadow:0 8px 32px rgba(241,82,0,.1);}
.sbnr-o5-tag{display:inline-block;background:var(--primary);color:#fff;padding:3px 12px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:7px;}
.sbnr-o5-title{font-family:var(--font-head);font-size:clamp(16px,3.2vw,28px);font-weight:900;color:#111;line-height:1.05;margin-bottom:4px;}
.sbnr-o5-title em{font-style:normal;color:var(--primary);}
.sbnr-o5-sub{font-size:11px;color:rgba(0,0,0,.45);margin-bottom:12px;}
.sbnr-o5-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.sbnr-o5-btn{background:var(--primary);color:#fff;border:none;padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);box-shadow:0 4px 14px rgba(241,82,0,.35);}
.sbnr-o5-btn:hover{transform:translateY(-2px);box-shadow:0 8px 22px rgba(241,82,0,.5);}
.sbnr-o5-ghost{background:transparent;color:var(--primary);border:1.5px solid rgba(241,82,0,.3);padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-o5-ghost:hover{background:rgba(241,82,0,.07);border-color:var(--primary);}
/* OPT 6 — DIAGONAL SPLIT */
.sbnr-o6{overflow:hidden;height:196px;position:relative;display:grid;grid-template-columns:55% 45%;}
@media(min-width:600px){.sbnr-o6{height:240px;}}
@media(min-width:768px){.sbnr-o6{height:295px;}}
@media(max-width:500px){.sbnr-o6{grid-template-columns:1fr;}}
.sbnr-o6-left{background:#111827;padding:28px 32px;display:flex;flex-direction:column;justify-content:center;position:relative;clip-path:polygon(0 0,100% 0,88% 100%,0 100%);}
.sbnr-o6-right{display:flex;align-items:center;justify-content:center;background:var(--primary);position:relative;overflow:hidden;}
@media(max-width:500px){.sbnr-o6-right{display:none;}}
.sbnr-o6-strips{position:absolute;inset:0;background:repeating-linear-gradient(45deg,transparent,transparent 12px,rgba(255,255,255,.06) 12px,rgba(255,255,255,.06) 24px);}
.sbnr-o6-tag{display:inline-block;border:1.5px solid rgba(255,255,255,.2);color:rgba(255,255,255,.6);padding:3px 12px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:7px;width:fit-content;}
.sbnr-o6-title{font-family:var(--font-head);font-size:clamp(16px,3.2vw,30px);font-weight:900;color:#fff;line-height:1.05;margin-bottom:4px;}
.sbnr-o6-title em{font-style:normal;color:var(--primary);}
.sbnr-o6-sub{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:12px;}
.sbnr-o6-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-o6-btn{background:var(--primary);color:#fff;border:none;padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-o6-btn:hover{background:var(--primary-dark);transform:translateY(-2px);}
.sbnr-o6-ghost{background:transparent;color:rgba(255,255,255,.6);border:1.5px solid rgba(255,255,255,.18);padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-o6-ghost:hover{border-color:rgba(255,255,255,.6);color:#fff;}
.sbnr-o6-emoji{font-size:clamp(80px,10vw,130px);line-height:1;position:relative;z-index:1;}
@media(max-width:480px){.sbnr-o6-emoji{font-size:80px;}}

/* ── MARQUEE STRIP ──────────────────────────────────────────────────────────── */
.sbnr-mk{overflow:hidden;height:196px;display:flex;flex-direction:column;position:relative;}
@media(min-width:600px){.sbnr-mk{height:240px;}}
@media(min-width:768px){.sbnr-mk{height:295px;}}
.sbnr-mk-strip{flex-shrink:0;overflow:hidden;white-space:nowrap;padding:6px 0;display:flex;}
.sbnr-mk-marquee{display:flex;animation:sbnr-marquee 48s linear infinite;}
.sbnr-mk-inner{white-space:nowrap;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.75);padding:0 0;}
@keyframes sbnr-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.sbnr-mk-body{flex:1;display:flex;align-items:center;padding:12px 32px;gap:16px;}
.sbnr-mk-left{flex:1;z-index:1;position:relative;}
.sbnr-mk-title{font-family:var(--font-head);font-size:clamp(17px,3.6vw,32px);font-weight:900;color:#fff;line-height:1.0;margin-bottom:4px;}
.sbnr-mk-title em{font-style:normal;}
.sbnr-mk-sub{font-size:11px;color:rgba(255,255,255,.5);margin-bottom:10px;max-width:320px;}
.sbnr-mk-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-mk-btn{color:#fff;border:none;padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-mk-btn:hover{transform:translateY(-2px);filter:brightness(1.1);}
.sbnr-mk-ghost{background:rgba(255,255,255,.08);color:rgba(255,255,255,.7);border:1.5px solid rgba(255,255,255,.2);padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-mk-ghost:hover{background:rgba(255,255,255,.16);}
.sbnr-mk-deco{flex-shrink:0;font-size:clamp(60px,9vw,110px);line-height:1;opacity:.9;}
@media(max-width:480px){.sbnr-mk-deco{display:none;}}

/* ── BRUTALIST ──────────────────────────────────────────────────────────────── */
.sbnr-br{overflow:hidden;height:196px;display:flex;align-items:center;padding:28px 28px 28px 48px;position:relative;}
@media(min-width:600px){.sbnr-br{height:240px;}}
@media(min-width:768px){.sbnr-br{height:295px;padding:32px 40px 32px 60px;}}
.sbnr-br-bar{position:absolute;left:0;top:0;bottom:0;width:12px;}
.sbnr-br-bg{position:absolute;inset:0;}
.sbnr-br-content{position:relative;z-index:1;flex:1;}
.sbnr-br-tag{display:inline-block;color:#fff;padding:4px 12px;border-radius:3px;font-family:var(--font-head);font-size:9px;font-weight:800;letter-spacing:3px;text-transform:uppercase;margin-bottom:8px;}
.sbnr-br-title{font-family:var(--font-head);font-size:clamp(20px,4.2vw,40px);font-weight:900;line-height:0.95;margin-bottom:4px;letter-spacing:-2px;}
.sbnr-br-title em{font-style:normal;display:block;}
.sbnr-br-sub{font-size:11px;margin-bottom:12px;max-width:380px;line-height:1.5;}
.sbnr-br-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-br-btn{color:#fff;border:none;padding:10px 22px;border-radius:4px;font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-br-btn:hover{filter:brightness(1.12);transform:translateY(-2px);}
.sbnr-br-ghost{background:transparent;border:2px solid;padding:10px 22px;border-radius:4px;font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-br-ghost:hover{opacity:.7;}
.sbnr-br-deco{position:absolute;right:28px;bottom:-8px;font-size:clamp(90px,13vw,170px);line-height:1;opacity:.05;pointer-events:none;transform:rotate(-10deg);}

/* ── AURORA ─────────────────────────────────────────────────────────────────── */
.sbnr-au{overflow:hidden;height:196px;display:flex;align-items:center;padding:28px 32px;position:relative;gap:20px;}
@media(min-width:600px){.sbnr-au{height:240px;}}
@media(min-width:768px){.sbnr-au{height:295px;}}
.sbnr-au-blob1{position:absolute;width:400px;height:400px;border-radius:50%;top:-120px;left:-100px;pointer-events:none;animation:sbnr-float 8s ease-in-out infinite alternate;}
.sbnr-au-blob2{position:absolute;width:300px;height:300px;border-radius:50%;bottom:-130px;right:22%;pointer-events:none;animation:sbnr-float 11s ease-in-out infinite alternate-reverse;}
.sbnr-au-blob3{position:absolute;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(120,80,255,.22) 0%,transparent 70%);top:-20px;right:8%;pointer-events:none;}
.sbnr-au-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:36px 36px;pointer-events:none;}
.sbnr-au-content{position:relative;z-index:1;flex:1;}
.sbnr-au-eyebrow{display:inline-flex;align-items:center;gap:6px;border:1px solid;padding:4px 12px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:8px;}
.sbnr-au-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;animation:sbnr-pulse 2s ease-in-out infinite;}
.sbnr-au-title{font-family:var(--font-head);font-size:clamp(17px,3.6vw,34px);font-weight:900;color:#fff;line-height:1.0;margin-bottom:4px;}
.sbnr-au-title em{font-style:normal;}
.sbnr-au-sub{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:12px;max-width:340px;}
.sbnr-au-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-au-btn{color:#fff;border:none;padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-au-btn:hover{transform:translateY(-2px);filter:brightness(1.12);}
.sbnr-au-ghost{background:rgba(255,255,255,.06);color:rgba(255,255,255,.6);border:1px solid rgba(255,255,255,.15);padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-au-ghost:hover{background:rgba(255,255,255,.12);color:#fff;}
.sbnr-au-right{position:relative;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.sbnr-au-orb{position:absolute;width:200px;height:200px;border-radius:50%;}
.sbnr-au-emoji{font-size:clamp(60px,9vw,100px);line-height:1;position:relative;z-index:1;}
@media(max-width:520px){.sbnr-au-right{display:none;}}
@keyframes sbnr-float{from{transform:translateY(0) scale(1)}to{transform:translateY(-18px) scale(1.05)}}
@keyframes sbnr-pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* ── MAGAZINE EDITORIAL ─────────────────────────────────────────────────────── */
.sbnr-mag{overflow:hidden;height:196px;display:grid;grid-template-columns:140px 1fr;}
@media(min-width:600px){.sbnr-mag{height:240px;grid-template-columns:180px 1fr;}}
@media(min-width:768px){.sbnr-mag{height:295px;grid-template-columns:220px 1fr;}}
@media(max-width:360px){.sbnr-mag{grid-template-columns:90px 1fr;}}
.sbnr-mag-left{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;}
.sbnr-mag-vert{writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font-family:var(--font-head);font-size:clamp(9px,1.5vw,13px);font-weight:800;letter-spacing:5px;text-transform:uppercase;position:relative;z-index:1;}
.sbnr-mag-decoL{position:absolute;font-size:clamp(80px,12vw,150px);line-height:1;opacity:.16;pointer-events:none;}
.sbnr-mag-right{background:var(--bg-card,#fff);padding:20px 24px;display:flex;flex-direction:column;justify-content:center;}
.sbnr-mag-rule{height:3px;width:48px;margin-bottom:5px;flex-shrink:0;}
.sbnr-mag-issue{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;margin-bottom:5px;}
.sbnr-mag-title{font-family:var(--font-head);font-size:clamp(15px,2.8vw,27px);font-weight:900;color:var(--text-primary,#111);line-height:1.0;margin-bottom:4px;letter-spacing:-.5px;}
.sbnr-mag-title strong{font-style:normal;font-weight:900;}
.sbnr-mag-sub{font-size:10px;color:var(--text-muted,#6b7280);margin-bottom:10px;line-height:1.5;}
.sbnr-mag-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-mag-btn{color:#fff;border:none;padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:11px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-mag-btn:hover{filter:brightness(1.12);transform:translateY(-2px);}
.sbnr-mag-ghost{background:transparent;border:1.5px solid;padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:11px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-mag-ghost:hover{opacity:.7;}

/* ── SPOTLIGHT ──────────────────────────────────────────────────────────────── */
.sbnr-spot{overflow:hidden;height:196px;position:relative;display:flex;align-items:center;justify-content:center;padding:28px 24px;}
@media(min-width:600px){.sbnr-spot{height:240px;}}
@media(min-width:768px){.sbnr-spot{height:295px;}}
.sbnr-spot-cone{position:absolute;inset:0;pointer-events:none;}
.sbnr-spot-dots{position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.1) 1px,transparent 1px);background-size:24px 24px;pointer-events:none;}
.sbnr-spot-content{position:relative;z-index:1;text-align:center;max-width:500px;}
.sbnr-spot-badge{display:inline-flex;align-items:center;padding:4px 16px;border-radius:var(--radius-full);border:1px solid;font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:8px;}
.sbnr-spot-title{font-family:var(--font-head);font-size:clamp(18px,4vw,36px);font-weight:900;color:#fff;line-height:1.0;margin-bottom:4px;}
.sbnr-spot-title em{font-style:normal;}
.sbnr-spot-sub{font-size:11px;color:rgba(255,255,255,.45);margin-bottom:12px;}
.sbnr-spot-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.sbnr-spot-btn{color:#fff;border:none;padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-spot-btn:hover{transform:translateY(-2px);filter:brightness(1.12);}
.sbnr-spot-ghost{background:transparent;color:rgba(255,255,255,.6);border:1.5px solid rgba(255,255,255,.2);padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:13px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-spot-ghost:hover{background:rgba(255,255,255,.07);color:#fff;}
.sbnr-spot-deco{position:absolute;right:20px;bottom:-4px;font-size:clamp(80px,11vw,130px);line-height:1;opacity:.06;pointer-events:none;transform:rotate(8deg);}

/* ── RETRO WAVE ─────────────────────────────────────────────────────────────── */
.sbnr-rw{overflow:hidden;height:196px;position:relative;display:flex;align-items:center;padding:24px 32px;}
@media(min-width:600px){.sbnr-rw{height:240px;}}
@media(min-width:768px){.sbnr-rw{height:295px;}}
.sbnr-rw-bg{position:absolute;inset:0;}
.sbnr-rw-scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.14) 3px,rgba(0,0,0,.14) 4px);pointer-events:none;}
.sbnr-rw-grid{position:absolute;bottom:0;left:0;right:0;height:42%;background:repeating-linear-gradient(90deg,rgba(168,85,247,.15) 0,rgba(168,85,247,.15) 1px,transparent 1px,transparent 38px),repeating-linear-gradient(0deg,rgba(168,85,247,.15) 0,rgba(168,85,247,.15) 1px,transparent 1px,transparent 22px);transform:perspective(180px) rotateX(40deg);transform-origin:bottom;pointer-events:none;}
.sbnr-rw-sun{position:absolute;top:-40px;left:50%;transform:translateX(-50%);width:180px;height:90px;border-radius:50% 50% 0 0;opacity:.55;pointer-events:none;}
.sbnr-rw-content{position:relative;z-index:1;flex:1;}
.sbnr-rw-tag{font-family:var(--font-head);font-size:10px;font-weight:800;letter-spacing:4px;text-transform:uppercase;margin-bottom:6px;}
.sbnr-rw-title{font-family:var(--font-head);font-size:clamp(18px,4vw,36px);font-weight:900;color:#fff;line-height:1.0;margin-bottom:4px;letter-spacing:-1px;}
.sbnr-rw-title em{font-style:normal;}
.sbnr-rw-sub{font-size:11px;color:rgba(255,255,255,.4);margin-bottom:10px;max-width:340px;}
.sbnr-rw-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-rw-btn{color:#fff;border:none;padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-rw-btn:hover{transform:translateY(-2px);filter:brightness(1.15);}
.sbnr-rw-ghost{background:transparent;border:1.5px solid;padding:10px 22px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-rw-ghost:hover{background:rgba(255,255,255,.07);}
.sbnr-rw-deco{position:absolute;right:20px;top:50%;transform:translateY(-50%);font-size:clamp(70px,9vw,110px);line-height:1;opacity:.12;pointer-events:none;}
@media(max-width:480px){.sbnr-rw-deco{display:none;}}

/* ── PILL ───────────────────────────────────────────────────────────────────── */
/* Minimalista centrado: badge pill + título limpio + botones outlined. */
.sbnr-pill{overflow:hidden;height:196px;display:flex;align-items:center;justify-content:center;padding:24px;}
@media(min-width:600px){.sbnr-pill{height:240px;}}
@media(min-width:768px){.sbnr-pill{height:295px;}}
.sbnr-pill-noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");opacity:.6;pointer-events:none;}
.sbnr-pill-content{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:0;}
.sbnr-pill-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 16px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;margin-bottom:8px;}
.sbnr-pill-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;}
.sbnr-pill-title{font-family:var(--font-head);font-size:clamp(18px,4vw,36px);font-weight:900;line-height:1.0;margin-bottom:4px;letter-spacing:-1px;}
.sbnr-pill-title em{font-style:normal;}
.sbnr-pill-sub{font-size:11px;margin-bottom:12px;max-width:360px;line-height:1.5;}
.sbnr-pill-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.sbnr-pill-btn{color:#fff;border:none;padding:10px 26px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-pill-btn:hover{transform:translateY(-2px);filter:brightness(1.1);}
.sbnr-pill-ghost{background:transparent;border:1.5px solid;padding:10px 26px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-pill-ghost:hover{opacity:.65;}

/* ── SIDE STAT ──────────────────────────────────────────────────────────────── */
/* Grid: stat/número enorme a la izquierda, contenido a la derecha. Corporativo. */
.sbnr-ss{overflow:hidden;height:196px;display:grid;grid-template-columns:220px 1fr;position:relative;}
@media(min-width:600px){.sbnr-ss{height:240px;}}
@media(min-width:768px){.sbnr-ss{height:295px;grid-template-columns:260px 1fr;}}
@media(max-width:440px){.sbnr-ss{grid-template-columns:120px 1fr;}}
.sbnr-ss-left{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px;position:relative;overflow:hidden;}
.sbnr-ss-num{font-family:var(--font-head);font-size:clamp(52px,10vw,100px);font-weight:900;line-height:0.85;letter-spacing:-4px;position:relative;z-index:1;}
.sbnr-ss-unit{font-family:var(--font-head);font-size:clamp(14px,2.5vw,22px);font-weight:700;letter-spacing:1px;position:relative;z-index:1;}
.sbnr-ss-bg-deco{position:absolute;font-size:220px;line-height:1;opacity:.06;pointer-events:none;z-index:0;bottom:-20px;right:-20px;}
.sbnr-ss-right{background:var(--bg-card,#fff);padding:24px 28px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid rgba(0,0,0,.06);}
.sbnr-ss-tag{font-family:var(--font-head);font-size:9px;font-weight:800;letter-spacing:3px;text-transform:uppercase;margin-bottom:6px;}
.sbnr-ss-title{font-family:var(--font-head);font-size:clamp(15px,3vw,27px);font-weight:900;color:var(--text-primary,#111);line-height:1.0;margin-bottom:4px;letter-spacing:-.5px;}
.sbnr-ss-title em{font-style:normal;}
.sbnr-ss-sub{font-size:10px;color:var(--text-muted,#6b7280);margin-bottom:10px;line-height:1.5;}
.sbnr-ss-btns{display:flex;gap:8px;flex-wrap:wrap;}
.sbnr-ss-btn{color:#fff;border:none;padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-ss-btn:hover{transform:translateY(-2px);filter:brightness(1.1);}
.sbnr-ss-ghost{background:transparent;border:1.5px solid;padding:9px 20px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-ss-ghost:hover{opacity:.6;}

/* ── DUO TONE ───────────────────────────────────────────────────────────────── */
/* Fondo dividido diagonal: mitad acento arriba, mitad oscuro abajo. Texto centrado. */
.sbnr-duo{overflow:hidden;height:196px;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;}
@media(min-width:600px){.sbnr-duo{height:240px;}}
@media(min-width:768px){.sbnr-duo{height:295px;}}
.sbnr-duo-bg{position:absolute;inset:0;}
.sbnr-duo-line{position:absolute;top:0;left:0;right:0;height:3px;pointer-events:none;}
.sbnr-duo-content{position:relative;z-index:1;text-align:center;max-width:520px;}
.sbnr-duo-label{display:inline-block;font-family:var(--font-head);font-size:9px;font-weight:800;letter-spacing:4px;text-transform:uppercase;margin-bottom:7px;padding:3px 12px;border-radius:var(--radius-full);}
.sbnr-duo-title{font-family:var(--font-head);font-size:clamp(19px,4.2vw,38px);font-weight:900;color:#fff;line-height:0.95;margin-bottom:4px;letter-spacing:-1.5px;}
.sbnr-duo-title em{font-style:normal;}
.sbnr-duo-sub{font-size:11px;color:rgba(255,255,255,.5);margin-bottom:12px;}
.sbnr-duo-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.sbnr-duo-btn{color:#fff;border:none;padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-duo-btn:hover{transform:translateY(-2px);filter:brightness(1.12);}
.sbnr-duo-ghost{background:rgba(255,255,255,.07);color:rgba(255,255,255,.65);border:1.5px solid rgba(255,255,255,.2);padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-duo-ghost:hover{background:rgba(255,255,255,.13);color:#fff;}

/* ── INK ────────────────────────────────────────────────────────────────────── */
/* Fondo oscuro. Título gigante que llena el espacio. CTA pequeño abajo. Extremo. */
.sbnr-ink{overflow:hidden;height:196px;display:flex;flex-direction:column;justify-content:space-between;padding:20px 28px;position:relative;}
@media(min-width:600px){.sbnr-ink{height:240px;padding:24px 36px;}}
@media(min-width:768px){.sbnr-ink{height:295px;padding:28px 44px;}}
.sbnr-ink-bg{position:absolute;inset:0;}
.sbnr-ink-top{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;}
.sbnr-ink-label{font-family:var(--font-head);font-size:9px;font-weight:800;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.35);}
.sbnr-ink-num{font-family:var(--font-head);font-size:10px;font-weight:700;letter-spacing:2px;color:rgba(255,255,255,.2);}
.sbnr-ink-mid{position:relative;z-index:1;flex:1;display:flex;align-items:center;}
.sbnr-ink-title{font-family:var(--font-head);font-size:clamp(22px,5vw,54px);font-weight:900;color:#fff;line-height:0.92;letter-spacing:-2px;}
.sbnr-ink-title em{font-style:normal;}
.sbnr-ink-bottom{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px;}
.sbnr-ink-sub{font-size:11px;color:rgba(255,255,255,.35);max-width:260px;}
.sbnr-ink-btns{display:flex;gap:8px;flex-shrink:0;}
.sbnr-ink-btn{color:#fff;border:none;padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:11px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-ink-btn:hover{transform:translateY(-2px);filter:brightness(1.1);}
.sbnr-ink-ghost{background:transparent;color:rgba(255,255,255,.5);border:1px solid rgba(255,255,255,.18);padding:8px 18px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:11px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-ink-ghost:hover{border-color:rgba(255,255,255,.45);color:#fff;}
.sbnr-ink-accent-bar{position:absolute;top:0;left:0;bottom:0;width:4px;}

/* ── BORDER FRAME ───────────────────────────────────────────────────────────── */
/* Fondo neutro con marco interior de acento y contenido centrado. Elegante. */
.sbnr-frame{overflow:hidden;height:196px;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;}
@media(min-width:600px){.sbnr-frame{height:240px;}}
@media(min-width:768px){.sbnr-frame{height:295px;}}
.sbnr-frame-bg{position:absolute;inset:0;}
.sbnr-frame-border{position:absolute;inset:10px;border:1.5px solid;border-radius:calc(var(--radius-xl) - 4px);pointer-events:none;}
.sbnr-frame-corner{position:absolute;width:14px;height:14px;pointer-events:none;}
.sbnr-frame-corner-tl{top:9px;left:9px;border-top:3px solid;border-left:3px solid;border-radius:3px 0 0 0;}
.sbnr-frame-corner-tr{top:9px;right:9px;border-top:3px solid;border-right:3px solid;border-radius:0 3px 0 0;}
.sbnr-frame-corner-bl{bottom:9px;left:9px;border-bottom:3px solid;border-left:3px solid;border-radius:0 0 0 3px;}
.sbnr-frame-corner-br{bottom:9px;right:9px;border-bottom:3px solid;border-right:3px solid;border-radius:0 0 3px 0;}
.sbnr-frame-content{position:relative;z-index:1;text-align:center;max-width:480px;}
.sbnr-frame-label{font-family:var(--font-head);font-size:9px;font-weight:800;letter-spacing:5px;text-transform:uppercase;margin-bottom:7px;}
.sbnr-frame-title{font-family:var(--font-head);font-size:clamp(16px,3.5vw,32px);font-weight:900;line-height:1.0;margin-bottom:4px;letter-spacing:-.5px;}
.sbnr-frame-title em{font-style:normal;}
.sbnr-frame-sub{font-size:11px;margin-bottom:12px;line-height:1.5;max-width:340px;margin-left:auto;margin-right:auto;}
.sbnr-frame-btns{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;}
.sbnr-frame-btn{color:#fff;border:none;padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:700;cursor:pointer;transition:var(--transition);}
.sbnr-frame-btn:hover{transform:translateY(-2px);filter:brightness(1.1);}
.sbnr-frame-ghost{background:transparent;border:1.5px solid;padding:10px 24px;border-radius:var(--radius-full);font-family:var(--font-head);font-size:12px;font-weight:600;cursor:pointer;transition:var(--transition);}
.sbnr-frame-ghost:hover{opacity:.65;}

/* ── MOBILE COMPACT OVERRIDES (≤479px) ─────────────────────────────────────── */
@media(max-width:479px){
  /* altura un poco mayor para que quepa el contenido */
  .sbnr-glow,.sbnr-o4,.sbnr-o5,.sbnr-o6,.sbnr-mk,.sbnr-br,.sbnr-au,
  .sbnr-spot,.sbnr-rw,.sbnr-pill,.sbnr-ss,.sbnr-duo,.sbnr-ink,.sbnr-frame{height:210px;}
  .sbnr-mag{height:210px;}
  /* reducir padding contenedores */
  .sbnr-glow{padding:16px 14px;}
  .sbnr-o4{padding:14px 16px;}
  .sbnr-o5{padding:14px 16px;}
  .sbnr-o6-left{padding:14px 16px;}
  .sbnr-mk-body{padding:8px 14px;gap:8px;}
  .sbnr-br{padding:14px 14px 14px 28px;}
  .sbnr-au{padding:14px 16px;gap:8px;}
  .sbnr-mag-right{padding:12px 14px;}
  .sbnr-spot{padding:14px 12px;}
  .sbnr-rw{padding:14px 16px;}
  .sbnr-pill{padding:14px 12px;}
  .sbnr-ss-right{padding:12px 14px;}
  .sbnr-duo{padding:14px 12px;}
  .sbnr-ink{padding:12px 16px;}
  .sbnr-frame{padding:12px;}
  /* reducir margin-bottom en tags/labels/eyebrows */
  .sbnr-glow-tag,.sbnr-o4-tag,.sbnr-o5-tag,.sbnr-o6-tag,
  .sbnr-br-tag,.sbnr-au-eyebrow,.sbnr-spot-badge,
  .sbnr-rw-tag,.sbnr-pill-badge,.sbnr-ss-tag,.sbnr-duo-label,
  .sbnr-mag-issue,.sbnr-mag-rule,.sbnr-frame-label{margin-bottom:5px!important;}
  /* reducir margin-bottom en títulos */
  .sbnr-glow-title,.sbnr-o4-title,.sbnr-o5-title,.sbnr-o6-title,
  .sbnr-mk-title,.sbnr-br-title,.sbnr-au-title,.sbnr-mag-title,
  .sbnr-spot-title,.sbnr-rw-title,.sbnr-pill-title,.sbnr-ss-title,
  .sbnr-duo-title,.sbnr-ink-title,.sbnr-frame-title{margin-bottom:4px!important;}
  /* reducir margin-bottom en subtítulos */
  .sbnr-glow-sub,.sbnr-o4-sub,.sbnr-o5-sub,.sbnr-o6-sub,
  .sbnr-mk-sub,.sbnr-br-sub,.sbnr-au-sub,.sbnr-mag-sub,
  .sbnr-spot-sub,.sbnr-rw-sub,.sbnr-pill-sub,.sbnr-ss-sub,
  .sbnr-duo-sub,.sbnr-ink-sub,.sbnr-frame-sub{margin-bottom:8px!important;font-size:11px;}
  /* botones más compactos */
  .sbnr-glow-btn,.sbnr-ghost,.sbnr-o4-btn,.sbnr-o4-ghost,
  .sbnr-o5-btn,.sbnr-o5-ghost,.sbnr-o6-btn,.sbnr-o6-ghost,
  .sbnr-mk-btn,.sbnr-mk-ghost,.sbnr-br-btn,.sbnr-br-ghost,
  .sbnr-au-btn,.sbnr-au-ghost,.sbnr-mag-btn,.sbnr-mag-ghost,
  .sbnr-spot-btn,.sbnr-spot-ghost,.sbnr-rw-btn,.sbnr-rw-ghost,
  .sbnr-pill-btn,.sbnr-pill-ghost,.sbnr-ss-btn,.sbnr-ss-ghost,
  .sbnr-duo-btn,.sbnr-duo-ghost,.sbnr-ink-btn,.sbnr-ink-ghost,
  .sbnr-frame-btn,.sbnr-frame-ghost{padding:7px 14px!important;font-size:11px!important;}
  /* columna izquierda side-stat más estrecha */
  .sbnr-ss{grid-template-columns:100px 1fr;}
  .sbnr-ss-num{font-size:clamp(36px,8vw,56px);}
}
/* ocultar subtítulo en pantallas muy pequeñas */
@media(max-width:370px){
  .sbnr-glow-sub,.sbnr-o4-sub,.sbnr-o5-sub,.sbnr-o6-sub,
  .sbnr-mk-sub,.sbnr-br-sub,.sbnr-au-sub,.sbnr-mag-sub,
  .sbnr-spot-sub,.sbnr-rw-sub,.sbnr-pill-sub,.sbnr-ss-sub,
  .sbnr-duo-sub,.sbnr-ink-sub,.sbnr-frame-sub{display:none;}
}
