/* ═══════════════════════════════════════════════════════
   MECKLY-UI.CSS — Shared design system for all .shop pages
   Mechanic-first: dark, high contrast, grease-finger safe
   Version: 1.0 — extracted from index.html

   Usage in every .shop page:
     <link rel="stylesheet" href="/assets/fonts/fonts.css">
     <link rel="stylesheet" href="/assets/meckly-ui.css">
     <script src="/assets/nav.js"></script>

   Then add page-specific <style> below.
═══════════════════════════════════════════════════════ */

/* ── RESET ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:'Inter','Segoe UI',system-ui,sans-serif;
  background:#070c14;
  min-height:100dvh;
  color:#F0F8FF;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  visibility:hidden; /* revealed by security module */
}
body.ready{visibility:visible}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit}
img{max-width:100%;height:auto;display:block}
::-webkit-scrollbar{width:3px;height:3px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12);border-radius:2px}

/* ── ANIMATIONS ── */
@keyframes mu-spin{to{transform:rotate(360deg)}}
@keyframes mu-fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
@keyframes mu-pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes mu-slideUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ── DESIGN TOKENS ── */
:root{
  /* Brand */
  --brand:#1a6fdb;
  --brand-d:#0d47a1;
  --g-brand:linear-gradient(135deg,#1a6fdb,#0d47a1);

  /* ── STATUS COLOURS ──
     These are the 5 pipeline states.
     Colour = status. One glance. No reading required.
  */
  --s-booked:         #4f8ef7;
  --s-booked-text:    #fff;

  --s-quoted-bg:      #F0EBD8;
  --s-quoted-text:    #1a2744;  /* always blue-family, never brown */

  --s-parts:          #f97316;
  --s-parts-text:     #fff;

  --s-progress-bg:    #f5d623;
  --s-progress-text:  #1a2744;  /* always blue-family */

  --s-finished:       #22d988;
  --s-finished-text:  #04200f;

  --s-cancelled:      #64748b;
  --s-cancelled-text: rgba(255,255,255,.75);

  /* Background scale */
  --bg0:#070c14;
  --bg1:#0b1525;
  --bg2:rgba(255,255,255,.04);
  --bg3:rgba(255,255,255,.07);
  --bg4:rgba(255,255,255,.11);

  /* Text scale */
  --txt:#F0F8FF;
  --txt2:rgba(240,248,255,.82);
  --muted:rgba(240,248,255,.48);
  --faint:rgba(240,248,255,.24);

  /* Border scale */
  --bd:rgba(255,255,255,.07);
  --bd2:rgba(255,255,255,.12);
  --bd3:rgba(255,255,255,.20);

  /* Semantic colours */
  --green:#22d988;
  --green-s:rgba(34,217,136,.10);
  --green-b:rgba(34,217,136,.25);
  --red:#f06060;
  --red-s:rgba(240,96,96,.10);
  --red-b:rgba(240,96,96,.28);
  --amber:#f5a623;
  --amber-s:rgba(245,166,35,.10);
  --amber-b:rgba(245,166,35,.25);

  /* Shape */
  --r:12px;
  --r2:10px;
  --r3:8px;

  /* Typography */
  --mono:'JetBrains Mono',ui-monospace,monospace;

  /* Layout */
  --sb-w:220px;         /* sidebar width on desktop */
  --tap:52px;           /* minimum tap target — grease finger rule */
  --max-content:900px;  /* max content width on pages without sidebar */
}

/* ═══════════════════════════════════════════════════════
   LAYOUT — sidebar + content (injected by nav.js)
═══════════════════════════════════════════════════════ */
.mu-layout{display:flex;min-height:100dvh}

/* ── DESKTOP SIDEBAR ── */
.mu-sidebar{
  width:var(--sb-w);flex-shrink:0;
  background:#0a1020;border-right:1px solid var(--bd2);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:hidden;
}
.mu-sb-head{padding:18px 16px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;flex-shrink:0}
.mu-sb-logo{width:34px;height:34px;border-radius:9px;flex-shrink:0;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-size:17px}
.mu-sb-shop{font-size:14px;font-weight:900;letter-spacing:.5px;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mu-sb-body{flex:1;overflow-y:auto;padding:8px}
.mu-sb-sec{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--faint);padding:12px 8px 4px}
.mu-sb-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:8px;
  color:var(--muted);font-size:13px;font-weight:600;
  cursor:pointer;transition:background .12s,color .12s;
  text-decoration:none;border:none;background:transparent;
  width:100%;text-align:left;min-height:40px;
  -webkit-tap-highlight-color:transparent;
}
.mu-sb-link:hover{background:var(--bg3);color:var(--txt)}
.mu-sb-link.active{background:rgba(26,111,219,.14);color:var(--brand);font-weight:700}
.mu-sb-icon{font-size:15px;width:22px;text-align:center;flex-shrink:0}
.mu-sb-soon{margin-left:auto;font-size:8px;font-weight:800;color:var(--faint);background:var(--bg3);padding:2px 6px;border-radius:4px;letter-spacing:.06em;flex-shrink:0}
.mu-sb-div{height:1px;background:var(--bd);margin:4px 8px}
.mu-sb-foot{padding:12px 10px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--bd);flex-shrink:0}
.mu-sb-user{display:flex;align-items:center;gap:8px}
.mu-sb-av{
  width:32px;height:32px;border-radius:50%;background:var(--g-brand);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:11px;font-weight:800;color:#fff;
  flex-shrink:0;border:2px solid rgba(26,111,219,.35);
}
.mu-sb-uname{font-size:12px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mu-sb-urole{font-size:10px;color:var(--muted);margin-top:1px;text-transform:capitalize}
.mu-sb-logout{
  margin-left:auto;width:30px;height:30px;border-radius:50%;
  border:1px solid rgba(240,96,96,.22);background:rgba(240,96,96,.08);
  color:#f06060;font-size:14px;cursor:pointer;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;transition:background .12s;
  -webkit-tap-highlight-color:transparent;
}
.mu-sb-logout:hover{background:rgba(240,96,96,.20)}

/* ── MAIN CONTENT AREA ── */
.mu-content{
  flex:1;
  margin-left:var(--sb-w);
  min-width:0;
  display:flex;
  flex-direction:column;
}

/* ── MOBILE TOP BAR ── */
.mu-topbar{
  display:none; /* shown on mobile via media query */
  height:54px;
  background:rgba(7,12,20,.92);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--bd);
  align-items:center;padding:0 16px;gap:10px;
  position:sticky;top:0;z-index:90;
}
.mu-tb-logo{width:32px;height:32px;border-radius:8px;flex-shrink:0;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-size:15px}
.mu-tb-shop{font-size:15px;font-weight:900;letter-spacing:.5px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.mu-tb-btn{
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--bd2);background:var(--bg2);
  color:var(--muted);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;transition:background .12s;
  -webkit-tap-highlight-color:transparent;
}
.mu-tb-btn:hover{background:var(--bg3);color:var(--txt)}
.mu-tb-btn.spin svg,.mu-tb-btn.spin{animation:mu-spin .6s linear infinite}
.mu-tb-av{
  width:40px;height:40px;border-radius:50%;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--mono);font-size:12px;font-weight:800;
  color:#fff;background:var(--g-brand);cursor:pointer;
  border:2px solid rgba(26,111,219,.45);
  -webkit-tap-highlight-color:transparent;
}
.mu-tb-menu{
  width:40px;height:40px;border-radius:50%;
  border:1px solid var(--bd2);background:var(--bg2);
  color:var(--muted);cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  flex-shrink:0;transition:background .12s;
  -webkit-tap-highlight-color:transparent;
}
.mu-tb-menu:hover{background:var(--bg3)}
.mu-tb-menu span{display:block;width:15px;height:1.5px;background:currentColor;border-radius:1px}

/* ── MOBILE DRAWER ── */
.mu-overlay{
  position:fixed;inset:0;z-index:200;
  background:rgba(0,0,0,.70);backdrop-filter:blur(6px);
  opacity:0;visibility:hidden;transition:opacity .2s,visibility 0s .2s;
  display:none; /* shown on mobile */
}
.mu-overlay.open{opacity:1;visibility:visible;transition:opacity .2s}
.mu-drawer{
  position:fixed;top:0;right:0;bottom:0;z-index:201;
  width:min(300px,90vw);
  background:linear-gradient(180deg,#0d1526,#070c14);
  border-left:1px solid var(--bd2);
  box-shadow:-24px 0 64px rgba(0,0,0,.75);
  transform:translateX(110%);
  transition:transform .26s cubic-bezier(.4,0,.2,1);
  display:none;flex-direction:column;overflow:hidden; /* shown on mobile */
}
.mu-drawer.open{transform:translateX(0)}
.mu-dr-body{flex:1;overflow-y:auto;padding:16px 10px 8px}
.mu-dr-sec{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.10em;color:var(--faint);padding:12px 10px 5px}
.mu-dr-link{
  display:flex;align-items:center;gap:12px;
  padding:12px 10px;border-radius:var(--r2);
  color:var(--txt2);font-size:14px;font-weight:600;
  cursor:pointer;transition:background .12s;
  text-decoration:none;border:none;background:transparent;
  width:100%;text-align:left;min-height:var(--tap);
  -webkit-tap-highlight-color:transparent;
}
.mu-dr-link:hover,.mu-dr-link.active{background:var(--bg3);color:var(--txt)}
.mu-dr-icon{width:36px;height:36px;border-radius:var(--r3);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--bg3);border:1px solid var(--bd)}
.mu-dr-icon.hi{background:rgba(26,111,219,.15);border-color:rgba(26,111,219,.28)}
.mu-dr-div{height:1px;background:var(--bd);margin:4px 10px}
.mu-dr-foot{padding:12px 10px calc(16px + env(safe-area-inset-bottom));border-top:1px solid var(--bd);flex-shrink:0}
.mu-dr-user{display:flex;align-items:center;gap:10px}
.mu-dr-av{width:40px;height:40px;border-radius:50%;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:800;color:#fff;flex-shrink:0;border:2px solid rgba(26,111,219,.35)}
.mu-dr-uname{font-size:14px;font-weight:700;color:var(--txt)}
.mu-dr-urole{font-size:11px;color:var(--muted);margin-top:2px;text-transform:capitalize}
.mu-dr-logout{margin-left:auto;height:36px;padding:0 14px;border-radius:999px;background:rgba(240,96,96,.10);color:#f06060;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .12s;border:1px solid rgba(240,96,96,.22);-webkit-tap-highlight-color:transparent}
.mu-dr-logout:hover{background:rgba(240,96,96,.22)}

/* ═══════════════════════════════════════════════════════
   SHARED COMPONENTS
═══════════════════════════════════════════════════════ */

/* ── PAGE WRAP (for pages without sidebar, like workflow/quote/close) ── */
.mu-page{
  max-width:var(--max-content);
  margin:0 auto;
  padding:16px 16px calc(80px + env(safe-area-inset-bottom));
}
@media(max-width:640px){.mu-page{padding:12px 12px calc(80px + env(safe-area-inset-bottom))}}

/* ── BACK NAV (for detail pages) ── */
.mu-back-nav{
  height:54px;
  background:rgba(7,12,20,.88);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;padding:0 16px;gap:10px;
  position:sticky;top:0;z-index:90;
}
.mu-back-btn{
  display:flex;align-items:center;gap:5px;
  height:36px;padding:0 14px 0 10px;
  border-radius:999px;border:1px solid var(--bd2);
  background:var(--bg2);color:var(--muted);
  font-size:13px;font-weight:700;cursor:pointer;
  text-decoration:none;transition:all .12s;flex-shrink:0;
  -webkit-tap-highlight-color:transparent;
}
.mu-back-btn:hover{color:var(--txt);background:var(--bg3)}
.mu-back-btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.mu-nav-title{font-size:14px;font-weight:800;color:var(--txt);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.02em}
.mu-nav-ref{font-family:var(--mono);font-size:12px;color:var(--muted);flex-shrink:0}

/* ── STATUS CHIPS ── */
.mu-chip{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}
.mu-chip-booked{background:var(--s-booked);color:var(--s-booked-text)}
.mu-chip-quoted{background:var(--s-quoted-bg);color:var(--s-quoted-text)}
.mu-chip-parts{background:var(--s-parts);color:var(--s-parts-text)}
.mu-chip-progress{background:var(--s-progress-bg);color:var(--s-progress-text)}
.mu-chip-finished{background:var(--s-finished);color:var(--s-finished-text)}
.mu-chip-cancelled{background:var(--s-cancelled);color:var(--s-cancelled-text)}

/* ── BUTTONS ── */
.mu-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:var(--tap);
  padding:0 20px;
  border-radius:var(--r2);border:none;
  font-size:15px;font-weight:800;
  cursor:pointer;transition:filter .12s,transform .08s;
  letter-spacing:-.01em;text-decoration:none;
  -webkit-tap-highlight-color:transparent;
}
.mu-btn:active{transform:scale(.98)}
.mu-btn:hover{filter:brightness(1.08)}
.mu-btn:disabled{opacity:.5;cursor:not-allowed;filter:none;transform:none}

.mu-btn-primary{background:var(--g-brand);color:#fff;box-shadow:0 4px 16px rgba(26,111,219,.30)}
.mu-btn-green{background:linear-gradient(135deg,#22d988,#0f9e75);color:#04200f;box-shadow:0 4px 16px rgba(34,217,136,.22)}
.mu-btn-orange{background:linear-gradient(135deg,#f97316,#c25a00);color:#fff;box-shadow:0 4px 16px rgba(249,115,22,.28)}
.mu-btn-yellow{background:linear-gradient(135deg,#f5d623,#c9a800);color:#1a2744;box-shadow:0 4px 16px rgba(245,214,35,.22)}
.mu-btn-red{background:linear-gradient(135deg,#f06060,#c0392b);color:#fff;box-shadow:0 4px 16px rgba(240,96,96,.22)}
.mu-btn-ghost{background:var(--bg2);color:var(--muted);border:1px solid var(--bd2);box-shadow:none}
.mu-btn-ghost:hover{background:var(--bg3);color:var(--txt);border-color:var(--bd3)}

/* Small button variant */
.mu-btn-sm{min-height:36px;padding:0 14px;font-size:12px;font-weight:700;border-radius:var(--r3)}

/* ── CARDS ── */
.mu-card{
  background:#0d1525;
  border-radius:var(--r);
  border:1px solid var(--bd2);
  overflow:hidden;
}
.mu-card-head{
  padding:14px 16px;
  border-bottom:1px solid var(--bd);
  display:flex;align-items:center;justify-content:space-between;gap:10px;
}
.mu-card-title{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--txt2)}
.mu-card-body{padding:16px}

/* ── DATA ROWS (for detail pages) ── */
.mu-drow{display:flex;align-items:baseline;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--bd);gap:12px}
.mu-drow:last-child{border-bottom:none}
.mu-dl{font-size:13px;color:var(--muted);flex-shrink:0;font-weight:500}
.mu-dv{font-size:14px;font-weight:700;color:var(--txt);text-align:right}
.mu-dv-mono{font-family:var(--mono);font-size:13px;font-weight:500;color:var(--txt);text-align:right}

/* ── FORM ELEMENTS ── */
.mu-field{display:flex;flex-direction:column;gap:6px}
.mu-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}
.mu-input{
  width:100%;
  min-height:var(--tap);
  padding:0 14px;
  border-radius:var(--r2);
  border:1px solid var(--bd2);
  background:var(--bg2);
  color:var(--txt);
  font-size:16px; /* 16px prevents iOS zoom */
  outline:none;
  transition:border-color .15s,background .15s;
}
.mu-input::placeholder{color:var(--muted)}
.mu-input:focus{border-color:rgba(26,111,219,.5);background:rgba(26,111,219,.04);box-shadow:0 0 0 3px rgba(26,111,219,.12)}
textarea.mu-input{min-height:100px;padding:12px 14px;resize:vertical;line-height:1.5}
select.mu-input{cursor:pointer}

/* ── TOAST ── */
#toast,.mu-toast{
  position:fixed;
  bottom:calc(20px + env(safe-area-inset-bottom));
  left:50%;
  transform:translateX(-50%) translateY(120px);
  background:rgba(10,16,28,.97);
  backdrop-filter:blur(16px);
  color:var(--txt);
  border:1px solid var(--bd2);
  border-radius:999px;
  padding:13px 24px;
  font-size:14px;font-weight:700;
  z-index:400;
  white-space:nowrap;pointer-events:none;
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  box-shadow:0 12px 40px rgba(0,0,0,.6);
  max-width:calc(100vw - 32px);text-align:center;
}
#toast.show,.mu-toast.show{transform:translateX(-50%) translateY(0)}

/* ── SPINNER ── */
.mu-spinner{
  width:28px;height:28px;border-radius:50%;
  border:2.5px solid rgba(255,255,255,.08);
  border-top-color:var(--brand);
  animation:mu-spin .75s linear infinite;
}
.mu-loading{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;min-height:50dvh;
  color:var(--faint);font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
}

/* ── EMPTY STATE ── */
.mu-empty{
  padding:60px 20px;text-align:center;
  color:var(--faint);font-size:13px;font-weight:700;
  text-transform:uppercase;letter-spacing:.08em;
}

/* ── SECTION HEADERS ── */
.mu-sec-head{
  display:flex;align-items:center;gap:10px;
  padding:10px 0 8px;margin-top:22px;
  border-bottom:2px solid var(--sc,var(--bd2));
}
.mu-sec-head:first-of-type{margin-top:12px}
.mu-sec-title{font-size:13px;font-weight:900;text-transform:uppercase;letter-spacing:.06em;color:var(--sc,var(--txt))}
.mu-sec-count{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--sc,var(--muted));background:rgba(255,255,255,.06);padding:3px 10px;border-radius:999px;border:1px solid rgba(255,255,255,.10)}

/* ── BADGE / TAG ── */
.mu-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:700;white-space:nowrap}
.mu-badge-green{background:var(--green-s);color:var(--green);border:1px solid var(--green-b)}
.mu-badge-amber{background:var(--amber-s);color:var(--amber);border:1px solid var(--amber-b)}
.mu-badge-red{background:var(--red-s);color:var(--red);border:1px solid var(--red-b)}
.mu-badge-muted{background:var(--bg3);color:var(--muted);border:1px solid var(--bd2)}

/* ── DIVIDER ── */
.mu-div{height:1px;background:var(--bd);margin:16px 0}

/* ── AVATAR ── */
.mu-av{border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-weight:800;color:#fff;flex-shrink:0}
.mu-av-sm{width:24px;height:24px;font-size:9px}
.mu-av-md{width:36px;height:36px;font-size:13px}
.mu-av-lg{width:48px;height:48px;font-size:16px}

/* ── UTILITY ── */
.mu-mono{font-family:var(--mono)}
.mu-muted{color:var(--muted)}
.mu-faint{color:var(--faint)}
.mu-hidden{display:none!important}
.mu-truncate{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ═══════════════════════════════════════════════════════
   RESPONSIVE — mobile breakpoint
   Sidebar hides, top bar shows
═══════════════════════════════════════════════════════ */
@media(max-width:860px){
  .mu-sidebar{display:none}
  .mu-content{margin-left:0}
  .mu-topbar{display:flex}
  .mu-overlay{display:block}
  .mu-drawer{display:flex}
}

/* ═══════════════════════════════════════════════════════
   LEGACY ALIASES — maps old index.html class names to
   the mu-* system. Allows index.html to work without
   renaming every element. Future pages use mu-* directly.
═══════════════════════════════════════════════════════ */
.layout{display:flex;min-height:100dvh}
.sidebar{width:var(--sb-w);flex-shrink:0;background:#0a1020;border-right:1px solid var(--bd2);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;overflow:hidden}
.sb-head{padding:18px 16px 14px;border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:10px;flex-shrink:0}
.sb-logo{width:34px;height:34px;border-radius:9px;flex-shrink:0;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-size:17px}
.sb-shop{font-size:14px;font-weight:900;letter-spacing:.5px;color:var(--txt);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sb-body{flex:1;overflow-y:auto;padding:8px}
.sb-sec-lbl{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--faint);padding:12px 8px 4px}
.sb-link{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:8px;color:var(--muted);font-size:13px;font-weight:600;cursor:pointer;transition:background .12s,color .12s;text-decoration:none;border:none;background:transparent;width:100%;text-align:left;min-height:40px}
.sb-link:hover{background:var(--bg3);color:var(--txt)}
.sb-link.active{background:rgba(26,111,219,.14);color:var(--brand);font-weight:700}
.sb-link-icon{font-size:15px;width:22px;text-align:center;flex-shrink:0}
.sb-link-soon{margin-left:auto;font-size:8px;font-weight:800;color:var(--faint);background:var(--bg3);padding:2px 6px;border-radius:4px;letter-spacing:.06em;flex-shrink:0}
.sb-div{height:1px;background:var(--bd);margin:4px 8px}
.sb-foot{padding:12px 10px calc(12px + env(safe-area-inset-bottom));border-top:1px solid var(--bd);flex-shrink:0}
.sb-user{display:flex;align-items:center;gap:8px}
.sb-av{width:32px;height:32px;border-radius:50%;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;font-weight:800;color:#fff;flex-shrink:0;border:2px solid rgba(26,111,219,.35)}
.sb-uname{font-size:12px;font-weight:700;color:var(--txt);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sb-urole{font-size:10px;color:var(--muted);margin-top:1px;text-transform:capitalize}
.sb-logout{margin-left:auto;width:30px;height:30px;border-radius:50%;border:1px solid rgba(240,96,96,.22);background:rgba(240,96,96,.08);color:#f06060;font-size:14px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .12s}
.sb-logout:hover{background:rgba(240,96,96,.20)}
.content{flex:1;margin-left:var(--sb-w);min-width:0;display:flex;flex-direction:column}
.top-bar{display:none;height:54px;background:rgba(7,12,20,.92);backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border-bottom:1px solid var(--bd);align-items:center;padding:0 14px;gap:10px;position:sticky;top:0;z-index:90}
.tb-logo{width:32px;height:32px;border-radius:8px;flex-shrink:0;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-size:15px}
.tb-shop{font-size:15px;font-weight:900;letter-spacing:.5px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tb-btn{width:40px;height:40px;border-radius:50%;border:1px solid var(--bd2);background:var(--bg2);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .12s}
.tb-btn:hover{background:var(--bg3);color:var(--txt)}
.tb-btn.spin svg{animation:mu-spin .6s linear infinite}
.tb-avatar{width:40px;height:40px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:800;color:#fff;background:var(--g-brand);cursor:pointer;border:2px solid rgba(26,111,219,.45)}
.tb-menu{width:40px;height:40px;border-radius:50%;border:1px solid var(--bd2);background:var(--bg2);color:var(--muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex-shrink:0;transition:background .12s}
.tb-menu:hover{background:var(--bg3)}
.tb-menu span{display:block;width:15px;height:1.5px;background:currentColor;border-radius:1px}
.drawer-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.70);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .2s,visibility 0s .2s;display:none}
.drawer-overlay.open{opacity:1;visibility:visible;transition:opacity .2s}
.drawer{position:fixed;top:0;right:0;bottom:0;z-index:201;width:min(300px,90vw);background:linear-gradient(180deg,#0d1526,#070c14);border-left:1px solid var(--bd2);box-shadow:-24px 0 64px rgba(0,0,0,.75);transform:translateX(110%);transition:transform .26s cubic-bezier(.4,0,.2,1);display:none;flex-direction:column;overflow:hidden}
.drawer.open{transform:translateX(0)}
.drawer-body{flex:1;overflow-y:auto;padding:16px 10px 8px}
.drawer-sec-lbl{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.10em;color:var(--faint);padding:12px 10px 5px}
.drawer-link{display:flex;align-items:center;gap:12px;padding:12px 10px;border-radius:var(--r2);color:var(--txt2);font-size:14px;font-weight:600;cursor:pointer;transition:background .12s;text-decoration:none;border:none;background:transparent;width:100%;text-align:left;min-height:52px}
.drawer-link:hover,.drawer-link.active{background:var(--bg3);color:var(--txt)}
.drawer-link-icon{width:36px;height:36px;border-radius:var(--r3);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--bg3);border:1px solid var(--bd)}
.drawer-link-icon.hi{background:rgba(26,111,219,.15);border-color:rgba(26,111,219,.28)}
.drawer-div{height:1px;background:var(--bd);margin:4px 10px}
.drawer-foot{padding:12px 10px calc(16px + env(safe-area-inset-bottom));border-top:1px solid var(--bd);flex-shrink:0}
.drawer-user{display:flex;align-items:center;gap:10px}
.drawer-av{width:40px;height:40px;border-radius:50%;background:var(--g-brand);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;font-weight:800;color:#fff;flex-shrink:0;border:2px solid rgba(26,111,219,.35)}
.drawer-uname{font-size:14px;font-weight:700;color:var(--txt)}
.drawer-urole{font-size:11px;color:var(--muted);margin-top:2px;text-transform:capitalize}
.drawer-logout{margin-left:auto;height:36px;padding:0 14px;border-radius:999px;background:rgba(240,96,96,.10);color:#f06060;font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;transition:background .12s;border:1px solid rgba(240,96,96,.22)}
.drawer-logout:hover{background:rgba(240,96,96,.22)}
#toast{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom));left:50%;transform:translateX(-50%) translateY(120px);background:rgba(10,16,28,.97);backdrop-filter:blur(16px);color:var(--txt);border:1px solid var(--bd2);border-radius:999px;padding:13px 24px;font-size:14px;font-weight:700;z-index:400;white-space:nowrap;pointer-events:none;transition:transform .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 12px 40px rgba(0,0,0,.6);max-width:calc(100vw - 32px);text-align:center}
#toast.show{transform:translateX(-50%) translateY(0)}
@media(max-width:860px){
  .sidebar{display:none}
  .content{margin-left:0}
  .top-bar{display:flex}
  .drawer-overlay{display:block}
  .drawer{display:flex}
}
