
:root {
  --primary:#0a6e4f; --primary-lt:#0d8f65; --primary-dk:#064a35;
  --accent:#f5a623; --red:#e74c3c; --blue:#2980b9; --purple:#8e44ad;
  --bg:#f0f4f2; --bg-card:#fff; --bg-dark:#0a3d2e;
  --text:#1a2e25; --text-sub:#5a7a6a; --text-dim:#9ab5a8; --border:#dce8e2;
  --shadow:0 4px 20px rgba(10,110,79,0.12);
  --radius:16px; --radius-sm:10px;
  --sans:'Plus Jakarta Sans',sans-serif; --display:'Outfit',sans-serif;
  --sidebar:240px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh}

/* ═══ LAYOUT ═══════════════════════════════ */
.app-shell{display:flex;min-height:100vh}

/* SIDEBAR (PC) */
.sidebar{
  width:var(--sidebar);min-width:var(--sidebar);
  background:var(--bg-dark);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:100;
  transform:translateX(0);transition:transform 0.3s;
}
.sidebar-logo{
  padding:20px 16px 16px;
  border-bottom:1px solid rgba(255,255,255,0.08);
  display:flex;align-items:center;gap:10px;
}
.logo-box{
  width:36px;height:36px;border-radius:10px;
  background:linear-gradient(135deg,var(--primary-lt),var(--accent));
  display:flex;align-items:center;justify-content:center;
  font-size:18px;box-shadow:0 4px 12px rgba(245,166,35,0.3);
}
.logo-text{font-family:var(--display);font-size:17px;font-weight:800;color:#fff}
.logo-text span{color:var(--accent)}
.logo-biz{font-size:10px;color:rgba(255,255,255,0.35);margin-top:1px}

.biz-type-badge{
  margin:10px 12px;padding:6px 10px;
  background:rgba(255,255,255,0.06);border-radius:8px;
  display:flex;align-items:center;gap:8px;cursor:pointer;
  border:1px solid rgba(255,255,255,0.1);transition:all 0.2s;
}
.biz-type-badge:hover{background:rgba(255,255,255,0.1)}
.biz-icon{font-size:16px}
.biz-name{font-size:11px;font-weight:700;color:rgba(255,255,255,0.7)}
.biz-switch{font-size:9px;color:rgba(255,255,255,0.3);margin-top:1px}

.sidebar-nav{flex:1;padding:8px 0;overflow-y:auto;scrollbar-width:none}
.sidebar-nav::-webkit-scrollbar{display:none}
.nav-section{padding:12px 16px 4px;font-size:9px;font-weight:800;
  letter-spacing:1.5px;color:rgba(255,255,255,0.25);text-transform:uppercase}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 16px;cursor:pointer;
  color:rgba(255,255,255,0.55);font-size:13px;font-weight:600;
  transition:all 0.15s;border-radius:0;position:relative;
  margin:1px 8px;border-radius:8px;
}
.nav-item:hover{background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.85)}
.nav-item.active{background:rgba(13,143,101,0.3);color:#fff}
.nav-item.active::before{
  content:'';position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:60%;background:var(--accent);border-radius:2px;
}
.nav-item i{width:18px;text-align:center;font-size:14px}
.nav-badge{
  margin-left:auto;background:var(--red);color:#fff;
  font-size:9px;font-weight:800;padding:2px 6px;border-radius:10px;
}

.sidebar-bottom{
  padding:12px;border-top:1px solid rgba(255,255,255,0.08);
}
.sync-btn{
  display:flex;align-items:center;gap:8px;padding:10px 12px;
  background:rgba(245,166,35,0.15);border:1px solid rgba(245,166,35,0.25);
  border-radius:8px;cursor:pointer;color:var(--accent);font-size:12px;font-weight:700;
  transition:all 0.2s;
}
.sync-btn:hover{background:rgba(245,166,35,0.25)}
.sync-btn i{animation:spin 2s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* MAIN CONTENT */
.main-content{
  margin-left:var(--sidebar);flex:1;display:flex;flex-direction:column;
  min-height:100vh;
}
.top-bar{
  height:56px;background:var(--bg-card);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;position:sticky;top:0;z-index:50;
  box-shadow:0 2px 8px rgba(0,0,0,0.04);
}
.top-bar-left{display:flex;align-items:center;gap:12px}
.hamburger{
  display:none;width:36px;height:36px;border-radius:8px;
  background:var(--bg);border:1px solid var(--border);
  align-items:center;justify-content:center;cursor:pointer;font-size:14px;
}
.page-title-bar{font-family:var(--display);font-size:17px;font-weight:700}
.top-bar-right{display:flex;align-items:center;gap:8px}
.top-btn{
  width:36px;height:36px;border-radius:8px;
  background:var(--bg);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:13px;color:var(--text-sub);
  transition:all 0.2s;position:relative;
}
.top-btn:hover{background:var(--border)}
.top-btn .badge{
  position:absolute;top:-3px;right:-3px;
  width:14px;height:14px;border-radius:50%;
  background:var(--red);color:#fff;font-size:8px;
  display:flex;align-items:center;justify-content:center;font-weight:800;
}
.lang-toggle{
  display:flex;background:var(--bg);border:1px solid var(--border);
  border-radius:8px;overflow:hidden;
}
.lt-btn{
  padding:6px 10px;font-size:11px;font-weight:700;cursor:pointer;
  color:var(--text-sub);transition:all 0.2s;
}
.lt-btn.active{background:var(--primary);color:#fff}

.page-body{padding:20px;flex:1}

/* ═══ SCREENS ═══════════════════════════════ */
.screen{display:none}
.screen.active{display:block}

/* ═══ DASHBOARD ════════════════════════════ */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.stat-card{
  background:var(--bg-card);border-radius:var(--radius);
  padding:18px;border:1px solid var(--border);
  position:relative;overflow:hidden;transition:all 0.2s;
}
.stat-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.stat-card::after{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
}
.stat-card.green::after{background:var(--primary)}
.stat-card.orange::after{background:var(--accent)}
.stat-card.red::after{background:var(--red)}
.stat-card.blue::after{background:var(--blue)}
.stat-icon{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:18px;margin-bottom:12px;
}
.sc-green{background:rgba(10,110,79,0.1);color:var(--primary)}
.sc-orange{background:rgba(245,166,35,0.1);color:#c47d00}
.sc-red{background:rgba(231,76,60,0.1);color:var(--red)}
.sc-blue{background:rgba(41,128,185,0.1);color:var(--blue)}
.stat-label{font-size:11px;color:var(--text-sub);font-weight:600;text-transform:uppercase;letter-spacing:0.5px}
.stat-value{font-family:var(--display);font-size:24px;font-weight:800;margin-top:4px}
.stat-change{font-size:11px;color:var(--text-dim);margin-top:3px}
.stat-change.up{color:var(--primary)}
.stat-change.down{color:var(--red)}

.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.dash-card{background:var(--bg-card);border-radius:var(--radius);padding:18px;border:1px solid var(--border)}
.dash-card-title{font-size:13px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:14px;display:flex;justify-content:space-between;align-items:center}
.dash-card-title a{font-size:11px;color:var(--primary);cursor:pointer;text-transform:none;letter-spacing:0;font-weight:600}

.activity-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.activity-row:last-child{border-bottom:none}
.act-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.act-dot.green{background:var(--primary)}
.act-dot.orange{background:var(--accent)}
.act-dot.red{background:var(--red)}
.act-text{flex:1;font-size:12px;color:var(--text)}
.act-time{font-size:11px;color:var(--text-dim)}
.act-val{font-size:13px;font-weight:700}
.act-val.pos{color:var(--primary)}
.act-val.neg{color:var(--red)}

/* ═══ POS SCREEN ════════════════════════════ */
.pos-layout{display:grid;grid-template-columns:1fr 360px;gap:16px;height:calc(100vh - 96px)}
.pos-left{display:flex;flex-direction:column;gap:12px;min-height:0}
.pos-right{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}

.pos-search-row{display:flex;gap:8px}
.pos-search{
  flex:1;display:flex;align-items:center;gap:8px;
  background:var(--bg-card);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:10px 14px;
}
.pos-search input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:14px;background:transparent}
.pos-search i{color:var(--text-dim)}
.scan-btn{
  padding:10px 16px;background:var(--primary);color:#fff;
  border:none;border-radius:var(--radius-sm);font-family:var(--sans);
  font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;gap:6px;
  white-space:nowrap;
}

.biz-mode-tabs{display:flex;gap:6px}
.biz-tab{
  padding:7px 14px;border-radius:20px;font-size:12px;font-weight:700;
  cursor:pointer;border:1px solid var(--border);background:var(--bg-card);
  color:var(--text-sub);transition:all 0.2s;
}
.biz-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}

.products-area{flex:1;overflow-y:auto;scrollbar-width:none}
.products-area::-webkit-scrollbar{display:none}
.product-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}
.prod-card{
  background:var(--bg-card);border-radius:var(--radius-sm);
  border:1px solid var(--border);overflow:hidden;cursor:pointer;
  transition:all 0.15s;
}
.prod-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.prod-card:active{transform:scale(0.97)}
.prod-img{
  height:80px;background:linear-gradient(135deg,#e8f4f0,#d0e8df);
  display:flex;align-items:center;justify-content:center;font-size:32px;
  position:relative;
}
.prod-stock{
  position:absolute;top:4px;right:4px;
  background:var(--primary);color:#fff;font-size:8px;font-weight:800;
  padding:2px 6px;border-radius:6px;
}
.prod-stock.low{background:var(--accent)}
.prod-stock.out{background:var(--red)}
.prod-info{padding:8px}
.prod-name{font-size:11px;font-weight:700;line-height:1.3}
.prod-price-row{display:flex;justify-content:space-between;align-items:center;margin-top:5px}
.prod-price{font-size:13px;font-weight:800;color:var(--primary)}
.prod-add{
  width:22px;height:22px;border-radius:6px;background:var(--primary);
  color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;
}

/* POS right panel */
.pos-right-header{
  padding:14px 16px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.pos-right-header h3{font-size:14px;font-weight:800}
.clear-btn{font-size:11px;color:var(--red);cursor:pointer;font-weight:700}

.customer-row{
  padding:10px 14px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;cursor:pointer;
  transition:background 0.15s;
}
.customer-row:hover{background:var(--bg)}
.cust-icon{width:32px;height:32px;border-radius:8px;background:rgba(10,110,79,0.1);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--primary);flex-shrink:0}
.cust-info{flex:1}
.cust-name{font-size:12px;font-weight:700}
.cust-type{font-size:10px;color:var(--text-sub)}
.phonebook-btn{font-size:11px;color:var(--blue);font-weight:700}

.cart-items{flex:1;overflow-y:auto;padding:8px 12px;scrollbar-width:none}
.cart-items::-webkit-scrollbar{display:none}
.cart-item{
  display:flex;align-items:center;gap:8px;
  padding:8px;background:var(--bg);border-radius:8px;margin-bottom:6px;
}
.ci-emoji{font-size:20px;width:32px;text-align:center;flex-shrink:0}
.ci-info{flex:1;min-width:0}
.ci-name{font-size:12px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ci-price{font-size:10px;color:var(--text-sub);margin-top:1px}
.ci-qty{display:flex;align-items:center;gap:5px}
.ci-qbtn{width:20px;height:20px;border-radius:5px;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;cursor:pointer;color:var(--primary)}
.ci-qval{font-size:12px;font-weight:800;min-width:16px;text-align:center}
.ci-total{font-size:13px;font-weight:800;color:var(--primary);min-width:50px;text-align:right}

.pos-totals{padding:10px 14px;border-top:1px solid var(--border)}
.tot-row{display:flex;justify-content:space-between;padding:4px 0;font-size:12px}
.tot-row .tl{color:var(--text-sub)}
.tot-row .tv{font-weight:700}
.tot-row.grand{border-top:1px solid var(--border);margin-top:6px;padding-top:8px}
.tot-row.grand .tl{font-size:14px;font-weight:800;color:var(--text)}
.tot-row.grand .tv{font-size:18px;font-weight:800;color:var(--primary)}

.payment-methods{padding:10px 14px;border-top:1px solid var(--border)}
.pm-label{font-size:11px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:8px}
.pm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.pm-btn{
  padding:7px 4px;border-radius:8px;font-size:10px;font-weight:700;
  cursor:pointer;border:1px solid var(--border);background:var(--bg);
  color:var(--text-sub);transition:all 0.2s;text-align:center;
}
.pm-btn.active{background:rgba(10,110,79,0.1);color:var(--primary);border-color:var(--primary)}
.pm-btn.custom{border-style:dashed;color:var(--accent)}
.charge-btn{
  width:100%;padding:13px;background:linear-gradient(135deg,var(--primary),var(--primary-lt));
  border:none;border-radius:var(--radius-sm);color:#fff;font-family:var(--sans);
  font-size:14px;font-weight:800;cursor:pointer;margin-top:10px;
  box-shadow:0 4px 14px rgba(10,110,79,0.3);transition:all 0.2s;
}
.charge-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(10,110,79,0.4)}

/* ═══ WHOLESALE ════════════════════════════ */
.ws-table-wrap{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}
.ws-table{width:100%;border-collapse:collapse}
.ws-table th{background:var(--bg);padding:12px 14px;font-size:11px;font-weight:800;color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px;border-bottom:1px solid var(--border);text-align:left}
.ws-table td{padding:10px 14px;font-size:13px;border-bottom:1px solid var(--border)}
.ws-table tr:last-child td{border-bottom:none}
.ws-table tr:hover td{background:var(--bg)}
.ws-qty-input{width:70px;padding:5px 8px;border:1px solid var(--border);border-radius:6px;font-family:var(--sans);font-size:13px;text-align:right;outline:none}
.ws-qty-input:focus{border-color:var(--primary)}
.ws-price{font-weight:700;color:var(--primary)}

/* ═══ PRODUCTS (Register) ═══════════════════ */
.prod-reg-grid{display:grid;grid-template-columns:1fr 340px;gap:16px}
.prod-form-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:20px}
.form-title{font-size:15px;font-weight:800;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}
.form-group{margin-bottom:12px}
.form-label{font-size:11px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;display:block}
.form-input{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--sans);font-size:13px;outline:none;transition:all 0.2s;background:var(--bg)}
.form-input:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(10,110,79,0.1)}
.form-select{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-family:var(--sans);font-size:13px;outline:none;background:var(--bg);cursor:pointer}
.scan-input-wrap{display:flex;gap:6px}
.scan-input-wrap .form-input{flex:1}
.scan-input-btn{padding:10px 14px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:14px}

/* ═══ FINANCE SCREENS ═══════════════════════ */
.fin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.fin-card{background:var(--bg-card);border-radius:var(--radius);padding:18px;border:1px solid var(--border)}
.fin-card-title{font-size:11px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:10px}
.fin-val{font-family:var(--display);font-size:22px;font-weight:800}
.fin-sub{font-size:11px;color:var(--text-dim);margin-top:4px}

.balance-sheet-table{width:100%;border-collapse:collapse}
.bs-header{background:var(--bg-dark);color:#fff;padding:10px 14px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.bs-row{display:flex;padding:9px 14px;border-bottom:1px solid var(--border);font-size:13px}
.bs-row:last-child{border-bottom:none}
.bs-row.total{background:rgba(10,110,79,0.06);font-weight:800}
.bs-label{flex:1;color:var(--text)}
.bs-val{font-weight:700;min-width:100px;text-align:right}
.bs-val.pos{color:var(--primary)}
.bs-val.neg{color:var(--red)}

/* ═══ SETTINGS ══════════════════════════════ */
.settings-grid{display:grid;grid-template-columns:240px 1fr;gap:16px}
.settings-menu{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:8px;height:fit-content}
.settings-menu-item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;
  color:var(--text-sub);transition:all 0.15s;
}
.settings-menu-item:hover{background:var(--bg)}
.settings-menu-item.active{background:rgba(10,110,79,0.1);color:var(--primary)}
.settings-menu-item i{width:16px;text-align:center}
.settings-panel{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:20px}
.settings-section{margin-bottom:24px}
.settings-section-title{font-size:14px;font-weight:800;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border)}

.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--bg)}
.toggle-info h4{font-size:13px;font-weight:700}
.toggle-info p{font-size:11px;color:var(--text-sub);margin-top:2px}
.toggle{width:40px;height:22px;background:var(--border);border-radius:11px;position:relative;cursor:pointer;transition:background 0.2s}
.toggle.on{background:var(--primary)}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:transform 0.2s;box-shadow:0 1px 4px rgba(0,0,0,0.2)}
.toggle.on::after{transform:translateX(18px)}

.profit-dist-card{background:var(--bg);border-radius:var(--radius-sm);padding:14px;margin-bottom:10px;border:1px solid var(--border)}
.pdc-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.pdc-label{flex:1;font-size:13px;font-weight:600}
.pdc-input{width:70px;padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px;font-weight:700;text-align:right;outline:none;font-family:var(--sans)}
.pdc-input:focus{border-color:var(--primary)}
.pdc-pct{font-size:12px;color:var(--text-sub);width:20px}
.pdc-bar{height:4px;background:var(--border);border-radius:2px;overflow:hidden}
.pdc-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,var(--primary),var(--primary-lt))}

/* Payment methods manager */
.pm-manager{display:flex;flex-direction:column;gap:8px}
.pm-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);border-radius:8px;border:1px solid var(--border)}
.pm-item-icon{font-size:18px;width:28px;text-align:center}
.pm-item-name{flex:1;font-size:13px;font-weight:700}
.pm-item-del{color:var(--red);cursor:pointer;font-size:13px;padding:4px}
.add-pm-row{display:flex;gap:8px}
.add-pm-input{flex:1;padding:9px 12px;border:1px solid var(--border);border-radius:8px;font-family:var(--sans);font-size:13px;outline:none}
.add-pm-input:focus{border-color:var(--primary)}
.add-pm-btn{padding:9px 16px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer}

/* ═══ BUDGET & EXPENSES ═════════════════════ */
.budget-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.budget-card{background:var(--bg-card);border-radius:var(--radius);padding:18px;border:1px solid var(--border)}
.bc-label{font-size:11px;font-weight:700;color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px}
.bc-val{font-family:var(--display);font-size:22px;font-weight:800;margin-top:6px}
.bc-progress{height:6px;background:var(--bg);border-radius:3px;margin-top:10px;overflow:hidden}
.bc-fill{height:100%;border-radius:3px;transition:width 0.3s}
.bc-meta{font-size:11px;color:var(--text-dim);margin-top:5px;display:flex;justify-content:space-between}

.expense-list{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}
.exp-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border)}
.exp-header h3{font-size:14px;font-weight:800}
.add-exp-btn{padding:7px 14px;background:var(--primary);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:700;cursor:pointer}
.exp-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border)}
.exp-item:last-child{border-bottom:none}
.exp-cat{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.exp-info{flex:1}
.exp-name{font-size:13px;font-weight:700}
.exp-date{font-size:11px;color:var(--text-sub);margin-top:2px}
.exp-amount{font-size:14px;font-weight:800;color:var(--red)}

/* ═══ MODAL ══════════════════════════════════ */
.modal-overlay{
  display:none;position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,0.5);backdrop-filter:blur(4px);
  align-items:center;justify-content:center;
}
.modal-overlay.show{display:flex;animation:fadeIn 0.2s}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal-box{
  background:var(--bg-card);border-radius:var(--radius);
  width:480px;max-width:92vw;
  box-shadow:0 24px 60px rgba(0,0,0,0.2);
  animation:slideUp 0.25s ease;overflow:hidden;
}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
.modal-header{
  padding:18px 20px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
}
.modal-header h3{font-size:16px;font-weight:800}
.modal-close{width:28px;height:28px;border-radius:50%;background:var(--bg);border:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-sub)}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:8px}
.btn-secondary{padding:9px 18px;border-radius:8px;background:var(--bg);border:1px solid var(--border);font-family:var(--sans);font-size:13px;font-weight:600;cursor:pointer;color:var(--text-sub)}
.btn-primary{padding:9px 20px;border-radius:8px;background:var(--primary);border:none;color:#fff;font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer}

/* ═══ TOAST ══════════════════════════════════ */
#toast{
  position:fixed;bottom:24px;right:24px;z-index:9999;
  background:#1a2e25;border-radius:var(--radius-sm);
  padding:12px 18px;display:flex;align-items:center;gap:10px;
  transform:translateY(20px);opacity:0;transition:all 0.3s;
  pointer-events:none;border-left:3px solid var(--primary);
  box-shadow:0 8px 30px rgba(0,0,0,0.2);
}
#toast.show{transform:none;opacity:1}
#toast.error{border-left-color:var(--red)}
#toast i{font-size:15px;color:var(--primary)}
#toast.error i{color:var(--red)}
#toast span{font-size:13px;color:#fff;font-weight:600}

/* ═══ RESPONSIVE ════════════════════════════ */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:none;box-shadow:4px 0 20px rgba(0,0,0,0.3)}
  .main-content{margin-left:0}
  .hamburger{display:flex}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .dash-row{grid-template-columns:1fr}
  .pos-layout{grid-template-columns:1fr;height:auto}
  .pos-right{position:fixed;bottom:0;left:0;right:0;border-radius:var(--radius) var(--radius) 0 0;max-height:50vh;transform:translateY(100%);transition:transform 0.3s;z-index:200}
  .pos-right.show{transform:none}
  .prod-reg-grid{grid-template-columns:1fr}
  .settings-grid{grid-template-columns:1fr}
  .fin-grid{grid-template-columns:repeat(2,1fr)}
  .budget-overview{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .page-body{padding:12px}
  .overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:99}
  .overlay.show{display:block}
}
/* ═══ AUDIT SCREEN ══════════════════════════════ */
.audit-mode-row{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.audit-mode-btn{
  display:flex;align-items:center;gap:7px;
  padding:8px 16px;border-radius:20px;font-size:12px;font-weight:700;
  cursor:pointer;border:1px solid var(--border);background:var(--bg-card);
  color:var(--text-sub);transition:all 0.2s;
}
.audit-mode-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.audit-mode-btn i{font-size:13px}

/* Scan panel */
.audit-scan-panel{
  background:var(--bg-card);border-radius:var(--radius);
  border:1px solid var(--border);margin-bottom:14px;overflow:hidden;
  display:none;
}
.audit-scan-panel.active{display:block}
.scan-split{display:grid;grid-template-columns:1fr 1fr;gap:0}
.scan-cam-area{
  background:#0a0a0a;min-height:220px;
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.scan-cam-video{width:100%;height:220px;object-fit:cover;display:none}
.scan-cam-video.on{display:block}
.scan-cam-ph{display:flex;flex-direction:column;align-items:center;gap:10px;color:rgba(255,255,255,0.25)}
.scan-cam-ph i{font-size:42px}
.scan-cam-ph p{font-size:11px;font-family:monospace}
.scan-cam-btn{
  position:absolute;bottom:12px;left:50%;transform:translateX(-50%);
  padding:7px 18px;background:rgba(10,110,79,0.9);
  border:none;border-radius:20px;color:#fff;
  font-size:11px;font-weight:700;cursor:pointer;white-space:nowrap;
}
.scan-cam-btn.stop{background:rgba(231,76,60,0.9)}
.scan-frame-overlay{
  position:absolute;inset:0;display:flex;align-items:center;
  justify-content:center;pointer-events:none;display:none;
}
.scan-frame-overlay.on{display:flex}
.scan-frm{
  width:180px;height:100px;border:2px solid var(--primary);
  border-radius:8px;position:relative;
}
.scan-frm::before,.scan-frm::after{
  content:'';position:absolute;width:16px;height:16px;
  border-color:var(--accent);border-style:solid;
}
.scan-frm::before{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:3px 0 0 0}
.scan-frm::after{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 3px 0}
.scan-line-anim{
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--primary),transparent);
  animation:scanLine 1.6s ease-in-out infinite;
}
@keyframes scanLine{0%,100%{top:0}50%{top:calc(100% - 2px)}}

/* Right input area */
.scan-input-side{
  padding:16px 18px;display:flex;flex-direction:column;gap:12px;
  border-left:1px solid var(--border);
}
.scan-side-label{font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.8px;color:var(--text-sub)}
.barcode-wrap{display:flex;gap:6px}
.barcode-field{
  flex:1;padding:10px 12px;
  border:2px solid var(--border);border-radius:var(--radius-sm);
  font-size:14px;font-weight:700;letter-spacing:1.5px;
  outline:none;background:var(--bg);transition:all 0.2s;
  color:var(--text);
}
.barcode-field:focus{border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px rgba(10,110,79,0.1)}
.barcode-field::placeholder{letter-spacing:0;font-weight:400;font-size:12px}
.barcode-go{
  width:40px;height:40px;border-radius:var(--radius-sm);
  background:var(--primary);border:none;color:#fff;
  font-size:15px;cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:all 0.2s;flex-shrink:0;
}
.barcode-go:hover{background:var(--primary-dk)}

/* Result card */
.scan-result{
  border-radius:var(--radius-sm);padding:12px 14px;
  display:none;border:1px solid var(--border);
}
.scan-result.found{
  display:block;border-color:var(--primary);
  background:rgba(10,110,79,0.06);
}
.scan-result.notfound{
  display:block;border-color:var(--red);
  background:rgba(231,76,60,0.06);
}
.sr-name{font-size:14px;font-weight:800;margin-bottom:3px}
.sr-meta{font-size:11px;color:var(--text-sub)}
.sr-qty-row{display:flex;gap:8px;align-items:center;margin-top:10px}
.sr-qty-inp{
  flex:1;padding:9px 12px;border:1px solid var(--border);
  border-radius:var(--radius-sm);font-size:15px;font-weight:700;
  text-align:right;outline:none;background:var(--bg);
  transition:border-color 0.2s;
}
.sr-qty-inp:focus{border-color:var(--primary)}
.sr-save{
  padding:9px 16px;background:var(--primary);border:none;
  border-radius:var(--radius-sm);color:#fff;font-size:12px;
  font-weight:700;cursor:pointer;transition:all 0.2s;white-space:nowrap;
}
.sr-save:hover{background:var(--primary-dk);transform:translateY(-1px)}

/* Scan history */
.scan-hist-wrap{max-height:120px;overflow-y:auto;scrollbar-width:none}
.scan-hist-wrap::-webkit-scrollbar{display:none}
.sh-item{
  display:flex;gap:8px;padding:5px 8px;border-radius:6px;
  background:var(--bg);margin-bottom:4px;font-size:11px;
  animation:fadeSlide 0.3s ease;
}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
.sh-bc{color:var(--primary);font-weight:700;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sh-nm{color:var(--text-sub);flex:2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sh-q{color:var(--primary-dk);font-weight:800;min-width:30px;text-align:right}
.sh-t{color:var(--text-dim);min-width:36px;text-align:right}

/* Scan stats footer */
.scan-footer{
  display:flex;gap:14px;padding:10px 16px;
  background:var(--bg);border-top:1px solid var(--border);
  font-size:11px;flex-wrap:wrap;align-items:center;
}
.sf-item{display:flex;align-items:center;gap:5px;color:var(--text-sub)}
.sf-val{font-weight:800}
.sf-val.g{color:var(--primary)}.sf-val.r{color:var(--red)}.sf-val.a{color:#c47d00}

/* Audit list items */
.audit-list-item{
  background:var(--bg-card);border-radius:var(--radius-sm);
  border:1px solid var(--border);padding:14px 16px;
  margin-bottom:8px;cursor:pointer;transition:all 0.2s;
  display:flex;align-items:center;gap:12px;
}
.audit-list-item:hover{box-shadow:var(--shadow);transform:translateY(-1px)}
.ali-icon{
  width:40px;height:40px;border-radius:10px;
  background:rgba(10,110,79,0.1);color:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;flex-shrink:0;
}
.ali-info{flex:1}
.ali-no{font-size:13px;font-weight:800}
.ali-meta{font-size:11px;color:var(--text-sub);margin-top:2px}
.ali-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}
.ali-prog{
  height:4px;width:80px;background:var(--border);
  border-radius:2px;overflow:hidden;margin-top:4px;
}
.ali-prog-fill{height:100%;border-radius:2px;background:var(--primary);transition:width 0.3s}
.ali-pct{font-size:10px;color:var(--text-dim)}

/* Audit detail */
.audit-detail-header{
  background:var(--bg-card);border-radius:var(--radius);
  border:1px solid var(--border);padding:16px 18px;
  margin-bottom:14px;display:flex;align-items:center;gap:12px;
}
.audit-mini-stats{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:8px;margin-bottom:14px;
}
.ams{
  background:var(--bg-card);border-radius:var(--radius-sm);
  border:1px solid var(--border);padding:12px;text-align:center;
}
.ams-val{font-size:20px;font-weight:800}
.ams-lbl{font-size:9px;color:var(--text-sub);text-transform:uppercase;
  letter-spacing:0.5px;margin-top:3px}

/* Lines table */
.audit-lines-table{width:100%;border-collapse:collapse}
.audit-lines-table th{
  background:var(--bg);padding:9px 12px;font-size:10px;font-weight:700;
  color:var(--text-sub);text-transform:uppercase;letter-spacing:0.5px;
  border-bottom:1px solid var(--border);text-align:left;
}
.audit-lines-table td{
  padding:9px 12px;font-size:12px;border-bottom:1px solid var(--border);
}
.audit-lines-table tr:last-child td{border-bottom:none}
.audit-lines-table tr:hover td{background:var(--bg)}
.audit-qty-inp{
  width:90px;padding:5px 8px;border:1px solid var(--border);
  border-radius:6px;font-size:12px;font-weight:700;text-align:right;
  outline:none;background:var(--bg);
}
.audit-qty-inp:focus{border-color:var(--primary)}
.var-pos{color:var(--primary);font-weight:700}
.var-neg{color:var(--red);font-weight:700}
.var-zero{color:var(--text-dim)}
@media(max-width:600px){
  .scan-split{grid-template-columns:1fr}
  .audit-mini-stats{grid-template-columns:repeat(3,1fr)}
  .scan-cam-area{min-height:180px}
}

/* ═══ FIXES v1.1 — Classes used in HTML but missing from CSS ═══ */

/* btype-btn (Settings → Aina ya Biashara) */
.btype-btn{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);color:var(--text);cursor:pointer;font-size:13px;font-weight:600;transition:all .2s;font-family:var(--sans)}
.btype-btn.active,.btype-btn:hover{background:rgba(10,110,79,.12);border-color:var(--primary);color:var(--primary)}

/* lang-btn (Settings → Lugha) */
.lang-btn{padding:8px 20px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:13px;font-weight:600;transition:all .2s;font-family:var(--sans)}
.lang-btn.active,.lang-btn:hover{background:rgba(10,110,79,.12);border-color:var(--primary);color:var(--primary)}

/* Topbar elements */
.topbar{height:52px;background:var(--bg-card);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 16px;gap:12px;position:sticky;top:0;z-index:100}
.topbar-title{font-size:15px;font-weight:700;flex:1}
.tb-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);cursor:pointer;color:var(--text-sub);position:relative;transition:background .2s}
.tb-btn:hover{background:var(--bg)}
.tb-dot{position:absolute;top:5px;right:5px;width:7px;height:7px;border-radius:50%;background:var(--red)}
.tb-l{display:flex;align-items:center;gap:8px}
.tb-r{display:flex;align-items:center;gap:6px;margin-left:auto}

/* Online status */
.online-chip{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-sub)}
.online-dot{width:8px;height:8px;border-radius:50%;background:#27ae60;transition:background .3s;flex-shrink:0}
.sc-dot{width:8px;height:8px;border-radius:50%;background:#27ae60}
.sc-type{font-size:11px;font-weight:600}

/* Sidebar */
.sb-overlay{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:199;display:none}
.sb-overlay.on{display:block}
.sb-brand{padding:16px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px}
.sb-logo-box{width:34px;height:34px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;color:#fff}
.sb-logo{font-size:15px;font-weight:900}
.sb-sub{font-size:10px;color:var(--text-dim)}
.sb-nav{flex:1;overflow-y:auto;padding:8px 0}
.sb-section{padding:4px 10px;font-size:10px;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-top:6px}
.sb-foot{padding:12px 14px;border-top:1px solid var(--border);font-size:11px;color:var(--text-dim)}

/* Page layout */
.content{flex:1;overflow-y:auto;padding:18px}
.page-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.page-top h2{font-size:20px;font-weight:900}

/* Generic card */
.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:18px}
.card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.card-head h3{font-size:14px;font-weight:800}
.card-p{padding:4px 0}

/* Badges */
.badge-red{background:rgba(231,76,60,.15);color:var(--red)}
.badge-green{background:rgba(10,110,79,.15);color:var(--primary)}
.badge-amber{background:rgba(245,166,35,.15);color:var(--accent)}
.badge-blue{background:rgba(41,128,185,.15);color:var(--blue)}
.badge-purple{background:rgba(142,68,173,.15);color:var(--purple)}
.badge-teal{background:rgba(22,160,133,.15);color:#16a085}

/* Button sizes */
.btn-sm{padding:5px 12px !important;font-size:11px !important}
.btn-lg{padding:12px 22px !important;font-size:15px !important}
.btn-green{background:var(--primary);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;font-size:13px;font-family:var(--sans)}
.btn-amber{background:var(--accent);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;font-size:13px;font-family:var(--sans)}
.btn-blue{background:var(--blue);color:#fff;border:none;padding:8px 16px;border-radius:var(--radius-sm);cursor:pointer;font-weight:700;font-size:13px;font-family:var(--sans)}

/* Search bar */
.search-bar{display:flex;align-items:center;gap:10px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px}
.search-bar input{flex:1;border:none;outline:none;font-size:14px;background:transparent;font-family:var(--sans)}

/* Stats grid */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.sg3{grid-template-columns:repeat(3,1fr) !important}
.sg4{grid-template-columns:repeat(4,1fr) !important}
.sc-arr{font-size:11px;color:var(--text-dim)}

/* POS */
.pos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.cart-panel{display:flex;flex-direction:column;height:100%}
.cart-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.cart-scroll{flex:1;overflow-y:auto;padding:8px 12px}
.cart-totals{padding:10px 14px;border-top:1px solid var(--border)}
.cart-actions{padding:10px 14px;border-top:1px solid var(--border)}
.cart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:120px;color:var(--text-dim);font-size:13px;gap:8px}
.ct-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}
.ct-row.grand{font-weight:900;font-size:15px;color:var(--primary);padding-top:8px;border-top:2px solid var(--border)}

/* Pay */
.pay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:8px 10px}
.pay-btn{padding:8px 4px;text-align:center;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);font-size:11px;font-weight:700;cursor:pointer;transition:all .15s}
.pay-btn.on{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Wholesale */
.ws-layout{display:grid;grid-template-columns:1fr 300px;gap:14px}
.ws-right{display:flex;flex-direction:column;gap:10px}
.ws-meta{padding:10px;display:flex;flex-direction:column;gap:7px}
.ws-actions{padding:12px;display:flex;flex-direction:column;gap:8px}
.ws-action-row{display:flex;gap:8px}
.ws-disc-tabs{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px}
.ws-disc-tab{padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);font-size:11px;cursor:pointer;font-weight:600;transition:all .15s}
.ws-disc-tab.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.unit-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px;align-items:center}
.unit-pill{padding:7px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:12px;font-weight:700;display:flex;align-items:center;gap:5px;transition:all .2s}
.unit-pill.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.ratio{font-size:10px;opacity:.7}
.doc-panel{border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);overflow:hidden;margin-bottom:10px}
.doc-types{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:10px}
.doc-type-btn{padding:7px 4px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);font-size:11px;font-weight:600;cursor:pointer;text-align:center;transition:all .2s}
.doc-type-btn.on{background:var(--primary);color:#fff;border-color:var(--primary)}
.tot-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border)}
.tot-row:last-child{border-bottom:none}
.tot-row.grand{font-weight:900;font-size:15px;color:var(--primary);padding-top:10px}
.totals-panel{padding:12px}
.disc-tab{padding:5px 10px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);font-size:11px;cursor:pointer;font-weight:600;transition:all .15s}
.disc-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.disc-row{display:flex;gap:8px;align-items:center;margin-bottom:8px}

/* Invoice */
.inv-preview{background:#fff;border-radius:var(--radius);border:1px solid var(--border);padding:28px;max-width:860px;margin:0 auto}
.inv-head{display:flex;justify-content:space-between;margin-bottom:22px;align-items:flex-start}
.inv-logo{display:flex;gap:12px;align-items:center}
.inv-logo-box{width:50px;height:50px;background:var(--primary);color:#fff;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900}
.inv-co h2{font-size:17px;margin-bottom:3px}
.inv-co p{font-size:11px;color:var(--text-sub);line-height:1.6}
.inv-doc{text-align:right}
.inv-doc-type{font-size:20px;font-weight:900;color:var(--primary)}
.inv-doc-no{font-size:12px;color:var(--text-sub);margin-top:4px}
.inv-parties{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}
.inv-party label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);display:block;margin-bottom:5px}
.inv-party h4{font-size:14px;font-weight:800;margin-bottom:3px}
.inv-table{width:100%;border-collapse:collapse;margin-bottom:20px}
.inv-table th{background:var(--bg);padding:9px 8px;font-size:11px;text-align:left;border-bottom:2px solid var(--border)}
.inv-table td{padding:8px;font-size:13px;border-bottom:1px solid var(--border)}
.inv-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}

/* Audit */
.audit-dhead{display:flex;align-items:center;gap:12px;margin-bottom:14px;flex-wrap:wrap}
.audit-dhead-back{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center}
.audit-badge{padding:4px 12px;border-radius:20px;font-size:10px;font-weight:800;letter-spacing:1px;text-transform:uppercase}
.audit-badge.prog{background:rgba(41,128,185,.15);color:var(--blue)}
.audit-badge.pend{background:rgba(245,166,35,.15);color:var(--accent)}
.audit-badge.conf{background:rgba(10,110,79,.15);color:var(--primary)}
.audit-mini{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:14px}
.ams{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px;text-align:center}
.ams-val{font-size:22px;font-weight:800}
.ams-lbl{font-size:10px;color:var(--text-sub);margin-top:2px;font-weight:600;text-transform:uppercase}
.mode-row{display:flex;gap:8px;margin-bottom:14px;align-items:center;flex-wrap:wrap}
.mode-btn{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:12px;font-weight:700;display:flex;align-items:center;gap:6px;transition:all .2s}
.mode-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}
.bc-wrap{display:flex;gap:6px;margin-bottom:10px}
.bc-field{flex:1;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:14px;font-family:var(--mono);background:var(--bg)}
.bc-go{padding:10px 14px;border-radius:var(--radius-sm);background:var(--primary);color:#fff;border:none;cursor:pointer;font-size:15px}
.scan-panel{display:flex;flex-direction:column;gap:10px}
.cam-area{background:#000;border-radius:var(--radius);position:relative;overflow:hidden;aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;min-height:200px}
.cam-video{width:100%;height:100%;object-fit:cover}
.cam-ph{position:absolute;color:#666;display:flex;flex-direction:column;align-items:center;gap:8px;font-size:13px}
.cam-ph i{font-size:32px}
.cam-btn{padding:8px 18px;border-radius:var(--radius-sm);background:var(--primary);color:#fff;border:none;cursor:pointer;font-size:12px;font-weight:700;margin-top:8px}
.cam-btn.stop{background:var(--red)}
.scan-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;pointer-events:none}
.scan-frm{width:70%;height:60%;border:2px solid var(--primary);border-radius:8px;position:relative;overflow:hidden}
.scan-line{position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent);animation:scanAnim 2s linear infinite}
@keyframes scanAnim{0%{top:0}50%{top:calc(100% - 2px)}100%{top:0}}
.scan-result{background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);padding:12px;margin-bottom:10px}
.sr-name{font-weight:800;font-size:15px;margin-bottom:4px}
.sr-meta{font-size:11px;color:var(--text-sub);margin-bottom:8px}
.sr-qty-row{display:flex;gap:8px}
.sr-qty{width:90px;padding:8px;border-radius:var(--radius-sm);border:2px solid var(--primary);font-size:16px;font-weight:700;text-align:center}
.sr-save{flex:1;padding:8px;border-radius:var(--radius-sm);background:var(--primary);color:#fff;border:none;cursor:pointer;font-weight:700}
.scan-hist{max-height:200px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}
.scan-hist-row{display:grid;grid-template-columns:1fr 2fr 50px 60px;gap:6px;padding:5px 8px;border-bottom:1px solid var(--border);align-items:center;font-size:11px}
.scan-hist-row:last-child{border-bottom:none}
.scan-footer{display:flex;gap:16px;align-items:center;padding:8px 12px;background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);font-size:11px;color:var(--text-sub)}
.sf-val{font-weight:800;font-size:14px}
.sf-g{color:var(--primary)}.sf-r{color:var(--red)}.sf-a{color:var(--accent)}

/* Finance */
.fin-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.balance-sheet{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.bs-col{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.bs-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--border);font-size:13px}
.bs-row:last-child{border-bottom:none}
.bs-row.total{font-weight:800;color:var(--primary)}

/* SMS */
.sms-layout{display:grid;grid-template-columns:1fr 280px;gap:14px}
.sms-types{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-bottom:12px}
.sms-type-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 8px;text-align:center;cursor:pointer;transition:all .2s}
.sms-type-card.on{border-color:var(--primary);background:rgba(10,110,79,.07)}
.stc-icon{font-size:22px;margin-bottom:4px}
.stc-name{font-size:10px;font-weight:700;color:var(--text-sub)}
.recip-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}

/* VAT */
.vat-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;font-size:12px;font-weight:600;border-bottom:1px solid var(--border)}

/* Form helpers */
.fg{display:flex;flex-direction:column;gap:4px}
.fl{font-size:11px;font-weight:700;color:var(--text-sub)}
.fi{padding:9px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;width:100%;box-sizing:border-box;font-family:var(--sans);background:var(--bg-card)}
.fi:focus{border-color:var(--primary);outline:none}
.fs{padding:9px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);font-size:13px;font-family:var(--sans);background:var(--bg-card)}
.frow{display:flex;gap:10px;flex-wrap:wrap}
.fc2{flex:1 1 calc(50% - 5px)}.fc3{flex:1 1 calc(33% - 7px)}.fc4{flex:1 1 calc(25% - 8px)}
.fg-row{display:flex;gap:10px}

/* Filter tabs */
.filter-tab{padding:6px 14px;border-radius:20px;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:12px;font-weight:600;transition:all .2s}
.filter-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}

/* Misc */
.store-chip{display:flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;background:rgba(10,110,79,.1);color:var(--primary);font-size:12px;font-weight:700}
.sync-badge{padding:2px 7px;border-radius:10px;font-size:10px;font-weight:800;background:rgba(10,110,79,.15);color:var(--primary)}
.sync-badge.amber{background:rgba(245,166,35,.2);color:var(--accent)}
.sync-badge.red{background:rgba(231,76,60,.2);color:var(--red)}
.sync-badge.green{background:rgba(10,110,79,.2);color:var(--primary)}
.sync-badge.dim{opacity:.5}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;color:var(--text-dim);gap:8px;font-size:13px}
.biz-tabs{display:flex;gap:6px;flex-wrap:wrap}
.prog{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:4px}
.sc-amber{color:var(--accent)}.sc-purple{color:var(--purple)}
.tbl{width:100%;border-collapse:collapse}
.tbl th{background:var(--bg);padding:9px 10px;font-size:11px;font-weight:700;text-align:left;border-bottom:2px solid var(--border)}
.tbl td{padding:9px 10px;font-size:13px;border-bottom:1px solid var(--border);vertical-align:middle}
.td-name{font-weight:700}.td-r{text-align:right}
.sc-icon{font-size:20px;margin-bottom:4px}
.sc-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:0.5px}
.sc-name{font-size:13px;color:var(--text-sub)}
.sc-value{font-size:22px;font-weight:900;font-family:var(--display)}
.sc-sub{font-size:11px;color:var(--text-sub);margin-top:2px}
.lg{font-size:15px}
.modal-bg{background:rgba(0,0,0,.5);position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:500}
.modal-x{position:absolute;top:12px;right:14px;font-size:20px;cursor:pointer;color:var(--text-sub);background:none;border:none}
.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}

/* Responsive */
@media(max-width:1100px){.ws-layout{grid-template-columns:1fr}}
@media(max-width:900px){
  .stat-grid,.sg4{grid-template-columns:repeat(2,1fr)}
  .audit-mini{grid-template-columns:repeat(3,1fr)}
  .balance-sheet,.fin-grid,.settings-grid{grid-template-columns:1fr}
  .sms-layout{grid-template-columns:1fr}
  .sms-types{grid-template-columns:repeat(3,1fr)}
  .inv-parties{grid-template-columns:1fr}
}
@media(max-width:600px){
  .stat-grid,.sg4,.sg3{grid-template-columns:repeat(2,1fr)}
  .audit-mini{grid-template-columns:repeat(2,1fr)}
  .doc-types{grid-template-columns:repeat(2,1fr)}
  .sms-types{grid-template-columns:repeat(2,1fr)}
  .pay-grid{grid-template-columns:repeat(2,1fr)}
  .content{padding:12px}
  .pos-layout{grid-template-columns:1fr;height:auto}
}
