    *,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
    :root{
      --navy:     #00092b;
      --navy2:    #06104a;
      --orange:   #ff450a;
      --orange-dk:#d93800;
      --orange-lt:#fff4f0;
      --orange-md:#ffe4d9;
      --white:    #ffffff;
      --bg:       #f2f5f9;
      --border:   #dde2ed;
      --text:     #0d1438;
      --text2:    #3d4566;
      --muted:    #7b84a8;
      --success:  #15803d;
      --danger:   #dc2626;
      --card-shadow: 0 1px 3px rgba(13,20,56,.07), 0 4px 16px rgba(13,20,56,.05);
      --card-shadow-hover: 0 4px 12px rgba(13,20,56,.1), 0 8px 24px rgba(13,20,56,.07);
      --nav-h:    62px;
      --top-h:    60px;
      --safe-top: env(safe-area-inset-top,0px);
    }
    html,body{height:100%;background:#ffffff;color:var(--text);font-family:'Inter',sans-serif;overflow:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
    #root{height:100%;display:flex;flex-direction:column;background:var(--bg)}
    ::-webkit-scrollbar{display:none}
    button{font-family:inherit;cursor:pointer}

    @keyframes fadeIn  {from{opacity:0}to{opacity:1}}
    @keyframes fadeUp  {from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
    @keyframes slideUp {from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
    @keyframes slideIn {from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:none}}
    @keyframes shimmer {from{background-position:-200% 0}to{background-position:200% 0}}
    @keyframes spin    {from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
    @keyframes expand  {from{opacity:0;max-height:0}to{opacity:1;max-height:600px}}


    /* ── TOPBAR ─────────────────────────────────────── */
    .topbar{
      position:fixed;top:0;left:0;right:0;z-index:200;
      height:calc(var(--top-h) + var(--safe-top));
      padding-top:var(--safe-top);
      background:var(--navy);
      display:flex;align-items:center;gap:10px;
      padding-left:16px;padding-right:16px;
      box-shadow:0 2px 20px rgba(0,9,43,.4);
    }
    .topbar-search{
      flex:1;min-width:0;
      display:flex;align-items:center;
      background:rgba(255,255,255,.12);
      border:1.5px solid rgba(255,255,255,.22);
      border-radius:22px;
      padding:0 12px 0 10px;
      height:38px;
      transition:background .15s,border-color .15s;
    }
    .topbar-search:focus-within{
      background:rgba(255,255,255,.18);
      border-color:rgba(255,255,255,.45);
    }
    .topbar-search-icon{display:flex;align-items:center;color:rgba(255,255,255,.6);flex-shrink:0;margin-right:7px}
    .topbar-search input{
      flex:1;min-width:0;background:none;border:none;outline:none;
      color:#fff;font-size:.83rem;font-family:'Inter',sans-serif;font-weight:500;
    }
    .topbar-search input::placeholder{color:rgba(255,255,255,.5)}
    .topbar-search-clear{
      background:none;border:none;color:rgba(255,255,255,.55);
      cursor:pointer;padding:0;display:flex;align-items:center;flex-shrink:0;font-size:1rem;line-height:1;
    }
    .topbar-logo{height:36px;display:flex;align-items:center}
    .topbar-logo img{height:36px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}
    .topbar-logo-fb{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.05rem;color:#fff;letter-spacing:-.01em}
    .topbar-logo-fb span{color:var(--orange)}

    /* Welcome pill — full-width clickable area, profile left / reorder right */
    .topbar-welcome{
      display:flex;align-items:center;gap:8px;
      background:rgba(255,255,255,.10);
      border:1.5px solid rgba(255,255,255,.25);
      border-radius:22px;padding:5px 5px 5px 8px;
      cursor:default;
      flex:1;min-width:0;max-width:260px;
      margin:0 10px;
    }
    .topbar-welcome-avatar{
      width:26px;height:26px;border-radius:50%;
      background:var(--orange);
      display:flex;align-items:center;justify-content:center;
      font-size:.6rem;font-weight:900;color:#fff;
      font-family:'Montserrat',sans-serif;flex-shrink:0;line-height:1;
    }
    .topbar-welcome-name{
      font-size:.72rem;font-weight:700;
      color:rgba(255,255,255,.9);
      font-family:'Montserrat',sans-serif;
      white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
      flex:1;min-width:0;
    }
    /* Orange reorder pill — sits on the right inside the blue pill */
    .topbar-reorder-pill{
      display:flex;align-items:center;gap:4px;
      background:var(--orange);
      border-radius:16px;padding:5px 10px;
      font-family:'Montserrat',sans-serif;font-weight:800;
      font-size:.65rem;color:#fff;letter-spacing:.01em;
      white-space:nowrap;flex-shrink:0;cursor:pointer;
      transition:background .15s;
      box-shadow:0 2px 8px rgba(255,69,10,.4);
    }
    .topbar-reorder-pill:active{background:var(--orange-dk);transform:scale(.96)}

    /* Cart button - white outline, transparent, white SVG icon */
    .cart-btn{
      position:relative;
      width:42px;height:42px;
      background:rgba(255,255,255,.06);
      border:2px solid rgba(255,255,255,.9);
      border-radius:10px;
      display:flex;align-items:center;justify-content:center;
      cursor:pointer;
      transition:all .18s;
      flex-shrink:0;
      box-shadow:0 0 0 1px rgba(255,255,255,.15);
    }
    .cart-btn:active{background:rgba(255,255,255,.18);transform:scale(.95)}
    .cart-badge{
      position:absolute;top:-7px;right:-7px;
      background:var(--orange);color:#fff;
      font-size:.6rem;font-weight:800;min-width:19px;height:19px;padding:0 4px;
      border-radius:10px;display:flex;align-items:center;justify-content:center;
      font-family:'Montserrat',sans-serif;letter-spacing:0;
      border:2.5px solid var(--navy);
      line-height:1;
    }

    /* ── BOTTOM NAV ─────────────────────────────────── */
    .bottomnav{
      position:fixed;bottom:0;left:0;right:0;z-index:200;
      height:var(--nav-h);
      background:#fff;
      border-top:1px solid var(--border);
      box-shadow:0 -2px 16px rgba(13,20,56,.06);
      display:flex;align-items:stretch;
      padding-bottom:env(safe-area-inset-bottom,0);
    }
    .nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;position:relative;transition:all .18s;border:none;background:none}
    .nav-item::before{content:'';position:absolute;top:0;left:30%;right:30%;height:2.5px;background:var(--orange);border-radius:0 0 4px 4px;opacity:0;transition:opacity .18s}
    .nav-item.active::before{opacity:1}
    .nav-icon-wrap{display:flex;align-items:center;justify-content:center;width:26px;height:26px}
    .nav-label{font-size:.58rem;letter-spacing:.04em;text-transform:uppercase;font-weight:700;color:var(--muted);font-family:'Montserrat',sans-serif;transition:color .18s}
    .nav-item.active .nav-label{color:var(--orange)}

    /* ── SCREEN ─────────────────────────────────────── */
    .screen{flex:1;overflow-y:auto;padding-top:calc(var(--top-h) + var(--safe-top));padding-bottom:calc(var(--nav-h) + 8px);background:var(--bg);animation:fadeIn .22s ease}
    .screen-head{padding:18px 16px 12px;background:#fff;border-bottom:1px solid var(--border)}
    .screen-title{font-family:'Montserrat',sans-serif;font-size:1.45rem;font-weight:900;color:var(--navy);letter-spacing:-.02em}
    .screen-sub{color:var(--muted);font-size:.8rem;margin-top:3px;font-weight:500}

    
/* ── NOTIFICATION PROMPT MODAL ──────────────────────────── */
function NotifPromptModal({onEnable,onDismiss}){
  const [loading,setLoading] = React.useState(false);
  async function handleEnable(){
    setLoading(true);
    await onEnable();
    setLoading(false);
  }
  return(
    <div style={{position:'fixed',inset:0,zIndex:9999,display:'flex',flexDirection:'column',justifyContent:'flex-end'}}>
      <div style={{position:'absolute',inset:0,background:'rgba(0,9,43,0.65)'}} onClick={onDismiss}/>
      <div style={{position:'relative',background:'#fff',borderRadius:'22px 22px 0 0',padding:'24px 24px 40px',boxShadow:'0 -4px 32px rgba(0,0,0,0.18)'}}>
        <div style={{width:36,height:4,borderRadius:2,background:'#dde2ed',margin:'0 auto 20px'}}/>
        <div style={{textAlign:'center',marginBottom:20}}>
          <div style={{width:64,height:64,borderRadius:18,background:'#00092b',display:'flex',alignItems:'center',justifyContent:'center',fontSize:'2rem',margin:'0 auto 14px',boxShadow:'0 4px 16px rgba(0,9,43,0.3)'}}>🔔</div>
          <div style={{fontFamily:"'Montserrat',sans-serif",fontWeight:900,fontSize:'1.15rem',color:'#00092b',marginBottom:8,letterSpacing:'-.02em'}}>Don't miss a thing</div>
          <div style={{fontSize:'.82rem',color:'#7b84a8',lineHeight:1.6,maxWidth:280,margin:'0 auto',fontWeight:500}}>
            Enable notifications for order updates, exclusive app-only deals &amp; reminders when you have points to redeem.
          </div>
        </div>
        <div style={{background:'#f2f5f9',border:'1.5px solid #dde2ed',borderRadius:12,padding:'12px 14px',marginBottom:16}}>
          {[['📦','Order updates','Confirmed, packed, dispatched &amp; delivered'],['🏷️','Exclusive deals','App-only offers sent straight to you'],['⭐','Points reminders','Know when you\'ve got rewards to spend']].map(([icon,title,desc])=>(
            <div key={title} style={{display:'flex',alignItems:'center',gap:12,padding:'6px 0',borderTop:title!=='Order updates'?'1px solid #dde2ed':'none',marginTop:title!=='Order updates'?6:0,paddingTop:title!=='Order updates'?12:6}}>
              <div style={{width:34,height:34,borderRadius:9,background:'#fff0ec',display:'flex',alignItems:'center',justifyContent:'center',fontSize:'1rem',flexShrink:0}}>{icon}</div>
              <div>
                <div style={{fontFamily:"'Montserrat',sans-serif",fontWeight:800,fontSize:'.8rem',color:'#00092b'}}>{title}</div>
                <div style={{fontSize:'.72rem',color:'#7b84a8',fontWeight:500}} dangerouslySetInnerHTML={{__html:desc}}/>
              </div>
            </div>
          ))}
        </div>
        <button onClick={handleEnable} disabled={loading}
          style={{width:'100%',padding:'14px',borderRadius:12,background:'linear-gradient(135deg,#ff450a,#d93800)',color:'#fff',fontFamily:"'Montserrat',sans-serif",fontWeight:800,fontSize:'.95rem',border:'none',cursor:'pointer',marginBottom:10,boxShadow:'0 4px 16px rgba(255,69,10,0.35)',opacity:loading?0.7:1}}>
          {loading?'Enabling…':'Enable Notifications'}
        </button>
        <button onClick={onDismiss}
          style={{width:'100%',padding:'11px',borderRadius:12,background:'transparent',color:'#7b84a8',fontFamily:"'Montserrat',sans-serif",fontWeight:600,fontSize:'.85rem',border:'none',cursor:'pointer'}}>
          Not now
        </button>
      </div>
    </div>
  );
}


/* ── INSTALL BANNER ─────────────────────────────────────── */
function InstallBanner({onDismiss}){
  const isIOS = /iphone|ipad|ipod/i.test(navigator.userAgent);
  const isStandalone = window.matchMedia('(display-mode: standalone)').matches || window.navigator.standalone;

  function handleInstall(){
    if(window._wvcInstallPrompt){
      window._wvcInstallPrompt.prompt();
      window._wvcInstallPrompt.userChoice.then(()=>{
        window._wvcInstallPrompt=null;
        onDismiss();
      });
    }
  }

  if(isStandalone) return null;

  return(
    <>
      <div className="install-overlay" onClick={onDismiss}/>
      <div className="install-banner">
        <div className="install-handle"/>
        <div className="install-icon">
          <img src="https://app.whitevapeco.uk/icon-192.png" alt="WhiteVape Co"/>
        </div>
        <div className="install-title">Get the White Vape App</div>
        <div className="install-sub">Order notifications, exclusive deals &amp; easy points redemption — all in one place.</div>
        {isIOS?(
          <div className="install-steps">
            <div className="install-step"><div className="install-step-num">1</div><span>Tap the <strong>Share</strong> button at the bottom of your browser</span></div>
            <div className="install-step"><div className="install-step-num">2</div><span>Scroll down and tap <strong>"Add to Home Screen"</strong></span></div>
            <div className="install-step"><div className="install-step-num">3</div><span>Tap <strong>"Add"</strong> in the top right corner</span></div>
          </div>
        ):(
          <button className="install-btn" onClick={handleInstall}>📲 Install App</button>
        )}
        <button className="install-dismiss" onClick={onDismiss}>Maybe later</button>
      </div>
    </>
  );
}

/* ── AGE GATE ───────────────────────────────────── */
    .agegate{position:fixed;inset:0;z-index:999;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 28px;text-align:center;animation:fadeIn .3s ease}
    .agegate-logo{margin-bottom:8px}
    .agegate-logo img{height:64px;width:auto}
    .agegate-logo-fb{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.9rem;color:var(--navy);letter-spacing:-.02em}
    .agegate-logo-fb span{color:var(--orange)}
    .agegate-tagline{color:var(--muted);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:32px;font-weight:600}
    .agegate-box{background:var(--bg);border:1.5px solid var(--border);border-radius:16px;padding:22px;margin-bottom:22px;max-width:320px;width:100%}
    .agegate-box h2{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.1rem;color:var(--navy);margin-bottom:8px}
    .agegate-box p{color:var(--muted);font-size:.82rem;line-height:1.65;font-weight:500}
    .agegate-btns{display:flex;gap:10px;width:100%;max-width:300px}
    .agegate-yes{flex:1;padding:15px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.9rem;border:none;border-radius:10px;transition:all .15s;box-shadow:0 4px 14px rgba(255,69,10,.35)}
    .agegate-yes:active{background:var(--orange-dk);transform:scale(.98)}
    .agegate-no{flex:1;padding:15px;background:var(--bg);color:var(--muted);border:1.5px solid var(--border);border-radius:10px;font-weight:600;font-size:.88rem}
    .agegate-verify{display:inline-flex;align-items:center;gap:6px;background:#f0fdf4;border:1px solid #bbf7d0;color:var(--success);font-size:.72rem;font-weight:700;padding:6px 14px;border-radius:20px;margin-top:18px;font-family:'Montserrat',sans-serif}
    .agegate-notice{margin-top:12px;font-size:.7rem;color:var(--muted);max-width:270px;line-height:1.65;font-weight:500}

    /* ── LOGIN ──────────────────────────────────────── */
    .login-wrap{min-height:100%;display:flex;flex-direction:column;justify-content:center;padding:32px 20px;background:#fff}
    .login-logo-wrap{display:flex;justify-content:center;margin-bottom:6px}
    .login-logo-wrap img{height:52px;width:auto}
    .login-logo-fb{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.9rem;color:var(--navy);text-align:center;letter-spacing:-.02em}
    .login-logo-fb span{color:var(--orange)}
    .login-tagline{text-align:center;color:var(--muted);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;margin-bottom:32px;font-weight:600}
    .login-tabs{display:flex;background:var(--bg);border-radius:10px;padding:4px;margin-bottom:24px;border:1px solid var(--border)}
    .login-tab{flex:1;padding:11px;text-align:center;font-size:.85rem;font-weight:700;font-family:'Montserrat',sans-serif;border-radius:8px;cursor:pointer;transition:all .18s;color:var(--muted);border:none;background:none}
    .login-tab.active{background:var(--orange);color:#fff;box-shadow:0 3px 10px rgba(255,69,10,.3)}
    .login-form{display:flex;flex-direction:column;gap:14px}

    /* ── INPUTS ─────────────────────────────────────── */
    .input-wrap{display:flex;flex-direction:column;gap:6px}
    .input-label{font-size:.71rem;color:var(--muted);font-weight:700;letter-spacing:.07em;text-transform:uppercase;font-family:'Montserrat',sans-serif}
    .input{width:100%;padding:13px 15px;background:#fff;border:1.5px solid var(--border);border-radius:10px;color:var(--text);font-size:.93rem;font-family:'Inter',sans-serif;outline:none;transition:border-color .2s;font-weight:500}
    .input:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,10,.08)}
    .input::placeholder{color:#b5bcd4;font-weight:400}

    /* ── BUTTONS ────────────────────────────────────── */
    .btn-primary{width:100%;padding:15px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.92rem;border:none;border-radius:10px;letter-spacing:.02em;transition:all .15s;box-shadow:0 4px 14px rgba(255,69,10,.3)}
    .btn-primary:active{background:var(--orange-dk);transform:scale(.98)}
    .btn-primary:disabled{opacity:.6}
    .btn-sm{padding:9px 18px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.75rem;border:none;border-radius:8px;white-space:nowrap;transition:all .15s;box-shadow:0 2px 8px rgba(255,69,10,.25);letter-spacing:.02em}
    .btn-sm:active{background:var(--orange-dk)}
    .btn-sm-outline{padding:9px 18px;background:transparent;color:var(--navy);font-family:'Montserrat',sans-serif;font-weight:700;font-size:.75rem;border:1.5px solid var(--border);border-radius:8px}

    /* ── SECTION HEADER ─────────────────────────────── */
    .sec-head{display:flex;justify-content:space-between;align-items:center;padding:18px 16px 10px}
    .sec-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.88rem;color:var(--navy);text-transform:uppercase;letter-spacing:.07em;display:flex;align-items:center;gap:9px}
    .sec-title::before{content:'';display:inline-block;width:4px;height:15px;background:var(--orange);border-radius:2px;flex-shrink:0}
    .sec-link{font-size:.8rem;color:var(--orange);font-weight:700;font-family:'Montserrat',sans-serif}

    /* ── HERO ───────────────────────────────────────── */
    .hero{
      margin:12px 14px 0;border-radius:16px;padding:22px 20px;
      background:linear-gradient(135deg, var(--navy) 0%, var(--navy2) 100%);
      position:relative;overflow:hidden;
      box-shadow:0 4px 20px rgba(0,9,43,.25);
    }
    .hero::after{
      content:'';position:absolute;right:-30px;top:-30px;
      width:160px;height:160px;
      background:radial-gradient(circle, rgba(255,69,10,.3) 0%, transparent 65%);
      border-radius:50%;pointer-events:none;
    }
    .hero-eyebrow{font-size:.7rem;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:.14em;font-weight:700;font-family:'Montserrat',sans-serif;margin-bottom:5px}
    .hero-name{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.7rem;color:#fff;letter-spacing:-.02em;line-height:1.1;margin-bottom:6px}
    .hero-sub{font-size:.78rem;color:rgba(255,255,255,.6);font-weight:600;font-family:'Montserrat',sans-serif;letter-spacing:.04em}
    .hero-pill{
      display:inline-flex;align-items:center;gap:5px;margin-top:12px;
      background:var(--orange);color:#fff;
      font-size:.72rem;font-weight:800;font-family:'Montserrat',sans-serif;
      padding:5px 12px;border-radius:20px;letter-spacing:.02em;
    }

    /* ── PROMO STRIP ────────────────────────────────── */
    .promo{
      margin:10px 14px 0;border-radius:12px;padding:14px 16px;
      background:#fff;border:1.5px solid var(--border);
      display:flex;align-items:center;gap:12px;cursor:pointer;
      box-shadow:var(--card-shadow);
      transition:box-shadow .18s;
    }
    .promo:active{box-shadow:var(--card-shadow-hover)}
    .promo-left{width:40px;height:40px;border-radius:10px;background:var(--orange-lt);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}
    .promo-text strong{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.85rem;color:var(--text);display:block;margin-bottom:2px}
    .promo-text span{font-size:.76rem;color:var(--muted);font-weight:500}
    .promo-right{color:var(--orange);margin-left:auto;flex-shrink:0}

    /* ── CATEGORY GRID ──────────────────────────────── */
    .cat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:9px;padding:0 14px}
    .cat-row+.cat-row{margin-top:9px}
    .cat-block{
      background:#fff;
      border:1.5px solid var(--border);
      border-radius:14px;padding:14px 8px 12px;
      display:flex;flex-direction:column;align-items:center;gap:7px;
      cursor:pointer;transition:all .18s;position:relative;overflow:hidden;
      text-align:center;
      box-shadow:var(--card-shadow);
    }
    .cat-block:active{transform:scale(.96)}
    .cat-block.active-cat{border-color:var(--orange);background:var(--orange-lt);box-shadow:0 4px 16px rgba(255,69,10,.15)}
    .cat-block-icon{
      display:flex;align-items:center;justify-content:center;
      width:44px;height:44px;border-radius:12px;
      background:var(--bg);transition:background .18s;flex-shrink:0;
    }
    .cat-block.active-cat .cat-block-icon{background:var(--orange-md)}
    .cat-block-name{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.68rem;color:var(--navy);line-height:1.25;letter-spacing:.01em;white-space:pre-line}
    .cat-block.active-cat .cat-block-name{color:var(--orange)}
    .cat-block-arrow{display:flex;align-items:center;justify-content:center;color:var(--muted);transition:transform .2s}
    .cat-block.active-cat .cat-block-arrow{transform:rotate(180deg);color:var(--orange)}
    .cat-badge{position:absolute;top:7px;right:7px;background:var(--orange);color:#fff;font-size:.54rem;font-weight:800;font-family:'Montserrat',sans-serif;padding:2px 5px;border-radius:4px;line-height:1.3}

    /* ── SUBCATEGORY TRAY (inline, attached to row) ── */
    .subcat-tray{
      margin:9px 14px 0;
      border-radius:12px;
      background:#fff;
      border:1.5px solid var(--orange);
      overflow:hidden;
      box-shadow:0 6px 24px rgba(255,69,10,.14);
      animation:subtrayIn .22s ease;
    }
    @keyframes subtrayIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:none}}
    .subcat-head{padding:11px 14px;background:var(--orange);display:flex;align-items:center;justify-content:space-between}
    .subcat-head-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.82rem;color:#fff;display:flex;align-items:center;gap:9px}
    .subcat-head-title svg{flex-shrink:0;opacity:.9}
    .subcat-close{background:rgba(255,255,255,.25);border:none;color:#fff;width:24px;height:24px;border-radius:6px;font-size:.8rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s}
    .subcat-close:active{background:rgba(255,255,255,.4)}
    .subcat-list{display:flex;flex-wrap:wrap;gap:7px;padding:12px 13px 13px}
    .subcat-chip{padding:7px 13px;background:var(--bg);border:1.5px solid var(--border);border-radius:20px;font-size:.76rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--navy);cursor:pointer;transition:all .15s;white-space:nowrap}
    .subcat-chip:active,.subcat-chip:hover{background:var(--orange);border-color:var(--orange);color:#fff}

    /* ── FEATURED SCROLL ─────────────────────────────── */
    .feat-scroll{display:flex;gap:10px;overflow-x:auto;padding:0 14px 4px}
    .feat-card{width:148px;min-width:148px;max-width:148px;border-radius:14px;background:#fff;border:1.5px solid var(--border);overflow:hidden;flex-shrink:0;flex-grow:0;cursor:pointer;transition:all .18s;box-shadow:var(--card-shadow)}
    .feat-card:active{transform:scale(.97)}
    .feat-img{width:100%;height:118px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:2.4rem;overflow:hidden;position:relative}
    .feat-img img{width:100%;height:100%;object-fit:cover}
    .feat-body{padding:10px 12px 12px}
    .feat-cat{font-size:.63rem;color:var(--orange);font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:3px;font-family:'Montserrat',sans-serif}
    .feat-name{font-size:.8rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--text);line-height:1.3;margin-bottom:4px}
    .feat-price{font-size:.92rem;font-weight:800;color:var(--navy);font-family:'Montserrat',sans-serif}

    /* ── PRODUCT GRID ───────────────────────────────── */
    .prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0 14px 14px}
    .prod-card{border-radius:14px;overflow:hidden;background:#fff;border:1.5px solid var(--border);cursor:pointer;transition:all .18s;box-shadow:var(--card-shadow);display:flex;flex-direction:column}
    .prod-card:active{transform:scale(.97);box-shadow:var(--card-shadow-hover)}
    .prod-img{width:100%;aspect-ratio:1;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:2.6rem;position:relative;overflow:hidden}
    .prod-img img{width:100%;height:100%;object-fit:cover}
    .prod-body{padding:10px 12px 12px;display:flex;flex-direction:column;flex:1}
    .prod-cat{font-size:.63rem;color:var(--orange);font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:3px;font-family:'Montserrat',sans-serif}
    .prod-name{font-size:.83rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--text);line-height:1.3;margin-bottom:4px}
    .prod-price{font-size:.92rem;font-weight:800;color:var(--navy);font-family:'Montserrat',sans-serif}
    .prod-add{margin-top:auto;width:100%;padding:9px;background:var(--orange);color:#fff;font-size:.74rem;font-weight:800;font-family:'Montserrat',sans-serif;border:none;border-radius:8px;transition:all .15s;letter-spacing:.02em;box-shadow:0 2px 6px rgba(255,69,10,.2)}
    .prod-qty-ctrl{margin-top:auto;display:flex;align-items:center;background:var(--orange-lt);border:1.5px solid var(--orange);border-radius:8px;overflow:hidden;width:100%}
    .prod-qty-ctrl button{flex:0 0 34px;height:34px;background:none;border:none;color:var(--orange);font-size:1.2rem;font-weight:700;cursor:pointer;}
    .prod-qty-ctrl span{flex:1;text-align:center;font-weight:800;font-size:.85rem;color:var(--navy);font-family:'Montserrat',sans-serif}
    .prod-add:active{background:var(--orange-dk)}

    /* ── DEALS STRIP ───────────────────────────────── */
    .deals-strip{display:flex;gap:8px;overflow-x:auto;padding:0 14px 4px;margin-top:10px}
    .deal-chip{
      display:inline-flex;align-items:center;gap:8px;
      background:#fff;border:1.5px solid var(--orange);
      border-radius:22px;padding:7px 14px 7px 7px;
      white-space:nowrap;flex-shrink:0;cursor:pointer;
      transition:all .15s;box-shadow:0 2px 10px rgba(255,69,10,.12);
    }
    .deal-chip:active{background:var(--orange-lt);transform:scale(.96)}
    .deal-chip-icon{
      width:26px;height:26px;border-radius:50%;
      background:var(--orange);color:#fff;
      display:flex;align-items:center;justify-content:center;
      font-size:.78rem;flex-shrink:0;
    }
    .deal-chip-text{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.72rem;color:var(--navy)}

    /* ── CART DISCOUNT BANNER ───────────────────────── */
    .cart-discount{background:#f0fdf4;border:1.5px solid #bbf7d0;border-radius:10px;padding:10px 13px;margin-bottom:10px;display:flex;align-items:center;gap:9px}
    .cart-discount-icon{font-size:1.1rem;flex-shrink:0}
    .cart-discount-text{font-size:.78rem;font-weight:700;color:var(--success);font-family:'Montserrat',sans-serif;flex:1}
    .cart-discount-saving{font-size:.78rem;font-weight:800;color:var(--success);font-family:'Montserrat',sans-serif;white-space:nowrap}

    /* ── SEARCH ─────────────────────────────────────── */
    .search-wrap{position:relative;padding:12px 14px}
    .search-icon{position:absolute;left:26px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none;display:flex;align-items:center}
    .search-input{padding-left:40px}

    /* ── FILTER TAGS ────────────────────────────────── */
    .tag-row{display:flex;gap:7px;overflow-x:auto;padding:0 14px 12px}
    .tag{padding:7px 14px;border-radius:20px;font-size:.74rem;font-weight:700;white-space:nowrap;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--muted);transition:all .18s;font-family:'Montserrat',sans-serif}
    .tag.active{background:var(--orange);border-color:var(--orange);color:#fff;box-shadow:0 2px 8px rgba(255,69,10,.25)}

    /* ── BRAND FILTER ROW ───────────────────────────── */
    .brand-row-wrap{padding:0 14px 4px}
    .brand-row-label{font-size:.64rem;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-family:'Montserrat',sans-serif;margin-bottom:6px;display:flex;align-items:center;gap:6px}
    .brand-row-label span{flex:1;height:1px;background:var(--border)}
    .brand-row{display:flex;gap:6px;overflow-x:auto;padding-bottom:10px}
    .brand-row::-webkit-scrollbar{display:none}
    .brand-pill{display:flex;align-items:center;gap:5px;padding:5px 12px;border-radius:20px;font-size:.7rem;font-weight:700;white-space:nowrap;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--muted);transition:all .18s;font-family:'Montserrat',sans-serif;flex-shrink:0}
    .brand-pill.active{background:var(--navy);border-color:var(--navy);color:#fff}
    .brand-pill .bp-count{font-size:.62rem;opacity:.6;font-weight:500}
    .brand-pill.active .bp-count{opacity:.7}

    /* ── ORDER CARDS ────────────────────────────────── */
    .order-card{margin:0 14px 10px;padding:16px;border-radius:14px;background:#fff;border:1.5px solid var(--border);animation:fadeUp .3s ease both;box-shadow:var(--card-shadow)}
    .order-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}
    .order-num{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.95rem;color:var(--navy)}
    .order-date{font-size:.72rem;color:var(--muted);margin-top:2px;font-weight:500}
    .order-status{display:inline-flex;align-items:center;gap:4px;font-size:.7rem;font-weight:700;padding:4px 10px;border-radius:20px;font-family:'Montserrat',sans-serif}
    .s-completed {background:#f0fdf4;color:var(--success);border:1px solid #bbf7d0}
    .s-processing{background:#fff4f0;color:var(--orange);border:1px solid rgba(255,69,10,.2)}
    .s-pending   {background:#fefce8;color:#ca8a04;border:1px solid #fde68a}
    .order-items{font-size:.8rem;color:var(--muted);margin-bottom:12px;line-height:1.75;font-weight:500}
    .order-foot{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid var(--border)}
    .order-total{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.05rem;color:var(--navy)}

    /* ── CART DRAWER ────────────────────────────────── */
    .cart-overlay{position:fixed;inset:0;background:rgba(0,9,43,.5);z-index:450;animation:fadeIn .2s ease;backdrop-filter:blur(2px)}
    .cart-drawer{position:fixed;top:0;right:0;bottom:0;z-index:451;width:min(100vw,400px);background:#fff;display:flex;flex-direction:column;animation:slideIn .25s ease;box-shadow:-8px 0 40px rgba(0,9,43,.2)}
    .cart-head{padding:16px;background:var(--navy);display:flex;align-items:center;justify-content:space-between;padding-top:calc(16px + var(--safe-top))}
    .cart-head-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.05rem;color:#fff;display:flex;align-items:center;gap:8px}
    .cart-head-count{font-size:.78rem;color:rgba(255,255,255,.55);margin-top:2px;font-weight:500}
    .cart-close{width:36px;height:36px;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.25);border-radius:8px;color:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
    .cart-close:active{background:rgba(255,255,255,.2)}
    .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:12px;text-align:center;color:var(--muted)}
    .cart-empty-icon{width:64px;height:64px;border-radius:16px;background:var(--bg);display:flex;align-items:center;justify-content:center}
    .cart-empty-text{font-size:.9rem;line-height:1.6;font-weight:500}
    .cart-item{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--border)}
    .cart-item:last-child{border-bottom:none}
    .cart-item-img{width:58px;height:58px;border-radius:10px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0;overflow:hidden;border:1px solid var(--border)}
    .cart-item-img img{width:100%;height:100%;object-fit:cover}
    .cart-item-info{flex:1;min-width:0}
    .cart-item-name{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.84rem;color:var(--text);line-height:1.3;margin-bottom:3px}
    .cart-item-cat{font-size:.68rem;color:var(--muted);font-weight:500;margin-bottom:4px}
    .cart-item-price{font-size:.88rem;font-weight:800;color:var(--navy);font-family:'Montserrat',sans-serif}
    .cart-item-actions{display:flex;align-items:center;gap:8px;margin-top:9px}
    .qty-btn{width:28px;height:28px;border-radius:8px;border:1.5px solid var(--border);background:#fff;color:var(--navy);font-size:1rem;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s;line-height:1}
    .qty-btn:active{background:var(--bg);border-color:var(--orange)}
    .qty-num{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.88rem;color:var(--navy);min-width:22px;text-align:center}
    .remove-btn{margin-left:auto;background:none;border:none;color:var(--muted);font-size:.76rem;cursor:pointer;font-weight:700;font-family:'Montserrat',sans-serif;padding:4px;transition:color .15s}
    .remove-btn:active{color:var(--danger)}
    .cart-foot{padding:14px;border-top:1.5px solid var(--border);background:#fff}
    .cart-summary{background:var(--bg);border-radius:11px;padding:13px;margin-bottom:12px;border:1px solid var(--border)}
    .cart-row{display:flex;justify-content:space-between;align-items:center;font-size:.83rem;color:var(--muted);margin-bottom:7px;font-weight:500}
    .cart-row.cart-total{margin-bottom:0;margin-top:9px;padding-top:9px;border-top:1px solid var(--border);font-family:'Montserrat',sans-serif;font-weight:900;font-size:1rem;color:var(--navy)}
    .cart-row.cart-total span:last-child{color:var(--orange);font-size:1.05rem}
    .free-ship{font-size:.74rem;color:#fff;font-weight:700;display:flex;align-items:center;gap:6px;background:#15803d;padding:8px 14px;border-radius:20px;justify-content:center;margin:10px 0 2px}
    .cart-checkout{width:100%;padding:15px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.95rem;border:none;border-radius:11px;box-shadow:0 4px 16px rgba(255,69,10,.35);transition:all .15s;letter-spacing:.02em}
    .cart-checkout:active{background:var(--orange-dk)}

    /* ── ACCOUNT ────────────────────────────────────── */
    .acct-header{padding:20px 16px 22px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px}
    .acct-avatar{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--orange),var(--orange-dk));display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-size:1.2rem;font-weight:900;color:#fff;flex-shrink:0}
    .acct-name{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.1rem;color:var(--navy);letter-spacing:-.01em}
    .acct-email{font-size:.8rem;color:var(--muted);margin-top:2px;font-weight:500}
    .acct-verify{display:inline-flex;align-items:center;gap:5px;background:#f0fdf4;border:1px solid #bbf7d0;color:var(--success);font-size:.7rem;font-weight:700;padding:4px 11px;border-radius:20px;margin-top:8px;font-family:'Montserrat',sans-serif}
    .age-info-overlay{position:fixed;inset:0;z-index:900;background:rgba(0,0,0,.45);display:flex;align-items:flex-end;justify-content:center}
    .flavour-overlay{position:fixed;inset:0;z-index:800;background:rgba(0,0,0,.55);display:flex;align-items:flex-end;justify-content:center}
    .flavour-sheet{background:#fff;border-radius:22px 22px 0 0;width:100%;max-width:480px;box-sizing:border-box;max-height:88vh;display:flex;flex-direction:column}
    .flavour-sheet-head{padding:18px 18px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);flex-shrink:0}
    .flavour-sheet-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1rem;color:var(--navy)}
    .flavour-sheet-close{width:30px;height:30px;border-radius:50%;background:var(--bg);border:none;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--muted)}
    .flavour-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:14px;overflow-y:auto}
    .flavour-tile{display:flex;flex-direction:column;align-items:center;background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:10px 6px 8px;cursor:pointer;transition:border-color .15s,background .15s;gap:6px}
    .flavour-tile:active{background:#fff0e8;border-color:var(--orange)}
    .flavour-tile img{width:72px;height:72px;object-fit:contain}
    .flavour-tile-label{font-family:'Montserrat',sans-serif;font-weight:700;font-size:.65rem;color:var(--navy);text-align:center;line-height:1.3}
    .age-info-sheet{background:#fff;border-radius:20px 20px 0 0;padding:24px 20px 36px;width:100%;max-width:480px;box-sizing:border-box}
    .age-info-sheet h3{font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.05rem;color:var(--navy);margin-bottom:12px}
    .age-info-sheet p{font-size:.84rem;color:var(--text2);line-height:1.65;font-weight:500;margin-bottom:10px}
    .age-info-sheet p:last-of-type{margin-bottom:0}
    .age-info-close{width:100%;margin-top:20px;padding:13px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.9rem;border:none;border-radius:11px;cursor:pointer}
    .menu-section{margin:14px 14px 0}
    .menu-label{font-size:.67rem;text-transform:uppercase;letter-spacing:.14em;color:var(--muted);margin-bottom:8px;padding:0 2px;font-family:'Montserrat',sans-serif;font-weight:700}
    .menu-group{background:#fff;border:1.5px solid var(--border);border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow)}
    .menu-item{display:flex;align-items:center;gap:13px;padding:14px 15px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border)}
    .menu-item:last-child{border-bottom:none}
    .menu-item:active{background:var(--bg)}
    .menu-icon{font-size:1rem;width:22px;text-align:center}
    .menu-text{flex:1;font-size:.88rem;font-weight:600;color:var(--text)}
    .menu-arrow{color:var(--muted);font-size:.7rem}
    .menu-danger{color:var(--danger)!important}
    .points-card{margin:12px 14px 0;border-radius:14px;padding:16px 18px;background:linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);border:1.5px solid rgba(255,255,255,.08);box-shadow:0 4px 18px rgba(0,9,43,.25)}
    .back-btn{background:none;border:none;color:var(--orange);font-size:.88rem;font-weight:700;font-family:'Montserrat',sans-serif;padding:0;cursor:pointer;margin-bottom:4px}
    .acct-sub-head{padding:14px 16px 10px;background:#fff;border-bottom:1px solid var(--border)}
    .acct-sub-body{padding:14px 14px 0}
    .legal-content{font-size:.84rem;color:var(--text);line-height:1.75;font-weight:400}
    .legal-content h1,.legal-content h2{font-family:'Montserrat',sans-serif;font-weight:800;color:var(--navy);margin:18px 0 8px;font-size:1rem;letter-spacing:-.01em}
    .legal-content h3,.legal-content h4{font-family:'Montserrat',sans-serif;font-weight:700;color:var(--navy);margin:14px 0 6px;font-size:.88rem}
    .legal-content p{margin-bottom:12px}
    .legal-content ul,.legal-content ol{padding-left:20px;margin-bottom:12px}
    .legal-content li{margin-bottom:5px}
    .legal-content a{color:var(--orange);font-weight:600;text-decoration:none}
    .legal-content strong{font-weight:700;color:var(--text)}

    /* ── NOTIF BANNER ───────────────────────────────── */
    .notif-banner{margin:12px 14px 0;border-radius:12px;padding:14px;background:var(--orange-lt);border:1.5px solid var(--orange-md);display:flex;align-items:center;gap:12px;box-shadow:var(--card-shadow)}
    .notif-icon{width:38px;height:38px;border-radius:10px;background:var(--orange-md);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}
    .notif-text strong{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.84rem;color:var(--navy);display:block;margin-bottom:2px}
    .notif-text span{font-size:.76rem;color:var(--muted);font-weight:500}

    /* ── BENEFITS ───────────────────────────────────── */
    .benefits{display:grid;grid-template-columns:1fr 1fr;gap:9px;padding:0 14px}
    .benefit{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:14px 12px;box-shadow:var(--card-shadow)}
    .benefit-icon{width:36px;height:36px;border-radius:9px;background:var(--orange-lt);display:flex;align-items:center;justify-content:center;font-size:1.15rem;margin-bottom:9px}
    .benefit-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.78rem;color:var(--navy);margin-bottom:3px}
    .benefit-sub{font-size:.71rem;color:var(--muted);font-weight:500;line-height:1.4}

    /* ── CONFIG NOTICE ──────────────────────────────── */
    .config-notice{margin:12px 14px 0;padding:13px 14px;border-radius:11px;background:#fffbeb;border:1.5px solid #fde68a;font-size:.79rem;color:#92400e;line-height:1.6;font-weight:500}
    .config-notice strong{font-family:'Montserrat',sans-serif;display:block;margin-bottom:3px;font-size:.83rem}

    /* ── QUICK REORDER CARD ─────────────────────────── */
    .reorder-card{margin:0 14px;background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:14px 15px;display:flex;justify-content:space-between;align-items:center;box-shadow:var(--card-shadow)}
    .reorder-label{font-size:.68rem;color:var(--muted);margin-bottom:3px;font-family:'Montserrat',sans-serif;font-weight:700;text-transform:uppercase;letter-spacing:.07em}
    .reorder-name{font-size:.88rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--navy)}
    .reorder-price{font-size:.84rem;color:var(--orange);font-weight:800;margin-top:2px;font-family:'Montserrat',sans-serif}

    /* ── TOAST ──────────────────────────────────────── */
    .toast{position:fixed;bottom:calc(var(--nav-h) + 14px);left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;padding:11px 20px;border-radius:10px;font-size:.82rem;font-weight:700;z-index:400;white-space:nowrap;animation:slideUp .2s ease;font-family:'Montserrat',sans-serif;box-shadow:0 4px 20px rgba(0,9,43,.3);letter-spacing:.01em}

    /* ── SKELETONS ──────────────────────────────────── */
    .skel{background:linear-gradient(90deg,#edf0f5 25%,#e0e4ec 50%,#edf0f5 75%);background-size:200% 100%;border-radius:8px;animation:shimmer 1.6s infinite}
    .spinner{width:22px;height:22px;border:2.5px solid var(--border);border-top-color:var(--orange);border-radius:50%;animation:spin .7s linear infinite}
    .loading-row{display:flex;justify-content:center;padding:40px}

    /* ── BADGES ─────────────────────────────────────── */
    .badge{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.63rem;font-weight:800;font-family:'Montserrat',sans-serif}
    .badge-sale{background:#fff4f0;color:var(--orange);border:1px solid rgba(255,69,10,.2)}
    .badge-new {background:#f0fdf4;color:var(--success);border:1px solid #bbf7d0}
    .badge-deal{background:var(--navy);color:#fff;font-size:.58rem;line-height:1.25;white-space:normal;text-align:left;padding:4px 7px;max-width:calc(100% - 14px);border:none}


    /* ── INSTALL BANNER ─────────────────────────────── */
    .install-overlay{position:fixed;inset:0;z-index:998;background:rgba(0,9,43,.55);backdrop-filter:blur(3px);animation:fadeIn .25s ease}
    .install-banner{
      position:fixed;bottom:0;left:0;right:0;z-index:999;
      background:#fff;border-radius:22px 22px 0 0;
      padding:10px 20px 36px;
      box-shadow:0 -8px 40px rgba(0,9,43,.18);
      animation:slideUp .3s ease;
    }
    .install-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:0 auto 18px}
    .install-icon{width:64px;height:64px;border-radius:16px;overflow:hidden;margin:0 auto 14px;box-shadow:0 4px 16px rgba(0,9,43,.15)}
    .install-icon img{width:100%;height:100%;object-fit:cover}
    .install-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.2rem;color:var(--navy);text-align:center;letter-spacing:-.02em;margin-bottom:6px}
    .install-sub{font-size:.8rem;color:var(--muted);text-align:center;line-height:1.6;font-weight:500;margin-bottom:20px;max-width:280px;margin-left:auto;margin-right:auto}
    .install-steps{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:18px}
    .install-step{display:flex;align-items:center;gap:12px;font-size:.83rem;color:var(--text);font-weight:500;padding:5px 0}
    .install-step+.install-step{border-top:1px solid var(--border);margin-top:5px;padding-top:10px}
    .install-step-num{width:24px;height:24px;border-radius:50%;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.72rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .install-btn{width:100%;padding:15px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.95rem;border:none;border-radius:12px;box-shadow:0 4px 16px rgba(255,69,10,.35);transition:all .15s;letter-spacing:.02em;margin-bottom:10px}
    .install-btn:active{background:var(--orange-dk);transform:scale(.98)}
    .install-dismiss{width:100%;padding:11px;background:none;border:none;color:var(--muted);font-size:.82rem;font-weight:600;font-family:'Montserrat',sans-serif}
    /* ── EMPTY STATE ────────────────────────────────── */
    .empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:10px;text-align:center}
    .empty-icon{font-size:2.8rem;opacity:.3;margin-bottom:4px}
    .empty-text{color:var(--muted);font-size:.88rem;line-height:1.7;font-weight:500}

    /* ── PRODUCT MODAL ──────────────────────────────── */
    @keyframes modalUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
    .pm-overlay{position:fixed;inset:0;background:rgba(0,9,43,.55);z-index:400;animation:fadeIn .2s ease;backdrop-filter:blur(2px)}
    .pm-sheet{position:fixed;left:0;right:0;bottom:0;z-index:401;background:#fff;border-radius:22px 22px 0 0;max-height:92vh;display:flex;flex-direction:column;animation:modalUp .32s cubic-bezier(.32,.72,0,1);box-shadow:0 -8px 40px rgba(0,9,43,.2)}
    .pm-handle{width:38px;height:4px;background:var(--border);border-radius:2px;margin:12px auto 0;flex-shrink:0}
    .pm-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:var(--bg);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--muted);cursor:pointer;z-index:2}
    .pm-gallery{position:relative;flex-shrink:0}
    .pm-img-wrap{width:100%;aspect-ratio:1;background:var(--bg);overflow:hidden;display:flex;align-items:center;justify-content:center;font-size:4rem;max-height:260px}
    .pm-img-wrap img{width:100%;height:100%;object-fit:cover}
    .pm-img-nav{position:absolute;top:50%;transform:translateY(-50%);width:32px;height:32px;background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--navy);box-shadow:0 2px 8px rgba(0,9,43,.1)}
    .pm-img-nav.prev{left:10px}
    .pm-img-nav.next{right:10px}
    .pm-dots{display:flex;gap:5px;justify-content:center;padding:8px 0 0;flex-shrink:0}
    .pm-dot{width:6px;height:6px;border-radius:50%;background:var(--border);transition:all .18s;cursor:pointer}
    .pm-dot.active{background:var(--orange);width:18px;border-radius:3px}
    .pm-variant-badge{position:absolute;bottom:10px;left:10px;background:rgba(0,9,43,.75);color:#fff;font-size:.68rem;font-weight:700;font-family:'Montserrat',sans-serif;padding:4px 10px;border-radius:20px;backdrop-filter:blur(4px);max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .pm-body{flex:1;overflow-y:auto;padding:14px 16px 0}
    .pm-cat{font-size:.68rem;color:var(--orange);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-family:'Montserrat',sans-serif;margin-bottom:5px}
    .pm-name{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.25rem;color:var(--navy);letter-spacing:-.02em;line-height:1.2;margin-bottom:6px}
    .pm-price-row{display:flex;align-items:baseline;gap:8px;margin-bottom:14px}
    .pm-price{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.4rem;color:var(--navy)}
    .pm-price-was{font-size:.88rem;color:var(--muted);text-decoration:line-through;font-weight:400}
    .pm-desc{font-size:.83rem;color:var(--text2);line-height:1.7;margin-bottom:16px;font-weight:400;overflow:hidden}
    .pm-desc p{margin-bottom:10px}
    .pm-desc p:last-child{margin-bottom:0}
    .pm-desc ul,.pm-desc ol{padding-left:18px;margin-bottom:10px}
    .pm-desc li{margin-bottom:4px}
    .pm-desc strong,.pm-desc b{font-weight:700;color:var(--text)}
    .pm-desc em,.pm-desc i{font-style:italic}
    .pm-desc h1,.pm-desc h2,.pm-desc h3,.pm-desc h4{font-family:'Montserrat',sans-serif;font-weight:800;color:var(--navy);margin:12px 0 6px;font-size:.9rem}
    .pm-desc h1{font-size:1rem}
    .pm-desc h2{font-size:.95rem}
    .pm-desc a{color:var(--orange);text-decoration:none}
    .pm-desc br{display:block;content:'';margin-bottom:4px}
    .pm-desc img{max-width:100%!important;width:100%!important;height:auto!important;display:block;border-radius:8px;margin:8px 0;object-fit:contain}
    .pm-desc figure,.pm-desc .wp-block-image,.pm-desc .aligncenter,.pm-desc .alignleft,.pm-desc .alignright{max-width:100%!important;width:100%!important;margin-left:0!important;margin-right:0!important;float:none!important}
    .pm-desc table{max-width:100%;width:100%;overflow-x:auto;display:block}
    .pm-desc *{max-width:100%!important;box-sizing:border-box}
    .pm-attrs{margin-bottom:14px}
    .pm-attr-label{font-size:.7rem;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-family:'Montserrat',sans-serif;margin-bottom:7px}
    .pm-attr-label span{color:var(--navy);font-weight:800}
    .pm-opts{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:12px}
    .pm-opt{padding:7px 14px;border-radius:8px;border:1.5px solid var(--border);font-size:.8rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--navy);cursor:pointer;transition:all .15s;background:#fff;white-space:nowrap}
    .pm-opt.sel{background:var(--navy);border-color:var(--navy);color:#fff}
    .pm-opt.oos{opacity:.38;cursor:not-allowed;text-decoration:line-through}
    /* Info attributes — compact read-only tags */
    .pm-info-attrs{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
    .pm-info-tag{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;background:var(--bg);border:1px solid var(--border);font-size:.68rem;font-weight:600;color:var(--text2);font-family:'Montserrat',sans-serif;white-space:nowrap}
    .pm-info-tag-label{color:var(--muted);font-weight:500;margin-right:2px}
    .pm-stock{display:inline-flex;align-items:center;gap:5px;font-size:.73rem;font-weight:600;padding:4px 10px;border-radius:20px;margin-bottom:12px}
    .pm-stock.in{background:#f0fdf4;color:var(--success);border:1px solid #bbf7d0}
    .pm-stock.out{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}
    .pm-foot{padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));border-top:1.5px solid var(--border);background:#fff;flex-shrink:0;display:flex;gap:8px}
    .pm-add{flex:1;padding:15px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:900;font-size:.92rem;border:none;border-radius:11px;box-shadow:0 4px 14px rgba(255,69,10,.3);transition:all .15s;letter-spacing:.02em}
    .pm-add:active{background:var(--orange-dk);transform:scale(.98)}
    .pm-add:disabled{opacity:.5;box-shadow:none}
    .pm-wish{width:48px;height:48px;border-radius:11px;background:var(--bg);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;flex-shrink:0}
    .pm-essentials{flex:0 0 auto;width:42%;padding:15px 10px;background:#fff;color:var(--navy);font-family:'Montserrat',sans-serif;font-weight:800;font-size:.78rem;border:2px solid var(--navy);border-radius:11px;transition:all .15s;letter-spacing:.01em;display:flex;align-items:center;justify-content:center;gap:5px;line-height:1.2;text-align:center}
    .pm-essentials:active{background:var(--bg);transform:scale(.98)}
    .pm-loading{display:flex;align-items:center;justify-content:center;padding:24px;gap:8px;color:var(--muted);font-size:.83rem}

    /* ── CHECKOUT ───────────────────────────────────── */
    @keyframes slideUpFull{from{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}
    .ck-overlay{position:fixed;inset:0;background:rgba(0,9,43,.6);z-index:500;animation:fadeIn .2s ease;backdrop-filter:blur(3px)}
    .ck-screen{position:fixed;inset:0;z-index:501;display:flex;flex-direction:column;background:#fff;animation:slideUpFull .3s cubic-bezier(.32,.72,0,1)}
    .ck-header{background:var(--navy);padding:16px;padding-top:calc(16px + var(--safe-top));display:flex;align-items:center;gap:12px;flex-shrink:0}
    .ck-back{width:36px;height:36px;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);border-radius:9px;color:#fff;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;flex-shrink:0}
    .ck-back:active{background:rgba(255,255,255,.2)}
    .ck-header-title{flex:1;font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.05rem;color:#fff;letter-spacing:-.01em}
    .ck-header-sub{font-size:.72rem;color:rgba(255,255,255,.5);margin-top:1px;font-weight:500}
    .ck-close{width:36px;height:36px;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);border-radius:9px;color:rgba(255,255,255,.8);font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}

    /* progress bar */
    .ck-progress{height:3px;background:rgba(255,255,255,.12);flex-shrink:0}
    .ck-progress-bar{height:100%;background:var(--orange);transition:width .35s ease}

    /* step pills */
    .ck-steps{display:flex;align-items:center;gap:0;padding:14px 16px 0;flex-shrink:0}
    .ck-step{display:flex;align-items:center;gap:6px;flex:1;min-width:0}
    .ck-step:last-child{flex:0;min-width:auto}
    .ck-step-dot{width:22px;height:22px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.6rem;font-weight:800;font-family:'Montserrat',sans-serif;color:var(--muted);background:#fff;flex-shrink:0;transition:all .25s}
    .ck-step-dot.done{background:var(--success);border-color:var(--success);color:#fff}
    .ck-step-dot.active{background:var(--orange);border-color:var(--orange);color:#fff}
    .ck-step-label{font-size:.64rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--muted);white-space:nowrap;min-width:0;overflow:hidden;text-overflow:ellipsis}
    .ck-step-label.active{color:var(--orange)}
    .ck-step-label.done{color:var(--success)}
    .ck-step-line{flex:1;height:1.5px;background:var(--border);margin:0 6px;transition:background .25s}
    .ck-step-line.done{background:var(--success)}

    /* body */
    .ck-body{flex:1;overflow-y:auto;padding:14px 14px 0}

    /* sections */
    .ck-section{background:#fff;border:1.5px solid var(--border);border-radius:14px;padding:15px;margin-bottom:12px;box-shadow:var(--card-shadow)}
    .ck-section-title{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.76rem;color:var(--navy);text-transform:uppercase;letter-spacing:.08em;margin-bottom:13px;display:flex;align-items:center;gap:7px}
    .ck-section-title::before{content:'';display:inline-block;width:3px;height:13px;background:var(--orange);border-radius:2px}

    /* two-col row */
    .ck-row{display:flex;gap:10px}
    .ck-row .input-wrap{flex:1}

    /* Worldpay 3DS iframes — defined above */
    /* SDK injection targets — must have no padding, SDK manages internal spacing */
    #wvc-card-number,#wvc-card-expiry,#wvc-card-cvc{width:100%;height:100%;display:block}
    #wvc-card-number iframe,#wvc-card-expiry iframe,#wvc-card-cvc iframe{width:100%!important;height:100%!important;display:block!important}
    /* Worldpay 3DS iframes */
    #wp-ddc-iframe{display:none}
    #wp-challenge-overlay{display:none;position:fixed;inset:0;z-index:9000;background:rgba(0,0,0,.6);align-items:center;justify-content:center}
    #wp-challenge-overlay.active{display:flex}
    #wp-challenge-box{background:#fff;border-radius:14px;overflow:hidden;width:min(380px,92vw);height:500px;position:relative}
    #wp-challenge-box iframe{width:100%;height:100%;border:none}
    .wp-secure{display:flex;align-items:center;gap:5px;margin-top:9px;font-size:.71rem;color:var(--muted);font-weight:600}

    /* demo card notice */

    /* order review */
    .ck-review-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border)}
    .ck-review-item:last-child{border-bottom:none}
    .ck-review-img{width:42px;height:42px;border-radius:8px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0;border:1px solid var(--border);overflow:hidden}
    .ck-review-img img{width:100%;height:100%;object-fit:cover}
    .ck-review-name{flex:1;font-size:.82rem;font-weight:700;font-family:'Montserrat',sans-serif;color:var(--text);line-height:1.3}
    .ck-review-qty{font-size:.73rem;color:var(--muted);font-weight:500;margin-top:2px}
    .ck-review-price{font-size:.88rem;font-weight:800;color:var(--navy);font-family:'Montserrat',sans-serif;flex-shrink:0}

    /* totals in review */
    .ck-totals{background:var(--bg);border-radius:10px;padding:12px;border:1px solid var(--border)}
    .ck-total-row{display:flex;justify-content:space-between;font-size:.82rem;color:var(--muted);margin-bottom:7px;font-weight:500}
    .ck-total-row.final{margin-bottom:0;margin-top:9px;padding-top:9px;border-top:1px solid var(--border);font-family:'Montserrat',sans-serif;font-weight:900;font-size:1rem;color:var(--navy)}
    .ck-total-row.final span:last-child{color:var(--orange)}

    /* age confirm checkbox */
    .age-confirm{display:flex;align-items:flex-start;gap:10px;padding:13px;background:var(--orange-lt);border:1.5px solid var(--orange-md);border-radius:11px;margin-bottom:12px;cursor:pointer}
    .age-confirm input[type=checkbox]{width:18px;height:18px;accent-color:var(--orange);flex-shrink:0;margin-top:1px;cursor:pointer}
    .age-confirm-text{font-size:.8rem;color:var(--text);font-weight:600;line-height:1.55}
    .age-confirm-text span{color:var(--orange);font-weight:700}

    /* footer CTA */
    .ck-foot{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));border-top:1.5px solid var(--border);background:#fff;flex-shrink:0}
    .ck-cta{width:100%;padding:16px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:900;font-size:.96rem;border:none;border-radius:12px;box-shadow:0 4px 18px rgba(255,69,10,.35);transition:all .15s;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:10px}
    .ck-cta:active{background:var(--orange-dk);transform:scale(.99)}
    .ck-cta:disabled{opacity:.55;box-shadow:none}
    .ck-error{background:#fef2f2;border:1.5px solid #fecaca;border-radius:9px;padding:10px 14px;font-size:.82rem;color:#dc2626;font-weight:600;margin-bottom:10px}

    /* success screen */
    .ck-success{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 28px;text-align:center;flex:1}
    .ck-success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;font-size:2.2rem;margin-bottom:20px;box-shadow:0 8px 28px rgba(34,197,94,.3);animation:popIn .4s cubic-bezier(.34,1.56,.64,1)}
    @keyframes popIn{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
    .ck-success-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.6rem;color:var(--navy);letter-spacing:-.02em;margin-bottom:6px}
    .ck-success-sub{color:var(--muted);font-size:.88rem;font-weight:500;line-height:1.65;max-width:280px;margin-bottom:20px}
    .ck-order-badge{background:var(--orange-lt);border:1.5px solid var(--orange-md);border-radius:12px;padding:14px 20px;margin-bottom:28px}
    .ck-order-badge-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700;font-family:'Montserrat',sans-serif;margin-bottom:4px}
    .ck-order-badge-num{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.4rem;color:var(--orange)}

    /* ── BUNDLE MODAL ───────────────────────────────── */
    .bm-overlay{position:fixed;inset:0;background:rgba(0,9,43,.55);z-index:400;animation:fadeIn .2s ease;backdrop-filter:blur(2px)}
    .bm-sheet{position:fixed;left:0;right:0;bottom:0;z-index:401;background:#fff;border-radius:22px 22px 0 0;height:92vh;display:flex;flex-direction:column;animation:modalUp .32s cubic-bezier(.32,.72,0,1);box-shadow:0 -8px 40px rgba(0,9,43,.2)}
    .bm-handle{width:38px;height:4px;background:var(--border);border-radius:2px;margin:12px auto 0;flex-shrink:0}
    .bm-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:50%;background:var(--bg);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.9rem;color:var(--muted);cursor:pointer;z-index:2}
    .bm-head{padding:12px 16px 0;flex-shrink:0}
    .bm-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.02rem;color:var(--navy);line-height:1.25;padding-right:36px}
    .bm-desc{font-size:.76rem;color:var(--muted);font-weight:500;margin-top:4px;line-height:1.5}
    .bm-price-row{display:flex;align-items:baseline;gap:8px;margin-top:8px}
    .bm-price{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1.4rem;color:var(--orange)}
    .bm-price-was{font-size:.9rem;color:var(--muted);text-decoration:line-through;font-weight:500}
    .bm-saving{font-size:.72rem;font-weight:700;background:var(--orange-lt);color:var(--orange);border-radius:6px;padding:2px 7px;font-family:'Montserrat',sans-serif}
    .bm-divider{height:1px;background:var(--border);margin:12px 0;flex-shrink:0}
    .bm-slots-label{font-size:.67rem;font-weight:800;font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.12em;color:var(--muted);padding:0 16px;margin-bottom:8px;flex-shrink:0}
    .bm-body{flex:1;overflow-y:auto;padding:0 12px}

    /* Slot row */
    .bm-slot{display:flex;align-items:center;gap:12px;background:#fff;border:1.5px solid var(--border);border-radius:13px;padding:11px 12px;margin-bottom:9px;position:relative;transition:border-color .15s}
    .bm-slot.chosen{border-color:rgba(255,69,10,.35);background:var(--orange-lt)}
    .bm-slot.required-empty{border-color:#fca5a5;background:#fef2f2}
    .bm-slot-img{width:52px;height:52px;border-radius:9px;object-fit:cover;background:var(--bg);flex-shrink:0;border:1px solid var(--border)}
    .bm-slot-img-ph{width:52px;height:52px;border-radius:9px;background:var(--bg);flex-shrink:0;border:1.5px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:1.4rem}
    .bm-slot-info{flex:1;min-width:0}
    .bm-slot-num{font-size:.6rem;font-weight:800;font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:2px}
    .bm-slot-name{font-size:.83rem;font-weight:700;color:var(--navy);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .bm-slot-sub{font-size:.72rem;color:var(--muted);font-weight:500;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .bm-slot-price{font-size:.82rem;font-weight:800;color:var(--navy);font-family:'Montserrat',sans-serif;flex-shrink:0}
    .bm-slot-chevron{color:var(--orange);font-size:1rem;flex-shrink:0}
    .bm-slot-tick{width:22px;height:22px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:.65rem;color:#fff;flex-shrink:0}

    /* Variant select inside slot */
    .bm-attr-select{width:100%;margin-top:7px;padding:7px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.8rem;font-weight:600;color:var(--text);background:#fff;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237b84a8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
    .bm-attr-select:focus{outline:none;border-color:var(--orange);box-shadow:0 0 0 3px rgba(255,69,10,.08)}
    .bm-attr-label{font-size:.68rem;font-weight:700;color:var(--muted);margin-top:6px;margin-bottom:2px;font-family:'Montserrat',sans-serif;text-transform:uppercase;letter-spacing:.08em}

    /* Bundle footer */
    .bm-foot{padding:12px 14px;padding-bottom:max(12px,env(safe-area-inset-bottom));border-top:1.5px solid var(--border);background:#fff;flex-shrink:0}
    .bm-add{width:100%;padding:16px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:900;font-size:.96rem;border:none;border-radius:12px;box-shadow:0 4px 18px rgba(255,69,10,.35);transition:all .15s;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;gap:8px}
    .bm-add:active{background:var(--orange-dk);transform:scale(.99)}
    .bm-add:disabled{background:var(--muted);box-shadow:none;opacity:.7}
    .bm-notice{font-size:.72rem;color:var(--muted);text-align:center;margin-top:7px;font-weight:500}

    /* Slot Picker sheet */
    .sp-overlay{position:fixed;inset:0;background:rgba(0,9,43,.4);z-index:500;animation:fadeIn .15s ease}
    .sp-sheet{position:fixed;left:0;right:0;bottom:0;z-index:501;background:#fff;border-radius:22px 22px 0 0;height:85vh;display:flex;flex-direction:column;animation:modalUp .28s cubic-bezier(.32,.72,0,1);box-shadow:0 -8px 40px rgba(0,9,43,.2)}
    .sp-head{padding:16px 16px 0;flex-shrink:0}
    .sp-back{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--orange);font-size:.82rem;font-weight:700;font-family:'Montserrat',sans-serif;padding:0;margin-bottom:10px;cursor:pointer}
    .sp-title{font-family:'Montserrat',sans-serif;font-weight:900;font-size:1rem;color:var(--navy);margin-bottom:4px}
    .sp-sub{font-size:.74rem;color:var(--muted);font-weight:500;margin-bottom:12px}
    .sp-search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;padding:8px 12px;margin-bottom:0}
    .sp-search input{flex:1;border:none;background:none;font-size:.85rem;color:var(--text);outline:none;font-family:'Inter',sans-serif}
    .sp-grid{display:flex;flex-direction:column;gap:0;padding:8px 14px;overflow-y:auto;flex:1}
    .sp-card{background:#fff;border:1.5px solid var(--border);border-radius:13px;cursor:pointer;transition:border-color .15s,box-shadow .15s;box-shadow:var(--card-shadow);display:flex;flex-direction:row;align-items:center;gap:14px;padding:10px 14px;margin-bottom:8px;min-height:68px}
    .sp-card:active,.sp-card.selected{border-color:var(--orange);box-shadow:0 0 0 2px rgba(255,69,10,.15)}
    .sp-card-img{width:56px;height:56px;min-width:56px;border-radius:9px;background:var(--bg);object-fit:contain;display:block;flex-shrink:0}
    .sp-card-img-ph{width:56px;height:56px;min-width:56px;border-radius:9px;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
    .sp-card-body{flex:1;min-width:0;display:flex;flex-direction:column}
    .sp-card-name{font-size:.82rem;font-weight:700;color:var(--navy);line-height:1.35;white-space:normal}
    .sp-card-oos{font-size:.68rem;color:var(--muted);font-weight:500}
    .sp-pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:10px 14px;flex-shrink:0;border-top:1px solid var(--border)}
    .sp-page-btn{padding:6px 14px;border:1.5px solid var(--border);border-radius:8px;background:#fff;font-size:.78rem;font-weight:700;color:var(--navy);cursor:pointer;font-family:'Montserrat',sans-serif}
    .sp-page-btn:disabled{opacity:.4;cursor:default}
    .sp-page-info{font-size:.78rem;color:var(--muted);font-weight:500}

    /* Variant picker inside slot picker */
    .sp-var-head{padding:0 16px 12px;flex-shrink:0}
    .sp-var-opts{display:flex;flex-wrap:wrap;gap:8px;padding:0 16px;overflow-y:auto;flex:1;align-content:flex-start}
    .sp-var-product-card{background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:12px;margin:0 16px 12px;display:flex;flex-direction:column;gap:10px;flex-shrink:0}
    .sp-var-product-top{display:flex;align-items:center;gap:12px}
    .sp-var-product-img{width:60px;height:60px;min-width:60px;object-fit:contain;border-radius:10px;background:#fff}
    .sp-var-product-img-ph{width:60px;height:60px;min-width:60px;display:flex;align-items:center;justify-content:center;font-size:1.6rem;background:#fff;border-radius:10px}
    .sp-var-product-name{font-size:.82rem;font-weight:800;color:var(--navy);line-height:1.35;font-family:'Montserrat',sans-serif}
    .sp-var-divider{height:1px;background:var(--border)}
    .sp-var-inner-opts{display:flex;flex-wrap:wrap;gap:8px}
    .sp-var-opt{padding:10px 16px;border:1.5px solid var(--border);border-radius:10px;font-size:.84rem;font-weight:600;color:var(--navy);background:#fff;cursor:pointer;transition:all .15s}
    .sp-var-opt.selected{border-color:var(--orange);background:var(--orange-lt);color:var(--orange)}
    .sp-var-opt:disabled{opacity:.4;cursor:default;text-decoration:line-through}
    .sp-var-foot{padding:12px 16px;padding-bottom:max(12px,env(safe-area-inset-bottom));flex-shrink:0}
    .sp-var-confirm{width:100%;padding:14px;background:var(--orange);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.9rem;border:none;border-radius:11px;cursor:pointer}
    .sp-var-confirm:disabled{background:var(--muted)}

    /* ── COMPANION PRODUCTS ──────────────────────────── */
    .cp-section{margin:16px 0 4px;padding:14px 14px 6px;background:var(--orange-lt);border-radius:14px;border:1.5px solid var(--orange-md)}
    .cp-heading{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.8rem;color:var(--orange-dk);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;display:flex;align-items:center;gap:6px}
    .cp-card{display:flex;align-items:flex-start;gap:12px;background:#fff;border:1.5px solid var(--orange-md);border-radius:12px;padding:12px;margin-bottom:8px}
    .cp-img{width:60px;height:60px;border-radius:8px;object-fit:cover;flex-shrink:0;background:#eee}
    .cp-img-placeholder{width:60px;height:60px;border-radius:8px;background:var(--border);display:flex;align-items:center;justify-content:center;font-size:1.6rem;flex-shrink:0}
    .cp-body{flex:1;min-width:0}
    .cp-name{font-weight:700;font-size:.82rem;color:var(--text);line-height:1.3;margin-bottom:2px}
    .cp-info{font-size:.74rem;color:var(--muted);margin-bottom:6px;line-height:1.3}
    .cp-price{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.9rem;color:var(--navy);margin-bottom:8px}
    .cp-attr-label{font-size:.72rem;font-weight:600;color:var(--text2);margin-bottom:4px}
    .cp-attr-select{width:100%;padding:7px 10px;border:1.5px solid var(--border);border-radius:8px;font-size:.8rem;font-weight:600;color:var(--text);background:#fff;margin-bottom:8px;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237b84a8' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
    .cp-add-btn{width:100%;padding:9px 14px;background:var(--navy);color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:.78rem;border:none;border-radius:9px;cursor:pointer;transition:background .15s}
    .cp-add-btn:active{background:var(--navy2)}
    .cp-add-btn:disabled{background:var(--muted);cursor:default}
    .cp-added{font-size:.75rem;color:var(--success);font-weight:600;text-align:center;margin-top:4px}
