@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;500;600;700&family=Plus+Jakarta+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500&display=swap');

/* ════════════ TOKENS ════════════ */
:root {
  /* Main area — warm ivory */
  --bg:        #F7F5F0;
  --bg2:       #FFFFFF;
  --bg3:       #F0EDE6;
  --bg4:       #E8E4DB;
  --border:    #DDD9CF;
  --border2:   #C8C3B8;

  /* Text — warm dark */
  --text1:     #1A1714;
  --text2:     #6B6560;
  --text3:     #A8A39B;

  /* Sidebar — deep violet */
  --sb-bg:     #12092A;
  --sb-bg2:    #1A1035;
  --sb-bg3:    #221540;
  --sb-border: #2D1F4E;
  --sb-text1:  #EDE8FF;
  --sb-text2:  #9B8DC4;
  --sb-text3:  #4D3F72;

  /* Accent — electric violet */
  --accent:      #7C3AED;
  --accent-lt:   #8B5CF6;
  --accent-dk:   #5B21B6;
  --accent-bg:   #F3EFFE;
  --accent-glow: rgba(124,58,237,0.18);

  /* Semantic */
  --blue:      #2563EB;
  --blue-dk:   #1D4ED8;
  --blue-bg:   #EFF6FF;
  --green:     #059669;
  --green-dk:  #047857;
  --green-bg:  #ECFDF5;
  --amber:     #D97706;
  --amber-dk:  #B45309;
  --amber-bg:  #FFFBEB;
  --red:       #DC2626;
  --red-dk:    #B91C1C;
  --red-bg:    #FEF2F2;
  --violet:    #7C3AED;
  --violet-bg: #F3EFFE;
  --teal:      #0891B2;
  --teal-bg:   #ECFEFF;

  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-xl: 20px;
  --sidebar-w: 230px;

  /* Shadows */
  --shadow-sm: 0 1px 3px rgba(26,23,20,0.08), 0 1px 2px rgba(26,23,20,0.04);
  --shadow-md: 0 4px 12px rgba(26,23,20,0.08), 0 2px 4px rgba(26,23,20,0.04);
  --shadow-lg: 0 12px 32px rgba(26,23,20,0.1), 0 4px 8px rgba(26,23,20,0.05);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Plus Jakarta Sans',sans-serif;font-size:13.5px;color:var(--text1);background:var(--bg);line-height:1.55;-webkit-font-smoothing:antialiased}
code,pre,.mono{font-family:'JetBrains Mono',monospace}

/* ── APP SHELL ── */
.app{display:flex;height:100vh;min-height:0}

/* ════════════════════════════════
   SIDEBAR — deep violet world
   ════════════════════════════════ */
.sidebar{
  width:var(--sidebar-w);min-width:var(--sidebar-w);
  display:flex;flex-direction:column;
  background:var(--sb-bg);
  border-right:none;
  padding:0;overflow-y:auto;overflow-x:hidden;position:relative;
}
/* Ambient glow top-left */
.sidebar::before{
  content:'';position:absolute;
  top:-40px;left:-40px;
  width:180px;height:180px;
  background:radial-gradient(circle,rgba(124,58,237,0.25),transparent 70%);
  pointer-events:none;
}

.logo{
  padding:22px 20px 20px;
  border-bottom:1px solid var(--sb-border);
  margin-bottom:10px;
  display:flex;align-items:center;
  min-height:68px;
}
.logo img{height:26px;width:auto;object-fit:contain;filter:brightness(0) invert(1)}
.logo-icon{
  width:32px;height:32px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent-lt),#C084FC);
  display:flex;align-items:center;justify-content:center;
  font-size:15px;flex-shrink:0;
  box-shadow:0 0 20px rgba(139,92,246,0.4);
}

.nav-section{
  padding:16px 20px 5px;
  font-family:'Plus Jakarta Sans',sans-serif;
  font-size:9px;font-weight:700;
  color:var(--sb-text3);
  text-transform:uppercase;letter-spacing:0.18em;
  margin-top:2px;
}
.nav-item{
  padding:9px 16px 9px 18px;cursor:pointer;
  font-size:12.5px;font-weight:500;
  color:var(--sb-text2);
  display:flex;align-items:center;gap:10px;
  margin:1px 10px;border-radius:var(--radius-md);
  transition:all 0.15s;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.nav-item:hover{background:var(--sb-bg3);color:var(--sb-text1)}
.nav-item.active{
  background:linear-gradient(90deg,rgba(124,58,237,0.25),rgba(124,58,237,0.08));
  color:#C4B5FD;
  font-weight:600;
  box-shadow:inset 2px 0 0 var(--accent-lt);
}
.nav-dot{width:5px;height:5px;border-radius:50%;flex-shrink:0;opacity:0.5}
.nav-item.active .nav-dot{opacity:1}
.nav-item[data-page=dashboard] .nav-dot{background:#60A5FA}
.nav-item[data-page=inventory] .nav-dot{background:#34D399}
.nav-item[data-page=stock] .nav-dot{background:#FCD34D}
.nav-item[data-page=handover] .nav-dot{background:#C084FC}
.nav-item[data-page=categories] .nav-dot{background:#FB7185}
.nav-item[data-page=users] .nav-dot{background:#34D399}
.nav-item[data-page=import] .nav-dot{background:#60A5FA}
.nav-item[data-page=invoice] .nav-dot{background:#22D3EE}
.nav-item[data-page=export] .nav-dot{background:#FCD34D}
.nav-item[data-page=analytics] .nav-dot{background:#C084FC}
.nav-item[data-page=statistics] .nav-dot{background:#60A5FA}
.nav-item[data-page=view-inventory] .nav-dot{background:#22D3EE}
.nav-item[data-page=alerts] .nav-dot{background:#F87171}
.nav-item[data-page=add-item] .nav-dot{background:#4ADE80}
.nav-item[data-page=logs] .nav-dot{background:#94A3B8}
.nav-item[data-page=locations] .nav-dot{background:#34D399}
.nav-item[data-page=reports] .nav-dot{background:#FCD34D}

/* ── MAIN — warm ivory world ── */
.main{flex:1;overflow-y:auto;padding:2.2rem 2.4rem;background:var(--bg)}
.page{display:none}
.page.active{display:block;animation:pageIn 0.2s ease}
@keyframes pageIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.page-title{
  font-family:'Playfair Display',serif;
  font-size:26px;font-weight:700;
  margin-bottom:1.8rem;
  letter-spacing:-0.3px;
  color:var(--text1);
  line-height:1.2;
}

/* ── METRICS ── */
.metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-bottom:1.8rem}
.metric{
  border-radius:var(--radius-lg);
  padding:1.2rem 1.4rem;
  border:1px solid;
  background:var(--bg2);
  position:relative;overflow:hidden;
  transition:transform 0.15s,box-shadow 0.15s;
  box-shadow:var(--shadow-sm);
}
.metric:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.metric::after{
  content:'';position:absolute;
  bottom:-10px;right:-10px;
  width:70px;height:70px;
  border-radius:50%;
  opacity:0.06;background:currentColor;
}
.metric-blue  {border-color:#BFDBFE;color:var(--blue)}
.metric-green {border-color:#A7F3D0;color:var(--green)}
.metric-red   {border-color:#FECACA;color:var(--red)}
.metric-amber {border-color:#FDE68A;color:var(--amber)}
.metric-violet{border-color:#DDD6FE;color:var(--violet)}
.metric-teal  {border-color:#A5F3FC;color:var(--teal)}
.metric-label{
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:0.12em;
  color:var(--text3);margin-bottom:8px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.metric-value{
  font-size:32px;font-weight:700;
  letter-spacing:-1px;color:var(--text1);
  line-height:1;
  font-family:'Playfair Display',serif;
}
.metric-sub{font-size:11px;color:var(--text3);margin-top:6px}

/* ── CARDS ── */
.card{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.2rem 1.5rem;
  margin-bottom:1.1rem;
  box-shadow:var(--shadow-sm);
}
.card-title{
  font-size:10.5px;font-weight:700;
  margin-bottom:1rem;color:var(--text3);
  text-transform:uppercase;letter-spacing:0.12em;
  font-family:'Plus Jakarta Sans',sans-serif;
}

/* ── TOOLBAR ── */
.toolbar{display:flex;gap:8px;margin-bottom:1.1rem;align-items:center;flex-wrap:wrap}
.toolbar input[type=text]{
  flex:1;min-width:140px;height:38px;
  font-size:13px;padding:0 14px;
  border-radius:var(--radius-md);
  border:1.5px solid var(--border);
  background:var(--bg2);color:var(--text1);
  font-family:'Plus Jakarta Sans',sans-serif;
  transition:border-color 0.15s,box-shadow 0.15s;
  box-shadow:var(--shadow-sm);
}
.toolbar input[type=text]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.toolbar input[type=text]::placeholder{color:var(--text3)}
.toolbar select{
  height:38px;font-size:13px;padding:0 12px;
  border-radius:var(--radius-md);
  border:1.5px solid var(--border);
  background:var(--bg2);color:var(--text1);
  font-family:'Plus Jakarta Sans',sans-serif;
  cursor:pointer;box-shadow:var(--shadow-sm);
}

/* ── BUTTONS ── */
.btn{
  height:36px;padding:0 16px;
  font-size:12.5px;font-weight:600;
  font-family:'Plus Jakarta Sans',sans-serif;
  border-radius:var(--radius-md);
  border:1.5px solid var(--border);
  background:var(--bg2);color:var(--text1);
  cursor:pointer;white-space:nowrap;
  transition:all 0.13s;
  display:inline-flex;align-items:center;gap:6px;
  box-shadow:var(--shadow-sm);
}
.btn:hover{background:var(--bg3);border-color:var(--border2);box-shadow:var(--shadow-md)}
.btn-primary{
  background:var(--accent);color:#fff;
  border-color:var(--accent-dk);
  box-shadow:0 2px 12px rgba(124,58,237,0.3);
}
.btn-primary:hover{background:var(--accent-lt);box-shadow:0 4px 20px rgba(124,58,237,0.4)}
.btn-green {background:var(--green); color:#fff;border-color:var(--green-dk)}.btn-green:hover{background:var(--green-dk)}
.btn-amber {background:var(--amber); color:#fff;border-color:var(--amber-dk)}.btn-amber:hover{background:var(--amber-dk)}
.btn-red   {background:var(--red);   color:#fff;border-color:var(--red-dk)}.btn-red:hover{background:var(--red-dk)}
.btn-sm{height:30px;padding:0 12px;font-size:11.5px}
.loc-action-btn{width:100%;height:32px;display:flex;align-items:center;justify-content:center;font-size:12px;white-space:nowrap}

/* ── TABLE ── */
table{width:100%;border-collapse:collapse;font-size:13px}
thead{background:var(--bg3)}
th{
  text-align:left;padding:10px 14px;
  border-bottom:1.5px solid var(--border);
  font-weight:700;color:var(--text3);
  font-size:10px;text-transform:uppercase;
  letter-spacing:0.1em;
  font-family:'Plus Jakarta Sans',sans-serif;
  white-space:nowrap;
}
td{padding:10px 14px;border-bottom:1px solid var(--border);color:var(--text1);font-size:13px}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--accent-bg)}

/* ── BADGES ── */
.badge{
  display:inline-flex;align-items:center;
  padding:3px 10px;border-radius:20px;
  font-size:11px;font-weight:600;
  gap:5px;letter-spacing:0.02em;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-green {background:var(--green-bg); color:var(--green);  border:1px solid #A7F3D0}
.badge-amber {background:var(--amber-bg); color:var(--amber);  border:1px solid #FDE68A}
.badge-red   {background:var(--red-bg);   color:var(--red);    border:1px solid #FECACA}
.badge-blue  {background:var(--blue-bg);  color:var(--blue);   border:1px solid #BFDBFE}
.badge-violet{background:var(--violet-bg);color:var(--violet); border:1px solid #DDD6FE}

/* ── BAR CHARTS ── */
.bar-row{display:flex;align-items:center;gap:10px;font-size:12px;margin-bottom:10px}
.bar-label{width:108px;color:var(--text2);text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{flex:1;height:8px;background:var(--bg3);border-radius:4px;overflow:hidden}
.bar-fill{height:100%;border-radius:4px;transition:width 0.6s cubic-bezier(.4,0,.2,1)}
.bar-val{width:40px;font-size:12px;color:var(--text2);text-align:right;font-weight:600;font-family:'JetBrains Mono',monospace}

/* ── MODALS ── */
.overlay{
  position:absolute;top:0;left:0;right:0;bottom:0;
  background:rgba(26,23,20,0.5);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  z-index:100;
}
.modal{
  background:var(--bg2);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:1.8rem;
  width:460px;max-width:96%;
  max-height:92vh;overflow-y:auto;
  box-shadow:var(--shadow-lg),0 0 0 1px rgba(124,58,237,0.06);
}
.modal-title{
  font-family:'Playfair Display',serif;
  font-size:20px;font-weight:700;
  margin-bottom:1.4rem;color:var(--text1);
}
.form-row{margin-bottom:14px}
.form-row label{
  display:block;font-size:10.5px;font-weight:700;
  color:var(--text3);text-transform:uppercase;
  letter-spacing:0.08em;margin-bottom:6px;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.form-row input,.form-row select,.form-row textarea{
  width:100%;padding:0 13px;
  font-size:13px;font-family:'Plus Jakarta Sans',sans-serif;
  border-radius:var(--radius-md);
  border:1.5px solid var(--border);
  background:var(--bg);color:var(--text1);
  height:40px;
  transition:border-color 0.15s,box-shadow 0.15s;
}
.form-row select{background:var(--bg);cursor:pointer}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-glow);
}
.form-row textarea{height:76px;padding:10px 13px;resize:vertical}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.modal-actions{
  display:flex;gap:8px;justify-content:flex-end;
  margin-top:1.4rem;padding-top:1.2rem;
  border-top:1px solid var(--border);
}

/* ── DROP ZONE ── */
.drop-zone{
  border:2px dashed var(--border);
  border-radius:var(--radius-lg);
  padding:2rem;text-align:center;
  cursor:pointer;transition:all 0.15s;
  margin-bottom:1rem;background:var(--bg3);
}
.drop-zone:hover,.drop-zone.drag-over{
  background:var(--accent-bg);border-color:var(--accent);
}

/* ── PREVIEW TABLE ── */
.preview-table-wrap{
  max-height:200px;overflow-y:auto;
  border:1px solid var(--border);
  border-radius:var(--radius-md);
  margin-bottom:10px;background:var(--bg2);
}

/* ── TOAST ── */
.toast{
  position:absolute;bottom:24px;right:24px;
  background:var(--sb-bg);
  border:1px solid var(--sb-border);
  border-radius:var(--radius-md);
  padding:13px 20px;
  font-size:13px;font-weight:500;
  z-index:200;opacity:0;
  transition:opacity 0.2s,transform 0.2s;
  pointer-events:none;
  box-shadow:0 16px 48px rgba(18,9,42,0.5);
  max-width:320px;transform:translateY(8px);
  font-family:'Plus Jakarta Sans',sans-serif;
  color:var(--sb-text1);
  border-left:3px solid var(--accent-lt);
}
.toast.show{opacity:1;transform:translateY(0)}

/* ── CAT CHIPS ── */
.cat-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:20px;
  font-size:12px;font-weight:600;margin:3px;border:1px solid;
}
.cat-chip-del{cursor:pointer;font-size:12px;opacity:0.4}.cat-chip-del:hover{opacity:1}

/* ── QTY CONTROLS ── */
.qty-ctrl{display:flex;align-items:center;gap:6px}
.stock-input{
  width:80px;height:34px;padding:0 8px;
  font-size:13px;font-family:'JetBrains Mono',monospace;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--border);
  background:var(--bg);color:var(--text1);text-align:center;
}
.qty-btn{
  width:32px;height:32px;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--border);
  background:var(--bg2);cursor:pointer;
  font-size:16px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text2);transition:all 0.1s;
}
.qty-btn:hover{background:var(--accent-bg);border-color:var(--accent);color:var(--accent)}

/* ── COLOR INPUT ── */
input[type=color]{
  width:40px;height:40px;padding:2px;
  border-radius:var(--radius-sm);
  border:1.5px solid var(--border);
  cursor:pointer;background:var(--bg);
}

/* ── AUTOSAVE BAR ── */
.autosave-bar{
  display:flex;align-items:center;gap:7px;
  font-size:11px;color:var(--sb-text3);
  padding:12px 16px;
  border-top:1px solid var(--sb-border);
  margin-top:auto;background:var(--sb-bg);
  flex-direction:column;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.autosave-dot{
  width:6px;height:6px;border-radius:50%;
  background:#34D399;flex-shrink:0;transition:background 0.3s;
}
.autosave-dot.saving{background:#FCD34D;animation:pulse 0.8s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.35}}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── USER AVATARS ── */
.user-avatar{
  width:30px;height:30px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;flex-shrink:0;
}

/* ── ROLE BADGES ── */
.role-badge{
  display:inline-flex;align-items:center;
  padding:3px 10px;border-radius:20px;
  font-size:11px;font-weight:600;gap:4px;
}
.role-badge::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;flex-shrink:0}
.role-admin {background:var(--green-bg); color:var(--green);  border:1px solid #A7F3D0}
.role-editor{background:var(--blue-bg);  color:var(--blue);   border:1px solid #BFDBFE}
.role-viewer{background:var(--bg3);      color:var(--text2);  border:1px solid var(--border)}

/* ── CURRENT USER BAR ── */
.current-user-bar{
  padding:12px 16px;font-size:12px;
  color:var(--sb-text2);
  display:flex;align-items:center;gap:9px;
  border-top:1px solid var(--sb-border);
  background:var(--sb-bg);
}

/* ── HANDOVER ── */
.ho-step-num{
  width:26px;height:26px;border-radius:50%;
  background:var(--accent);color:#fff;
  font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;margin-top:1px;
}
.ho-step-num.done{background:var(--green);color:#fff}
.ho-step-num.pending{background:var(--bg3);color:var(--text3);border:1.5px solid var(--border)}
.ho-basket-row{display:flex;align-items:center;gap:8px;padding:8px 0;border-bottom:1px solid var(--border);font-size:13px}
.ho-basket-row:last-child{border-bottom:none}
.ho-badge-issued   {background:var(--blue-bg);  color:var(--blue);  border:1px solid #BFDBFE;display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.ho-badge-pending  {background:var(--amber-bg); color:var(--amber); border:1px solid #FDE68A;display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.ho-badge-cancelled{background:var(--bg3);      color:var(--text3); border:1px solid var(--border);display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;text-decoration:line-through}
.ho-badge-edited   {background:var(--amber-bg); color:var(--amber); border:1px solid #FDE68A;display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600}
.ho-record-card{
  border-left:3px solid var(--accent);
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  padding:12px 16px;margin-bottom:10px;
  background:var(--bg2);
  border-top:1px solid var(--border);
  border-right:1px solid var(--border);
  border-bottom:1px solid var(--border);
  transition:all 0.13s;box-shadow:var(--shadow-sm);
}
.ho-record-card:hover{box-shadow:var(--shadow-md);transform:translateX(2px)}
.ho-record-card.signed{border-left-color:var(--green)}
.ho-record-card.rejected{border-left-color:var(--red)}
.ho-record-card.cancelled{border-left-color:var(--border2);opacity:.65}
.ho-record-card.edited{border-left-color:var(--amber)}
.sign-pad-wrap{border:1.5px solid var(--border);border-radius:var(--radius-md);background:#fff;margin-bottom:8px;cursor:crosshair;touch-action:none}

/* ── HANDOVER TABS ── */
.ho-tab-bar{display:flex;gap:0;border-bottom:1.5px solid var(--border);margin-bottom:1.5rem}
.ho-tab{padding:10px 22px;font-size:13px;font-weight:600;cursor:pointer;border-bottom:2px solid transparent;color:var(--text2);transition:all 0.15s;margin-bottom:-1.5px}
.ho-tab.active{border-bottom-color:var(--accent);color:var(--accent)}
.ho-tab:hover:not(.active){color:var(--text1)}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* ── LOGIN SCREEN ── */
#login-screen{
  position:fixed;inset:0;z-index:9999;
  background:var(--sb-bg);
  display:flex;align-items:center;justify-content:center;
  font-family:'Plus Jakarta Sans',sans-serif;
  background-image:
    radial-gradient(ellipse 60% 60% at 20% 50%,rgba(124,58,237,0.12),transparent),
    radial-gradient(ellipse 40% 40% at 80% 20%,rgba(139,92,246,0.08),transparent);
}
.login-card{
  width:420px;max-width:96vw;
  background:rgba(26,16,53,0.95);
  border:1px solid var(--sb-border);
  border-radius:var(--radius-xl);
  padding:2.5rem 2.5rem 2.2rem;
  box-shadow:0 48px 120px rgba(0,0,0,0.8),0 0 0 1px rgba(139,92,246,0.15);
  animation:loginFadeIn .45s cubic-bezier(.4,0,.2,1);
  position:relative;overflow:hidden;
  backdrop-filter:blur(20px);
}
.login-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(139,92,246,0.6) 50%,transparent);
}
@keyframes loginFadeIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.login-logo{display:flex;align-items:center;gap:14px;margin-bottom:2.2rem}
.login-logo-icon{width:46px;height:46px;border-radius:14px;background:linear-gradient(135deg,var(--accent),#A855F7);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;box-shadow:0 6px 24px rgba(124,58,237,0.4)}
.login-logo-text{font-family:'Playfair Display',serif;font-size:22px;font-weight:700;letter-spacing:-.3px;color:var(--sb-text1)}
.login-logo-sub{font-size:11px;color:var(--sb-text3);margin-top:2px}
.login-field{margin-bottom:16px}
.login-field label{display:block;font-size:10.5px;font-weight:700;color:var(--sb-text3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.login-field input{
  width:100%;height:46px;padding:0 16px;
  font-size:14px;border-radius:var(--radius-md);
  border:1px solid var(--sb-border);
  background:rgba(255,255,255,0.05);
  color:var(--sb-text1);
  transition:border-color .15s,box-shadow .15s;
  font-family:'Plus Jakarta Sans',sans-serif;
}
.login-field input::placeholder{color:var(--sb-text3)}
.login-field input:focus{outline:none;border-color:var(--accent-lt);box-shadow:0 0 0 3px rgba(139,92,246,0.2)}
.login-btn{
  width:100%;height:48px;font-size:14px;font-weight:700;
  border-radius:var(--radius-md);border:none;
  background:linear-gradient(135deg,var(--accent),var(--accent-lt));
  color:#fff;cursor:pointer;margin-top:8px;letter-spacing:.02em;
  transition:opacity .15s,transform .1s,box-shadow .15s;
  display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 4px 24px rgba(124,58,237,0.4);
  font-family:'Plus Jakarta Sans',sans-serif;
}
.login-btn:hover{opacity:0.92;box-shadow:0 6px 32px rgba(124,58,237,0.5)}
.login-btn:active{transform:scale(.98)}
.login-btn:disabled{background:var(--sb-bg3);color:var(--sb-text3);cursor:not-allowed;box-shadow:none}
.login-error{margin-top:12px;padding:11px 14px;background:rgba(220,38,38,0.12);border:1px solid rgba(220,38,38,0.3);border-radius:var(--radius-md);font-size:12.5px;color:#FCA5A5;display:none}
.login-footer{margin-top:1.8rem;padding-top:1.2rem;border-top:1px solid var(--sb-border);font-size:11px;color:var(--sb-text3);text-align:center}

/* ── SELECT ── */
select{background:var(--bg) !important;color:var(--text1) !important}
select option{background:var(--bg2);color:var(--text1)}

/* ── STATUS ROW TINTING ── */
tr.row-out td{background:rgba(220,38,38,0.04)}
tr.row-out:hover td{background:rgba(220,38,38,0.08)}
tr.row-low td{background:rgba(217,119,6,0.04)}
tr.row-low:hover td{background:rgba(217,119,6,0.08)}

/* ════════════════════════════════════════
   MOBILE / RESPONSIVE
   ════════════════════════════════════════ */
.mob-menu-btn{display:none;position:fixed;top:12px;left:12px;z-index:1001;width:44px;height:44px;border-radius:var(--radius-md);background:var(--sb-bg);border:1px solid var(--sb-border);cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:5px;box-shadow:0 2px 16px rgba(0,0,0,0.4);transition:background 0.15s}
.mob-menu-btn:hover{background:var(--sb-bg2)}
.mob-menu-btn span{display:block;width:18px;height:2px;background:var(--sb-text1);border-radius:2px;transition:all 0.2s}
.mob-menu-btn.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.mob-menu-btn.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.mob-menu-btn.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(18,9,42,0.7);backdrop-filter:blur(4px);z-index:999}

@media(max-width:768px){
  .app{flex-direction:column;min-height:100vh}
  .mob-menu-btn{display:flex}
  .sidebar{position:fixed;top:0;left:0;bottom:0;z-index:1000;width:260px;min-width:0;transform:translateX(-100%);transition:transform 0.25s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:8px 0 40px rgba(0,0,0,0.6)}
  .sidebar.mob-open{transform:translateX(0)}
  .sidebar-overlay.mob-open{display:block}
  .main{padding:1rem 1rem 5rem;padding-top:68px;width:100%}
  .page-title{font-size:20px;margin-bottom:1.2rem}
  .metrics{grid-template-columns:repeat(2,1fr);gap:10px}
  .metric-value{font-size:26px}
  .toolbar{flex-wrap:wrap;gap:6px}
  .toolbar input[type=text]{min-width:100%;flex:1 1 100%}
  .toolbar select{flex:1;min-width:120px}
  .card{padding:.9rem;overflow-x:auto}
  table{min-width:520px}
  th,td{padding:8px 10px;font-size:12px}
  .form-grid{grid-template-columns:1fr}
  .modal{width:96vw;padding:1.3rem}
  .bar-label{width:80px;font-size:11px}
  .ho-tab-bar{overflow-x:auto;white-space:nowrap;padding-bottom:2px}
  .toast{bottom:12px;right:10px;left:10px;max-width:unset}
}
@media(max-width:480px){
  .metrics{grid-template-columns:1fr}
  .btn{height:40px;padding:0 16px;font-size:13px}
  .btn-sm{height:32px;padding:0 10px;font-size:12px}
  .nav-item{padding:10px 14px 10px 18px}
  .page-title{font-size:18px}
  .login-card{padding:1.8rem 1.4rem}
  body{font-size:14px}
  .qty-btn{width:36px;height:36px;font-size:18px}
  .col-hide-sm{display:none}
  .metric-value{font-size:28px}
}
@media(max-width:480px){
  .mob-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg2);border-top:1.5px solid var(--border);z-index:998;height:60px;justify-content:space-around;align-items:stretch;box-shadow:0 -4px 20px rgba(26,23,20,0.08)}
  .mob-bottom-nav a,.mob-bottom-nav button{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text3);background:none;border:none;cursor:pointer;gap:3px;transition:color 0.15s;text-decoration:none;font-family:'Plus Jakarta Sans',sans-serif}
  .mob-bottom-nav a:hover,.mob-bottom-nav button:hover{color:var(--text1)}
  .mob-bottom-nav a.active,.mob-bottom-nav button.active{color:var(--accent)}
  .mob-nav-icon{font-size:18px;line-height:1}
}
@media(min-width:481px){.mob-bottom-nav{display:none}}

/* ── GLOBAL SEARCH ── */
.gs-section-title{padding:8px 16px 4px;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.1em;background:var(--bg3);border-bottom:1px solid var(--border)}
.gs-result{padding:10px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s}
.gs-result:hover{background:var(--accent-bg)}
.gs-result:last-child{border-bottom:none}

/* ── STATISTICS PERIOD FILTER ── */
.stat-period-btn.active{background:var(--accent);color:#fff;border-color:var(--accent-dk)}
