/* ============================================================
   SiDARO — app.css  |  Dark Industrial Theme
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Sans:wght@300;400;500&family=DM+Mono:wght@400;500&display=swap');

:root {
  --bg:       #0d0d12;
  --bg2:      #13131a;
  --bg3:      #1a1a24;
  --bg4:      #22222f;
  --border:   rgba(255,255,255,.07);
  --border2:  rgba(255,255,255,.13);
  --text:     #e2e0da;
  --muted:    #6b6966;
  --accent:   #e8a020;
  --accent2:  #c8501a;
  --teal:     #1ab8a0;
  --purple:   #8b5cf6;
  --red:      #e84040;
  --green:    #22c55e;
  --blue:     #3b82f6;
  --font-d:   'Bebas Neue', sans-serif;
  --font-b:   'DM Sans', sans-serif;
  --font-m:   'DM Mono', monospace;
  --r:        6px;
  --r2:       10px;
  --sidebar-w: 240px;
  --nav-h:    56px;
}

/* Pusat = purple accent */
.theme-pusat   { --role-color: var(--purple); --role-bg: rgba(139,92,246,.08); }
/* Cabang = teal */
.theme-cabang  { --role-color: var(--teal);   --role-bg: rgba(26,184,160,.08); }
/* Outlet = amber */
.theme-outlet  { --role-color: var(--accent); --role-bg: rgba(232,160,32,.08); }
/* Sales = coral */
.theme-sales   { --role-color: var(--accent2);--role-bg: rgba(200,80,26,.08);  }

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font-b);font-size:15px;line-height:1.6;min-height:100vh}

/* ── SCROLLBAR ─────────────────────────────── */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}

/* ── TOPNAV ────────────────────────────────── */
.topnav{
  position:fixed;top:0;left:var(--sidebar-w);right:0;height:var(--nav-h);
  background:rgba(13,13,18,.9);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);z-index:100;
  display:flex;align-items:center;padding:0 24px;gap:16px;
}
.topnav-title{font-family:var(--font-d);font-size:1.1rem;letter-spacing:2px;color:var(--text)}
.topnav-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.notif-btn{position:relative;background:none;border:1px solid var(--border);color:var(--muted);padding:6px 10px;border-radius:var(--r);cursor:pointer;font-size:.9rem;transition:.2s}
.notif-btn:hover{border-color:var(--border2);color:var(--text)}
.notif-badge{position:absolute;top:-5px;right:-5px;background:var(--red);color:#fff;font-size:.55rem;width:17px;height:17px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-m)}
.user-chip{background:var(--bg3);border:1px solid var(--border);padding:6px 14px;border-radius:var(--r);font-size:.82rem;color:var(--muted)}
.user-chip strong{color:var(--text)}

/* ── SIDEBAR ───────────────────────────────── */
.sidebar{
  position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);
  background:var(--bg2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;overflow-y:auto;z-index:200;
}
.sidebar-brand{
  padding:20px 20px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
}
.sidebar-brand .brand-name{font-family:var(--font-d);font-size:1.6rem;letter-spacing:3px;color:var(--accent)}
.sidebar-brand .brand-role{font-family:var(--font-m);font-size:.6rem;color:var(--muted);letter-spacing:2px}
.sidebar-section{padding:16px 16px 6px;font-family:var(--font-m);font-size:.6rem;color:var(--muted);letter-spacing:3px;text-transform:uppercase}
.sidebar-nav{list-style:none;padding:0 8px}
.sidebar-nav a{
  display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--r);
  color:var(--muted);text-decoration:none;font-size:.85rem;font-weight:400;transition:.15s;
  margin-bottom:2px;
}
.sidebar-nav a:hover{background:var(--bg3);color:var(--text)}
.sidebar-nav a.active{background:var(--role-bg);color:var(--role-color);font-weight:500}
.sidebar-nav .nav-icon{width:18px;text-align:center;font-size:1rem}
.sidebar-bottom{margin-top:auto;padding:12px;border-top:1px solid var(--border)}
.logout-btn{
  display:block;width:100%;padding:9px;background:none;border:1px solid var(--border);
  color:var(--muted);border-radius:var(--r);font-size:.82rem;cursor:pointer;text-align:center;
  font-family:var(--font-b);transition:.2s;text-decoration:none;
}
.logout-btn:hover{border-color:var(--red);color:var(--red)}

/* ── MAIN CONTENT ──────────────────────────── */
.main{margin-left:var(--sidebar-w);padding-top:var(--nav-h)}
.page-inner{padding:28px 32px;max-width:1400px}

/* ── PAGE HEADER ───────────────────────────── */
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:28px;gap:16px}
.page-header h1{font-family:var(--font-d);font-size:2rem;letter-spacing:2px;color:#fff}
.page-header .sub{font-size:.82rem;color:var(--muted);margin-top:2px}

/* ── STAT CARDS ────────────────────────────── */
.stat-grid{display:grid;gap:12px;margin-bottom:28px}
.stat-grid.cols-4{grid-template-columns:repeat(4,1fr)}
.stat-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.stat-grid.cols-2{grid-template-columns:repeat(2,1fr)}
.stat-card{background:var(--bg2);border:1px solid var(--border);padding:20px;border-radius:var(--r2)}
.stat-card .sc-val{font-family:var(--font-d);font-size:2.2rem;letter-spacing:2px;line-height:1;margin-bottom:4px}
.stat-card .sc-lbl{font-family:var(--font-m);font-size:.68rem;color:var(--muted);letter-spacing:1px}
.stat-card .sc-sub{font-size:.78rem;color:var(--muted);margin-top:6px}

/* ── CARD ──────────────────────────────────── */
.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden;margin-bottom:20px}
.card-head{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-head h3{font-family:var(--font-d);font-size:1.1rem;letter-spacing:2px;color:#fff}
.card-body{padding:20px}

/* ── TABLE ─────────────────────────────────── */
.tbl-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:.85rem}
table.tbl th{padding:10px 14px;text-align:left;font-family:var(--font-m);font-size:.65rem;color:var(--muted);letter-spacing:2px;border-bottom:1px solid var(--border2);font-weight:400;white-space:nowrap}
table.tbl td{padding:11px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
table.tbl tr:last-child td{border-bottom:none}
table.tbl tr:hover td{background:rgba(255,255,255,.02)}
table.tbl .mono{font-family:var(--font-m);font-size:.8rem}

/* ── BADGE / STATUS ────────────────────────── */
.badge{display:inline-block;font-family:var(--font-m);font-size:.62rem;padding:3px 9px;border-radius:3px;letter-spacing:.5px}
.badge-green {background:rgba(34,197,94,.1); color:var(--green)}
.badge-amber {background:rgba(232,160,32,.1);color:var(--accent)}
.badge-red   {background:rgba(232,64,64,.1); color:var(--red)}
.badge-blue  {background:rgba(59,130,246,.1);color:var(--blue)}
.badge-purple{background:rgba(139,92,246,.1);color:var(--purple)}
.badge-teal  {background:rgba(26,184,160,.1);color:var(--teal)}
.badge-muted {background:rgba(255,255,255,.05);color:var(--muted)}

/* ── BUTTONS ───────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 18px;border-radius:var(--r);font-family:var(--font-b);font-size:.84rem;font-weight:500;cursor:pointer;text-decoration:none;border:none;transition:.15s;white-space:nowrap}
.btn-primary{background:var(--role-color,var(--accent));color:#000}
.btn-primary:hover{filter:brightness(1.15)}
.btn-outline{background:none;border:1px solid var(--border2);color:var(--text)}
.btn-outline:hover{border-color:var(--role-color,var(--accent));color:var(--role-color,var(--accent))}
.btn-danger {background:rgba(232,64,64,.1);border:1px solid rgba(232,64,64,.2);color:var(--red)}
.btn-danger:hover{background:rgba(232,64,64,.2)}
.btn-sm{padding:5px 12px;font-size:.78rem}
.btn-xs{padding:3px 9px;font-size:.72rem}

/* ── FORMS ─────────────────────────────────── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-family:var(--font-m);font-size:.68rem;color:var(--muted);letter-spacing:1px;margin-bottom:6px;text-transform:uppercase}
.form-control{
  width:100%;background:var(--bg3);border:1px solid var(--border2);color:var(--text);
  padding:9px 12px;border-radius:var(--r);font-family:var(--font-b);font-size:.88rem;
  transition:.15s;outline:none;
}
.form-control:focus{border-color:var(--role-color,var(--accent));box-shadow:0 0 0 2px rgba(232,160,32,.1)}
.form-control::placeholder{color:var(--muted)}
select.form-control{cursor:pointer}
textarea.form-control{resize:vertical;min-height:80px}
.form-row{display:grid;gap:16px}
.form-row.cols-2{grid-template-columns:1fr 1fr}
.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}

/* ── ALERT FLASH ───────────────────────────── */
.alert{padding:12px 16px;border-radius:var(--r);margin-bottom:20px;font-size:.85rem;display:flex;align-items:flex-start;gap:10px;border-left:3px solid}
.alert-success{background:rgba(34,197,94,.06);border-color:var(--green);color:var(--green)}
.alert-error  {background:rgba(232,64,64,.06);border-color:var(--red);color:var(--red)}
.alert-info   {background:rgba(59,130,246,.06);border-color:var(--blue);color:var(--blue)}
.alert-warning{background:rgba(232,160,32,.06);border-color:var(--accent);color:var(--accent)}

/* ── NOTA PRINT ────────────────────────────── */
@media print {
  .no-print{display:none!important}
  .sidebar,.topnav{display:none!important}
  .main{margin-left:0!important;padding:0!important}
  body{background:#fff;color:#000}
  .nota-wrap{box-shadow:none;border:none}
}
.nota-wrap{background:#fff;color:#111;font-family:'Courier New',monospace;font-size:12px;line-height:1.7;max-width:320px;margin:0 auto;padding:20px;border-radius:var(--r);box-shadow:0 4px 24px rgba(0,0,0,.4)}
.nota-sep{border-top:1px dashed #ccc;margin:8px 0}
.nota-sep-bold{border-top:2px solid #333;margin:8px 0}
.nota-head{text-align:center;font-weight:bold}
.nota-row{display:flex;justify-content:space-between}
.nota-lunas{text-align:center;border:2px solid green;color:green;font-weight:bold;padding:2px;letter-spacing:4px;margin-top:6px}

/* ── LOGIN PAGE ────────────────────────────── */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}
.login-box{background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);padding:40px 36px;width:100%;max-width:400px}
.login-logo{font-family:var(--font-d);font-size:3rem;letter-spacing:5px;color:var(--accent);text-align:center;margin-bottom:4px}
.login-sub{text-align:center;font-family:var(--font-m);font-size:.65rem;color:var(--muted);letter-spacing:3px;margin-bottom:32px}

/* ── GRID LAYOUTS ──────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.gap-4{gap:4px}.gap-8{gap:8px}.gap-12{gap:12px}

/* ── UTILITY ───────────────────────────────── */
.text-accent{color:var(--accent)}.text-muted{color:var(--muted)}.text-white{color:#fff}
.text-green{color:var(--green)}.text-red{color:var(--red)}.text-teal{color:var(--teal)}
.fw-bold{font-weight:500}.mono{font-family:var(--font-m)}.uppercase{text-transform:uppercase}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}
.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:16px}.mt-4{margin-top:24px}.mt-5{margin-top:32px}
.mb-3{margin-bottom:16px}.mb-4{margin-bottom:24px}
.p-4{padding:16px}.p-5{padding:24px}
.w-full{width:100%}
.text-right{text-align:right}.text-center{text-align:center}
.kasir-grid{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}
.cart-fixed{position:sticky;top:calc(var(--nav-h)+20px);background:var(--bg2);border:1px solid var(--border);border-radius:var(--r2);overflow:hidden}
.cart-item{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid var(--border)}
.cart-total{padding:14px 16px;border-top:2px solid var(--border2);display:flex;justify-content:space-between;align-items:center}
.cart-total .total-val{font-family:var(--font-d);font-size:1.5rem;color:var(--accent)}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px}
.product-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:16px;cursor:pointer;transition:.15s}
.product-card:hover{border-color:var(--role-color,var(--accent));transform:translateY(-2px)}
.product-card .pc-name{font-weight:500;color:#fff;margin-bottom:4px}
.product-card .pc-merek{font-size:.75rem;color:var(--muted);margin-bottom:8px}
.product-card .pc-price{font-family:var(--font-d);font-size:1.1rem;color:var(--accent)}
.product-card .pc-stok{font-size:.72rem;font-family:var(--font-m);color:var(--muted)}
.qty-control{display:flex;align-items:center;gap:6px}
.qty-btn{background:var(--bg4);border:1px solid var(--border);color:var(--text);width:26px;height:26px;border-radius:4px;cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;transition:.15s}
.qty-btn:hover{background:var(--role-color,var(--accent));border-color:transparent;color:#000}

/* ── MAPS / GPS ────────────────────────────── */
.gps-status{padding:10px 14px;border-radius:var(--r);font-family:var(--font-m);font-size:.75rem;border:1px solid}
.gps-ok  {background:rgba(34,197,94,.06);border-color:var(--green);color:var(--green)}
.gps-err {background:rgba(232,64,64,.06);border-color:var(--red);color:var(--red)}
.gps-wait{background:rgba(232,160,32,.06);border-color:var(--accent);color:var(--accent)}

/* ── RESPONSIVE ────────────────────────────── */
@media(max-width:900px){
  :root{--sidebar-w:0px}
  .sidebar{transform:translateX(-240px);transition:.25s}
  .sidebar.open{transform:translateX(0)}
  .topnav{left:0}
  .topnav .menu-toggle{display:flex}
  .page-inner{padding:16px}
  .stat-grid.cols-4{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .kasir-grid{grid-template-columns:1fr}
}
.menu-toggle{display:none;background:none;border:1px solid var(--border);color:var(--muted);padding:7px 10px;border-radius:var(--r);cursor:pointer;font-size:1.1rem}
