/* ═══════════════════════════════════════════
   Tbeem Flow v1.0 — Complete Styles
   ═══════════════════════════════════════════ */
:root {
  --bg:#F4F6FB; --card:#fff;
  --primary:#6C63FF; --primary-dark:#5A52E0; --primary-light:rgba(108,99,255,0.1);
  --accent2:#43C6AC; --accent3:#FF6584; --success:#28A745; --warning:#F7B731;
  --text:#1A1D2E; --text-muted:#8A8FA8; --border:#E8EAF0;
  --shadow-card:0 4px 24px rgba(0,0,0,0.07);
  --radius:16px; --radius-sm:10px;
  --font:'DM Sans',sans-serif; --mono:'DM Mono',monospace;
  --header-h:58px;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html,body{font-family:var(--font);background:var(--bg);color:var(--text);height:100%;overflow-x:hidden;font-size:15px}

/* ── SCREENS ── */
.screen{position:fixed;inset:0}
.screen.hidden{display:none}
.screen.active{display:flex;flex-direction:column}

/* ── LOGIN ── */
#screen-login{background:#fff;align-items:center;justify-content:center;padding:24px;overflow:hidden}
.login-bg{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.login-blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:0.15}
.b1{width:300px;height:300px;background:var(--primary);top:-80px;right:-80px}
.b2{width:250px;height:250px;background:var(--accent2);bottom:-60px;left:-60px}
.login-card{width:100%;max-width:380px;background:var(--card);border-radius:24px;padding:36px 28px;box-shadow:0 20px 60px rgba(108,99,255,0.15);position:relative;z-index:1}
.brand{text-align:center;margin-bottom:32px}
.brand-icon{font-size:44px;margin-bottom:10px;display:block}
.brand h1{font-size:26px;font-weight:700;color:var(--primary);letter-spacing:-0.5px}
.brand p{color:var(--text-muted);font-size:13px;margin-top:4px}
.login-hint{text-align:center;font-size:11.5px;color:var(--text-muted);margin-top:16px;font-family:var(--mono)}

/* ── HEADER ── */
.app-header{height:var(--header-h);background:var(--card);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 16px;position:sticky;top:0;z-index:100;box-shadow:0 1px 12px rgba(0,0,0,0.05)}
.header-left,.header-right{display:flex;align-items:center;gap:10px}
.header-title{font-weight:600;font-size:16px;letter-spacing:-0.3px}
.icon-btn{width:38px;height:38px;background:var(--bg);border:none;border-radius:10px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:background 0.2s}
.icon-btn:active{background:var(--border)}
.header-avatar{width:34px;height:34px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;cursor:pointer;overflow:hidden;border:2px solid var(--primary-light)}
.header-avatar img{width:100%;height:100%;object-fit:cover}

/* ── SIDE MENU ── */
.side-menu{position:fixed;top:0;left:0;width:280px;height:100%;background:var(--card);z-index:300;box-shadow:4px 0 30px rgba(0,0,0,0.12);display:flex;flex-direction:column}
.side-menu.hidden{display:none}
.menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.35);z-index:299;backdrop-filter:blur(2px)}
.menu-overlay.hidden{display:none}
.menu-user{padding:44px 16px 16px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;display:flex;align-items:center;gap:12px;cursor:pointer;position:relative}
.menu-user:active{opacity:0.9}
.menu-avatar-img{width:52px;height:52px;border-radius:50%;background:rgba(255,255,255,0.25);display:flex;align-items:center;justify-content:center;font-size:22px;overflow:hidden;border:2px solid rgba(255,255,255,0.4);flex-shrink:0}
.menu-avatar-img img{width:100%;height:100%;object-fit:cover}
.menu-user-info{flex:1;min-width:0}
.menu-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.menu-role{font-size:11.5px;opacity:0.75;margin-top:1px}
.menu-phone{font-size:11px;opacity:0.65;margin-top:1px;font-family:var(--mono)}
.menu-edit-badge{font-size:14px;opacity:0.7}
.menu-nav{flex:1;padding:12px;display:flex;flex-direction:column;gap:3px;overflow-y:auto}
.menu-item{width:100%;padding:11px 14px;border:none;background:transparent;border-radius:var(--radius-sm);text-align:left;font-family:var(--font);font-size:14px;color:var(--text);cursor:pointer;transition:all 0.18s;font-weight:500}
.menu-item:hover,.menu-item.active{background:var(--primary-light);color:var(--primary)}
.menu-item.active{font-weight:700}
.menu-item.logout-btn{color:var(--accent3)}
.menu-item.logout-btn:hover{background:rgba(255,101,132,0.1)}
.menu-divider{height:1px;background:var(--border);margin:6px 0}
.menu-footer{padding:12px;font-size:11px;color:var(--text-muted);text-align:center;font-family:var(--mono)}

/* ── PAGES ── */
.page{flex:1;overflow-y:auto}
.page.hidden{display:none}
.page-content{padding:16px 16px 100px;max-width:600px;margin:0 auto}
.page-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.page-title-row .section-title{margin-bottom:0}

/* ── STATS ── */
.greeting{font-size:18px;font-weight:600;margin-bottom:16px}
.stats-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}
.stat-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-card);border-left:4px solid var(--c,var(--primary));transition:transform 0.2s}
.stat-card:active{transform:scale(0.97)}
.stat-num{font-size:28px;font-weight:700;color:var(--c,var(--primary));font-family:var(--mono)}
.stat-lbl{font-size:12px;color:var(--text-muted);margin-top:2px;font-weight:500}

/* ── DISPATCH ALERT ── */
.dispatch-alert{background:linear-gradient(135deg,#FF6584,#FF8E5A);color:#fff;border-radius:var(--radius);padding:14px 16px;display:flex;align-items:center;gap:12px;margin-bottom:18px;cursor:pointer;font-size:14px;font-weight:600;box-shadow:0 6px 20px rgba(255,101,132,0.3)}
.dispatch-alert span:first-child{font-size:22px}
.dispatch-alert div{flex:1}
.dispatch-alert span:last-child{font-size:18px;opacity:0.8}

/* ── DISPATCH HEADER ── */
.dispatch-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:10px}
.dispatch-filter select{padding:9px 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;background:var(--card);outline:none}

/* ── SECTION / FORM LABELS ── */
.section-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:12px;letter-spacing:-0.2px}
.form-section-label{font-size:11.5px;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:14px;padding-bottom:6px;border-bottom:1.5px solid var(--primary-light)}

/* ── CARDS ── */
.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:20px}
.form-card{margin-bottom:20px}

/* ── FORM ── */
.form-group{margin-bottom:14px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.form-group label{display:block;font-size:11.5px;font-weight:600;color:var(--text-muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:0.5px}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:11px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;color:var(--text);background:var(--bg);outline:none;transition:border-color 0.2s,box-shadow 0.2s;-webkit-appearance:none}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(108,99,255,0.1);background:#fff}
.form-group textarea{resize:vertical;min-height:76px}

/* ── BUTTONS ── */
.btn-primary{width:100%;padding:13px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;transition:background 0.2s,transform 0.1s}
.btn-primary:active{background:var(--primary-dark);transform:scale(0.98)}
.btn-outline{width:100%;padding:12px;background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:all 0.2s}
.btn-outline:active{background:var(--primary-light)}
.btn-outline-sm{padding:6px 13px;background:transparent;color:var(--primary);border:1.5px solid var(--primary);border-radius:8px;font-family:var(--font);font-size:12.5px;font-weight:600;cursor:pointer;white-space:nowrap;transition:all 0.2s}
.btn-outline-sm.danger{color:var(--accent3);border-color:var(--accent3)}
.btn-row{display:flex;gap:10px;margin-top:14px}
.btn-row .btn-primary,.btn-row .btn-outline{flex:1}
.btn-fab{position:fixed;bottom:24px;right:20px;background:var(--primary);color:#fff;border:none;border-radius:50px;padding:13px 20px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;box-shadow:0 6px 24px rgba(108,99,255,0.4);z-index:50;transition:transform 0.2s}
.btn-fab:active{transform:scale(0.95)}
.btn-scan{width:46px;height:46px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:20px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.btn-logout-full{width:calc(100% - 0px);margin:0 0 80px;padding:14px;background:#fff;color:var(--accent3);border:1.5px solid var(--accent3);border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;display:block}
.scan-row{display:flex;gap:8px}
.scan-row input{flex:1}

/* ── PILL SELECT ── */
.pill-select{display:flex;flex-wrap:wrap;gap:7px;margin-top:4px}
.pill-btn{padding:7px 13px;border:1.5px solid var(--border);border-radius:24px;background:var(--bg);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;color:var(--text);transition:all 0.18s;white-space:nowrap}
.pill-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}
.pill-btn:hover:not(.active){border-color:var(--primary);color:var(--primary)}

/* ── PAYMENT SUB-FIELDS ── */
.pay-sub-fields{margin-top:4px;margin-bottom:4px}
.sub-field-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:13px 13px 3px}

/* ── BANK PREVIEW ── */
.bank-preview{background:linear-gradient(135deg,#1A1D2E,#2D3155);color:#fff;border-radius:var(--radius-sm);padding:14px;margin:10px 0;font-size:13px}
.bank-preview .bp-bank{font-size:15px;font-weight:700;margin-bottom:8px}
.bank-preview .bp-row{display:flex;justify-content:space-between;padding:3px 0;opacity:0.85;font-size:12px}
.bank-preview .bp-label{opacity:0.6;font-size:10.5px;text-transform:uppercase;letter-spacing:0.5px}
.bank-preview .bp-val{font-family:var(--mono);font-weight:600}

/* ── ORDER CARDS ── */
.order-list{display:flex;flex-direction:column;gap:10px}
.order-card{background:var(--card);border-radius:var(--radius);padding:15px;box-shadow:var(--shadow-card);cursor:pointer;transition:transform 0.15s;border-left:4px solid var(--border)}
.order-card:active{transform:scale(0.98)}
.order-card.status-pending   {border-left-color:#F7B731}
.order-card.status-processing{border-left-color:#007BFF}
.order-card.status-shipped   {border-left-color:#43C6AC}
.order-card.status-delivered {border-left-color:#17A2B8}
.order-card.priority-high    {box-shadow:var(--shadow-card),inset 3px 0 0 0 #FF8E5A}
.order-card.priority-urgent  {box-shadow:var(--shadow-card),inset 3px 0 0 0 #FF6584}
.order-card-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.order-name{font-weight:600;font-size:15px}
.status-pill{font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:20px;text-transform:uppercase;letter-spacing:0.4px;flex-shrink:0}
.status-pending   .status-pill,.status-pill.sp-pending   {background:#FFF3CD;color:#856404}
.status-processing .status-pill,.status-pill.sp-processing{background:#CCE5FF;color:#004085}
.status-shipped   .status-pill,.status-pill.sp-shipped   {background:#D4EDDA;color:#155724}
.status-delivered .status-pill,.status-pill.sp-delivered {background:#D1ECF1;color:#0c5460}
.status-pill.sp-preorder{background:#E8E3FF;color:#4A35CC}
.status-pill.sp-backordr{background:#FFF0E0;color:#884400}
.order-card-mid{color:var(--text-muted);font-size:12px;margin-top:5px}
.order-card-bot{display:flex;justify-content:space-between;align-items:center;margin-top:8px}
.order-wpo{font-family:var(--mono);font-size:11.5px;color:var(--primary);font-weight:500}
.order-amount{font-weight:700;font-size:14.5px}
.order-tags{display:flex;align-items:center;gap:6px;margin-top:6px;flex-wrap:wrap}
.pay-badge{display:inline-block;font-size:10.5px;padding:2px 8px;border-radius:8px;font-weight:600}
.pay-badge.paid   {background:#D4EDDA;color:#155724}
.pay-badge.partial{background:#FFF3CD;color:#856404}
.pay-badge.unpaid {background:#F8D7DA;color:#721c24}
.pay-badge.cod    {background:#E2E3E5;color:#383d41}
.preorder-badge{background:#E8E3FF;color:#4A35CC;font-size:10.5px;padding:2px 8px;border-radius:8px;font-weight:600}
.priority-badge{font-size:10.5px;padding:2px 8px;border-radius:8px;font-weight:600}
.priority-badge.high  {background:#FFE8D9;color:#CC5500}
.priority-badge.urgent{background:#FFD9DF;color:#CC0033}

/* ── DISPATCH CARD ── */
.dispatch-card{background:var(--card);border-radius:var(--radius);padding:15px;box-shadow:var(--shadow-card);border-left:4px solid var(--warning);margin-bottom:10px}
.dispatch-card-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.dispatch-card-name{font-weight:700;font-size:15px}
.dispatch-card-info{font-size:12.5px;color:var(--text-muted);margin-bottom:10px}
.dispatch-date-badge{display:inline-block;background:#FFF3CD;color:#856404;font-size:11px;padding:3px 10px;border-radius:8px;font-weight:600;margin-bottom:6px}
.dispatch-date-badge.overdue{background:#F8D7DA;color:#721c24}
.btn-dispatch{padding:9px 18px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;font-weight:600;cursor:pointer}

/* ── ITEMS ── */
.item-header{display:grid;grid-template-columns:1fr 58px 78px 30px;gap:6px;margin-bottom:4px}
.item-header span{font-size:10px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.4px}
.item-row{display:grid;grid-template-columns:1fr 58px 78px 30px;gap:6px;align-items:center;margin-bottom:6px}
.item-row input{padding:8px 9px;font-size:13px}
.btn-del{background:#FFE5E5;color:var(--accent3);border:none;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center}

/* ── TOTALS ── */
.totals-box{background:var(--bg);border-radius:var(--radius-sm);padding:13px;margin:10px 0;border:1px solid var(--border)}
.total-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}
.total-row span:last-child{font-family:var(--mono)}
.muted-row{color:var(--text-muted);font-size:11.5px}
.total-final{border-top:1.5px solid var(--border);margin-top:6px;padding-top:7px;font-weight:700;font-size:15px;color:var(--primary)}

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

/* ── SEARCH ── */
.search-bar{display:flex;gap:8px;margin-bottom:14px}
.search-bar input{flex:1;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:14px;outline:none;background:var(--card)}
.search-bar select{padding:10px 8px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-family:var(--font);font-size:13px;background:var(--card);outline:none;-webkit-appearance:none}

/* ── ADMIN TABS ── */
.admin-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.tab-btn{padding:7px 13px;border:1.5px solid var(--border);border-radius:20px;background:var(--card);font-family:var(--font);font-size:12.5px;font-weight:500;cursor:pointer;transition:all 0.2s;color:var(--text)}
.tab-btn.active{background:var(--primary);color:#fff;border-color:var(--primary);font-weight:600}
.admin-tab-content.hidden{display:none}

/* ── REPORT TABLES ── */
.report-table{width:100%;border-collapse:collapse;font-size:12.5px;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);margin-bottom:14px}
.report-table th{background:var(--primary);color:#fff;padding:9px 11px;text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:0.5px}
.report-table td{padding:9px 11px;border-bottom:1px solid var(--border);vertical-align:middle}
.report-table tr:last-child td{border-bottom:none}
.report-table tr:hover td{background:rgba(108,99,255,0.03)}
.report-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.summary-card{background:var(--card);border-radius:var(--radius-sm);padding:13px;box-shadow:var(--shadow-card)}
.summary-card .s-num{font-size:20px;font-weight:700;color:var(--primary);font-family:var(--mono)}
.summary-card .s-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}

/* ── SETTINGS ── */
.settings-section{background:var(--card);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-card);margin-bottom:14px}
.settings-section-title{font-size:13.5px;font-weight:700;color:var(--text);margin-bottom:14px;padding-bottom:10px;border-bottom:1.5px solid var(--border)}
.settings-hint{font-size:12.5px;color:var(--text-muted);margin-bottom:12px;line-height:1.6}

/* ── LOGO UPLOAD ── */
.logo-upload-wrap{display:flex;align-items:flex-start;gap:14px}
.logo-preview{width:70px;height:70px;border-radius:12px;border:2px dashed var(--border);display:flex;align-items:center;justify-content:center;font-size:26px;background:var(--bg);overflow:hidden;flex-shrink:0}
.logo-preview.sm{width:54px;height:54px;font-size:13px;font-weight:700;color:var(--text-muted)}
.logo-preview img{width:100%;height:100%;object-fit:contain}
.logo-upload-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding-top:4px}
.upload-hint{font-size:11px;color:var(--text-muted);width:100%;margin-top:2px}

/* ── PROFILE PAGE ── */
.profile-header-card{background:linear-gradient(135deg,var(--primary),var(--primary-dark));border-radius:var(--radius);padding:28px 20px;text-align:center;color:#fff;margin-bottom:16px;position:relative}
.profile-photo-wrap{position:relative;display:inline-block;margin-bottom:14px}
.profile-photo-big{width:86px;height:86px;border-radius:50%;border:3px solid rgba(255,255,255,0.5);background:rgba(255,255,255,0.2);display:flex;align-items:center;justify-content:center;font-size:36px;overflow:hidden;margin:0 auto}
.profile-photo-big img{width:100%;height:100%;object-fit:cover}
.profile-photo-edit{position:absolute;bottom:0;right:0;width:28px;height:28px;background:#fff;border:none;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.profile-name-big{font-size:20px;font-weight:700;letter-spacing:-0.3px}
.profile-role-big{font-size:12.5px;opacity:0.8;margin-top:3px}
.profile-phone-big{font-size:13px;opacity:0.7;margin-top:2px;font-family:var(--mono)}
.profile-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ps-item{background:var(--bg);border-radius:var(--radius-sm);padding:12px;text-align:center}
.ps-num{font-size:22px;font-weight:700;color:var(--primary);font-family:var(--mono)}
.ps-lbl{font-size:11px;color:var(--text-muted);margin-top:2px}

/* ── USER MANAGEMENT ── */
.user-admin-card{background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-card);margin-bottom:10px;display:flex;align-items:center;gap:12px}
.uac-photo{width:46px;height:46px;border-radius:50%;background:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden;flex-shrink:0}
.uac-photo img{width:100%;height:100%;object-fit:cover}
.uac-info{flex:1;min-width:0}
.uac-name{font-weight:700;font-size:14.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.uac-sub{font-size:12px;color:var(--text-muted);margin-top:2px;font-family:var(--mono)}
.uac-role{display:inline-block;font-size:10.5px;padding:2px 9px;border-radius:8px;font-weight:600;margin-top:4px}
.uac-role.admin{background:#E8E3FF;color:#4A35CC}
.uac-role.user {background:#D4EDDA;color:#155724}
.uac-actions{display:flex;gap:6px;flex-shrink:0}
.uac-btn{width:34px;height:34px;border:1.5px solid var(--border);border-radius:9px;background:var(--bg);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}

/* ── BANK ACCOUNT CARDS ── */
.bank-account-item{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:13px;margin-bottom:12px}
.bank-account-item .bai-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.bank-account-item .bai-name{font-weight:700;font-size:14px}
.bank-account-item .bai-remove{background:none;border:none;color:var(--accent3);font-size:18px;cursor:pointer;padding:0}

/* ── MODAL ── */
.modal{position:fixed;inset:0;z-index:500}
.modal.hidden{display:none}
.modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.45);backdrop-filter:blur(3px)}
.modal-sheet{position:absolute;bottom:0;left:0;right:0;background:var(--card);border-radius:24px 24px 0 0;padding:8px 20px 36px;max-height:93vh;overflow-y:auto;animation:slideUp 0.3s ease}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.modal-handle{width:36px;height:4px;background:var(--border);border-radius:2px;margin:8px auto 14px}
.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.modal-header h2{font-size:17px;font-weight:700}
.detail-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid var(--border);gap:12px}
.detail-row:last-child{border-bottom:none}
.detail-label{color:var(--text-muted);font-size:12px;flex-shrink:0}
.detail-value{text-align:right;font-weight:500;font-size:13px;word-break:break-word}
.detail-value a{color:var(--primary);text-decoration:none}
.modal-actions{display:flex;flex-direction:column;gap:9px;margin-top:18px}
.modal-section-title{font-weight:700;font-size:13px;margin:10px 0 8px}
.dispatch-order-info{background:var(--bg);border-radius:var(--radius-sm);padding:13px;font-size:13px}

/* ── PRINT OPTIONS ── */
.print-options{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.print-option{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:18px 12px;text-align:center;cursor:pointer;transition:all 0.2s}
.print-option:hover{border-color:var(--primary);background:var(--primary-light)}
.print-option:active{transform:scale(0.97)}
.po-icon{font-size:30px;margin-bottom:7px}
.po-label{font-weight:700;font-size:13px}
.po-desc{font-size:11px;color:var(--text-muted);margin-top:3px}

/* ── SCAN ── */
#scan-preview-wrap{position:relative;border-radius:12px;overflow:hidden}
#scan-video{width:100%;display:block;background:#000;border-radius:12px;max-height:260px;object-fit:cover}
.scan-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.scan-frame{width:200px;height:120px;border:2.5px solid var(--primary);border-radius:12px;box-shadow:0 0 0 9999px rgba(0,0,0,0.4);position:relative;overflow:hidden}
.scan-line{position:absolute;width:180px;height:2px;background:var(--accent2);animation:scanAnim 2s infinite;border-radius:1px}
@keyframes scanAnim{0%,100%{top:10%}50%{top:85%}}

/* ── TOAST ── */
.toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%);background:#1A1D2E;color:#fff;padding:11px 18px;border-radius:12px;font-size:13.5px;font-weight:500;z-index:9999;box-shadow:0 8px 30px rgba(0,0,0,0.25);white-space:nowrap;animation:toastIn 0.25s ease}
.toast.hidden{display:none}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}

/* ── MISC ── */
.error-msg{color:var(--accent3);font-size:13px;margin-bottom:12px;text-align:center}
.hidden{display:none!important}
.empty-state{text-align:center;padding:38px 20px;color:var(--text-muted)}
.empty-state .e-icon{font-size:42px;margin-bottom:11px;display:block}
.empty-state p{font-size:14px}
.report-cards{display:flex;flex-direction:column;gap:14px}
.report-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:16px}
.report-card h3{font-size:14px;font-weight:600;margin-bottom:11px}

/* ── REPORT BUILDER ── */
.rb-toolbar{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.rb-filter-bar{display:flex;gap:8px;flex-wrap:wrap;background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-card);margin-bottom:14px;align-items:flex-end}
.rb-workspace{display:flex;gap:12px;align-items:flex-start;min-height:400px}
.rb-palette{width:168px;flex-shrink:0;background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-card)}
.rb-palette-title{font-size:11.5px;font-weight:700;color:var(--text);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.5px}
.rb-palette-hint{font-size:10.5px;color:var(--text-muted);margin-bottom:8px}
.rb-field-list{display:flex;flex-direction:column;gap:5px}
.rb-field-chip{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:7px 10px;font-size:12.5px;font-weight:500;cursor:grab;user-select:none;display:flex;align-items:center;gap:6px;transition:all 0.18s;color:var(--text)}
.rb-field-chip:hover{border-color:var(--primary);color:var(--primary);background:var(--primary-light)}
.rb-field-chip:active{cursor:grabbing;transform:scale(0.97)}
.rb-field-chip .fc-icon{font-size:14px;flex-shrink:0}
.rb-canvas-wrap{flex:1;background:var(--card);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-card);min-width:0}
.rb-canvas-title{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:700;margin-bottom:10px;color:var(--text)}
.rb-columns-row{display:flex;flex-wrap:wrap;gap:7px;min-height:44px;border:2px dashed var(--border);border-radius:var(--radius-sm);padding:8px 10px;margin-bottom:8px;transition:border-color 0.2s;align-items:center}
.rb-columns-row.drag-over{border-color:var(--primary);background:var(--primary-light)}
.rb-summary-row{display:flex;flex-wrap:wrap;gap:7px;min-height:40px;border:2px dashed #43C6AC55;border-radius:var(--radius-sm);padding:7px 10px;margin-bottom:12px;transition:border-color 0.2s;align-items:center}
.rb-summary-row.drag-over{border-color:var(--accent2);background:rgba(67,198,172,0.08)}
.rb-drop-hint{font-size:12px;color:var(--text-muted);pointer-events:none;font-style:italic}
.rb-col-chip{display:inline-flex;align-items:center;gap:6px;background:var(--primary);color:#fff;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;cursor:default;user-select:none;animation:chipIn 0.2s ease}
.rb-col-chip .chip-del{cursor:pointer;opacity:0.75;font-size:14px;line-height:1;margin-left:2px}
.rb-col-chip .chip-del:hover{opacity:1}
.rb-col-chip.dragging-chip{cursor:grab}
.rb-sum-chip{display:inline-flex;align-items:center;gap:6px;background:var(--accent2);color:#fff;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:600;cursor:default;user-select:none;animation:chipIn 0.2s ease}
.rb-sum-chip .chip-del{cursor:pointer;opacity:0.75;font-size:14px;line-height:1;margin-left:2px}
@keyframes chipIn{from{opacity:0;transform:scale(0.85)}to{opacity:1;transform:scale(1)}}
.rb-preview-wrap{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--border)}
.rb-table{width:100%;border-collapse:collapse;font-size:12.5px}
.rb-table th{background:var(--primary);color:#fff;padding:9px 12px;text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:0.5px;white-space:nowrap;position:sticky;top:0}
.rb-table td{padding:9px 12px;border-bottom:1px solid var(--border);vertical-align:middle;white-space:nowrap}
.rb-table tr:last-child td{border-bottom:none}
.rb-table tr:hover td{background:rgba(108,99,255,0.03)}
.rb-table tfoot td{background:#f0f0f7;font-weight:700;color:var(--primary);border-top:2px solid var(--primary);font-size:12.5px}
.rb-summary-cards{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.rb-sum-card{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;min-width:110px}
.rb-sum-card .sc-val{font-size:20px;font-weight:700;color:var(--primary);font-family:var(--mono)}
.rb-sum-card .sc-lbl{font-size:10.5px;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:0.4px}
.rb-template-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border);gap:10px}
.rb-template-item:last-child{border-bottom:none}
.rb-template-name{font-weight:600;font-size:14px}
.rb-template-meta{font-size:11.5px;color:var(--text-muted);margin-top:2px}
.rb-template-actions{display:flex;gap:6px;flex-shrink:0}

/* ── BONUS PROGRAMME ── */
.bonus-hero{background:linear-gradient(140deg,#1A1D2E 0%,#2D1F6E 60%,#4A2080 100%);border-radius:var(--radius);padding:22px 20px 20px;color:#fff;margin-bottom:14px;position:relative;overflow:hidden}
.bonus-hero::before{content:'';position:absolute;top:-30px;right:-30px;width:160px;height:160px;border-radius:50%;background:rgba(255,255,255,0.04)}
.bonus-hero::after{content:'';position:absolute;bottom:-40px;left:-20px;width:120px;height:120px;border-radius:50%;background:rgba(255,255,255,0.03)}
.bh-top{display:flex;align-items:center;gap:12px;margin-bottom:18px;position:relative;z-index:1}
.bh-avatar{width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,0.15);border:2px solid rgba(255,255,255,0.3);display:flex;align-items:center;justify-content:center;font-size:20px;overflow:hidden;flex-shrink:0}
.bh-avatar img{width:100%;height:100%;object-fit:cover}
.bh-name{font-size:17px;font-weight:700;letter-spacing:-0.3px}
.bh-role{font-size:11.5px;opacity:0.65;margin-top:2px}
.bh-earned-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;opacity:0.6;margin-bottom:5px;position:relative;z-index:1}
.bh-earned{font-size:40px;font-weight:900;font-family:var(--mono);letter-spacing:-1px;line-height:1;position:relative;z-index:1;color:#FFD700}
.bh-sub{font-size:12.5px;opacity:0.65;margin-top:5px;position:relative;z-index:1}
.bh-progress-wrap{margin-top:18px;position:relative;z-index:1}
.bh-progress-track{height:8px;background:rgba(255,255,255,0.15);border-radius:4px;overflow:hidden;margin-bottom:6px}
.bh-progress-bar{height:100%;background:linear-gradient(90deg,#FFD700,#FF8C00);border-radius:4px;transition:width 0.8s cubic-bezier(.4,0,.2,1)}
.bh-progress-labels{display:flex;justify-content:space-between;font-size:10px;opacity:0.6}
.bonus-period-row{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:16px;background:var(--card);border-radius:var(--radius-sm);padding:12px 14px;box-shadow:var(--shadow-card)}
.bonus-tiers-row{display:flex;gap:10px;overflow-x:auto;padding-bottom:6px;margin-bottom:18px}
.bonus-tier-card{flex-shrink:0;width:150px;border-radius:var(--radius);padding:16px 14px;position:relative;overflow:hidden;cursor:default;transition:transform 0.2s}
.bonus-tier-card:active{transform:scale(0.97)}
.btc-pct{font-size:28px;font-weight:900;font-family:var(--mono);line-height:1}
.btc-label{font-size:11px;font-weight:600;margin-top:4px;opacity:0.85;text-transform:uppercase;letter-spacing:0.5px}
.btc-range{font-size:10.5px;margin-top:5px;opacity:0.7}
.btc-sales{font-size:13px;font-weight:700;margin-top:10px;font-family:var(--mono)}
.btc-bonus{font-size:12px;margin-top:2px;opacity:0.8}
.btc-badge{position:absolute;top:10px;right:10px;background:rgba(255,255,255,0.25);border-radius:20px;padding:2px 8px;font-size:10px;font-weight:700}
.btc-active{box-shadow:0 0 0 3px #FFD700,0 8px 24px rgba(0,0,0,0.15)}
.bonus-today-card{background:var(--card);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-card);margin-bottom:18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.btd-item{text-align:center}
.btd-val{font-size:20px;font-weight:700;font-family:var(--mono);color:var(--primary)}
.btd-lbl{font-size:10.5px;color:var(--text-muted);margin-top:2px;text-transform:uppercase;letter-spacing:0.4px}
.bonus-table{width:100%;border-collapse:collapse;font-size:13px;background:var(--card);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card)}
.bonus-table th{background:#1A1D2E;color:#fff;padding:9px 12px;text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:0.5px}
.bonus-table td{padding:9px 12px;border-bottom:1px solid var(--border)}
.bonus-table tr:last-child td{border-bottom:none;background:#f0f0f7;font-weight:700}
.bonus-table tr.today-row td{background:rgba(255,215,0,0.08)}
/* Admin bonus settings */
.bonus-enable-row{padding:10px 0 6px}
.bonus-tier-header{display:grid;grid-template-columns:1fr 1fr 80px 1fr 32px;gap:8px;margin-bottom:6px}
.bonus-tier-header span{font-size:10.5px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.4px}
.bonus-tier-row{display:grid;grid-template-columns:1fr 1fr 80px 1fr 32px;gap:8px;align-items:center;margin-bottom:8px}
.bonus-tier-row input{padding:9px 10px;font-size:13px;border:1.5px solid var(--border);border-radius:8px;background:var(--bg);font-family:var(--font);width:100%;outline:none}
.bonus-tier-row input:focus{border-color:var(--primary);background:#fff}
/* Admin bonus panel — leaderboard */
.abp-team-banner{background:linear-gradient(135deg,#1A1D2E 0%,#2D1F6E 55%,#3D1080 100%);border-radius:var(--radius);padding:18px 18px 16px;color:#fff;margin-bottom:14px}
.abp-team-title{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.abp-team-icon{font-size:26px}
.abp-team-label{font-size:16px;font-weight:700;letter-spacing:-0.3px}
.abp-team-month{font-size:11.5px;opacity:0.6;margin-top:2px}
.abp-team-stats{display:flex;gap:0;background:rgba(255,255,255,0.08);border-radius:var(--radius-sm);overflow:hidden}
.abp-ts-item{flex:1;padding:10px 8px;text-align:center}
.abp-ts-val{font-size:15px;font-weight:800;font-family:var(--mono);color:#fff}
.abp-ts-lbl{font-size:9.5px;opacity:0.6;text-transform:uppercase;letter-spacing:0.5px;margin-top:2px}
.abp-ts-divider{width:1px;background:rgba(255,255,255,0.15);margin:8px 0}

.abp-lb-header{display:flex;justify-content:space-between;align-items:center;font-size:14px;font-weight:700;color:var(--text);margin-bottom:10px;padding:0 2px}

.abp-agent-list{display:flex;flex-direction:column;gap:12px}

.abp-agent-card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow-card);padding:16px;position:relative;border-left:4px solid var(--ac,var(--primary));transition:transform 0.15s}
.abp-agent-card:active{transform:scale(0.99)}
.abp-top-agent{background:linear-gradient(135deg,#fffdf0,#fff9e6);border-left-color:#FFD700;box-shadow:0 4px 24px rgba(255,215,0,0.18)}

.abp-rank{position:absolute;top:14px;right:14px;font-size:20px;line-height:1}

.abp-agent-info{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.abp-agent-photo{width:52px;height:52px;border-radius:50%;border:2.5px solid var(--ac,var(--primary));display:flex;align-items:center;justify-content:center;background:var(--bg);overflow:hidden;flex-shrink:0}
.abp-agent-meta{flex:1;min-width:0}
.abp-agent-name{font-size:15px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.abp-crown{font-size:10.5px;background:#FFD70022;color:#997700;padding:2px 8px;border-radius:8px;font-weight:700}
.abp-agent-sub{font-size:11.5px;color:var(--text-muted);margin-top:3px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.abp-tier-pill{padding:2px 9px;border-radius:12px;font-weight:700;font-size:11px}
.abp-bonus-big{text-align:right;flex-shrink:0}
.abp-bonus-val{font-size:20px;font-weight:900;font-family:var(--mono);line-height:1}
.abp-bonus-lbl{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-top:3px}

.abp-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}
.abp-stat-box{background:var(--bg);border-radius:var(--radius-sm);padding:9px 8px;text-align:center}
.abp-sb-val{font-size:14px;font-weight:700;color:var(--text);font-family:var(--mono)}
.abp-sb-lbl{font-size:9.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.4px;margin-top:2px}

.abp-progress-wrap{margin-bottom:12px}
.abp-progress-labels{display:flex;justify-content:space-between;font-size:10px;color:var(--text-muted);margin-bottom:5px;font-weight:500}
.abp-progress-track{height:7px;background:var(--border);border-radius:4px;overflow:hidden}
.abp-progress-fill{height:100%;border-radius:4px;transition:width 0.8s cubic-bezier(.4,0,.2,1)}

.abp-sparkline{border-top:1px solid var(--border);padding-top:10px}
.abp-spark-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.5px;margin-bottom:6px;font-weight:600}
.abp-spark-bars{display:flex;align-items:flex-end;gap:4px;height:40px}
.abp-spark-bar{flex:1;min-height:4px;transition:background 0.2s;cursor:default}
.abp-spark-today{position:relative}
.abp-spark-today::after{content:'▾';position:absolute;bottom:-12px;left:50%;transform:translateX(-50%);font-size:9px;color:var(--primary)}
.bonus-disabled-notice{text-align:center;padding:40px 20px;color:var(--text-muted)}
.bonus-disabled-notice .e-icon{font-size:40px;margin-bottom:10px;display:block}

/* ── PRINT ── */
@media print {
  @page {
    size: A4 portrait;
    margin: 8mm 8mm 8mm 8mm;
  }
  body > *:not(#print-area) { display: none !important; }
  #print-area {
    display: block !important;
    position: fixed;
    inset: 0;
    background: #fff;
    overflow: visible;
  }
  #sl-wrap {
    width: 100% !important;
    outline: 2.5px solid #000 !important;
  }
}

/* ── AUTO ORDER BANNER ── */
.auto-order-banner{display:flex;align-items:center;gap:10px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border-radius:var(--radius-sm);padding:10px 16px;margin-bottom:12px;font-size:13.5px;font-weight:600}
.auto-order-num{font-family:var(--mono);font-size:15px;font-weight:700;letter-spacing:0.5px;background:rgba(255,255,255,0.2);padding:3px 12px;border-radius:6px}

/* ── ITEM TAG COLUMN ── */
.item-header{display:grid;grid-template-columns:80px 1fr 50px 72px 30px;gap:5px;margin-bottom:4px}
.item-header span{font-size:10px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:0.4px}
.item-row{display:grid;grid-template-columns:80px 1fr 50px 72px 30px;gap:5px;align-items:center;margin-bottom:6px}
.item-row input{padding:8px 8px;font-size:13px}
.btn-del{background:#FFE5E5;color:var(--accent3);border:none;border-radius:8px;width:30px;height:30px;cursor:pointer;font-size:17px;display:flex;align-items:center;justify-content:center}

/* ── CANCEL / REFUND BADGES ── */
.status-pill.sp-cancelled{background:#F8D7DA;color:#721c24}
.status-pill.sp-refunded {background:#D4EDDA;color:#155724}
.order-card.status-cancelled{border-left-color:#dc3545}
.order-card.status-refunded {border-left-color:#28A745}
.cancelled-banner{background:#F8D7DA;border:1px solid #f5c6cb;border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:12px;font-size:13px}
.refunded-banner {background:#D4EDDA;border:1px solid #c3e6cb;border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:12px;font-size:13px}
.cancel-order-info{background:var(--bg);border-radius:var(--radius-sm);padding:13px;font-size:13px;margin-bottom:4px}
.cancel-order-info .ci-name{font-weight:700;font-size:15px;margin-bottom:4px}
.cancel-order-info .ci-row{display:flex;justify-content:space-between;font-size:12.5px;color:var(--text-muted);padding:2px 0}

/* ── INFO BOXES ── */
.info-box{border-radius:var(--radius-sm);padding:11px 14px;font-size:12.5px;line-height:1.6;margin-top:10px}
.warning-box{background:#FFF3CD;border:1px solid #ffc107;color:#856404}
.success-box{background:#D4EDDA;border:1px solid #c3e6cb;color:#155724}
.field-hint{font-size:11.5px;color:var(--text-muted);margin-top:4px}

/* ── DANGER BUTTON ── */
.btn-danger{width:100%;padding:13px;background:#dc3545;color:#fff;border:none;border-radius:var(--radius-sm);font-family:var(--font);font-size:15px;font-weight:600;cursor:pointer;transition:background 0.2s}
.btn-danger:active{background:#c82333}

/* ── REFUND TRACK BADGE ── */
.refund-track-pill{display:inline-flex;align-items:center;gap:6px;background:#D4EDDA;color:#155724;border-radius:8px;padding:4px 12px;font-size:12px;font-weight:600;font-family:var(--mono);margin-top:6px}

