/* ============================================================
   Draw Command — Premium Minimal UI
   Palette: warm neutral canvas · obsidian sidebar · emerald accent
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=JetBrains+Mono:wght@500;600&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Warm neutral canvas */
  --bg:#f6f5f2;
  --surface:#ffffff;
  --surface-2:#faf9f6;
  --surface-3:#f1efe9;
  --border:#e9e6df;
  --border-2:#dcd8cf;
  --text:#1b1a17;
  --text-2:#5e584e;
  --text-3:#a09a8d;

  /* Single accent — refined emerald */
  --primary:#0c7a5e;
  --primary-h:#0a6650;
  --primary-press:#085441;
  --primary-soft:#ecfdf6;
  --primary-border:#bbe9d6;

  /* Obsidian sidebar (warm near-black) */
  --sidebar:#1a1916;
  --sidebar-2:#2a2823;
  --sidebar-3:#383530;
  --sidebar-text:#a8a298;
  --sidebar-text-dim:#6f695f;

  /* Semantic (muted, premium) */
  --success:#0c7a5e; --success-soft:#ecfdf6; --success-bd:#bbe9d6;
  --danger:#b4231b;  --danger-soft:#fdf2f1;  --danger-bd:#f3c9c5; --danger-h:#971c15;
  --warning:#a96a10; --warning-soft:#fdf6ec; --warning-bd:#efd9b3;
  --info:#1f6f8b;    --info-soft:#eef6fa;

  /* Login-compat aliases */
  --red:#b4231b; --red-bg:#fdf2f1; --blue:#1f6f8b; --blue-bg:#eef6fa;

  --radius:14px; --radius-sm:10px; --radius-xs:8px;
  --shadow:0 1px 2px rgba(27,26,23,.04), 0 1px 3px rgba(27,26,23,.05);
  --shadow-md:0 10px 34px -14px rgba(27,26,23,.14), 0 3px 8px -4px rgba(27,26,23,.06);
  --shadow-lg:0 24px 60px -20px rgba(27,26,23,.22);
  --ring:0 0 0 3px var(--primary-soft);
  --ease:cubic-bezier(.4,0,.2,1);
  --font:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,'Segoe UI',system-ui,sans-serif;
  --mono:'JetBrains Mono','SF Mono','Consolas',monospace;
}

body{
  font-family:var(--font);font-size:14px;line-height:1.55;
  background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  letter-spacing:-0.006em;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:none;color:var(--primary-h)}
.icon{display:inline-block;vertical-align:middle;flex-shrink:0}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}

/* ───────────────────────── Layout ───────────────────────── */
.panel{display:flex;min-height:100vh}
.sidebar{
  width:248px;background:var(--sidebar);color:var(--sidebar-text);
  display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;
  height:100vh;overflow-y:auto;z-index:100;
}
.sidebar::-webkit-scrollbar{width:0}
.sidebar-logo{display:flex;align-items:center;gap:12px;padding:22px 20px 20px}
.sidebar-logo-icon,.sidebar-logo .logo-mark{
  width:38px;height:38px;border-radius:11px;flex-shrink:0;
  background:linear-gradient(150deg,#13b88a,#0c7a5e 60%,#085441);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:17px;
  box-shadow:0 4px 14px -4px rgba(12,122,94,.6);
}
.sidebar-logo h2,.sidebar-logo .logo-mark + div h2{font-size:15.5px;font-weight:700;color:#f5f3ef;line-height:1.15;letter-spacing:-.02em}
.sidebar-logo span{font-size:11px;color:var(--sidebar-text-dim);font-weight:500}
.sidebar-nav{padding:8px 12px;flex:1}
.nav-section-label{
  display:block;padding:16px 10px 7px;font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.13em;color:var(--sidebar-text-dim);
}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:9px 12px;margin-bottom:2px;
  color:var(--sidebar-text);font-size:13.5px;font-weight:500;border-radius:10px;
  position:relative;transition:background .16s var(--ease),color .16s var(--ease);
}
.nav-item .icon,.nav-icon{color:var(--sidebar-text-dim);transition:color .16s var(--ease)}
.nav-item:hover{background:var(--sidebar-2);color:#f0eee9}
.nav-item:hover .icon,.nav-item:hover .nav-icon{color:#cfcabf}
.nav-item.active{background:linear-gradient(100deg,rgba(12,122,94,.22),rgba(12,122,94,.10));color:#fff;font-weight:600}
.nav-item.active::before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--primary)}
.nav-item.active .icon,.nav-item.active .nav-icon{color:#34d39e}
.sidebar-footer{padding:14px;border-top:1px solid var(--sidebar-2)}
.sidebar-user{display:flex;align-items:center;gap:11px;padding:6px}
.sidebar-avatar{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:var(--sidebar-3);color:#f0eee9;font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;
}
.sidebar-user-info{min-width:0}
.sidebar-user-name{font-size:13px;font-weight:600;color:#f0eee9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sidebar-user-role{font-size:11px;color:var(--sidebar-text-dim);text-transform:capitalize}
.logout-btn{margin-left:auto;color:var(--sidebar-text-dim);padding:8px;border-radius:9px;display:flex;transition:.16s var(--ease)}
.logout-btn:hover{color:#fff;background:var(--sidebar-2)}

.main-content{margin-left:248px;flex:1;display:flex;flex-direction:column;min-height:100vh}
.top-header{
  height:64px;background:rgba(255,255,255,.85);backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;
  padding:0 10px;position:sticky;top:0;z-index:50;
}
.page-title-area h1,.top-header h1{font-size:17px;font-weight:700;letter-spacing:-.02em;color:var(--text)}
.breadcrumb{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px;margin-top:1px;font-weight:500}
.breadcrumb a{color:var(--text-3)}.breadcrumb a:hover{color:var(--text-2)}
.breadcrumb .sep{opacity:.5}
.header-actions{display:flex;align-items:center;gap:10px}
.header-balance{
  display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;
  padding:8px 14px;border:1px solid var(--border);border-radius:11px;background:var(--surface);color:var(--text-2);
}
.header-balance .icon{color:var(--primary)}
.header-balance b{color:var(--text);font-family:var(--mono);font-weight:700}
.menu-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--text-2);padding:6px}
.page-body{padding:28px;max-width:1440px;width:100%}

/* ───────────────────────── Buttons ───────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:9px 16px;font-size:13.5px;font-weight:600;font-family:inherit;
  border:1px solid transparent;border-radius:10px;cursor:pointer;white-space:nowrap;
  transition:transform .12s var(--ease),background .16s var(--ease),border-color .16s,box-shadow .16s;
  letter-spacing:-.01em;
}
.btn:active{transform:translateY(1px) scale(.99)}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 1px 2px rgba(8,84,65,.3),0 4px 12px -4px rgba(12,122,94,.45)}
.btn-primary:hover{background:var(--primary-h);color:#fff}
.btn-secondary{background:var(--surface);color:var(--text-2);border-color:var(--border-2)}
.btn-secondary:hover{background:var(--surface-2);color:var(--text);border-color:var(--text-3)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:var(--danger-h);color:#fff}
.btn-success{background:var(--success);color:#fff}
.btn-ghost{background:transparent;color:var(--text-2)}
.btn-ghost:hover{background:var(--surface-3);color:var(--text)}
.btn-sm{padding:6.5px 12px;font-size:12.5px;border-radius:9px}
.btn-icon{padding:8px;border-radius:9px}
.btn-icon.btn-sm{padding:6.5px}

/* ───────────────────────── Cards / sections ───────────────────────── */
.section-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);margin-bottom:20px;overflow:hidden;
}
.section-header{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 20px;border-bottom:1px solid var(--border)}
.section-header h2{font-size:15px;font-weight:700;letter-spacing:-.02em}
.section-header p{font-size:12.5px;color:var(--text-3);margin-top:2px;font-weight:500}

/* ───────────────────────── Stats ───────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:20px}
.stat-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:20px;display:flex;align-items:center;gap:16px;
  transition:box-shadow .2s var(--ease),transform .2s var(--ease);
}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.stat-ico{
  width:46px;height:46px;border-radius:13px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  background:var(--primary-soft);color:var(--primary);border:1px solid var(--primary-border);
}
.stat-label{font-size:12px;color:var(--text-3);margin-bottom:4px;font-weight:600;letter-spacing:.01em}
.stat-value{font-size:25px;font-weight:800;letter-spacing:-.03em;line-height:1;color:var(--text)}

/* ───────────────────────── Tables ───────────────────────── */
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead th{
  background:var(--surface-2);padding:12px 18px;text-align:left;
  font-size:11px;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.07em;
  border-bottom:1px solid var(--border);white-space:nowrap;
}
thead th.center{text-align:center}thead th.right{text-align:right}
tbody td{padding:13px 18px;font-size:13.5px;border-bottom:1px solid var(--border);vertical-align:middle;color:var(--text-2)}
tbody td.fw-600,tbody td.fw-700{color:var(--text)}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:background .12s var(--ease)}
tbody tr:hover{background:var(--surface-2)}
td.center{text-align:center}td.right{text-align:right}
tfoot td{padding:14px 18px;font-size:13.5px;background:var(--surface-2);font-weight:700;color:var(--text);border-top:2px solid var(--border)}

/* ───────────────────────── Badges ───────────────────────── */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3.5px 10px;border-radius:999px;font-size:11.5px;font-weight:600;line-height:1.45;letter-spacing:-.01em;border:1px solid transparent}
.badge .dot,.badge-dot{width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge-active   {background:var(--success-soft);color:var(--success);border-color:var(--success-bd)}
.badge-inactive {background:var(--surface-3);color:var(--text-3);border-color:var(--border-2)}
.badge-daily    {background:var(--info-soft);color:var(--info);border-color:#cfe4ec}
.badge-biweekly {background:#f3f0fb;color:#6b4ea3;border-color:#e0d8f2}
.badge-admin    {background:var(--danger-soft);color:var(--danger);border-color:var(--danger-bd)}
.badge-distributor{background:var(--info-soft);color:var(--info);border-color:#cfe4ec}
.badge-dealer   {background:var(--success-soft);color:var(--success);border-color:var(--success-bd)}
/* Game types — harmonious, desaturated */
.badge-figure  {background:#f2f1ed;color:#5e584e;border-color:#e2ded5}
.badge-akra    {background:var(--success-soft);color:var(--success);border-color:var(--success-bd)}
.badge-tendola {background:var(--warning-soft);color:var(--warning);border-color:var(--warning-bd)}
.badge-pangora {background:var(--danger-soft);color:var(--danger);border-color:var(--danger-bd)}
.badge-single  {background:var(--info-soft);color:var(--info);border-color:#cfe4ec}
.badge-first   {background:var(--success-soft);color:var(--success);border-color:var(--success-bd)}
.badge-second  {background:var(--warning-soft);color:var(--warning);border-color:var(--warning-bd)}

/* ───────────────────────── Forms ───────────────────────── */
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group:last-child{margin-bottom:0}
.gap-2{gap:8px}
.form-label{font-size:12.5px;font-weight:600;color:var(--text-2);letter-spacing:-.01em}
.required{color:var(--danger)}
.form-control{
  padding:10px 13px;font-size:13.5px;font-family:inherit;color:var(--text);
  border:1px solid var(--border-2);border-radius:10px;background:var(--surface);width:100%;outline:none;
  transition:border-color .16s var(--ease),box-shadow .16s var(--ease);
}
.form-control::placeholder{color:var(--text-3)}
.form-control:focus{border-color:var(--primary);box-shadow:var(--ring)}
.form-control.is-invalid{border-color:var(--danger)}
.form-control.is-invalid:focus{box-shadow:0 0 0 3px var(--danger-soft)}
.form-select{
  appearance:none;cursor:pointer;padding-right:34px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%23a09a8d' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M2 4l4 4 4-4'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;
}
.form-error{font-size:11.5px;color:var(--danger);min-height:15px;display:block;font-weight:500}
.form-hint{font-size:11.5px;color:var(--text-3)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}

/* ───────────────────────── Modal ───────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(27,26,23,.42);backdrop-filter:blur(3px);z-index:200;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex;animation:fade .18s var(--ease)}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{
  background:var(--surface);border:1px solid var(--border);border-radius:18px;
  width:100%;max-width:560px;max-height:92vh;overflow-y:auto;box-shadow:var(--shadow-lg);
  animation:pop .22s var(--ease);
}
@keyframes pop{from{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:none}}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--border)}
.modal-header h3{font-size:16px;font-weight:700;letter-spacing:-.02em}
.modal-close{background:none;border:none;cursor:pointer;color:var(--text-3);padding:6px;border-radius:9px;display:flex;transition:.16s var(--ease)}
.modal-close:hover{background:var(--surface-3);color:var(--text)}
.modal-body{padding:20px}
.modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border);background:var(--surface-2)}

/* ───────────────────────── Toast ───────────────────────── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:999;display:flex;flex-direction:column;gap:10px}
.toast{
  display:flex;align-items:flex-start;gap:11px;background:var(--surface);
  border:1px solid var(--border);border-left:3px solid var(--text-3);border-radius:12px;
  padding:13px 16px;font-size:13.5px;min-width:290px;box-shadow:var(--shadow-md);
  transition:opacity .3s var(--ease);animation:slideIn .3s var(--ease);
}
@keyframes slideIn{from{opacity:0;transform:translateX(16px)}to{opacity:1;transform:none}}
.toast-success{border-left-color:var(--success)}.toast-success .toast-ico{color:var(--success)}
.toast-error{border-left-color:var(--danger)}.toast-error .toast-ico{color:var(--danger)}
.toast-warning{border-left-color:var(--warning)}.toast-warning .toast-ico{color:var(--warning)}
.toast-info{border-left-color:var(--info)}.toast-info .toast-ico{color:var(--info)}
.toast-ico{flex-shrink:0;margin-top:1px}
.toast-msg{flex:1;color:var(--text-2);font-weight:500}
.toast-close{background:none;border:none;cursor:pointer;color:var(--text-3);display:flex;padding:0}
.toast-close:hover{color:var(--text)}

/* ───────────────────────── Filter / bulk bars ───────────────────────── */
.filter-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px 20px;margin-bottom:20px}
.filter-form{display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap}
.filter-group{display:flex;flex-direction:column;gap:6px}
.filter-group .form-control{min-width:160px}
.filter-actions{display:flex;gap:9px}
.bulk-bar{
  display: flex;
  align-items:center;gap:10px;background:var(--primary-soft);
  border:1px solid var(--primary-border);padding:11px 18px;
  font-size:13.5px;font-weight:600;color:var(--primary-h);
}
.bulk-bar span{
  display: flex;
  align-items: center;
  gap: 5px;
}

.bulk-bar span b{
  display: flex;
  align-items: center;
}

/* ───────────────────────── Empty state ───────────────────────── */
.empty-state{padding:56px 20px;text-align:center;color:var(--text-3)}
.empty-ico,.empty-icon{
  width:56px;height:56px;border-radius:16px;margin:0 auto 14px;
  background:var(--surface-3);display:flex;align-items:center;justify-content:center;color:var(--text-3);
}
.empty-title{font-size:15px;font-weight:700;margin-bottom:5px;color:var(--text-2);letter-spacing:-.02em}
.empty-desc{font-size:12.5px;font-weight:500}

/* ───────────────────────── Summary cards ───────────────────────── */
.summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:20px}
.summary-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:18px 20px;position:relative;overflow:hidden;
}
.summary-card::before{content:"";position:absolute;inset:0 0 auto 0;height:3px;background:var(--border-2)}
.summary-card.c-first::before {background:var(--primary)}
.summary-card.c-second::before{background:var(--warning)}
.summary-card.c-sale::before  {background:var(--info)}
.summary-card.c-net::before   {background:var(--success)}
.summary-card.c-com::before   {background:var(--danger)}
.summary-label{font-size:12px;color:var(--text-3);margin-bottom:7px;font-weight:600}
.summary-value{font-size:23px;font-weight:800;letter-spacing:-.03em;color:var(--text)}

/* ───────────────────────── Prize grid ───────────────────────── */
.prize-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:18px;margin-bottom:20px}
.prize-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;transition:box-shadow .2s var(--ease)}
.prize-card:hover{box-shadow:var(--shadow-md)}
.prize-card-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:16px 18px;border-bottom:1px solid var(--border)}
.prize-card-icon{width:36px;height:36px;border-radius:10px;background:var(--primary-soft);color:var(--primary);display:flex;align-items:center;justify-content:center;border:1px solid var(--primary-border)}
.prize-card-name{font-size:14px;font-weight:700;letter-spacing:-.01em}
.prize-fields{display:grid;grid-template-columns:1fr 1fr;gap:14px;padding:16px 18px}
.prize-field .form-label{font-size:11.5px;margin-bottom:5px}
.prize-card-footer{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-top:1px solid var(--border);background:var(--surface-2);font-size:11.5px;color:var(--text-3);font-weight:500}

/* ───────────────────────── Ledger groups ───────────────────────── */
.ledger-group{margin-bottom:20px}
.ledger-group-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--surface);border:1px solid var(--border);border-bottom:none;border-radius:var(--radius) var(--radius) 0 0}
.ledger-group-head h3{font-size:14px;font-weight:700;display:flex;align-items:center;gap:10px;letter-spacing:-.01em}

/* ───────────────────────── Auth / login ───────────────────────── */
.auth-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden;background:var(--bg)}
.auth-bg{position:fixed;inset:0;background:
  radial-gradient(60rem 40rem at 15% -10%, rgba(12,122,94,.10), transparent 60%),
  radial-gradient(50rem 40rem at 110% 110%, rgba(31,111,139,.08), transparent 55%);pointer-events:none}
.auth-grid{position:fixed;inset:0;pointer-events:none;opacity:.5;
  background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:42px 42px;-webkit-mask-image:radial-gradient(ellipse at center,#000,transparent 75%);mask-image:radial-gradient(ellipse at center,#000,transparent 75%)}
.auth-card{position:relative;z-index:1;width:100%;max-width:392px;background:var(--surface);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-lg);padding:36px}
.auth-logo{text-align:center;margin-bottom:26px}
.auth-logo-mark,.login-logo{width:52px;height:52px;border-radius:15px;margin:0 auto 16px;
  background:linear-gradient(150deg,#13b88a,#0c7a5e 60%,#085441);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:22px;
  box-shadow:0 8px 22px -8px rgba(12,122,94,.6)}
.auth-logo h1,.login-title{font-size:21px;font-weight:800;letter-spacing:-.03em;color:var(--text)}
.auth-logo p,.login-sub{font-size:13px;color:var(--text-3);margin-top:3px;font-weight:500}

/* ───────────────────────── Utilities ───────────────────────── */
.text-muted{color:var(--text-3)}.text-xs{font-size:11.5px}.text-sm{font-size:12.5px}
.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-primary{color:var(--primary)}
.text-center{text-align:center}
.fw-600{font-weight:600}.fw-700{font-weight:700}
.flex-center{display:flex;align-items:center;justify-content:center}
.w-full{width:100%}
.big-num{font-family:var(--mono);font-weight:700;font-size:14.5px;color:var(--text);letter-spacing:-.02em}

/* ───────────────────────── Print ───────────────────────── */
@media print{
  .sidebar,.top-header,.no-print,.filter-bar,.bulk-bar,.btn{display:none!important}
  .main-content{margin-left:0!important}
  body,.section-card,.ledger-group{background:#fff!important;box-shadow:none}
  .section-card,.ledger-group,.summary-card{break-inside:avoid;border-color:#ccc}
}

/* ───────────────────────── Responsive ───────────────────────── */
@media(max-width:900px){
  .sidebar{transform:translateX(-248px);transition:transform .24s var(--ease)}
  .sidebar.open{transform:none;box-shadow:var(--shadow-lg)}
  .main-content{margin-left:0}
  .menu-toggle{display:flex}
  .stats-grid,.summary-grid{grid-template-columns:repeat(2,1fr)}
  .form-row,.form-row-3{grid-template-columns:1fr}
  .page-body{padding:18px}
}
@media(max-width:560px){.stats-grid,.summary-grid{grid-template-columns:1fr}}

.display-none{
  display: none;
}

[hidden]{display:none!important}

/* Welcome note */
.welcome-note{margin-bottom:22px}
.welcome-note h2{font-size:22px;font-weight:800;letter-spacing:-.03em;color:var(--text)}
.welcome-note p{font-size:13.5px;color:var(--text-3);margin-top:3px;font-weight:500}
.stat-ico-accent{background:#f0fdf4;color:#16a34a;border-color:#bbf7d0}

.modal-sm{max-width:440px}
.modal-md{max-width:560px}
.time-cell{width:140px;margin:0 auto;text-align:center}
.mb-1{margin-bottom:10px}

/* Flash (login / non-toast contexts) */
.flash{display:flex;align-items:center;gap:10px;padding:11px 14px;margin-bottom:14px;border-radius:11px;font-size:13px;font-weight:500;line-height:1.45;border:1px solid var(--border);border-left:3px solid var(--text-3);background:var(--surface-2);color:var(--text-2)}
.flash-danger {background:var(--danger-soft); border-color:var(--danger-bd); border-left-color:var(--danger); color:var(--danger-h)}
.flash-success{background:var(--success-soft);border-color:var(--success-bd);border-left-color:var(--success);color:var(--primary-press)}
.flash-warning{background:var(--warning-soft);border-color:var(--warning-bd);border-left-color:var(--warning);color:#7a4e0c}
.flash-info   {background:var(--info-soft);   border-color:#cfe4ec;          border-left-color:var(--info);   color:#185465}

/* Login extras */
.remember-row{display:flex;align-items:center;gap:8px; flex-direction: row;}
.remember-row input{width:16px;height:16px;accent-color:var(--primary)}
.remember-row label{font-size:13px;color:var(--text-2);cursor:pointer;font-weight:500}
.btn-block{width:100%;justify-content:center;padding:11px;font-size:14.5px;margin-top:6px}
.captcha-row{display:flex;align-items:flex-end;gap:12px}
.captcha-row .form-control{flex:1;min-width:0}      /* lets the input shrink instead of overflowing */
.captcha-q{
  flex-shrink:0;display:flex;align-items:center;justify-content:center;
  min-width:84px;height:42px;padding:0 14px;
  font-family:var(--mono);font-size:16px;font-weight:700;color:var(--text);
  background:var(--surface-3);border:1px solid var(--border-2);border-radius:10px;
  letter-spacing:.04em;user-select:none;white-space:nowrap;
}


/* ===== Voucher print layout ===== */
.print-voucher{display:none}
@media print{
  @page{size:A4 portrait;margin:12mm}
  body{background:#fff!important}
  .sidebar,.top-header,.no-print,.filter-bar,.bulk-bar{display:none!important}
  .main-content{margin-left:0!important}
  .page-body{padding:0!important;max-width:none!important}

  .print-voucher{display:block;color:#000;font-family:'JetBrains Mono','Consolas',monospace}
  .vc-head,.vc-sub{display:flex;justify-content:space-between;font-size:12px;line-height:1.6}
  .vc-sub{border-bottom:1.5px solid #000;padding-bottom:6px;margin-bottom:4px}
  .vc-slot{display:flex;justify-content:space-between;align-items:center;
    font-weight:700;font-size:12px;background:#eee;border:1px solid #000;
    padding:4px 8px;margin-top:12px;break-after:avoid}
  .vc-table{width:100%;border-collapse:collapse;margin-top:2px}
  .vc-table th{font-size:8.5px;text-transform:uppercase;letter-spacing:.03em;
    padding:3px 5px;border-bottom:1px solid #000;text-align:right}
  .vc-table th:nth-child(3n+1){text-align:left;border-left:1px solid #bbb}
  .vc-table th:first-child{border-left:none}
  .vc-table td{font-size:10.5px;padding:2px 5px;border-bottom:1px dotted #ddd}
  .vc-table td:nth-child(3n+1){text-align:left;font-weight:700;border-left:1px solid #eee}
  .vc-table td:first-child{border-left:none}
  .vc-amt{text-align:right;font-variant-numeric:tabular-nums}
  .vc-table tr{break-inside:avoid}
  .vc-foot{display:flex;justify-content:space-between;font-weight:700;font-size:12px;
    border-top:1.5px solid #000;margin-top:12px;padding-top:6px}
  .vc-pageno{text-align:center;font-size:9px;color:#555;margin-top:6px}
  .vc-empty{padding:20px;text-align:center;font-size:12px}
}

/* ===== Ledger screen (replaces old inline styles) ===== */
.ledger-table-wrap{border:1px solid var(--border);border-top:none}
.ledger-foot{display:flex;flex-wrap:wrap;align-items:center;gap:20px;padding:11px 16px;border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);background:var(--surface-2);font-size:13px}
.ledger-foot .push{margin-left:auto}
.ledger-foot .lg-warn{color:var(--warning)}
.ledger-net-lg{font-size:15px}
.ledger-total-card{margin-top:4px}
.ledger-total-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px}
.ledger-total-row .label{font-weight:700;font-size:15px}
.ledger-total-row .value{font-family:var(--mono);font-weight:700;font-size:22px;color:var(--primary)}

/* ===== Ledger print layout ===== */
.print-ledger{display:none}
@media print{
  @page{size:A4 portrait;margin:11mm}
  .sidebar,.top-header,.no-print,.filter-bar,.bulk-bar{display:none!important}
  .main-content{margin-left:0!important}
  .page-body{padding:0!important;max-width:none!important}
  body{background:#fff!important}

  .print-ledger{display:block;color:#000;font-family:'JetBrains Mono','Consolas',monospace;font-size:10px}
  .lg-head{display:flex;justify-content:space-between;font-size:11px;line-height:1.6}
  .lg-slot{font-weight:700;font-size:11px;margin:2px 0}
  .lg-title{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1.5px solid #000;padding-bottom:4px;margin-bottom:5px;font-weight:800;font-size:13px}
  .lg-title span:last-child{font-weight:400;font-size:10px}
  .lg-dealer{font-size:9.5px;border:1px solid #000;padding:4px 6px;margin-bottom:6px}
  .lg-winhead{font-weight:700;font-size:10px;margin-top:2px}
  .lg-winrow{display:flex;flex-wrap:wrap;gap:16px;font-size:11px;margin:2px 0 8px;border-bottom:1px dotted #999;padding-bottom:6px}
  .lg-group{font-weight:800;font-size:12px;letter-spacing:.06em;margin-top:10px}
  .lg-cols{display:flex;gap:10px;align-items:flex-start}
  .lg-coltable{flex:1;border-collapse:collapse}
  .lg-coltable th{font-size:8px;text-transform:uppercase;letter-spacing:.03em;border-bottom:1px solid #000;padding:2px 4px;text-align:right}
  .lg-coltable th:first-child{text-align:left}
  .lg-coltable td{font-size:10px;padding:1px 4px;border-bottom:1px dotted #e3e3e3}
  .lg-num{font-weight:700}
  .lg-amt{text-align:right;font-variant-numeric:tabular-nums}
  .lg-gfoot{display:flex;flex-wrap:wrap;gap:18px;font-weight:700;font-size:10.5px;border-top:1px solid #000;border-bottom:1px solid #000;padding:4px 2px;margin-top:5px}
  .lg-total{font-weight:800;font-size:14px;text-align:right;border-top:2px solid #000;margin-top:10px;padding-top:6px}
  .lg-pageno{text-align:center;font-size:9px;color:#555;margin-top:6px}
  .lg-group,.lg-cols,.lg-gfoot{break-inside:avoid}
}

/* ===== Booking page layout ===== */
/* .bk-layout{display:grid;grid-template-columns:7fr 3fr;gap:20px;min-height:calc(100vh - 120px)}
.bk-main{display:flex;flex-direction:column;gap:16px;min-width:0}
.bk-side{display:flex;flex-direction:column;min-width:0}
.bk-table-area{flex:1;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.bk-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.bk-search-input{width:180px;padding:7px 10px;font-size:13px}
.bk-toolbar-right{display:flex;align-items:center;gap:10px;margin-left:auto}
.bk-count{font-size:12px;color:var(--text-3);font-weight:500}
.bk-table-wrap{flex:1;overflow-y:auto;max-height:calc(100vh - 275px)}
.bk-table-wrap table{width:100%;border-collapse:collapse}
.bk-table-wrap thead th{position:sticky;top:0;z-index:1;background:var(--surface-2)}
.bk-th-check{width:36px} */

/* Inline booking form */
/* .bk-form-area{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px}
.bk-inline-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.bk-slot-select{width:130px;padding:9px 10px;font-size:13px;flex-shrink:0}
.bk-number-input{width:100px;font-size:16px;font-weight:700;padding:9px 10px;text-align:center;letter-spacing:.06em}
.bk-amt-input{width:90px;padding:9px 10px;font-size:13.5px;text-align:right}
.bk-book-btn{padding:9px 20px;flex-shrink:0}
.bk-paste-btn{padding:9px 14px;flex-shrink:0}
.bk-inline-form .badge{flex-shrink:0}
.bk-error{color:var(--danger);font-size:12px;font-weight:500;margin-top:6px}
.slot-closed{color:var(--danger);font-weight:600} */

/* Right-side tabs */
/* .bk-tabs{display:flex;border-bottom:2px solid var(--border);margin-bottom:0}
.bk-tab{flex:1;padding:10px 6px;font-size:13px;font-weight:600;text-align:center;color:var(--text-3);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.bk-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.bk-tab:hover{color:var(--text)}
.bk-tab-body{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow);padding:16px;flex:1;overflow-y:auto} */

/* Scheme buttons */
/* .scheme-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.scheme-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:12px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer;transition:border-color .15s,background .15s;font-family:inherit}
.scheme-btn:hover{border-color:var(--primary);background:var(--primary-soft)}
.scheme-btn b{font-size:14px;color:var(--text)}
.scheme-btn span{font-size:11px;color:var(--text-3);direction:rtl} */

/* File Scheme */
/* .file-scheme-form{display:flex;flex-direction:column;gap:12px}
.fs-header{text-align:center;font-size:16px;font-weight:700;padding:10px;background:var(--surface-3);border-radius:var(--radius-sm);direction:rtl;color:var(--text)}
.fs-row{display:flex;align-items:center;gap:10px}
.fs-label{font-size:14px;font-weight:700;min-width:50px;text-align:right;direction:rtl;color:var(--text)}
.fs-row .form-control{flex:1}
.fs-amounts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fs-amt{display:flex;flex-direction:column;gap:4px}
.fs-amt label{font-size:13px;font-weight:700;color:var(--text-2);text-align:center}
.fs-amt .form-control{text-align:center} */

/* @media(max-width:1100px){.bk-layout{grid-template-columns:1fr}.bk-side{display:none}}
@media(max-width:640px){.bk-inline-form{flex-wrap:wrap}.bk-slot-select,.bk-number-input,.bk-amt-input{width:100%}} */

/* ===== Booking page ===== */
.bk-layout{display:grid;grid-template-columns:7fr 3fr;gap:20px;min-height:calc(100vh - 120px)}
.bk-main{display:flex;flex-direction:column;gap:16px;min-width:0}
.bk-side{display:flex;flex-direction:column;min-width:0}
.bk-table-area{flex:1;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden}
.bk-toolbar{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap}
.bk-search-input{width:150px;padding:7px 10px;font-size:13px}
.bk-slot-select{width:130px;padding:7px 10px;font-size:13px;flex-shrink:0}
.slot-closed{color:var(--danger)!important}
.slot-timer{font-size:12px;font-weight:700;font-family:var(--mono);padding:5px 9px;border-radius:8px;flex-shrink:0}
.timer-open{background:var(--success-soft);color:var(--success);border:1px solid var(--success-bd)}
.timer-closed{background:var(--danger-soft);color:var(--danger);border:1px solid var(--danger-bd)}
.bk-toolbar-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.bk-count{font-size:12px;color:var(--text-3);font-weight:500;white-space:nowrap}
.bk-table-wrap{flex:1;overflow-y:auto;max-height:calc(100vh - 250px)}
.bk-table-wrap table{width:100%;border-collapse:collapse}
.bk-table-wrap thead th{position:sticky;top:0;z-index:1;background:var(--surface-2)}
.bk-th-check{width:36px}
.bk-form-area{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:14px 16px}
.bk-inline-form{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.bk-number-input{width:90px;font-size:16px;font-weight:700;padding:9px 10px;text-align:center;letter-spacing:.06em}
.bk-amt-input{width:85px;padding:9px 10px;font-size:13.5px;text-align:right}
.bk-book-btn{padding:9px 20px;flex-shrink:0}
.bk-paste-btn{padding:9px 14px;flex-shrink:0}
.bk-inline-form .badge{flex-shrink:0}
.bk-error{color:var(--danger);font-size:12px;font-weight:500;margin-top:6px}

/* Right side tabs */
.bk-tabs{display:flex;border-bottom:2px solid var(--border)}
.bk-tab{flex:1;padding:10px 6px;font-size:13px;font-weight:600;text-align:center;color:var(--text-3);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}
.bk-tab.active{color:var(--primary);border-bottom-color:var(--primary)}
.bk-tab:hover{color:var(--text)}
.bk-tab-body{background:var(--surface);border:1px solid var(--border);border-top:none;border-radius:0 0 var(--radius) var(--radius);box-shadow:var(--shadow);padding:16px;overflow-y:auto;flex: 1;}

/* Scheme tab */
.scheme-form{display:flex;flex-direction:column;gap:8px;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.scheme-amounts{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.scheme-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.scheme-btn{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface-2);cursor:pointer;transition:border-color .15s,background .15s;font-family:inherit}
.scheme-btn:hover{border-color:var(--primary);background:var(--primary-soft)}
.scheme-btn:active{transform:scale(.97)}
.scheme-btn b{font-size:13px;color:var(--text)}
.scheme-btn span{font-size:11px;color:var(--text-3);direction:rtl;text-align:center;line-height:1.3}

/* File Scheme tab */
.file-scheme-form{display:flex;flex-direction:column;gap:12px}
.fs-header{text-align:center;font-size:16px;font-weight:700;padding:10px;background:var(--surface-3);border-radius:var(--radius-sm);direction:rtl}
.fs-row{display:flex;align-items:center;gap:10px}
.fs-label{font-size:14px;font-weight:700;min-width:46px;text-align:right;direction:rtl;flex-shrink:0}
.fs-row .form-control{flex:1}
.fs-amounts{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fs-amt{display:flex;flex-direction:column;gap:4px}
.fs-amt label{font-size:13px;font-weight:700;text-align:center}
.fs-amt .form-control{text-align:center}

/* Shared utilities (add only if not already in your file) */
[hidden]{display:none!important}
.row-actions{display:inline-flex;gap:6px;justify-content:center}
.modal-sm{max-width:440px}
.mb-1{margin-bottom:10px}
.push{margin-left:auto}

/* Paste preview table */
.paste-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:10px}
.paste-table th{background:var(--surface-2);padding:7px 10px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);border-bottom:1px solid var(--border)}
.paste-table th.right{text-align:right}
.paste-table td{padding:6px 10px;border-bottom:1px solid var(--border);vertical-align:middle}
.paste-table tfoot td{padding:8px 10px;background:var(--surface-2);border-top:2px solid var(--border)}
.paste-table td.right{text-align:right}
.paste-row-warn{background:var(--warning-soft)}

@media(max-width:1100px){.bk-layout{grid-template-columns:1fr}.bk-side{display:none}}
@media(max-width:640px){.bk-inline-form{flex-wrap:wrap}.bk-number-input,.bk-amt-input{width:100%}}

/* ===== Mobile viewport — Booking page ===== */
@media(max-width:768px){

  /* Stack layout to single column */
  .bk-layout{grid-template-columns:1fr;gap:12px}
  .bk-side{display:block}

  /* Toolbar: wrap to two rows */
  .bk-toolbar{padding:10px 12px;gap:8px}
  .bk-search-input{width:100%;flex:1;min-width:0}
  .bk-slot-select{width:100%;flex:1;min-width:0}
  .slot-timer{font-size:11px;padding:4px 7px}
  .bk-toolbar-right{width:100%;justify-content:flex-end}

  /* Bulk bar */
  .bulk-bar{padding:8px 12px;font-size:12.5px;flex-wrap:wrap;gap:8px}

  /* Table: smaller text, hide less important columns */
  .bk-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .bk-table-wrap table{min-width:480px}
  .bk-table-wrap thead th{font-size:10px;padding:8px 6px}
  .bk-table-wrap tbody td{font-size:12px;padding:7px 6px}
  .big-num{font-size:13px}

  /* Booking form: stack vertically */
  .bk-form-area{padding:12px}
  .bk-inline-form{flex-direction:column;align-items:stretch;gap:8px}
  .bk-number-input{width:100%;font-size:18px;text-align:left}
  .bk-amt-input{width:100%;text-align:left}
  .bk-book-btn{width:100%;justify-content:center}
  .bk-paste-btn{width:100%;justify-content:center}
  .bk-inline-form .badge{align-self:flex-start}

  /* Tabs: full width */
  .bk-tabs{margin-top:4px}
  .bk-tab{font-size:12.5px;padding:9px 4px}
  .bk-tab-body{max-height:none;padding:14px 12px}

  /* Scheme buttons: 2 per row */
  .scheme-grid{grid-template-columns:1fr 1fr;gap:8px}
  .scheme-btn{padding:10px 6px}
  .scheme-btn span{font-size:10px}

  /* File scheme */
  .fs-label{min-width:40px;font-size:12px}

  /* Summary grid on voucher/ledger: 2 cols */
  .summary-grid{grid-template-columns:1fr 1fr}

  /* Modals: full width */
  .modal{max-width:100%;border-radius:14px 14px 0 0;position:fixed;bottom:0;left:0;right:0;top:auto;max-height:90vh}
  .modal-overlay{align-items:flex-end;padding:0}
}

@media(max-width:400px){
  .scheme-grid{grid-template-columns:1fr}
  .bk-table-wrap thead th:nth-child(4),
  .bk-table-wrap tbody td:nth-child(4){display:none} /* hide 2nd amt col on very small */
}