/* ================================================================
   OnSpot SaaS — Master Stylesheet
   Theme: Dark (default) / Light toggle, Cyan #00d4ff primary
   ================================================================ */

:root {
    --primary:       #00d4ff;
    --primary-dim:   rgba(0,212,255,.15);
    --primary-hover: #00b8dc;
    --bg:            #0b0f1a;
    --surface:       #131a2a;
    --surface2:      #1a2235;
    --sidebar-bg:    #0e1525;
    --text:          #e2e8f0;
    --muted:         #94a3b8;
    --line:          rgba(255,255,255,.08);
    --success:       #00ff95;
    --danger:        #ff5757;
    --warning:       #ffa500;
    --info:          #60a5fa;
    --radius:        10px;
    --radius-sm:     6px;
    --radius-pill:   999px;
    --shadow:        0 4px 24px rgba(0,0,0,.4);
    --shadow-sm:     0 2px 8px rgba(0,0,0,.25);
    --transition:    all .2s ease;
}
[data-theme="light"] {
    --bg:         #f0f2f7;
    --surface:    #ffffff;
    --surface2:   #f8fafc;
    --sidebar-bg: #ffffff;
    --text:       #1e293b;
    --muted:      #64748b;
    --line:       rgba(0,0,0,.08);
    --shadow:     0 4px 24px rgba(0,0,0,.1);
    --shadow-sm:  0 2px 8px rgba(0,0,0,.07);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
body {
    font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
    background:var(--bg);
    color:var(--text);
    transition:background .3s,color .3s;
    min-height:100vh;
    font-size:.9rem;
}
a { color:inherit; text-decoration:none; }
img { max-width:100%; }

/* ── Scrollbar ────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--line); border-radius:9px; }

/* ── Sidebar ──────────────────────────────────────────── */
.sidebar {
    width:248px;
    background:var(--sidebar-bg);
    border-right:1px solid var(--line);
    position:fixed;
    top:0;left:0;bottom:0;
    display:flex;
    flex-direction:column;
    z-index:200;
    overflow:hidden;
    transition:transform .3s, width .25s ease;
}

/* ── Logo ── */
.sidebar-logo {
    padding:18px 18px 16px;
    display:flex;
    align-items:center;
    gap:10px;
    flex-shrink:0;
}
.sidebar-logo img { height:32px; max-width:140px; object-fit:contain; }
.sidebar-logo-icon {
    width:34px; height:34px; border-radius:9px;
    background:var(--primary-dim);
    display:flex; align-items:center; justify-content:center;
    color:var(--primary); font-size:1rem; flex-shrink:0;
}
.sidebar-logo-text {
    font-size:1.15rem;
    font-weight:900;
    color:var(--text);
    letter-spacing:-.5px;
    line-height:1;
}
.sidebar-logo-sub { font-size:.58rem; color:var(--muted); letter-spacing:.5px; text-transform:uppercase; margin-top:2px; }

/* ── Nav ── */
.sidebar-nav {
    flex:1; padding:8px 10px 4px;
    overflow-y:auto; overflow-x:hidden;
    scrollbar-width:none;
}
.sidebar-nav::-webkit-scrollbar { display:none; }

.nav-section { margin-bottom:4px; }
.nav-section-hdr {
    display:flex; align-items:center; justify-content:space-between;
    width:100%; padding:8px 10px 6px;
    font-size:.68rem; font-weight:700;
    color:var(--muted); text-transform:uppercase; letter-spacing:.9px;
    background:none; border:none; cursor:pointer;
    border-radius:var(--radius-sm);
    transition:color .15s;
}
.nav-section-hdr:hover { color:var(--text); }
.nav-section-arrow { font-size:.6rem; transition:transform .25s ease; }
.nav-section.collapsed .nav-section-arrow { transform:rotate(-90deg); }
.nav-section-body { overflow:hidden; transition:max-height .28s ease; }
.nav-section.collapsed .nav-section-body { max-height:0 !important; }

/* keep nav-group + nav-label for backward compat */
.nav-group { margin-bottom:2px; }
.nav-label {
    font-size:.66rem; font-weight:700; color:var(--muted);
    text-transform:uppercase; letter-spacing:1px; padding:10px 10px 4px;
}

.nav-link {
    display:flex; align-items:center; gap:11px;
    padding:9px 12px; border-radius:var(--radius-sm);
    color:rgba(255,255,255,.5); font-weight:600; font-size:.875rem;
    transition:var(--transition); position:relative;
}
.nav-link:hover { color:var(--text); background:rgba(255,255,255,.04); }
.nav-link.active { background:rgba(255,255,255,.06); color:var(--text); font-weight:700; }
.nav-link.active::before {
    content:''; position:absolute; left:0; top:20%; bottom:20%;
    width:3px; background:var(--primary); border-radius:0 3px 3px 0;
}
.nav-link i { width:18px; text-align:center; font-size:.88rem; flex-shrink:0; }
.nav-badge {
    margin-left:auto; background:var(--primary); color:#000;
    font-size:.6rem; font-weight:800; padding:2px 7px;
    border-radius:var(--radius-pill); letter-spacing:.3px;
}

/* ── Subscription Badge Card ── */
.sb-plan-card {
    margin:6px 12px 8px;
    background:rgba(255,255,255,.04);
    border:1px solid rgba(255,255,255,.09);
    border-radius:12px;
    padding:14px 14px 12px;
    flex-shrink:0;
    position:relative;
    overflow:hidden;
}
.sb-plan-card::before {
    content:'';
    position:absolute; top:0; left:0; right:0; height:2px;
    background:linear-gradient(90deg,var(--primary),rgba(0,212,255,.2));
    border-radius:12px 12px 0 0;
}
.sb-plan-icon {
    width:32px; height:32px; border-radius:8px;
    background:var(--primary-dim);
    display:flex; align-items:center; justify-content:center;
    color:var(--primary); font-size:.95rem; margin-bottom:10px;
}
.sb-plan-name {
    font-size:.8rem; font-weight:800; color:var(--text);
    margin-bottom:4px; line-height:1.2;
}
.sb-plan-msg {
    font-size:.7rem; color:var(--muted); margin-bottom:10px; line-height:1.4;
}
.sb-plan-btn {
    display:block; text-align:center;
    background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
    color:var(--text); font-size:.72rem; font-weight:700;
    padding:7px 10px; border-radius:7px;
    transition:.15s;
}
.sb-plan-btn:hover { background:var(--primary-dim); color:var(--primary); border-color:var(--primary); }

/* ── Sidebar user card ── */
.sidebar-user-card {
    display:flex; align-items:center; gap:10px;
    padding:12px 14px; margin:0;
    border-top:1px solid var(--line);
    flex-shrink:0; cursor:pointer;
    transition:.15s;
}
.sidebar-user-card:hover { background:rgba(255,255,255,.03); }
.sb-user-avatar {
    width:34px; height:34px; border-radius:50%;
    background:var(--primary-dim); color:var(--primary);
    display:flex; align-items:center; justify-content:center;
    font-size:.75rem; font-weight:800; flex-shrink:0;
}
.sb-user-info { flex:1; min-width:0; }
.sb-user-name {
    font-size:.8rem; font-weight:800; color:var(--text);
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sb-user-email {
    font-size:.65rem; color:var(--muted); margin-top:1px;
    white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
}
.sb-user-more {
    background:none; border:none; color:var(--muted); cursor:pointer;
    padding:4px; font-size:.85rem; flex-shrink:0; border-radius:5px;
    transition:.15s;
}
.sb-user-more:hover { color:var(--text); background:rgba(255,255,255,.06); }

/* keep legacy footer rule so nothing breaks */
.sidebar-footer { padding:0; border-top:none; font-size:.8rem; color:var(--muted); }
.sidebar-footer a { color:var(--danger); font-weight:600; }
.sidebar-footer a:hover { text-decoration:underline; }

/* ── Topbar ───────────────────────────────────────────── */
.topbar {
    background:var(--surface);
    border-bottom:1px solid var(--line);
    padding:0 24px;
    height:58px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    position:sticky;
    top:0;
    z-index:100;
    box-shadow:var(--shadow-sm);
}
.topbar-left { display:flex; align-items:center; gap:14px; }
.topbar-title { font-size:1rem; font-weight:700; color:var(--text); }
.topbar-logo-mobile { display: none; }
.topbar-user-name-mobile {
  display: none;
  flex-direction: column;
  align-items: flex-end;
  line-height: 1.2;
}
.topbar-user-name-mobile .tun-name {
  font-size: .78rem;
  font-weight: 800;
  color: var(--text);
  white-space: nowrap;
  max-width: 110px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.topbar-user-name-mobile .tun-role {
  font-size: .6rem;
  color: var(--muted);
  font-weight: 600;
  text-transform: capitalize;
}
.topbar-right { display:flex; align-items:center; gap:10px; }

/* ── Main Content ─────────────────────────────────────── */
.main-wrap { margin-left:248px; min-height:100vh; display:flex; flex-direction:column; }
.main-content { flex:1; padding:24px; }
.page-header {
    display:flex;
    align-items:center;
    justify-content:space-between;
    margin-bottom:20px;
    flex-wrap:wrap;
    gap:12px;
}
.page-title { font-size:1.25rem; font-weight:800; color:var(--text); }
.page-subtitle { font-size:.8rem; color:var(--muted); margin-top:2px; }

/* ── Cards ────────────────────────────────────────────── */
.card {
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:20px;
    box-shadow:var(--shadow-sm);
}
.card-header {
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding-bottom:16px;
    margin-bottom:16px;
    border-bottom:1px solid var(--line);
}
.card-title { font-size:1rem; font-weight:700; color:var(--text); }

/* ── Stat Cards ────────────────────────────────────────── */
.stats-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
    gap:16px;
    margin-bottom:24px;
}
.stat-card {
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:18px 20px;
    display:flex;
    flex-direction:column;
    gap:8px;
    box-shadow:var(--shadow-sm);
    transition:var(--transition);
}
.stat-card:hover { border-color:var(--primary); box-shadow:0 0 0 1px var(--primary),var(--shadow-sm); }
.stat-icon {
    width:36px;height:36px;
    border-radius:var(--radius-sm);
    background:var(--primary-dim);
    color:var(--primary);
    display:flex;align-items:center;justify-content:center;
    font-size:1rem;
}
.stat-label { font-size:.73rem; color:var(--muted); font-weight:600; text-transform:uppercase; letter-spacing:.5px; }
.stat-value { font-size:1.6rem; font-weight:900; color:var(--text); line-height:1; }
.stat-sub { font-size:.73rem; color:var(--muted); }
.stat-up { color:var(--success); }
.stat-down { color:var(--danger); }

/* ── Buttons ──────────────────────────────────────────── */
.btn {
    display:inline-flex;align-items:center;gap:8px;
    padding:8px 16px;
    border-radius:var(--radius-sm);
    border:none;
    font-size:.85rem;
    font-weight:700;
    cursor:pointer;
    transition:var(--transition);
    text-decoration:none;
    white-space:nowrap;
}
.btn:disabled { opacity:.5; cursor:not-allowed; }
.btn-primary { background:var(--primary); color:#000; }
.btn-primary:hover { background:var(--primary-hover); }
.btn-success { background:#16a34a; color:#fff; }
.btn-success:hover { background:#15803d; }
.btn-danger { background:var(--danger); color:#fff; }
.btn-danger:hover { background:#e04444; }
.btn-warning { background:var(--warning); color:#000; }
.btn-warning:hover { background:#e09400; }
.btn-secondary { background:var(--surface2); color:var(--text); border:1px solid var(--line); }
.btn-secondary:hover { background:var(--line); }
.btn-sm { padding:5px 12px; font-size:.78rem; }
.btn-xs { padding:3px 9px; font-size:.72rem; }
.btn-icon { padding:8px; width:36px;height:36px;justify-content:center; }
.btn-outline { background:transparent; color:var(--primary); border:1px solid var(--primary); }
.btn-outline:hover { background:var(--primary-dim); }

/* ── Forms ────────────────────────────────────────────── */
.form-group { margin-bottom:16px; }
.form-group label { display:block; font-size:.8rem; font-weight:700; color:var(--muted); margin-bottom:6px; }
.form-control {
    width:100%;
    padding:9px 12px;
    background:var(--surface2);
    border:1px solid var(--line);
    border-radius:var(--radius-sm);
    color:var(--text);
    font-size:.875rem;
    transition:var(--transition);
}
.form-control:focus { outline:none; border-color:var(--primary); box-shadow:0 0 0 3px var(--primary-dim); }
.form-control::placeholder { color:var(--muted); }
select.form-control { cursor:pointer; }
textarea.form-control { resize:vertical; min-height:80px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-row-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px; }
.form-hint { font-size:.73rem; color:var(--muted); margin-top:4px; }
.form-check { display:flex; align-items:center; gap:8px; cursor:pointer; }
.form-check input { accent-color:var(--primary); width:15px; height:15px; cursor:pointer; }

/* ── Tables ───────────────────────────────────────────── */
.table-wrap { overflow-x:auto; border-radius:var(--radius); border:1px solid var(--line); }
table { width:100%; border-collapse:collapse; min-width:600px; background:var(--surface); }
thead th {
    text-align:left;
    font-size:.72rem;
    font-weight:800;
    color:var(--muted);
    text-transform:uppercase;
    letter-spacing:.5px;
    padding:11px 14px;
    border-bottom:1px solid var(--line);
    background:var(--surface2);
    white-space:nowrap;
}
tbody td {
    padding:11px 14px;
    border-bottom:1px solid var(--line);
    font-size:.86rem;
    color:var(--text);
    vertical-align:middle;
}
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover { background:rgba(255,255,255,.02); }
[data-theme="light"] tbody tr:hover { background:rgba(0,0,0,.015); }

/* ── Badges / Pills ───────────────────────────────────── */
.badge {
    display:inline-flex;align-items:center;gap:5px;
    padding:3px 9px;
    border-radius:var(--radius-pill);
    font-size:.72rem;
    font-weight:800;
    text-transform:uppercase;
    letter-spacing:.3px;
}
.badge-success { background:rgba(0,255,149,.12); color:#00e07a; }
.badge-danger  { background:rgba(255,87,87,.12);  color:#ff5757; }
.badge-warning { background:rgba(255,165,0,.12);  color:#ffa500; }
.badge-info    { background:rgba(96,165,250,.12); color:#60a5fa; }
.badge-muted   { background:rgba(148,163,184,.1); color:var(--muted); }
.badge-primary { background:var(--primary-dim);   color:var(--primary); }
[data-theme="light"] .badge-success { color:#16a34a; }
[data-theme="light"] .badge-danger  { color:#dc2626; }
[data-theme="light"] .badge-warning { color:#d97706; }
[data-theme="light"] .badge-info    { color:#2563eb; }

/* ── Alerts ───────────────────────────────────────────── */
.alert { padding:12px 16px; border-radius:var(--radius-sm); font-size:.875rem; font-weight:600; margin-bottom:16px; display:flex; align-items:center; gap:10px; }
.alert-success { background:rgba(0,255,149,.08); border:1px solid rgba(0,255,149,.25); color:#00c66e; }
.alert-danger  { background:rgba(255,87,87,.08);  border:1px solid rgba(255,87,87,.25);  color:#ff5757; }
.alert-warning { background:rgba(255,165,0,.08);  border:1px solid rgba(255,165,0,.25);  color:#ffa500; }
.alert-info    { background:rgba(0,212,255,.08);  border:1px solid rgba(0,212,255,.25);  color:var(--primary); }
[data-theme="light"] .alert-success { color:#15803d; }
[data-theme="light"] .alert-danger  { color:#b91c1c; }

/* ── Modal ────────────────────────────────────────────── */
.modal-backdrop {
    display:none;
    position:fixed;inset:0;
    background:rgba(0,0,0,.6);
    z-index:999;
    align-items:center;
    justify-content:center;
    padding:20px;
}
.modal-backdrop.show { display:flex; }
.modal {
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--radius);
    width:100%;
    max-width:520px;
    max-height:90vh;
    overflow-y:auto;
    box-shadow:var(--shadow);
    animation:modalIn .2s ease;
}
@keyframes modalIn { from{opacity:0;transform:translateY(-16px)} to{opacity:1;transform:none} }
.modal-header {
    display:flex;align-items:center;justify-content:space-between;
    padding:16px 20px;
    border-bottom:1px solid var(--line);
}
.modal-title { font-size:1rem; font-weight:800; }
.modal-close { background:none;border:none;color:var(--muted);font-size:1.2rem;cursor:pointer;padding:4px; }
.modal-close:hover { color:var(--text); }
.modal-body { padding:20px; }
.modal-footer { padding:14px 20px; border-top:1px solid var(--line); display:flex; gap:10px; justify-content:flex-end; }

/* ── Search / Filters ─────────────────────────────────── */
.toolbar {
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom:16px;
}
.search-box {
    display:flex;align-items:center;gap:8px;
    background:var(--surface2);
    border:1px solid var(--line);
    border-radius:var(--radius-sm);
    padding:0 12px;
    flex:1;
    min-width:200px;
    max-width:340px;
}
.search-box i { color:var(--muted); font-size:.85rem; }
.search-box input { border:none;background:none;color:var(--text);font-size:.875rem;width:100%;padding:9px 0; }
.search-box input:focus { outline:none; }

/* ── Pagination ───────────────────────────────────────── */
.pagination { display:flex; align-items:center; gap:6px; margin-top:16px; }
.page-btn {
    min-width:32px;height:32px;
    display:flex;align-items:center;justify-content:center;
    background:var(--surface2);
    border:1px solid var(--line);
    border-radius:var(--radius-sm);
    color:var(--muted);
    font-size:.8rem;
    font-weight:700;
    cursor:pointer;
    transition:var(--transition);
    padding:0 10px;
}
.page-btn:hover { border-color:var(--primary); color:var(--primary); }
.page-btn.active { background:var(--primary); border-color:var(--primary); color:#000; }
.page-btn:disabled { opacity:.4; cursor:not-allowed; }

/* ── Toast ────────────────────────────────────────────── */
.toast-wrap {
    position:fixed;
    bottom:24px;right:24px;
    z-index:9999;
    display:flex;flex-direction:column;gap:10px;
    pointer-events:none;
}
.toast {
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:12px 16px;
    font-size:.875rem;
    font-weight:600;
    box-shadow:var(--shadow);
    display:flex;align-items:center;gap:10px;
    pointer-events:all;
    animation:toastIn .25s ease;
    min-width:250px;
    max-width:380px;
}
@keyframes toastIn { from{opacity:0;transform:translateX(30px)} to{opacity:1;transform:none} }
.toast.fade-out { animation:toastOut .3s ease forwards; }
@keyframes toastOut { to{opacity:0;transform:translateX(30px)} }
.toast-success { border-left:3px solid var(--success); }
.toast-danger  { border-left:3px solid var(--danger); }
.toast-warning { border-left:3px solid var(--warning); }
.toast-info    { border-left:3px solid var(--primary); }

/* ── Voucher Type Badges ──────────────────────────────── */
.vtype-online        { background:rgba(0,212,255,.12); color:var(--primary); }
.vtype-physical      { background:rgba(255,165,0,.12); color:#ffa500; }
.vtype-complimentary { background:rgba(0,255,149,.12); color:#00e07a; }
[data-theme="light"] .vtype-online        { color:#0891b2; }
[data-theme="light"] .vtype-physical      { color:#d97706; }
[data-theme="light"] .vtype-complimentary { color:#16a34a; }

/* ── Login Page ───────────────────────────────────────── */
.login-page {
    min-height:100vh;
    display:flex;align-items:center;justify-content:center;
    background:var(--bg);
    padding:20px;
}
.login-card {
    background:var(--surface);
    border:1px solid var(--line);
    border-radius:var(--radius);
    padding:36px 32px;
    width:100%;max-width:420px;
    box-shadow:var(--shadow);
}
.login-logo { text-align:center; margin-bottom:28px; }
.login-logo-text { font-size:2rem;font-weight:900;color:var(--primary); }
.login-logo-sub { font-size:.75rem;color:var(--muted);letter-spacing:2px;text-transform:uppercase; }
.login-title { font-size:1.1rem;font-weight:800;margin-bottom:6px; }
.login-sub { font-size:.82rem;color:var(--muted);margin-bottom:24px; }

/* ── SaaS Plan Card ───────────────────────────────────── */
.plan-card {
    background:var(--surface);
    border:2px solid var(--line);
    border-radius:var(--radius);
    padding:24px;
    text-align:center;
    transition:var(--transition);
}
.plan-card.featured { border-color:var(--primary); }
.plan-card:hover { border-color:var(--primary); transform:translateY(-2px); box-shadow:var(--shadow); }
.plan-name { font-size:1.1rem;font-weight:800;color:var(--text); }
.plan-price { font-size:2rem;font-weight:900;color:var(--primary);margin:10px 0; }
.plan-price span { font-size:.85rem;font-weight:600;color:var(--muted); }
.plan-feature { font-size:.82rem;color:var(--muted);padding:4px 0;border-bottom:1px solid var(--line); }

/* ── Wallet Card ──────────────────────────────────────── */
.wallet-card {
    background:linear-gradient(135deg, #0f2d50 0%, #1a4870 100%);
    border:1px solid rgba(0,212,255,.2);
    border-radius:12px;
    padding:24px;
    color:#e2e8f0;
    position:relative;overflow:hidden;
}
.wallet-card::after {
    content:'';
    position:absolute;right:-30px;top:-30px;
    width:120px;height:120px;
    border-radius:50%;
    background:rgba(0,212,255,.06);
}
.wallet-balance { font-size:2.4rem;font-weight:900;color:var(--primary); }
.wallet-label   { font-size:.78rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:1px; }

/* ── Progress Bar ─────────────────────────────────────── */
.progress { height:6px;background:var(--line);border-radius:var(--radius-pill);overflow:hidden; }
.progress-bar { height:100%;background:var(--primary);border-radius:var(--radius-pill);transition:width .5s ease; }
.progress-bar.danger { background:var(--danger); }
.progress-bar.warning { background:var(--warning); }
.progress-bar.success { background:var(--success); }

/* ── Empty State ──────────────────────────────────────── */
.empty-state { text-align:center;padding:48px 24px;color:var(--muted); }
.empty-state i { font-size:2.5rem;opacity:.4;margin-bottom:12px; }
.empty-state h3 { font-size:1rem;font-weight:700;margin-bottom:6px; }
.empty-state p { font-size:.82rem; }

/* ── Section Divider ──────────────────────────────────── */
.section-divider {
    display:flex;align-items:center;gap:12px;
    margin:20px 0;
    font-size:.72rem;font-weight:700;color:var(--muted);
    text-transform:uppercase;letter-spacing:1px;
}
.section-divider::before,.section-divider::after { content:'';flex:1;border-top:1px solid var(--line); }

/* ── Utilities ────────────────────────────────────────── */
.flex        { display:flex; }
.flex-wrap   { flex-wrap:wrap; }
.items-center{ align-items:center; }
.justify-between { justify-content:space-between; }
.gap-2  { gap:8px; }
.gap-3  { gap:12px; }
.gap-4  { gap:16px; }
.mt-2   { margin-top:8px; }
.mt-4   { margin-top:16px; }
.mb-4   { margin-bottom:16px; }
.text-muted   { color:var(--muted); }
.text-primary { color:var(--primary); }
.text-success { color:var(--success); }
.text-danger  { color:var(--danger); }
.text-warning { color:var(--warning); }
.text-right   { text-align:right; }
.font-bold    { font-weight:700; }
.font-black   { font-weight:900; }
.text-sm      { font-size:.8rem; }
.text-xs      { font-size:.72rem; }
.text-lg      { font-size:1.1rem; }
.nowrap       { white-space:nowrap; }
.truncate     { overflow:hidden;text-overflow:ellipsis;white-space:nowrap; }
.w-full       { width:100%; }
.hidden       { display:none !important; }

/* ── Grid Layouts ─────────────────────────────────────── */
.grid-2 { display:grid;grid-template-columns:1fr 1fr;gap:16px; }
.grid-3 { display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px; }
.grid-4 { display:grid;grid-template-columns:repeat(4,1fr);gap:16px; }

/* ── Mobile ───────────────────────────────────────────── */
.hamburger { display:none;background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer; }
.sidebar-overlay { display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:199; }

@media(max-width:900px) {
    .sidebar { transform:translateX(-100%); }
    .sidebar.open { transform:translateX(0); }
    .sidebar-overlay.show { display:block; }
    .main-wrap { margin-left:0; }
    .hamburger { display:flex; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .grid-2,.grid-3,.grid-4 { grid-template-columns:1fr; }
    .form-row,.form-row-3 { grid-template-columns:1fr; }
}
@media(max-width:480px) {
    .stats-grid { grid-template-columns:1fr; }
    .main-content { padding:16px; }
    .modal { max-width:100%; margin:0; border-radius:var(--radius) var(--radius) 0 0; }
    .modal-backdrop { align-items:flex-end; padding:0; }
}

/* ── Theme Toggle ─────────────────────────────────────── */
.theme-btn {
    width:36px;height:36px;
    background:var(--surface2);
    border:1px solid var(--line);
    border-radius:var(--radius-sm);
    color:var(--muted);
    display:flex;align-items:center;justify-content:center;
    cursor:pointer;
    transition:var(--transition);
}
.theme-btn:hover { color:var(--primary); border-color:var(--primary); }

/* ── Subscription Badge ───────────────────────────────── */
.plan-badge {
    display:inline-flex;align-items:center;gap:5px;
    background:var(--primary-dim);
    color:var(--primary);
    font-size:.68rem;font-weight:800;
    padding:3px 9px;
    border-radius:var(--radius-pill);
    text-transform:uppercase;
    letter-spacing:.5px;
}

/* ── Spinner ──────────────────────────────────────────── */
.spinner {
    width:18px;height:18px;
    border:2px solid var(--line);
    border-top-color:var(--primary);
    border-radius:50%;
    animation:spin .7s linear infinite;
    display:inline-block;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ── Code / Mono ──────────────────────────────────────── */
code,pre { font-family:'Courier New',monospace;font-size:.85rem; }
.code-pill {
    background:var(--surface2);
    border:1px solid var(--line);
    border-radius:var(--radius-sm);
    padding:2px 8px;
    font-family:monospace;
    font-size:.8rem;
    color:var(--primary);
}

/* ── Tab Panes ─────────────────────────────────────────── */
.tab-pane { display:block; }
.tab-pane.hidden { display:none; }

/* ── Print Vouchers ─────────────────────────────────────── */
.voucher-print-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
    gap:12px;
    padding:16px 0;
}
.voucher-print-card {
    border:2px dashed var(--line);
    border-radius:var(--radius-sm);
    padding:14px;
    text-align:center;
    background:var(--surface2);
    position:relative;
    transition:var(--transition);
}
.voucher-print-card:hover { border-color:var(--primary); }
.voucher-print-card .vpc-logo { font-size:.7rem;color:var(--muted);font-weight:800;text-transform:uppercase;letter-spacing:1px;margin-bottom:6px; }
.voucher-print-card .vpc-code { font-size:1.1rem;font-weight:900;color:var(--text);letter-spacing:1px;margin:4px 0;font-family:monospace; }
.voucher-print-card .vpc-pass { font-size:1.8rem;font-weight:900;color:var(--primary);letter-spacing:2px;font-family:monospace;margin:6px 0; }
.voucher-print-card .vpc-profile { font-size:.72rem;color:var(--muted);margin:4px 0; }
.voucher-print-card .vpc-type { position:absolute;top:8px;right:8px; }

@media print {
    .sidebar,.topbar,.modal-backdrop,.toast-wrap,.page-header .btn,
    .toolbar,.pagination,.btn,.card-header .btn,
    .loc-card-footer,#filterForm,.no-print { display:none !important; }
    .main-wrap { margin-left:0 !important; }
    .voucher-print-grid { grid-template-columns:repeat(4,1fr); }
    .voucher-print-card { break-inside:avoid; border:1px dashed #ccc; }
    body { background:#fff !important; color:#000 !important; }
    .voucher-print-card .vpc-code { color:#000 !important; }
    .voucher-print-card .vpc-pass { color:#000 !important; }
}

/* ── Location Card code-pill override ─────────────────── */
.loc-card .code-pill {
    background:var(--primary-dim);
    border:none;
    color:var(--primary);
    font-size:.7rem;
    font-weight:800;
    letter-spacing:.5px;
}

/* ── Sidebar Collapse / Hide ─────────────────────────── */
body.sb-collapsed .sidebar { width: 68px; }
body.sb-collapsed .main-wrap { margin-left: 68px; }
body.sb-collapsed .nav-label,
body.sb-collapsed .nav-text,
body.sb-collapsed .nav-section-hdr,
body.sb-collapsed .sidebar-logo-text,
body.sb-collapsed .sidebar-logo-sub,
body.sb-collapsed .sb-plan-card,
body.sb-collapsed .sb-user-info,
body.sb-collapsed .sb-user-more,
body.sb-collapsed .sb-footer-text { display: none !important; }
body.sb-collapsed .nav-link { justify-content: center; padding: 10px; gap: 0; }
body.sb-collapsed .nav-link i { width: auto; margin: 0; }
body.sb-collapsed .sidebar-logo { justify-content: center; padding: 14px 8px; }
body.sb-collapsed .sb-logo-full { display: none !important; }
body.sb-collapsed .sb-logo-icon-only { display: flex !important; }
body.sb-collapsed .sidebar-user-card { justify-content: center; padding: 12px 8px; }

/* Default: full logo visible, icon-only hidden */
.sb-logo-full { display: flex; align-items: center; gap: 10px; }
.sb-logo-icon-only { display: none; align-items: center; justify-content: center; }
body.sb-collapsed .sb-logout-ico { display: flex !important; margin: 0 auto; }
body.sb-hidden .sidebar { transform: translateX(-260px) !important; }
body.sb-hidden .main-wrap { margin-left: 0 !important; }

/* ── Sidebar ctrl buttons ────────────────────────────── */
.sb-ctrl-btn {
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: none; border: none; border-radius: var(--radius-sm);
  color: var(--muted); cursor: pointer; font-size: .85rem;
  transition: var(--transition);
}
.sb-ctrl-btn:hover { background: var(--surface2); color: var(--text); }
.sb-ctrl-btns { display: flex; align-items: center; gap: 2px; }

/* ── User Avatar / Dropdown ──────────────────────────── */
.user-menu { position: relative; }
.user-avatar {
  width: 36px; height: 36px;
  background: var(--primary-dim); border: 1.5px solid var(--primary);
  border-radius: 50%; display: flex; align-items: center;
  justify-content: center; font-size: .75rem; font-weight: 900;
  color: var(--primary); cursor: pointer; transition: var(--transition);
  user-select: none; flex-shrink: 0;
}
.user-avatar:hover { background: rgba(0,212,255,.25); }
.user-dropdown {
  position: absolute; right: 0; top: calc(100% + 8px);
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); min-width: 230px;
  box-shadow: var(--shadow); z-index: 9000; display: none;
  animation: modalIn .15s ease;
}
.user-dropdown.open { display: block; }
.udrop-header { padding: 14px 16px 10px; border-bottom: 1px solid var(--line); }
.udrop-name { font-weight: 800; font-size: .9rem; color: var(--text); }
.udrop-email { font-size: .73rem; color: var(--muted); margin-top: 2px; word-break: break-all; }
.udrop-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px; font-size: .85rem; font-weight: 600;
  color: var(--text); text-decoration: none;
  cursor: pointer; background: none; border: none; width: 100%;
  transition: background .12s;
}
.udrop-item:hover { background: var(--surface2); }
.udrop-item.danger { color: var(--danger); }
.udrop-item i { width: 16px; text-align: center; color: var(--muted); font-size: .83rem; }
.udrop-item.danger i { color: var(--danger); }
.udrop-divider { height: 1px; background: var(--line); margin: 4px 0; }

/* ── DataTable-style toolbar / footer ────────────────── */
.dt-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-bottom: 14px;
}
.dt-show { display: flex; align-items: center; gap: 7px; font-size: .82rem; color: var(--muted); }
.dt-show select {
  padding: 4px 8px; background: var(--surface2); border: 1px solid var(--line);
  border-radius: var(--radius-sm); color: var(--text); font-size: .82rem; cursor: pointer;
}
.dt-search-wrap { display: flex; align-items: center; gap: 7px; font-size: .82rem; color: var(--muted); }
.dt-search-wrap input {
  padding: 6px 10px; background: var(--surface2); border: 1px solid var(--line);
  border-radius: var(--radius-sm); color: var(--text); font-size: .82rem; min-width: 220px;
}
.dt-search-wrap input:focus { outline: none; border-color: var(--primary); }
.dt-footer { display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 10px; margin-top: 14px; font-size: .82rem; color: var(--muted); }
.dt-pager { display: flex; gap: 4px; }
.dt-pg-btn {
  padding: 5px 12px; background: var(--surface2); border: 1px solid var(--line);
  border-radius: var(--radius-sm); color: var(--muted); font-size: .79rem; font-weight: 700;
  cursor: pointer; transition: var(--transition); text-decoration: none; display: inline-flex;
  align-items: center;
}
.dt-pg-btn:hover { border-color: var(--primary); color: var(--primary); }
.dt-pg-btn.active { background: var(--primary); border-color: var(--primary); color: #000; }
.dt-pg-btn:disabled { opacity: .4; cursor: not-allowed; }

/* ── Location table action btn group ─────────────────── */
.loc-actions { display: flex; align-items: center; gap: 4px; }
.loc-act-btn {
  width: 30px; height: 30px; display: inline-flex; align-items: center;
  justify-content: center; border-radius: var(--radius-sm); border: 1px solid var(--line);
  background: var(--surface2); color: var(--muted); cursor: pointer;
  font-size: .8rem; transition: var(--transition); text-decoration: none;
}
.loc-act-btn:hover { border-color: var(--primary); color: var(--primary); background: var(--primary-dim); }
.loc-act-btn.danger:hover { border-color: var(--danger); color: var(--danger); background: rgba(255,87,87,.1); }

/* ── Digital Wallet filters ──────────────────────────── */
.dw-filter-bar {
  display: flex; gap: 10px; flex-wrap: wrap; align-items: flex-end;
  margin-bottom: 16px;
}
.dw-fg { display: flex; flex-direction: column; gap: 4px; }
.dw-fg label { font-size: .71rem; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .5px; }
.dw-fg input, .dw-fg select {
  padding: 7px 10px; background: var(--surface2); border: 1px solid var(--line);
  border-radius: var(--radius-sm); color: var(--text); font-size: .83rem; min-width: 120px;
}
.dw-fg input:focus, .dw-fg select:focus { outline: none; border-color: var(--primary); }

/* ── Settings sections ───────────────────────────────── */
.settings-section-title {
  display: flex; align-items: center; gap: 8px;
  font-size: .75rem; font-weight: 800; color: var(--primary);
  text-transform: uppercase; letter-spacing: 1px; margin-bottom: 14px;
  padding-bottom: 8px; border-bottom: 1px solid var(--line);
}
.settings-section-title i { font-size: .9rem; }
.sa-badge {
  display: inline-flex; align-items: center; gap: 5px;
  background: rgba(255,87,87,.12); color: var(--danger); border: 1px solid rgba(255,87,87,.3);
  font-size: .68rem; font-weight: 800; padding: 2px 8px; border-radius: var(--radius-pill);
  text-transform: uppercase; letter-spacing: .5px;
}

/* ================================================================
   MOBILE-FIRST — Bottom Navigation & Responsive Overrides
   ================================================================ */

/* ── Bottom Navigation Bar ─────────────────────────────────────── */
.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 350;
  background: var(--surface);
  border-top: 2px solid var(--line);
  padding-bottom: env(safe-area-inset-bottom, 0px);
  box-shadow: 0 -4px 20px rgba(0,0,0,.35);
}
.bottom-nav-inner {
  display: flex;
  align-items: stretch;
  height: 58px;
}
.bn-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  color: var(--muted);
  font-size: .6rem;
  font-weight: 700;
  text-decoration: none;
  padding: 6px 0 4px;
  border-top: 2px solid transparent;
  border-left: none; border-right: none; border-bottom: none;
  background: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: color .15s, border-color .15s;
  position: relative;
  letter-spacing: .3px;
}
.bn-item i { font-size: 1.15rem; }
.bn-item.active { color: var(--primary); border-top-color: var(--primary); }
.bn-item:active { color: var(--primary); opacity: .8; }
.bn-badge {
  position: absolute; top: 5px; right: calc(50% - 18px);
  background: var(--danger); color: #fff;
  font-size: .5rem; font-weight: 900;
  padding: 1px 4px; border-radius: var(--radius-pill);
  min-width: 13px; text-align: center;
}

/* ── More / Drawer overlay ─────────────────────────────────────── */
.mmd-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  z-index: 340;
  backdrop-filter: blur(2px);
}
.mmd-overlay.show { display: block; }

/* ── More drawer ───────────────────────────────────────────────── */
.mobile-more-drawer {
  display: none;
  position: fixed;
  bottom: 58px; left: 0; right: 0;
  background: var(--surface);
  border-top: 1px solid var(--line);
  border-radius: 18px 18px 0 0;
  z-index: 345;
  padding: 18px 16px 24px;
  box-shadow: 0 -8px 40px rgba(0,0,0,.4);
  max-height: 70vh;
  overflow-y: auto;
}
.mobile-more-drawer.show { display: block; }
.mmd-handle {
  width: 40px; height: 4px;
  background: var(--line); border-radius: 999px;
  margin: 0 auto 16px; display: block;
}
.mmd-title {
  font-size: .65rem; font-weight: 800;
  color: var(--muted); text-transform: uppercase;
  letter-spacing: 1px; margin-bottom: 14px;
}
.mmd-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.mmd-item {
  display: flex; flex-direction: column;
  align-items: center; gap: 6px;
  padding: 13px 6px 10px;
  background: var(--surface2);
  border-radius: var(--radius);
  color: var(--muted);
  text-decoration: none;
  font-size: .65rem; font-weight: 700;
  border: 1px solid var(--line);
  text-align: center;
  transition: color .12s, border-color .12s, background .12s;
  cursor: pointer;
}
.mmd-item i { font-size: 1.25rem; color: var(--primary); }
.mmd-item:active, .mmd-item:hover {
  color: var(--primary); border-color: var(--primary);
  background: var(--primary-dim);
}
.mmd-item.danger i { color: var(--danger); }
.mmd-item.danger:hover { border-color: var(--danger); color: var(--danger); background: rgba(255,87,87,.08); }

/* ── Responsive breakpoints ────────────────────────────────────── */
@media (max-width: 767px) {
  .bottom-nav { display: block; }
  body { padding-bottom: 70px; }

  /* Hide sidebar completely on phones */
  .sidebar { transform: translateX(-100%); }
  .sidebar.mobile-open {
    transform: translateX(0);
    box-shadow: 4px 0 30px rgba(0,0,0,.5);
    z-index: 500;
  }
  .sidebar-overlay.show { display: block; z-index: 490; }

  /* Main content spans full width */
  .main-wrap { margin-left: 0 !important; }
  .main-content { padding: 14px 12px !important; }
  .topbar { left: 0 !important; }

  /* Desktop sidebar controls hidden on mobile */
  .sb-ctrl-btns { display: none !important; }

  /* Hide page title in topbar on mobile — logo shows instead */
  .topbar-title { display: none !important; }
  .topbar-date-label { display: none !important; }
  .topbar-date { display: none; }

  /* Hide location selector, theme toggle, search and refresh from topbar on mobile */
  .tb-loc-wrap { display: none !important; }
  .theme-btn { display: none !important; }
  .tb-search-wrap { display: none !important; }
  #tbRefreshBtn { display: none !important; }

  /* Show user name label next to avatar on mobile */
  .topbar-user-name-mobile { display: flex !important; }

  /* Mobile logo in topbar */
  .topbar-logo-mobile {
    display: flex !important;
    align-items: center;
  }
  .topbar-logo-mobile img {
    height: 28px;
    max-width: 130px;
    object-fit: contain;
  }
  .topbar-logo-mobile .logo-text {
    font-weight: 900;
    font-size: 1.1rem;
    color: var(--text);
    letter-spacing: -.02em;
  }

  /* Stack stat grids to single column on phones */
  .stat-row, .dash-stat-row { grid-template-columns: 1fr 1fr !important; }
  .dash-kpi-grid { grid-template-columns: 1fr 1fr !important; }

  /* Scroll tables horizontally */
  .table-responsive { overflow-x: auto; -webkit-overflow-scrolling: touch; }

  /* Cards: remove fixed widths */
  .card { border-radius: var(--radius-sm); }

  /* Page header: stack on mobile */
  .page-header { flex-direction: column; align-items: flex-start !important; gap: 10px; }
  .page-header .page-actions { width: 100%; }
  .page-header .page-actions .btn { flex: 1; text-align: center; }
}

@media (max-width: 420px) {
  .stat-row, .dash-stat-row, .dash-kpi-grid { grid-template-columns: 1fr !important; }
  .mmd-grid { grid-template-columns: repeat(3, 1fr); }
  .main-content { padding: 10px 8px !important; }
}

/* ── Agent / Partner Portal shared styles ──────────────────────── */
.portal-wrap {
  min-height: 100vh;
  background: var(--bg);
  display: flex;
  flex-direction: column;
}
.portal-topbar {
  background: var(--surface);
  border-bottom: 1px solid var(--line);
  padding: 0 16px;
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky; top: 0; z-index: 100;
}
.portal-logo { font-size: 1.1rem; font-weight: 900; color: var(--primary); display: flex; align-items: center; gap: 8px; }
.portal-logo-sub { font-size: .6rem; color: var(--muted); font-weight: 700; text-transform: uppercase; letter-spacing: 1px; }
.portal-user { display: flex; align-items: center; gap: 10px; }
.portal-avatar {
  width: 34px; height: 34px; border-radius: 50%;
  background: var(--primary-dim); border: 2px solid var(--primary);
  color: var(--primary); font-weight: 900; font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
}
.portal-main { flex: 1; padding: 16px 14px 80px; max-width: 680px; margin: 0 auto; width: 100%; }

/* ── Portal wallet card ─────────────────────────────────────────── */
.wallet-hero {
  background: linear-gradient(135deg, #0d2137 0%, #0a1628 60%, #0e1a2e 100%);
  border: 1px solid rgba(0,212,255,.25);
  border-radius: 18px;
  padding: 24px 20px 20px;
  margin-bottom: 18px;
  position: relative; overflow: hidden;
}
.wallet-hero::before {
  content: '';
  position: absolute; top: -40px; right: -40px;
  width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(0,212,255,.12) 0%, transparent 70%);
  border-radius: 50%;
}
.wallet-hero-label { font-size: .65rem; font-weight: 800; color: rgba(0,212,255,.6); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px; }
.wallet-hero-amount { font-size: 2.4rem; font-weight: 900; color: #fff; letter-spacing: -1px; margin-bottom: 16px; }
.wallet-hero-amount span { font-size: 1rem; color: var(--primary); font-weight: 700; margin-right: 4px; }
.wallet-hero-row { display: flex; gap: 12px; flex-wrap: wrap; }
.wallet-mini-card {
  flex: 1; min-width: 120px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 10px; padding: 12px 14px;
}
.wallet-mini-label { font-size: .6rem; color: rgba(255,255,255,.5); font-weight: 700; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 4px; }
.wallet-mini-val { font-size: 1.15rem; font-weight: 900; color: #fff; }

/* ── Portal quick-action buttons ───────────────────────────────── */
.portal-quick-actions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-bottom: 18px;
}
.pqa-btn {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 7px; padding: 16px 6px 12px;
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); color: var(--muted);
  font-size: .65rem; font-weight: 700;
  text-decoration: none; cursor: pointer;
  transition: var(--transition); text-align: center;
}
.pqa-btn i { font-size: 1.3rem; color: var(--primary); }
.pqa-btn:hover, .pqa-btn:active { border-color: var(--primary); color: var(--primary); background: var(--primary-dim); }
@media (max-width: 380px) { .portal-quick-actions { grid-template-columns: repeat(3, 1fr); } }

/* ── Portal section header ─────────────────────────────────────── */
.portal-section-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.portal-section-title { font-size: .8rem; font-weight: 800; color: var(--text); text-transform: uppercase; letter-spacing: .5px; }

/* ── Transaction list item ─────────────────────────────────────── */
.txn-list { display: flex; flex-direction: column; gap: 0; }
.txn-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 0; border-bottom: 1px solid var(--line);
}
.txn-item:last-child { border-bottom: none; }
.txn-icon {
  width: 38px; height: 38px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  font-size: .95rem; flex-shrink: 0;
}
.txn-icon.in  { background: rgba(0,255,149,.1); color: var(--success); }
.txn-icon.out { background: rgba(255,87,87,.1);  color: var(--danger); }
.txn-icon.neutral { background: var(--surface2); color: var(--muted); }
.txn-body { flex: 1; min-width: 0; }
.txn-desc { font-size: .84rem; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.txn-date { font-size: .68rem; color: var(--muted); margin-top: 2px; }
.txn-amount { font-size: .95rem; font-weight: 900; flex-shrink: 0; }
.txn-amount.in  { color: var(--success); }
.txn-amount.out { color: var(--danger); }

/* ── Portal modal / bottom sheet ──────────────────────────────── */
.portal-sheet-overlay {
  display: none; position: fixed; inset: 0;
  background: rgba(0,0,0,.6); z-index: 800;
  backdrop-filter: blur(3px);
}
.portal-sheet-overlay.show { display: flex; align-items: flex-end; justify-content: center; }
.portal-sheet {
  background: var(--surface); border-radius: 20px 20px 0 0;
  padding: 24px 20px 40px; width: 100%; max-width: 520px;
  max-height: 90vh; overflow-y: auto;
  border-top: 1px solid var(--line);
}
.sheet-handle {
  width: 40px; height: 4px; background: var(--line);
  border-radius: 999px; margin: 0 auto 20px; display: block;
}
.sheet-title { font-size: 1.05rem; font-weight: 900; color: var(--text); margin-bottom: 18px; }

/* ── Portal bottom nav (agent/partner) ────────────────────────── */
.portal-bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: var(--surface); border-top: 2px solid var(--line);
  display: flex; align-items: stretch; height: 58px;
  z-index: 200; padding-bottom: env(safe-area-inset-bottom, 0px);
  box-shadow: 0 -4px 20px rgba(0,0,0,.35);
}
.pbn-item {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 3px;
  color: var(--muted); font-size: .6rem; font-weight: 700;
  text-decoration: none; border-top: 2px solid transparent;
  cursor: pointer; -webkit-tap-highlight-color: transparent;
  transition: color .15s, border-color .15s;
  background: none; border-left: none; border-right: none; border-bottom: none;
  padding: 6px 0 4px;
}
.pbn-item i { font-size: 1.15rem; }
.pbn-item.active { color: var(--primary); border-top-color: var(--primary); }
.pbn-item:active { opacity: .75; }

/* ── Agent portal accent (orange tint) ─────────────────────────── */
.agent-portal { --primary: #ff8c00; --primary-dim: rgba(255,140,0,.12); --primary-hover: #e07b00; }

/* ── Partner portal accent (green tint) ────────────────────────── */
.partner-portal { --primary: #00c896; --primary-dim: rgba(0,200,150,.12); --primary-hover: #00a87d; }

/* ── Stat mini-row (2-up) ──────────────────────────────────────── */
.stat-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 14px; }
.stat-mini {
  background: var(--surface); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 14px 16px;
}
.stat-mini-label { font-size: .62rem; font-weight: 800; color: var(--muted); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 4px; }
.stat-mini-val { font-size: 1.35rem; font-weight: 900; color: var(--primary); }
.stat-mini-sub { font-size: .65rem; color: var(--muted); margin-top: 2px; }
