/* ═══════════════════════════════════════════════════
   PHONE WORLD DUNSTABLE — POS System
   Theme: Light mode, Navy + Crimson Red brand colours
   Brand: #c0272d (red), #1e2a3a (navy), #ffffff (white)
═══════════════════════════════════════════════════ */
:root{
  --navy:    #1e2a3a;
  --navy2:   #263447;
  --red:     #c0272d;
  --red2:    #a01f24;
  --red-lt:  #fdf0f0;
  --red-mid: #f5c5c6;
  --surface: #ffffff;
  --surface2:#f4f6f9;
  --surface3:#e8ecf2;
  --border:  #d1d8e4;
  --border2: #b8c2d4;
  --text:    #1a2332;
  --text2:   #4a5568;
  --text3:   #8a96a8;
  --accent:  #c0272d;
  --green:   #16a34a;
  --green2:  #15803d;
  --lgreen:  #f0fdf4;
  --orange:  #ea580c;
  --lorange: #fff7ed;
  --yellow:  #ca8a04;
  --lyellow: #fefce8;
  --purple:  #7c3aed;
  --pink:    #db2777;
  --white:   #ffffff;
  --shadow:  0 1px 3px rgba(0,0,0,.08), 0 2px 8px rgba(0,0,0,.06);
  --shadow2: 0 4px 16px rgba(0,0,0,.10);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'DM Sans',sans-serif;background:var(--surface2);color:var(--text);min-height:100vh;}

/* ── LOGIN ──────────────────────────────────────── */
.login-screen{display:none;position:fixed;inset:0;background:var(--navy);z-index:2000;align-items:center;justify-content:center;flex-direction:column;}
.login-screen.show{display:flex;}
.login-box{background:#fff;border-radius:16px;padding:40px;width:380px;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.login-logo{text-align:center;margin-bottom:28px;}
.login-logo .icon{width:56px;height:56px;background:var(--red);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;margin:0 auto 12px;}
.login-logo-img{display:block;width:100%;max-width:300px;height:auto;margin:0 auto 10px;}
.login-logo h1{font-family:'Rajdhani',sans-serif;font-size:26px;font-weight:700;color:var(--navy);}
.login-logo h1 span{color:var(--red);}
.login-logo p{font-size:13px;color:var(--text2);margin-top:3px;}
.login-field{margin-bottom:16px;}
.login-field label{display:block;font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:5px;font-family:'Rajdhani',sans-serif;}
.login-field input{width:100%;background:#f8fafc;border:1.5px solid var(--border);border-radius:8px;padding:11px 13px;color:var(--text);font-size:14px;font-family:'DM Sans',sans-serif;outline:none;transition:border-color .15s;}
.login-field input:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,39,45,.1);}
.login-btn{width:100%;padding:12px;background:var(--red);color:#fff;border:none;border-radius:9px;font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;letter-spacing:1px;cursor:pointer;margin-top:4px;transition:all .15s;}
.login-btn:hover{background:var(--red2);}
.login-err{color:var(--red);font-size:12px;margin-top:8px;text-align:center;min-height:18px;}

/* ── APP ────────────────────────────────────────── */
.app{display:none;}
.app.show{display:block;}

/* ── TOPBAR ─────────────────────────────────────── */
.topbar{background:#fff;border-bottom:3px solid var(--red);padding:0 18px;display:flex;align-items:center;justify-content:space-between;height:62px;position:sticky;top:0;z-index:100;box-shadow:0 2px 10px rgba(0,0,0,.08);}
.logo{font-family:'Rajdhani',sans-serif;font-size:21px;font-weight:700;color:var(--navy);letter-spacing:1px;display:flex;align-items:center;gap:9px;}
.logo span{color:var(--red);}
.logo-icon{width:34px;height:34px;background:var(--red);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:17px;}
.logo-img{height:44px;width:auto;display:block;}
.topbar-right{display:flex;align-items:center;gap:8px;}
#today-date,#clock{color:var(--text2);font-size:12px;font-weight:600;font-family:'Rajdhani',sans-serif;}
#clock{color:var(--red);font-weight:600;font-family:'DM Mono',monospace;font-size:12px;}
#today-date{color:#8bafd4;font-size:11px;font-family:'DM Mono',monospace;}
.emp-badge{background:var(--surface2);border:1px solid var(--border);border-radius:20px;padding:4px 12px;font-size:12px;color:var(--text);font-family:'Rajdhani',sans-serif;font-weight:600;}
.emp-badge span{color:var(--red);}

/* ── SIDEBAR ─────────────────────────────────────── */
.layout{display:flex;min-height:calc(100vh - 58px);}
.sidebar{width:210px;background:var(--surface2);border-right:1px solid var(--border);padding:14px 0;flex-shrink:0;overflow-y:auto;}
.nav-section{padding:10px 16px 3px;font-size:9px;font-weight:700;color:var(--text3);letter-spacing:2px;text-transform:uppercase;font-family:'Rajdhani',sans-serif;}
.nav-btn{display:flex;align-items:center;gap:9px;padding:9px 18px;cursor:pointer;color:var(--text2);font-size:13px;font-weight:500;border:none;background:none;width:100%;text-align:left;border-left:3px solid transparent;transition:all .12s;font-family:'DM Sans',sans-serif;}
.nav-btn:hover{background:var(--surface3);color:var(--text);}
.nav-btn.active{background:var(--red);color:#fff;border-left-color:var(--red2);font-weight:700;}
.ni{font-size:14px;width:18px;text-align:center;}
.main{flex:1;padding:22px;overflow-y:auto;background:var(--surface2);}

/* ── PAGES ──────────────────────────────────────── */
.page{display:none;}.page.active{display:block;animation:fi .18s ease;}
@keyframes fi{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;}
.page-title{font-family:'Rajdhani',sans-serif;font-size:23px;font-weight:700;color:var(--navy);}
.page-title span{color:var(--red);}
.page-sub{font-size:12px;color:var(--text2);margin-top:2px;}

/* ── CARDS ──────────────────────────────────────── */
.card{background:#fff;border:1px solid var(--border);border-radius:10px;padding:18px;margin-bottom:14px;box-shadow:var(--shadow);}
.ct{font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;color:var(--red);letter-spacing:1px;text-transform:uppercase;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--border);display:flex;align-items:center;gap:6px;}

/* ── FORMS ──────────────────────────────────────── */
.fg{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.fg.c3{grid-template-columns:1fr 1fr 1fr;}
.fg.c4{grid-template-columns:1fr 1fr 1fr 1fr;}
.fw{grid-column:1/-1;}
.fgroup{display:flex;flex-direction:column;gap:4px;}
.flabel{font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;font-family:'Rajdhani',sans-serif;}
.req{color:var(--red);margin-left:2px;}
input[type=text],input[type=number],input[type=tel],input[type=search],input[type=password],input[type=email],select,textarea{background:#fff;border:1.5px solid var(--border);border-radius:7px;padding:8px 10px;color:var(--text);font-size:13px;font-family:'DM Sans',sans-serif;transition:border-color .12s;outline:none;width:100%;}
input:focus,select:focus,textarea:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,39,45,.08);}
select option{background:#fff;color:var(--text);}
textarea{resize:vertical;}
.iro{background:var(--surface2);border-color:var(--border2);color:var(--red);font-family:'DM Mono',monospace;font-weight:700;cursor:default;}
.ipriv{background:#fdf5ff;border-color:#e9d5ff;color:#7c3aed;}
.itotal{background:#f0fdf4;border-color:#86efac;color:var(--green);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;text-align:right;}
.idue{background:var(--lorange);border-color:#fdba74;color:var(--orange);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;text-align:right;}
.ipaid{background:#eff6ff;border-color:#93c5fd;color:#1d4ed8;font-family:'DM Mono',monospace;font-size:14px;font-weight:600;text-align:right;}
/* Checkboxes */
input[type=checkbox]{width:14px;height:14px;accent-color:var(--red);cursor:pointer;}

/* Remove spinners */
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0;}
input[type=number]{-moz-appearance:textfield;appearance:textfield;}

/* ── BUTTONS ─────────────────────────────────────── */
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px;}
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;font-family:'Rajdhani',sans-serif;font-size:13px;font-weight:700;letter-spacing:.7px;cursor:pointer;border:none;transition:all .12s;text-transform:uppercase;}
.btn:hover{transform:translateY(-1px);filter:brightness(.95);}
.btn:active{transform:translateY(0);}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--navy2);}
.btn-success{background:var(--green2);color:#fff;}
.btn-danger{background:var(--red);color:#fff;}
.btn-warning{background:var(--orange);color:#fff;}
.btn-pink{background:var(--pink);color:#fff;}
.btn-print{background:var(--navy);color:#fff;border:2px solid var(--red);}
.btn-new{background:var(--surface2);color:var(--text2);border:1.5px solid var(--border);}
.btn-export{background:var(--lgreen);color:var(--green2);border:1.5px solid #86efac;}
.btn-import{background:#eff6ff;color:#1d4ed8;border:1.5px solid #93c5fd;}
.btn-report{background:#faf5ff;color:var(--purple);border:1.5px solid #c4b5fd;}
.btn-lg{padding:11px 24px;font-size:14px;}

/* ── PAY TOGGLE ─────────────────────────────────── */
.pay-toggle{display:flex;border-radius:8px;overflow:hidden;border:1.5px solid var(--border);width:fit-content;}
.po{padding:8px 16px;cursor:pointer;font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;letter-spacing:.5px;border:none;background:var(--surface2);color:var(--text2);transition:all .12s;border-right:1px solid var(--border);}
.po:last-child{border-right:none;}
.po:hover{color:var(--text);}
.po.ac{background:#fff0f0;color:var(--red);border-bottom:2px solid var(--red);}
.po.acard{background:#eff6ff;color:#1d4ed8;border-bottom:2px solid #1d4ed8;}
.po.asplit{background:#faf5ff;color:var(--purple);border-bottom:2px solid var(--purple);}
.po.aunpaid{background:#fffbeb;color:var(--yellow);border-bottom:2px solid var(--yellow);}

/* ── STATUS BADGES ──────────────────────────────── */
.badge{display:inline-block;padding:3px 10px;border-radius:5px;font-size:11px;font-weight:700;font-family:'Rajdhani',sans-serif;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;}
.b-Pending{background:#fefce8;color:#854d0e;border:1px solid #fde68a;}
.b-In-Progress{background:#eff6ff;color:#1d4ed8;border:1px solid #93c5fd;}
.b-Awaiting-Parts{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa;}
.b-Ready-for-Collection{background:#f0fdf4;color:#166534;border:1px solid #86efac;}
.b-Collected{background:#f0fdf4;color:#15803d;border:1px solid #4ade80;}
.b-Cancelled{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5;}
.b-Cash{background:#f0fdf4;color:#166534;border:1px solid #86efac;}
.b-Card{background:#eff6ff;color:#1d4ed8;border:1px solid #93c5fd;}
.b-Split{background:#faf5ff;color:#6d28d9;border:1px solid #c4b5fd;}
.b-Unpaid{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5;}
.b-Partial{background:#fffbeb;color:#92400e;border:1px solid #fcd34d;}
.po.apartial{background:#fffbeb;color:#92400e;border-bottom:2px solid #fcd34d;}
.ss-Pending{background:#fefce8;color:#854d0e;}
.ss-In-Progress{background:#eff6ff;color:#1d4ed8;}
.ss-Awaiting-Parts{background:#fff7ed;color:#9a3412;}
.ss-Ready-for-Collection{background:#f0fdf4;color:#166534;}
.ss-Collected{background:#dcfce7;color:#15803d;}
.ss-Cancelled{background:#fef2f2;color:#991b1b;}
.status-select{border:1px solid var(--border);font-size:11px;font-family:'Rajdhani',sans-serif;font-weight:700;cursor:pointer;padding:3px 6px;outline:none;border-radius:5px;min-width:130px;}
.status-select.ss-Pending{background:#fefce8;color:#854d0e;}
.status-select.ss-In-Progress{background:#eff6ff;color:#1d4ed8;}
.status-select.ss-Awaiting-Parts{background:#fff7ed;color:#9a3412;}
.status-select.ss-Ready-for-Collection{background:#f0fdf4;color:#166534;}
.status-select.ss-Collected{background:#dcfce7;color:#15803d;}
.status-select.ss-Cancelled{background:#fef2f2;color:#991b1b;}
/* Force dropdown options to light theme */
/* Order / Return / RMA statuses */
.ss-Ordered,.status-select.ss-Ordered{background:#eff6ff;color:#1d4ed8;}
.ss-Partially-Received,.status-select.ss-Partially-Received{background:#fff7ed;color:#9a3412;}
.ss-Completed,.status-select.ss-Completed{background:#f0fdf4;color:#166534;}
.ss-Approved,.status-select.ss-Approved{background:#eff6ff;color:#1d4ed8;}
.ss-Refunded,.status-select.ss-Refunded{background:#dcfce7;color:#15803d;}
.ss-Rejected,.status-select.ss-Rejected{background:#fef2f2;color:#991b1b;}
.ss-Exchanged,.status-select.ss-Exchanged{background:#f5f3ff;color:#6d28d9;}
.ss-Replaced,.status-select.ss-Replaced{background:#f5f3ff;color:#6d28d9;}
.status-select option{background:#fff;color:var(--text);font-family:'DM Sans',sans-serif;}

/* ── TABLES ─────────────────────────────────────── */
.dt{width:100%;border-collapse:collapse;font-size:13px;}
.dt th{background:var(--navy);color:#fff;font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:10px 12px;text-align:left;border-bottom:none;}
.dt td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle;font-size:13px;background:#fff;}
.dt tr:hover td{background:var(--surface2);}
.dt tr.row-due td{background:#fff5f5;}
.dt tr.row-due:hover td{background:#fee2e2;}
.due-blink{animation:dueblink 2s ease-in-out infinite;font-weight:700;}
@keyframes dueblink{0%,100%{color:var(--red);}50%{color:#fca5a5;}}
.ta{background:#fff;border:1px solid var(--border);cursor:pointer;color:var(--navy);font-size:13px;padding:5px 8px;border-radius:6px;transition:all .1s;margin:1px;line-height:1;box-shadow:0 1px 1px rgba(0,0,0,.04);}
.ta:hover{background:var(--surface2);border-color:var(--border2);}
.ta.del{color:var(--red);border-color:var(--red-mid);}
.ta.del:hover{background:var(--red-lt);}
/* keep a row's action buttons together as a neat group */
.dt td:last-child{white-space:nowrap;}

/* ── KPI CARDS ──────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:13px;margin-bottom:16px;}
.kpi-grid.c5{grid-template-columns:repeat(5,1fr);}
.kc{background:#fff;border:1px solid var(--border);border-radius:10px;padding:16px;position:relative;overflow:hidden;box-shadow:var(--shadow);}
.kc::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;}
.kc.blue::before{background:var(--navy);}
.kc.green::before{background:var(--green);}
.kc.orange::before{background:var(--orange);}
.kc.accent::before{background:var(--red);}
.kc.purple::before{background:var(--purple);}
.kc.red::before{background:var(--red);}
.kc.pink::before{background:var(--pink);}
.kc.yellow::before{background:var(--yellow);}
.kl{font-size:10px;color:var(--text2);font-weight:700;letter-spacing:.8px;text-transform:uppercase;font-family:'Rajdhani',sans-serif;}
.kv{font-family:'Rajdhani',sans-serif;font-size:26px;font-weight:700;color:var(--navy);margin:4px 0 2px;}
.ks{font-size:10px;color:var(--text3);}

/* ── SEARCH BAR ─────────────────────────────────── */
.sbar{display:flex;gap:8px;margin-bottom:12px;align-items:center;}
.sbar input{max-width:280px;}

/* ── ITEMS TABLE (sale) ─────────────────────────── */
.it{width:100%;border-collapse:collapse;font-size:12px;}
.it th{background:var(--navy);color:#fff;font-size:10px;font-family:'Rajdhani',sans-serif;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:7px 8px;text-align:left;}
.it td{padding:4px 5px;border-bottom:1px solid var(--border);vertical-align:middle;background:#fff;}
.it input,.it select{padding:6px 8px;font-size:12px;}
.rm-btn{background:var(--red);border:none;color:#fff;border-radius:5px;cursor:pointer;padding:4px 8px;font-size:12px;line-height:1;}
.rm-btn:hover{background:var(--red2);}

/* ── PARTS ROW ──────────────────────────────────── */
.parts-row{display:flex;gap:7px;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);font-size:12px;}
.parts-row:last-child{border-bottom:none;}

/* ── SCAN / BARCODE ─────────────────────────────── */
.barcode-row{display:flex;gap:7px;align-items:center;margin-bottom:7px;}
.barcode-row input{flex:1;}
.scan-btn{padding:7px 12px;background:var(--navy);color:#fff;border:none;border-radius:7px;font-size:12px;cursor:pointer;white-space:nowrap;transition:all .12s;font-family:'Rajdhani',sans-serif;font-weight:700;}
.scan-btn:hover{background:var(--red);}

/* ── DIVIDER ─────────────────────────────────────── */
.divider{border:none;border-top:1px solid var(--border);margin:13px 0;}

/* ── EMPTY STATE ─────────────────────────────────── */
.empty{text-align:center;padding:32px;color:var(--text3);font-size:13px;}

/* ── STOCK TAGS ─────────────────────────────────── */
.tag-low{background:#fff7ed;color:#c2410c;border:1px solid #fed7aa;border-radius:5px;padding:2px 7px;font-size:10px;font-family:'Rajdhani',sans-serif;font-weight:700;}
.tag-out{background:#fef2f2;color:#991b1b;border:1px solid #fca5a5;border-radius:5px;padding:2px 7px;font-size:10px;font-family:'Rajdhani',sans-serif;font-weight:700;}

/* ── MODALS ─────────────────────────────────────── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(30,42,58,.6);z-index:999;align-items:center;justify-content:center;}
.modal-overlay.open{display:flex;}

/* ── 80mm RECEIPT (browser preview) ─────────────── */
.modal-receipt{background:#fff;color:#000;border-radius:10px;width:330px;max-height:92vh;overflow-y:auto;padding:0;box-shadow:0 20px 60px rgba(0,0,0,.3);}
.rw{width:100%;margin:0 auto;padding:12px 10px;font-family:'Courier New',Courier,monospace;font-size:12px;line-height:1.55;color:#000;background:#fff;-webkit-font-smoothing:none;font-smooth:never;}
.rh{text-align:center;padding-bottom:8px;margin-bottom:8px;border-bottom:3px solid #000;}
.rlogo{display:block;max-width:80%;max-height:70px;width:auto;margin:0 auto 6px;object-fit:contain;}
.rhs{font-size:18px;font-weight:900;letter-spacing:2px;font-family:'Courier New',monospace;text-transform:uppercase;color:#000;}
.rhsub{font-size:10px;color:#000;margin-top:2px;font-weight:600;}
.rht{font-size:12px;font-weight:900;margin-top:5px;letter-spacing:4px;text-transform:uppercase;color:#000;}
.rdiv{border:none;border-top:2px dotted #000;margin:7px 0;}
.rdiv-bold{border:none;border-top:3px solid #000;margin:6px 0;}
.rsim{text-align:center;font-size:11px;font-weight:800;color:#000;font-family:'Courier New',monospace;padding:3px 2px;line-height:1.4;}
.rjob{font-size:14px;font-weight:900;color:#000;font-family:'Courier New',monospace;letter-spacing:1px;padding:2px 0;}
.rcollected{font-size:12px;font-weight:800;color:#000;font-family:'Courier New',monospace;padding:1px 0 2px;}
.rfaultbox{border:2px solid #000;border-radius:4px;padding:5px 8px;margin:4px 0;font-size:12px;font-weight:700;color:#000;font-family:'Courier New',monospace;word-break:break-word;}
.rdisc{font-size:9.5px;line-height:1.5;color:#000;font-family:'Courier New',monospace;text-align:justify;margin-top:6px;padding-top:6px;border-top:2px dotted #000;font-weight:600;}
.rkv{display:flex;justify-content:space-between;font-size:12px;padding:2px 0;font-family:'Courier New',monospace;}
.rkv .k{color:#000;font-weight:600;}
.rkv .v{font-weight:800;text-align:right;max-width:170px;word-break:break-word;color:#000;}
.rst{font-size:10px;font-weight:900;letter-spacing:2px;text-transform:uppercase;color:#000;margin:7px 0 3px;border-bottom:2px solid #000;padding-bottom:2px;}
.ri{font-size:12px;padding:2px 0;font-family:'Courier New',monospace;}
.ri-d{font-weight:800;color:#000;}
.ri-l{display:flex;justify-content:space-between;}
.ri-s{color:#000;font-size:11px;font-weight:600;}
.rmn{display:flex;justify-content:space-between;font-size:12px;padding:2px 0;font-family:'Courier New',monospace;font-weight:600;color:#000;}
.rtot{display:flex;justify-content:space-between;font-size:15px;font-weight:900;padding:5px 0 3px;border-top:3px solid #000;border-bottom:1px solid #000;margin-top:4px;font-family:'Courier New',monospace;color:#000;}
.rdue{display:flex;justify-content:space-between;font-size:13px;font-weight:900;padding:3px 0;font-family:'Courier New',monospace;color:#000;}
.rft{text-align:center;font-size:11px;color:#000;margin-top:8px;padding-top:8px;border-top:1px dashed #000;line-height:1.8;font-family:'Courier New',monospace;font-weight:600;}
.mbtns{display:flex;gap:8px;padding:10px;background:var(--surface2);border-top:1px solid var(--border);border-radius:0 0 10px 10px;}
.mbtn{flex:1;padding:9px;border-radius:7px;font-weight:700;cursor:pointer;font-family:'Rajdhani',sans-serif;font-size:13px;letter-spacing:.5px;border:none;}
.mbtn.print{background:var(--navy);color:#fff;}
.mbtn.cls{background:var(--surface3);color:var(--text2);}

/* ── PREVIEW MODAL ──────────────────────────────── */
.preview-modal-box{background:#fff;border:2px solid var(--red);border-radius:14px;width:700px;max-height:95vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow2);}
.preview-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:var(--navy);border-bottom:3px solid var(--red);border-radius:12px 12px 0 0;flex-shrink:0;}
.preview-title{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:#fff;letter-spacing:1px;}
.pv-shop{text-align:center;padding:14px;background:var(--navy);border-bottom:2px solid var(--red);margin-bottom:12px;border-radius:8px;}
.pv-shop-name{font-family:'Rajdhani',sans-serif;font-size:20px;font-weight:700;color:#fff;letter-spacing:2px;}
.pv-shop-type{font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:600;color:var(--red);letter-spacing:3px;margin-top:4px;}
.pv-section{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:12px 14px;margin-bottom:10px;}
.pv-section-title{font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;color:var(--red);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--border);}
.pv-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px;border-bottom:1px solid rgba(209,216,228,.5);}
.pv-row:last-child{border-bottom:none;}
.pv-key{color:var(--text2);font-size:12px;}
.pv-val{color:var(--text);font-weight:600;text-align:right;max-width:280px;word-break:break-word;}
.pv-val.mono{font-family:'DM Mono',monospace;}
.pv-val.accent{color:var(--red);font-family:'DM Mono',monospace;}
.pv-val.yellow{color:var(--yellow);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;}
.pv-val.green{color:var(--green);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;}
.pv-val.orange{color:var(--orange);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;}
.pv-val.red{color:var(--red);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;}
.pv-val.pink{color:var(--pink);font-family:'DM Mono',monospace;font-size:15px;font-weight:700;}
.pv-total-box{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--navy);border-radius:8px;margin-bottom:10px;}
.pv-total-label{font-family:'Rajdhani',sans-serif;font-size:16px;font-weight:700;color:#fff;}
.pv-total-val{font-family:'Rajdhani',sans-serif;font-size:22px;font-weight:700;color:var(--red);}
.pv-due-box{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;margin-bottom:10px;font-family:'Rajdhani',sans-serif;font-weight:700;}
.pv-change-box{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;background:var(--lgreen);border:1px solid #86efac;border-radius:8px;margin-bottom:10px;font-family:'Rajdhani',sans-serif;font-weight:700;}
.pv-item{display:flex;justify-content:space-between;align-items:flex-start;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px;}
.pv-item:last-child{border-bottom:none;}
.pv-item-desc{color:var(--text);font-weight:600;}
.pv-item-sub{color:var(--text2);font-size:11px;margin-top:2px;}
.pv-item-total{color:var(--red);font-family:'DM Mono',monospace;font-weight:700;white-space:nowrap;margin-left:8px;}

/* ── STOCK MODAL ─────────────────────────────────── */
.sk-modal{background:#fff;border:1px solid var(--border);border-radius:12px;width:490px;max-height:90vh;overflow-y:auto;padding:22px;box-shadow:var(--shadow2);}
.emp-modal{background:#fff;border:1px solid var(--border);border-radius:12px;width:420px;max-height:90vh;overflow-y:auto;padding:22px;box-shadow:var(--shadow2);}
.report-modal{background:#fff;border:1px solid var(--border);border-radius:12px;width:680px;max-height:95vh;overflow-y:auto;padding:22px;box-shadow:var(--shadow2);}

/* ── SCAN OVERLAY ────────────────────────────────── */
.scan-overlay{display:none;position:fixed;inset:0;background:rgba(30,42,58,.85);z-index:1100;align-items:center;justify-content:center;}
.scan-overlay.open{display:flex;}
.scan-box{background:#fff;border:3px solid var(--red);border-radius:14px;padding:28px;width:380px;text-align:center;}
.scan-box h3{font-family:'Rajdhani',sans-serif;font-size:20px;color:var(--red);margin-bottom:12px;}
.scan-box input{font-size:18px;text-align:center;letter-spacing:3px;padding:12px;font-family:'DM Mono',monospace;}

/* ── TOAST ───────────────────────────────────────── */
#toast{position:fixed;bottom:18px;right:18px;background:var(--green2);color:#fff;padding:10px 18px;border-radius:8px;font-weight:700;font-size:13px;display:none;z-index:9999;box-shadow:var(--shadow2);}
#toast.err{background:var(--red);}

/* ── SPINNER ─────────────────────────────────────── */
.sp{display:inline-block;width:12px;height:12px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;margin-right:5px;}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── REPORT ──────────────────────────────────────── */
.report-section-toggle{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px;}
.rst-btn{padding:6px 14px;border-radius:20px;font-family:'Rajdhani',sans-serif;font-size:12px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--text2);transition:all .12s;}
.rst-btn.on{background:var(--red);color:#fff;border-color:var(--red);}
.date-preset{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:10px;}
.dp-btn{padding:5px 12px;border-radius:6px;font-family:'Rajdhani',sans-serif;font-size:11px;font-weight:700;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--text2);transition:all .12s;}
.dp-btn:hover{border-color:var(--red);color:var(--red);}
.pdf-frame{width:100%;height:500px;border:1px solid var(--border);border-radius:6px;}

/* ── MOBILE RESPONSIVE ───────────────────────────── */
.mob-menu-btn{display:none;background:none;border:none;color:#fff;font-size:22px;cursor:pointer;padding:4px 8px;line-height:1;}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(30,42,58,.5);z-index:98;}
.sidebar-overlay.open{display:block;}
.dash-two-col{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:0;}

@media(max-width:768px){
  .topbar{padding:0 12px;height:50px;}
  .mob-menu-btn{display:block;}
  #today-date{display:none;}
  .emp-badge{display:none;}
  .topbar-right .btn{display:none;}
  .topbar-right .btn-report{display:inline-flex;padding:4px 8px;font-size:10px;}
  .sidebar{position:fixed;top:50px;left:0;height:calc(100vh - 50px);z-index:99;transform:translateX(-100%);transition:transform .25s ease;width:220px;}
  .sidebar.open{transform:translateX(0);}
  .layout{flex-direction:column;}
  .main{padding:12px;}
  .kpi-grid{grid-template-columns:1fr 1fr!important;gap:8px;}
  .fg.c3,.fg.c4{grid-template-columns:1fr 1fr!important;}
  .fg{grid-template-columns:1fr!important;}
  .dash-two-col{display:block!important;}
  .dash-two-col > .card{margin-bottom:12px;}
  .card[style*="padding:0"]{overflow-x:auto!important;}
  .dt{min-width:600px;}
  .it{min-width:500px;}
  .btn-row{gap:5px;}
  .btn{padding:9px 12px;font-size:12px;}
  .btn-lg{padding:10px 16px;font-size:13px;}
  .page-header{flex-direction:column;align-items:flex-start;gap:8px;}
  .sk-modal,.emp-modal,.report-modal,.preview-modal-box{width:95vw!important;padding:16px!important;}
  .modal-receipt{width:95vw!important;}
  .report-modal .pdf-frame{height:360px!important;}
  .login-box{width:92vw;padding:24px 18px;}
  .scan-box{width:92vw;padding:20px 16px;}
  input[type=text],input[type=number],input[type=tel],input[type=search],input[type=password],select,textarea{font-size:16px!important;}
}
@media(max-width:420px){
  .kpi-grid{grid-template-columns:1fr 1fr!important;}
  .kv{font-size:18px;}
  .page-title{font-size:18px;}
}

/* ── PRINT (80mm thermal) ────────────────────────── */
@media print{
  @page{margin:0;size:80mm auto;}
  body *{visibility:hidden!important;}
  #receipt-modal,#receipt-modal *{visibility:visible!important;}
  #receipt-modal{position:fixed!important;inset:0!important;background:white!important;display:flex!important;align-items:flex-start!important;justify-content:center!important;padding:0!important;margin:0!important;}
  .modal-receipt{box-shadow:none!important;border-radius:0!important;width:80mm!important;max-height:none!important;overflow:visible!important;border:none!important;}
  .rw{width:76mm!important;padding:2mm 2mm!important;font-size:10pt!important;line-height:1.4!important;-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important;color-adjust:exact!important;font-family:'Courier New',Courier,monospace!important;-webkit-font-smoothing:none!important;font-smooth:never!important;color:#000!important;}
  .rhs{font-size:14pt!important;font-weight:900!important;}
  .rhsub{font-size:9pt!important;}
  .rht{font-size:10pt!important;}
  .rkv{font-size:9pt!important;padding:1pt 0!important;}
  .rkv .k{font-weight:700!important;}
  .rkv .v{font-weight:900!important;}
  .rmn{font-size:9pt!important;}
  .rtot{font-size:13pt!important;font-weight:900!important;}
  .rdue{font-size:11pt!important;font-weight:900!important;}
  .rst{font-size:8pt!important;}
  .ri{font-size:9pt!important;}
  .ri-d{font-weight:900!important;}
  .rft{font-size:8pt!important;}
  .rdiv{border-top:2px dotted #000!important;}
  .rdiv-bold{border-top:3px solid #000!important;}
  .rsim{font-size:8.5pt!important;font-weight:800!important;}
  .rjob{font-size:11pt!important;font-weight:900!important;}
  .rcollected{font-size:9pt!important;font-weight:800!important;}
  .rfaultbox{border:1.5px solid #000!important;font-size:8.5pt!important;}
  .rdisc{font-size:7pt!important;line-height:1.4!important;border-top:2px dotted #000!important;}
  .mbtns{display:none!important;}
  *{color:#000!important;border-color:#000!important;}
}

/* Delete controls are admin-only. Server also enforces this. */
body:not(.is-admin) .admin-del,
body:not(.is-admin) .ta.del{display:none!important;}

/* Admin-only blocks (e.g. monthly dashboard KPIs) */
body:not(.is-admin) .admin-only{display:none!important;}

/* Bigger checkbox/radio option chips (repair types, terms) */
.opt-grid{display:flex;flex-wrap:wrap;gap:10px;padding:10px;background:var(--surface2);border:1.5px solid var(--border);border-radius:8px;}
.rt-opt{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer;padding:9px 13px;background:#fff;border:1.5px solid var(--border);border-radius:8px;transition:border-color .12s,box-shadow .12s;white-space:nowrap;}
.rt-opt:hover{border-color:var(--red-mid);}
.rt-opt input{width:19px;height:19px;flex-shrink:0;accent-color:var(--red);cursor:pointer;}
.rt-opt:has(input:checked){border-color:var(--red);box-shadow:0 0 0 2px rgba(192,39,45,.12);background:var(--red-lt);}
