/* Snackly Wholesale Portal — Premium B2B Commerce v1 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --brand:#e8713a;--brand2:#f59044;--brand3:#fbc47a;--brand-glow:rgba(232,113,58,.35);
  --accent:#e8713a;--accent2:#f59044;--accent-soft:#fbc47a;
  --dk:#070b12;--dk2:#0d1219;--dk3:#131b26;
  --wh:#fff;--surface:#ffffff;--g50:#f4f6f9;--g100:#e8ecf1;--g200:#d8dee8;--g300:#c2cad6;
  --g400:#8b9cb3;--g500:#5c6f85;--g600:#3d4f63;--g700:#1e293b;
  --gn:#059669;--gnl:rgba(5,150,105,.12);
  --am:#d97706;--aml:rgba(217,119,6,.12);
  --rd:#dc2626;--rdl:rgba(220,38,38,.1);
  --pu:#7c3aed;--pul:rgba(124,58,237,.1);
  --bll:rgba(59,130,246,.12);
  --r:12px;--rlg:16px;--rxl:22px;--sb:280px;
  --glass:rgba(255,255,255,.78);--sh:0 1px 2px rgba(7,11,18,.04),0 4px 20px rgba(7,11,18,.06);
  --sh-md:0 4px 24px rgba(7,11,18,.08);
  --sh-lg:0 12px 40px rgba(7,11,18,.11);
  --display:'Syne',system-ui,sans-serif;--font:'DM Sans',system-ui,sans-serif;--mono:'DM Mono',ui-monospace,monospace;
  --ease:cubic-bezier(.22,1,.36,1);
}
html{scroll-behavior:smooth}
html,body{height:100%;font-family:var(--font);background:var(--g50);color:var(--g700);font-size:14px;line-height:1.55;-webkit-font-smoothing:antialiased}
::selection{background:rgba(232,113,58,.15)}

@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes pulseGlow{0%,100%{opacity:.35}50%{opacity:.65}}
@keyframes mi{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}
@keyframes sp{to{transform:rotate(360deg)}}
.reveal{opacity:0;animation:fadeUp .6s var(--ease) forwards}
.reveal-d1{animation-delay:.05s}.reveal-d2{animation-delay:.1s}.reveal-d3{animation-delay:.15s}
.reveal-d4{animation-delay:.2s}.reveal-d5{animation-delay:.25s}.reveal-d6{animation-delay:.3s}
@media(prefers-reduced-motion:reduce){
  .reveal,.reveal-d1,.reveal-d2,.reveal-d3,.reveal-d4,.reveal-d5,.reveal-d6{opacity:1;animation:none}
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
}

.app{display:flex;height:100vh;overflow:hidden}
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(7,11,18,.55);z-index:250;backdrop-filter:blur(4px);opacity:0;transition:opacity .3s var(--ease)}
.sb-overlay.open{display:block;opacity:1}
.sb{
  width:var(--sb);background:var(--dk);display:flex;flex-direction:column;flex-shrink:0;z-index:300;
  border-right:1px solid rgba(255,255,255,.05);position:relative;overflow:hidden;
}
.sb::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(ellipse 100% 70% at 0% 0%,rgba(232,113,58,.22),transparent 55%),
    radial-gradient(ellipse 60% 40% at 100% 100%,rgba(232,113,58,.08),transparent 50%);
}
.sb>*{position:relative;z-index:1}
.sb-logo{padding:26px 22px 22px;border-bottom:1px solid rgba(255,255,255,.06)}
.sb-logo img{width:118px;display:block;filter:brightness(1.06)}
.sb-logo-tag{display:flex;align-items:center;gap:10px;margin-top:12px}
.sb-logo-sub{font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-soft)}
.sb-tier-pill{
  font-size:9px;font-weight:700;padding:4px 11px;border-radius:99px;
  background:linear-gradient(135deg,var(--brand),var(--brand3));color:#fff;
  box-shadow:0 4px 16px var(--brand-glow);
}
.sb-nav{flex:1;padding:16px 14px;overflow-y:auto}
.sb-nav::-webkit-scrollbar{width:5px}
.sb-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:99px}
.sb-section{font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#5a6d82;padding:18px 14px 10px}
.ni{
  display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:14px;
  color:#94a3b8;font-size:13px;font-weight:500;text-decoration:none;
  transition:all .22s var(--ease);margin-bottom:4px;position:relative;cursor:pointer;
}
.ni>svg{display:none!important}
.ni-icon{
  width:36px;height:36px;border-radius:11px;background:rgba(255,255,255,.05);
  display:flex!important;align-items:center;justify-content:center;flex-shrink:0;transition:all .22s;
}
.ni-icon svg{display:block!important;width:16px;height:16px;color:#6b8299}
.ni>span{flex:1;color:#e2e8f0}
.ni:hover{background:rgba(255,255,255,.06);transform:translateX(2px)}
.ni:hover .ni-icon{background:rgba(255,255,255,.08)}
.ni.active{
  background:linear-gradient(135deg,rgba(37,99,235,.28),rgba(59,130,246,.1));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.ni.active>span{color:#bfdbfe}
.ni.active .ni-icon{background:rgba(37,99,235,.35);box-shadow:0 4px 14px var(--brand-glow)}
.ni.active .ni-icon svg{color:var(--brand3)}
.ni.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:58%;background:linear-gradient(180deg,var(--brand2),var(--brand3));
  border-radius:0 4px 4px 0;
}
.nb{
  font-size:10px;font-weight:700;padding:3px 9px;border-radius:99px;
  background:linear-gradient(135deg,var(--brand2),var(--brand));color:#fff;min-width:22px;text-align:center;
  box-shadow:0 2px 10px var(--brand-glow);
}
.sb-profile{
  margin:12px 14px 16px;border-radius:var(--rxl);
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);
  padding:15px;cursor:pointer;transition:all .22s;
}
.sb-profile:hover{background:rgba(255,255,255,.07);transform:translateY(-1px)}
.sb-profile-inner{display:flex;align-items:center;gap:12px}
.sb-av{
  width:40px;height:40px;border-radius:12px;
  background:linear-gradient(135deg,var(--brand),var(--brand3));
  display:flex;align-items:center;justify-content:center;
  font-size:14px;font-weight:700;color:#fff;box-shadow:0 6px 18px var(--brand-glow);
}
.sb-info{flex:1;min-width:0}
.sb-nm{font-size:13px;font-weight:600;color:#f8fafc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-rl{font-size:11px;color:#6b8299;margin-top:2px}
.sb-chevron{color:#6b8299;transition:transform .25s}
.sb-profile.open .sb-chevron{transform:rotate(180deg)}
.sb-profile-menu{display:none;margin-top:12px;border-top:1px solid rgba(255,255,255,.06);padding-top:10px}
.sb-profile.open .sb-profile-menu{display:block}
.sb-pm-item{
  display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:11px;
  color:#94a3b8;font-size:12.5px;font-weight:500;text-decoration:none;transition:all .18s;cursor:pointer;
}
.sb-pm-item:hover{color:#fff;background:rgba(255,255,255,.06)}

.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0;position:relative}
.main::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(ellipse 80% 50% at 100% -5%,rgba(232,113,58,.08),transparent 50%),
    radial-gradient(ellipse 50% 40% at 0% 80%,rgba(232,113,58,.04),transparent 45%),
    linear-gradient(180deg,var(--g50),#eef1f6);
}
.main>*{position:relative;z-index:1}
.topbar{
  background:var(--glass);backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid rgba(216,222,232,.85);
  padding:0 28px;min-height:68px;display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;gap:16px;flex-wrap:wrap;box-shadow:0 1px 0 rgba(255,255,255,.8) inset;
}
.tb-left{display:flex;align-items:center;gap:14px;min-width:0}
.tb-bc{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--g400);flex-wrap:wrap}
.tb-bc strong{color:var(--g700);font-size:17px;font-weight:700;letter-spacing:-.02em}
.tb-title{font-size:17px;font-weight:700;color:var(--g700);letter-spacing:-.02em}
.tb-r{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.sb-toggle{
  display:none;width:42px;height:42px;border-radius:var(--rlg);border:1px solid var(--g200);
  background:var(--surface);align-items:center;justify-content:center;cursor:pointer;
  color:var(--g600);box-shadow:var(--sh);transition:all .22s var(--ease);
}
.sb-toggle:hover{border-color:var(--brand2);color:var(--brand);transform:translateY(-1px);box-shadow:var(--sh-md)}
.sb-toggle:active{transform:scale(.96)}
.sb-toggle:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(37,99,235,.15)}
.pg{flex:1;overflow-y:auto;padding:28px 32px 40px}
.pg::-webkit-scrollbar{width:8px}
.pg::-webkit-scrollbar-thumb{background:var(--g300);border-radius:99px}

/* Hero */
.hero{
  background:var(--dk);border-radius:var(--rxl);padding:32px 36px;margin-bottom:26px;
  position:relative;overflow:hidden;box-shadow:var(--sh-lg);
}
.hero::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,var(--dk2),var(--dk));z-index:0}
.hero-glow{
  position:absolute;top:-100px;right:-60px;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle,rgba(37,99,235,.28) 0%,transparent 70%);z-index:0;
  animation:pulseGlow 5s ease infinite;
}
.hero-inner{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.hero-greeting{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--brand3);margin-bottom:8px;font-family:var(--display)}
.hero-title{font-size:clamp(1.35rem,3vw,1.65rem);font-weight:800;color:#f8fafc;line-height:1.2;margin-bottom:14px;letter-spacing:-.02em;font-family:var(--display)}
.hero-pills{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hpill{
  display:inline-flex;align-items:center;gap:6px;font-size:11.5px;padding:6px 14px;
  border-radius:99px;border:1px solid rgba(255,255,255,.1);color:#e2e8f0;background:rgba(255,255,255,.05);
}
.hpill.blue{color:#bfdbfe;border-color:rgba(147,197,253,.3);background:rgba(37,99,235,.15)}
.hpill.green{color:#6ee7b7;border-color:rgba(110,231,183,.25);background:rgba(5,150,105,.12)}
.hero-btn-ghost{
  background:rgba(255,255,255,.08)!important;color:#cbd5e1!important;
  border:1px solid rgba(255,255,255,.12)!important;box-shadow:none!important;
}
.hero-btn-ghost:hover:not(:disabled){background:rgba(255,255,255,.14)!important;transform:translateY(-2px)}

/* Stats */
.sg{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:26px}
.sc{
  background:var(--glass);border:1px solid rgba(255,255,255,.95);border-radius:var(--rxl);
  padding:24px;box-shadow:var(--sh);backdrop-filter:blur(12px);
  position:relative;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s;
}
.sc::before{
  content:'';position:absolute;top:-50px;right:-50px;width:100px;height:100px;border-radius:50%;
  filter:blur(35px);opacity:.45;
}
.sc.c-bl::before{background:var(--brand3)}.sc.c-gn::before{background:#34d399}
.sc.c-or::before{background:var(--accent2)}.sc.c-pu::before{background:#a78bfa}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:3px}
.sc.c-bl::after{background:linear-gradient(90deg,var(--brand),var(--brand3))}
.sc.c-gn::after{background:linear-gradient(90deg,#059669,#34d399)}
.sc.c-or::after{background:linear-gradient(90deg,var(--accent),var(--accent2))}
.sc.c-pu::after{background:linear-gradient(90deg,#7c3aed,#a78bfa)}
.sc:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.sc-icon{width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;margin-bottom:16px;position:relative;z-index:1}
.sc-icon svg{width:20px;height:20px}
.c-bl .sc-icon{background:var(--bll)} .c-bl .sc-icon svg{color:var(--brand)}
.c-gn .sc-icon{background:var(--gnl)} .c-gn .sc-icon svg{color:var(--gn)}
.c-or .sc-icon{background:rgba(232,113,58,.12)} .c-or .sc-icon svg{color:var(--accent)}
.c-pu .sc-icon{background:var(--pul)} .c-pu .sc-icon svg{color:var(--pu)}
.sc-label{font-size:10px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;position:relative;z-index:1}
.sc-val{font-size:2rem;font-weight:800;color:var(--g700);font-family:var(--mono);line-height:1;margin-bottom:8px;letter-spacing:-.03em;position:relative;z-index:1}
.sc-sub{font-size:12px;color:var(--g500);position:relative;z-index:1}

.g2{display:grid;grid-template-columns:1fr minmax(280px,320px);gap:20px;margin-bottom:20px;align-items:start}
.cart-layout{display:grid;grid-template-columns:1fr minmax(300px,380px);gap:20px;align-items:start}
.cart-summary-col{position:sticky;top:0}

.card{
  background:var(--glass);border:1px solid rgba(255,255,255,.95);border-radius:var(--rxl);
  box-shadow:var(--sh);overflow:hidden;backdrop-filter:blur(16px);margin-bottom:20px;
  transition:box-shadow .3s var(--ease),transform .3s var(--ease);
}
.card:hover{box-shadow:var(--sh-md)}
.ch{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding:20px 24px;border-bottom:1px solid rgba(232,236,241,.9);
  background:linear-gradient(180deg,rgba(255,255,255,.5),transparent);
}
.ct{font-size:15px;font-weight:700;color:var(--g700);letter-spacing:-.01em}
.cs{font-size:12px;font-weight:500;color:var(--g400);margin-left:10px}
.cb{padding:18px 22px}
.cf{
  padding:16px 24px;border-top:1px solid var(--g100);background:rgba(244,246,249,.7);
  font-size:13px;color:var(--g500);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:7px;
  padding:10px 20px;border-radius:var(--rlg);font-size:13px;font-weight:600;cursor:pointer;
  border:none;font-family:var(--font);transition:all .22s var(--ease);text-decoration:none;white-space:nowrap;
}
.bp{background:linear-gradient(135deg,var(--brand),var(--brand2) 50%,var(--brand3));color:#fff;box-shadow:0 4px 18px var(--brand-glow)}
.bp:hover{transform:translateY(-2px);box-shadow:0 8px 28px var(--brand-glow)}
.bp:active{transform:translateY(0)}
.bo:active{transform:scale(.98)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 4px rgba(37,99,235,.2)}
.bo{background:rgba(255,255,255,.95);color:var(--g700);border:1px solid var(--g200)}
.bo:hover{border-color:var(--brand2);color:var(--brand);box-shadow:0 0 0 4px rgba(37,99,235,.1)}
.bg{background:transparent;color:var(--g500);padding:8px 14px}
.bg:hover{background:rgba(37,99,235,.06);color:var(--brand);border-radius:var(--r)}
.bsm{padding:8px 16px;font-size:12.5px}
.bxs{padding:6px 12px;font-size:12px;border-radius:10px}
.b-fl{width:100%;background:linear-gradient(135deg,var(--brand),var(--brand3))!important;color:#fff!important;justify-content:center;box-shadow:0 4px 18px var(--brand-glow)}
.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important;box-shadow:none!important}

.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:18px;padding:16px 20px;background:var(--glass);border:1px solid rgba(255,255,255,.9);border-radius:var(--rxl);box-shadow:var(--sh);backdrop-filter:blur(12px)}
.toolbar .srch{flex:1;min-width:200px}
.srch{display:flex;align-items:center;gap:10px;border:1px solid var(--g200);border-radius:var(--rlg);padding:0 16px;background:rgba(255,255,255,.9);transition:all .2s;min-width:220px}
.srch:focus-within{border-color:var(--brand2);box-shadow:0 0 0 4px rgba(37,99,235,.12);background:#fff}
.srch svg{color:var(--g400);flex-shrink:0}
.srch input{border:none;outline:none;font-size:13px;font-family:var(--font);padding:11px 0;flex:1;min-width:0;background:transparent;color:var(--g700)}
.srch input::placeholder{color:var(--g400)}
select.sort-sel,select.sel{
  border:1px solid var(--g200);border-radius:var(--rlg);padding:10px 16px;padding-right:36px;
  font-size:13px;font-family:var(--font);color:var(--g700);background:rgba(255,255,255,.9);cursor:pointer;outline:none;
  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='%235c6f85' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
select.sort-sel:focus,select.sel:focus{border-color:var(--brand2);box-shadow:0 0 0 4px rgba(37,99,235,.1)}

.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.chip{
  padding:8px 16px;border-radius:99px;font-size:12px;font-weight:600;cursor:pointer;
  border:1px solid var(--g200);background:rgba(255,255,255,.85);color:var(--g500);transition:all .2s;
}
.chip:hover{border-color:var(--brand2);color:var(--brand);transform:translateY(-1px)}
.chip.active{background:linear-gradient(135deg,var(--brand),var(--brand2));border-color:transparent;color:#fff;box-shadow:0 4px 14px var(--brand-glow)}
.view-toggle{display:flex;gap:4px;padding:4px;background:var(--g100);border-radius:var(--rlg);border:1px solid var(--g200)}
.view-toggle button{
  padding:6px 14px;border:none;background:transparent;border-radius:10px;
  font-size:12px;font-weight:600;color:var(--g500);cursor:pointer;font-family:var(--font);transition:all .18s;
}
.view-toggle button.active{background:#fff;color:var(--brand);box-shadow:var(--sh)}

.tw{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:separate;border-spacing:0}
thead{position:sticky;top:0;z-index:2}
thead tr{background:linear-gradient(180deg,rgba(248,250,252,.98),rgba(244,246,249,.95))}
th{
  font-size:10px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.1em;
  padding:14px 18px;text-align:left;white-space:nowrap;border-bottom:1px solid var(--g200);
}
td{padding:16px 18px;border-bottom:1px solid rgba(232,236,241,.75);font-size:13px;vertical-align:middle;background:rgba(255,255,255,.45)}
tbody tr:last-child td{border-bottom:none}
tbody tr.tbl-row{transition:background .18s}
tbody tr.tbl-row:hover td{background:rgba(37,99,235,.04)}
tbody tr.tbl-row:hover{box-shadow:inset 3px 0 0 var(--brand2)}
.tmono{font-family:var(--mono);font-size:12px}
.tc{text-align:center}.tr{text-align:right}
.cell-title{font-weight:600;color:var(--g700);font-size:13px}
.cell-sub{font-size:11.5px;color:var(--g500);margin-top:3px}
.td-actions{display:flex;gap:6px;flex-wrap:wrap;align-items:center}

.badge{display:inline-flex;align-items:center;padding:5px 11px;border-radius:99px;font-size:11px;font-weight:600;white-space:nowrap;border:1px solid transparent}
.b-bl{background:rgba(37,99,235,.1);color:var(--brand);border-color:rgba(37,99,235,.15)}
.b-gn{background:var(--gnl);color:var(--gn);border-color:rgba(5,150,105,.15)}
.b-or{background:rgba(232,113,58,.1);color:var(--accent);border-color:rgba(232,113,58,.15)}
.b-am{background:var(--aml);color:var(--am);border-color:rgba(217,119,6,.15)}
.b-rd{background:var(--rdl);color:var(--rd);border-color:rgba(220,38,38,.15)}
.b-gy{background:var(--g100);color:var(--g500);border-color:var(--g200)}
.price-mid{color:var(--am);font-weight:600}
.price-bulk{color:var(--gn);font-weight:700}

/* Quantity stepper */
.qs{
  display:inline-flex;align-items:center;border:1px solid var(--g200);border-radius:var(--rlg);
  overflow:hidden;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.04);
}
.qs button{
  background:var(--g50);border:none;cursor:pointer;padding:8px 12px;
  font-size:15px;font-weight:600;color:var(--g600);transition:all .15s;min-width:36px;
}
.qs button:hover{background:var(--g100);color:var(--brand)}
.qs button:active{background:var(--g200);transform:scale(.95)}
.qs input{
  border:none;width:48px;text-align:center;font-size:13px;font-weight:700;
  font-family:var(--mono);background:#fff;color:var(--g700);padding:8px 0;outline:none;
  transition:background .15s;
}
.qs input:focus{background:rgba(37,99,235,.04)}

/* Product grid (catalog) */
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px;padding:20px}
.product-card{
  background:#fff;border:1px solid var(--g200);border-radius:var(--rxl);padding:20px;
  display:flex;flex-direction:column;gap:14px;transition:all .25s var(--ease);position:relative;overflow:hidden;
}
.product-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--brand),var(--brand3));opacity:0;transition:opacity .2s}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(37,99,235,.25)}
.product-card:hover::before{opacity:1}
.pc-brand{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--g500)}
.pc-title{font-size:15px;font-weight:700;color:var(--g700);line-height:1.35;letter-spacing:-.01em}
.pc-meta{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:12px}
.pc-meta span{color:var(--g500)}.pc-meta strong{color:var(--g700);font-family:var(--mono);font-size:12px}
.pc-prices{display:flex;gap:8px;flex-wrap:wrap}
.pc-price-tag{font-size:11px;padding:4px 10px;border-radius:8px;background:var(--g50);font-family:var(--mono);font-weight:600}
.pc-price-tag.bulk{background:var(--gnl);color:var(--gn)}
.pc-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:4px}

/* Tier cards */
.tier-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;padding:18px}
.tier-card{
  border:1px solid var(--g200);border-radius:var(--rlg);padding:16px;text-align:center;
  transition:all .25s;background:rgba(255,255,255,.6);
}
.tier-card.active{border-color:var(--brand2);background:rgba(37,99,235,.06);box-shadow:0 0 0 3px rgba(37,99,235,.12)}
.tier-card .tc-range{font-size:10px;font-weight:700;color:var(--g500);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.tier-card .tc-disc{font-size:22px;font-weight:800;color:var(--gn);margin-bottom:6px;font-family:var(--mono)}
.tier-card.active .tc-range{color:var(--brand)}

/* Timeline */
.timeline{display:flex;align-items:flex-start;margin-bottom:16px;gap:0}
.tl-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative}
.tl-dot{
  width:30px;height:30px;border-radius:50%;border:2px solid var(--g300);
  display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;
  background:#fff;color:var(--g400);z-index:1;transition:all .3s;
}
.tl-dot.done{background:var(--gn);border-color:var(--gn);color:#fff}
.tl-dot.active{background:var(--brand);border-color:var(--brand);color:#fff;box-shadow:0 0 0 4px rgba(37,99,235,.2)}
.tl-label{font-size:10px;margin-top:8px;color:var(--g400);font-weight:500;text-align:center}
.tl-label.active{color:var(--brand);font-weight:700}
.tl-bar{flex:1;height:2px;background:var(--g200);margin-top:15px;align-self:flex-start;min-width:20px}
.tl-bar.done{background:var(--gn)}

/* Notice */
.notice{
  display:flex;gap:14px;align-items:flex-start;border-radius:var(--rxl);padding:16px 20px;
  font-size:13px;margin-bottom:20px;backdrop-filter:blur(8px);
}
.n-bl{background:rgba(37,99,235,.06);border:1px solid rgba(37,99,235,.15);color:#1e3a6e;border-left:4px solid var(--brand)}

/* Cart summary */
.moq-bar{background:var(--g100);border-radius:99px;height:10px;overflow:hidden;margin-top:8px}
.moq-fill{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--brand),var(--brand3));transition:width .5s var(--ease)}
.summary-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;font-size:13px;border-bottom:1px solid var(--g100)}
.summary-row:last-child{border-bottom:none}
.summary-row.total{font-size:16px;font-weight:800;padding-top:14px;margin-top:6px;border-bottom:none}
.summary-row.total span:last-child{color:var(--brand);font-family:var(--mono)}
.discount-banner{
  display:none;background:var(--gnl);border:1px solid rgba(5,150,105,.2);
  border-radius:var(--rlg);padding:12px 16px;margin-bottom:16px;font-size:13px;
  color:#065f46;font-weight:600;text-align:center;
}
.delivery-opts{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:16px 0}
.delivery-opt{
  display:block;padding:14px 16px;border:1.5px solid var(--g200);border-radius:var(--rlg);
  cursor:pointer;transition:all .2s;background:rgba(255,255,255,.8);
}
.delivery-opt:has(input:checked){border-color:var(--brand2);background:rgba(37,99,235,.05);box-shadow:0 0 0 3px rgba(37,99,235,.1)}
.delivery-opt input{margin-right:8px;accent-color:var(--brand)}
.delivery-opt-title{font-size:13px;font-weight:700;color:var(--g700)}
.delivery-opt-sub{font-size:11px;margin-top:4px;display:block;margin-left:22px}
.delivery-opt-sub.fee{color:var(--accent)}.delivery-opt-sub.free{color:var(--gn)}

.order-notes{
  width:100%;border:1.5px solid var(--g200);border-radius:var(--rlg);padding:12px 14px;
  font-size:13px;font-family:var(--font);color:var(--g700);resize:none;outline:none;transition:all .2s;
}
.order-notes:focus{border-color:var(--brand2);box-shadow:0 0 0 4px rgba(37,99,235,.1)}

/* Order detail expand */
.order-detail{display:none}
.order-detail.open{display:table-row}
.order-detail td{padding:0!important;border-bottom:none;background:transparent!important}
.detail-inner{
  padding:22px 24px;background:linear-gradient(180deg,rgba(244,246,249,.95),rgba(255,255,255,.98));
  border-top:1px solid var(--g200);animation:fadeUp .35s var(--ease);
}
.detail-inner table thead tr{box-shadow:none}

/* Modal */
.modal-overlay{
  position:fixed;inset:0;background:rgba(7,11,18,.55);z-index:1000;display:none;
  align-items:center;justify-content:center;backdrop-filter:blur(8px);padding:20px;
  opacity:0;transition:opacity .28s var(--ease);
}
.modal-overlay.open{display:flex;opacity:1}
.modal{
  background:#fff;border-radius:var(--rxl);padding:0;width:100%;max-width:500px;
  box-shadow:var(--sh-lg);animation:mi .28s var(--ease);max-height:90vh;overflow:hidden;
  border:1px solid rgba(255,255,255,.9);
}
.modal-head{
  padding:28px 32px 0;background:linear-gradient(180deg,rgba(37,99,235,.04),transparent);
}
.modal-body{padding:8px 32px 32px;overflow-y:auto;max-height:calc(90vh - 120px)}
.modal::before{
  content:'';display:block;height:3px;
  background:linear-gradient(90deg,var(--brand),var(--brand3));
}
.mtitle{font-size:20px;font-weight:800;color:var(--g700);letter-spacing:-.02em;margin-bottom:6px}
.msub{font-size:14px;color:var(--g500);margin-bottom:20px;line-height:1.5}
.fg{margin-bottom:16px}
.fg label{display:block;font-size:10px;font-weight:700;color:var(--g500);margin-bottom:6px;text-transform:uppercase;letter-spacing:.08em}
.fg input,.fg textarea{
  width:100%;padding:12px 16px;border:1.5px solid var(--g200);border-radius:var(--rlg);
  font-size:14px;font-family:var(--font);color:var(--g700);outline:none;transition:all .2s;
}
.fg input:focus,.fg textarea:focus{border-color:var(--brand2);box-shadow:0 0 0 4px rgba(37,99,235,.1)}
.mbtns{display:flex;gap:12px;margin-top:24px;flex-wrap:wrap}

.state-box{text-align:center;padding:48px 28px;color:var(--g500)}
.state-box.state-inline{padding:32px 20px}
.state-icon{
  width:52px;height:52px;border-radius:16px;margin:0 auto 16px;
  display:flex;align-items:center;justify-content:center;
  background:var(--g100);color:var(--g400);
}
.state-empty .state-icon{background:rgba(37,99,235,.08);color:var(--brand)}
.state-error .state-icon{background:var(--rdl);color:var(--rd)}
.state-loading .state-icon{background:rgba(37,99,235,.06);color:var(--brand)}
.state-error .state-box-title{color:var(--rd)}
.state-box-title{font-size:15px;font-weight:600;color:var(--g600);margin-bottom:8px;letter-spacing:-.01em}
.state-box-sub{font-size:13px;color:var(--g400);line-height:1.5;max-width:320px;margin:0 auto}
.state-box-sub a.empty-link{display:inline-block;margin-top:8px}

/* Table skeleton rows */
.skel-row td{padding:14px 18px!important;border-bottom:1px solid var(--g100)!important}
.skel-row .skel-cell{height:14px;border-radius:6px}
.skel-row .skel-cell.w40{width:40px;margin:0 auto}
.skel-row .skel-cell.w80{width:80%}
.skel-row .skel-cell.w60{width:60%}
.skel-row .skel-cell.w50{width:50%;margin-left:auto}

/* Layout helpers */
.hero-actions{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.summary-body{padding:20px 22px}
.moq-block{margin-bottom:18px}
.moq-head{display:flex;justify-content:space-between;font-size:12px;margin-bottom:6px}
.moq-head span:first-child{color:var(--g500);font-weight:500}
.moq-head span:last-child{font-weight:700;color:var(--brand);font-family:var(--mono)}
.moq-note{font-size:11.5px;color:var(--g500);margin-top:6px;transition:color .25s}
.moq-note.met{color:var(--gn);font-weight:600}
.delivery-info-box{
  margin:0 18px 18px;padding:14px 16px;background:var(--g50);
  border-radius:var(--rlg);border:1px solid var(--g100);font-size:12.5px;
}
.delivery-info-box strong{display:block;font-size:13px;margin-bottom:8px;color:var(--g700)}
.delivery-info-row{display:flex;justify-content:space-between;margin-bottom:4px}
.delivery-info-row span:first-child{color:var(--g500)}
.tier-list{padding:4px 0}
.tier-list-item{
  display:flex;justify-content:space-between;padding:10px 20px;font-size:12.5px;
  border-bottom:1px solid var(--g100);transition:background .25s;
}
.tier-list-item:last-child{border-bottom:none}
.tier-list-item.active{background:rgba(232,113,58,.08)}
.tier-list-item .tier-pct-am{color:var(--am);font-weight:700}
.tier-list-item .tier-pct-gn{color:var(--gn);font-weight:700}
.field-label{
  font-size:11px;font-weight:700;color:var(--g500);display:block;margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.06em;
}
.checkout-foot{text-align:center;font-size:11.5px;color:var(--g400);margin-top:10px;line-height:1.45}
.btn-icon-remove{
  background:none;border:none;cursor:pointer;color:var(--g400);padding:6px;
  border-radius:8px;transition:all .18s;display:inline-flex;align-items:center;justify-content:center;
}
.btn-icon-remove:hover{color:var(--rd);background:var(--rdl)}
.row-chevron{
  display:inline-flex;width:22px;height:22px;align-items:center;justify-content:center;
  border-radius:6px;color:var(--g400);font-size:10px;transition:transform .25s var(--ease),background .18s;
}
.tbl-row.open .row-chevron,.order-detail.open+.tbl-row .row-chevron{transform:rotate(90deg)}
.tbl-row:hover .row-chevron{background:rgba(37,99,235,.08);color:var(--brand)}
.stat-mini-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:16px}
.stat-mini{
  background:var(--g50);border-radius:var(--rlg);padding:12px 14px;border:1px solid var(--g100);
  transition:transform .2s var(--ease);
}
.stat-mini:hover{transform:translateY(-2px)}
.stat-mini-label{font-size:10px;color:var(--g500);margin-bottom:4px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}
.stat-mini-val{font-size:14px;font-weight:700;font-family:var(--mono);color:var(--g700)}
.stat-mini-val.accent{color:var(--brand)}

/* Mobile sticky checkout */
.cart-mobile-bar{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:400;
  background:var(--glass);backdrop-filter:blur(20px) saturate(1.3);
  border-top:1px solid rgba(216,222,232,.9);
  padding:12px 18px;padding-bottom:max(12px,env(safe-area-inset-bottom));
  box-shadow:0 -8px 32px rgba(7,11,18,.1);
  align-items:center;gap:14px;justify-content:space-between;
}
.cart-mobile-bar .mobile-bar-label{font-size:11px;color:var(--g500);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.cart-mobile-bar .mobile-bar-total{font-size:18px;font-weight:800;color:var(--brand);letter-spacing:-.02em}
.pg-cart{padding-bottom:32px}
.nb-pulse{animation:nbPulse .45s var(--ease)}
@keyframes nbPulse{0%{transform:scale(1)}50%{transform:scale(1.15)}100%{transform:scale(1)}}

.catalog-toolbar-mobile{display:none}
.chip:active{transform:scale(.97)}
@media(hover:hover){
  .card:hover{box-shadow:var(--sh-md)}
  .sc:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
  .product-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(37,99,235,.25)}
}
@media(hover:none){
  .card:hover,.sc:hover,.product-card:hover{transform:none}
}
.view-toggle button:active{transform:scale(.96)}
.delivery-opt:hover{border-color:var(--brand2);background:rgba(37,99,235,.03)}
.product-card:active{transform:translateY(-2px)}

.skel{background:linear-gradient(90deg,var(--g100) 25%,var(--g200) 50%,var(--g100) 75%);background-size:200% 100%;animation:sk 1.5s ease infinite;border-radius:8px;display:inline-block}
.spin{width:18px;height:18px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:sp .7s linear infinite;display:none;margin-right:8px}

.swal2-popup{border-radius:var(--rxl)!important;font-family:var(--font)!important}
.swal2-confirm{background:linear-gradient(135deg,var(--brand),var(--brand2))!important;border-radius:var(--rlg)!important;font-weight:700!important}

.empty-link{color:var(--brand);font-weight:600;text-decoration:none}
.empty-link:hover{text-decoration:underline}

@media(max-width:1280px){
  .sg{grid-template-columns:repeat(2,1fr)}
  .g2,.cart-layout{grid-template-columns:1fr}
  .cart-summary-col{position:sticky;top:12px}
  .tb-r .srch{display:none}
}
@media(max-width:960px){
  .sb{position:fixed;left:0;top:0;bottom:0;transform:translateX(-100%);transition:transform .35s var(--ease);box-shadow:var(--sh-lg)}
  .sb.open{transform:translateX(0)}
  .sb-toggle{display:inline-flex}
  .topbar{padding:12px 16px;min-height:60px}
  .pg{padding:18px 16px 32px}
  .pg-cart{padding-bottom:96px}
  .hero{padding:22px 20px}
  .hero-inner{flex-direction:column;align-items:flex-start}
  .hero-actions{width:100%}
  .hero-actions .btn{flex:1;justify-content:center;min-width:140px}
  .product-grid{grid-template-columns:1fr}
  .cart-layout{gap:16px}
  .cart-summary-col{position:static}
  .cart-mobile-bar{display:flex}
  .ch{padding:16px 18px}
  .cb,.summary-body{padding:16px 18px}
  th,td{padding:12px 14px}
  .toolbar{padding:12px 14px;gap:10px}
  .toolbar .srch{max-width:none!important;flex:1 1 100%}
  .tb-r{gap:8px}
  .tb-r .sort-sel{display:none}
  .catalog-toolbar-mobile{display:flex!important;width:100%;gap:8px;margin-bottom:14px}
  .catalog-toolbar-mobile .sort-sel{flex:1}
  thead{position:sticky;top:0}
}
@media(max-width:768px){
  .sg{grid-template-columns:1fr 1fr;gap:12px}
  .sc{padding:18px}
  .sc-val{font-size:1.65rem}
  .stat-mini-grid{grid-template-columns:1fr}
  .td-actions{flex-direction:column;align-items:stretch}
  .td-actions .btn{width:100%;justify-content:center}
  .product-grid{gap:14px;padding:14px}
}
@media(max-width:600px){
  .sg{grid-template-columns:1fr}
  .tier-cards{grid-template-columns:1fr}
  .delivery-opts{grid-template-columns:1fr}
  .mbtns{flex-direction:column}
  .mbtns .btn{width:100%}
  .modal-head,.modal-body{padding-left:22px;padding-right:22px}
}

/* Wholesale legacy tokens */
:root{
  --or:var(--brand);--or2:var(--brand2);--orm:var(--brand3);--orl:#fde8c8;
  --dk:#0f1318;--dk2:#161c24;--wh:#ffffff;--bl:#3b82f6;
  --gn:#10b981;--gnl:rgba(16,185,129,.1);--rd:#ef4444;--rdl:rgba(239,68,68,.08);
  --am:#f59e0b;--aml:rgba(245,158,11,.1);--pu:#8b5cf6;--pul:rgba(139,92,246,.1);
}
.ct,.sc-label,.mtitle,.fg label,.sb-logo-sub{font-family:var(--display)}
.sb-lbl{font-size:9px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#5a6d82;padding:18px 14px 10px}
.sb-badge{font-size:9px;font-weight:700;padding:4px 11px;border-radius:99px;background:linear-gradient(135deg,var(--brand),var(--brand3));color:#fff;box-shadow:0 4px 16px var(--brand-glow);letter-spacing:.05em;text-transform:uppercase}
.g3{display:grid;grid-template-columns:1fr 1fr minmax(260px,296px);gap:20px;margin-bottom:20px;align-items:start}
.hero-glow1{position:absolute;top:-80px;right:-80px;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(232,113,58,.2) 0%,transparent 70%);z-index:0;animation:pulseGlow 5s ease infinite}
.hero-glow2{position:absolute;bottom:-60px;left:35%;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(251,196,122,.12) 0%,transparent 70%);z-index:0}
.hero-btns{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap}
.hpill.orange{color:var(--brand3);border-color:rgba(251,196,122,.25);background:rgba(251,196,122,.08)}
.tl{display:flex;align-items:flex-start;padding:14px 0 4px}
.tl-step{display:flex;flex-direction:column;align-items:center;flex:1}
.tl-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;border:2px solid var(--g200);background:#fff;color:var(--g400);z-index:1;transition:all .3s}
.tl-dot.done{background:var(--gn);border-color:var(--gn);color:#fff;box-shadow:0 0 0 4px rgba(16,185,129,.12)}
.tl-dot.active{background:linear-gradient(135deg,var(--brand),var(--brand2));border-color:var(--brand);color:#fff;box-shadow:0 0 0 4px rgba(232,113,58,.15)}
.tl-lbl{font-size:10px;color:var(--g400);margin-top:5px;text-align:center;font-weight:500}
.tl-lbl.done{color:var(--gn);font-weight:600}.tl-lbl.active{color:var(--brand);font-weight:700}
.tl-line{flex:1;height:2px;background:var(--g200);margin-top:14px;align-self:flex-start;min-width:12px}
.tl-line.done{background:var(--gn)}
.vi{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:var(--rlg);font-size:13px;margin-bottom:4px;border:1px solid transparent;transition:all .2s}
.vi.active{background:linear-gradient(135deg,rgba(232,113,58,.07),rgba(245,158,11,.04));border-color:rgba(232,113,58,.18)}
.vi.active .vi-l{color:var(--brand);font-weight:700}.vi.active .vi-r{color:var(--brand);font-weight:700}
.vi:not(.active) .vi-l{font-weight:500;color:var(--g600)}.vi:not(.active) .vi-r{color:var(--gn);font-weight:700}
.n-or{background:rgba(232,113,58,.06);border:1px solid rgba(232,113,58,.15);color:#8b4a1a;border-left:4px solid var(--brand)}
.detail-table{width:100%;border-collapse:collapse;font-size:12.5px}
.detail-table td{padding:8px 12px;border-bottom:1px solid var(--g200)}
.detail-table tr:last-child td{border-bottom:none}
.sb-pm-item.danger{color:#fca5a5}
.sb-pm-item.danger:hover{color:var(--rd);background:rgba(220,38,38,.08)}
.qo-panel{max-height:190px;overflow-y:auto}
.qo-queue{margin-top:10px;border-top:1px solid var(--g100);padding-top:10px}
.qo-queue-label{font-size:10px;font-weight:700;color:var(--g400);text-transform:uppercase;letter-spacing:.07em;margin-bottom:8px;font-family:var(--display)}
@media(max-width:1100px){.g3{grid-template-columns:1fr 1fr}}
@media(max-width:960px){.g3{grid-template-columns:1fr}}
@media print{.sb,.topbar,.btn,.cf,.notice,.cart-mobile-bar{display:none!important}.main{overflow:visible!important}.pg{padding:0!important}body{background:#fff!important}.invoice-print{display:block!important}}
.invoice-print{display:none}
