:root{
  --bg:#0B0D14;--s1:#131620;--s2:#191C28;--s3:#1F2333;
  --b1:#252A3A;--b2:#2E3447;
  --t1:#F0F2F8;--t2:#A0A8BE;--t3:#636B84;--t4:#3D4459;
  --acc:#7C6FFF;--acc2:#6358E8;--acc-lt:rgba(124,111,255,.10);--acc-bd:rgba(124,111,255,.30);
  --grn:#1FC87B;--grn-lt:rgba(31,200,123,.10);--grn-bd:rgba(31,200,123,.25);
  --amb:#F0A030;--amb-lt:rgba(240,160,48,.10);--amb-bd:rgba(240,160,48,.25);
  --blu:#4A9EFF;--blu-lt:rgba(74,158,255,.10);--blu-bd:rgba(74,158,255,.25);
  --mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box}
body{font-family:'Inter',system-ui,sans-serif;background:var(--bg);color:var(--t1);font-size:14px}
.msr{font-family:'Material Symbols Rounded';font-weight:400;font-style:normal;font-size:20px;line-height:1;vertical-align:middle;display:inline-block}
.fill{font-variation-settings:'FILL' 1}

/* ===== AUTH PAGES (login / register) ===== */
.auth-shell{min-height:100vh;display:flex}
.auth-left{flex:1;background:var(--s1);border-right:1px solid var(--b1);display:flex;flex-direction:column;justify-content:center;padding:56px}
.auth-right{width:460px;background:var(--s2);display:flex;align-items:center;padding:40px 48px}
.logo-mark{width:38px;height:38px;background:var(--acc);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:18px}
.auth-h1{font-size:30px;font-weight:700;line-height:1.25}
.auth-h1 .accent{color:var(--acc)}
.perk{display:flex;gap:12px;align-items:center;color:var(--t2);font-size:14px}
.perk-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.form-control,.form-select{background:var(--s3);border:1px solid var(--b2);color:var(--t1);font-size:13px}
.form-control:focus,.form-select:focus{background:var(--s3);border-color:var(--acc);color:var(--t1);box-shadow:0 0 0 .2rem var(--acc-lt)}
.form-control::placeholder{color:var(--t4)}
.form-label{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.04em}
.chip-toggle{padding:5px 13px;border-radius:20px;font-size:12px;font-weight:500;border:1px solid var(--b2);color:var(--t3);cursor:pointer;background:none;transition:.15s}
.chip-toggle:hover{border-color:var(--acc);color:var(--acc)}
.chip-toggle.active{background:var(--acc-lt);border-color:var(--acc);color:var(--acc)}
.btn-acc{background:var(--acc);border:none;color:#fff;font-weight:600}
.btn-acc:hover{background:var(--acc2);color:#fff}
.auth-link{color:var(--acc);text-decoration:none;font-weight:500}
.auth-link:hover{text-decoration:underline;color:var(--acc)}
@media(max-width:900px){
  .auth-left{display:none}
  .auth-right{width:100%}
}

/* ===== DASHBOARD SHELL ===== */
body.dashboard-body{height:100vh;overflow:hidden}
.app-shell{display:flex;height:100vh}
.sidebar{width:226px;background:var(--s1);border-right:1px solid var(--b1);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto}
.sb-logo{padding:18px;border-bottom:1px solid var(--b1);display:flex;align-items:center;gap:10px}
.utm-pill{margin:12px 14px;background:var(--acc-lt);border:1px solid var(--acc-bd);border-radius:8px;padding:8px 12px}
.utm-pill .lbl{font-size:10px;color:var(--acc);font-weight:600;letter-spacing:.06em;text-transform:uppercase}
.utm-pill .val{font-family:var(--mono);font-size:12px;color:var(--t1)}
.nav-section{font-size:10px;font-weight:600;color:var(--t4);text-transform:uppercase;letter-spacing:.07em;padding:12px 12px 4px}
.nav-link-custom{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;font-size:13px;color:var(--t3);cursor:pointer;margin:0 8px 2px;transition:.15s;text-decoration:none}
.nav-link-custom:hover{background:var(--s3);color:var(--t1)}
.nav-link-custom.active{background:var(--acc-lt);color:var(--acc)}
.nav-link-custom .msr{font-size:19px}
.sb-foot{padding:14px;border-top:1px solid var(--b1);display:flex;align-items:center;gap:10px;margin-top:auto}
.avatar-circle{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--acc),#9B7FFF);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:#fff}

.main-col{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{background:var(--s1);border-bottom:1px solid var(--b1);padding:13px 24px;display:flex;justify-content:space-between;align-items:center;flex-shrink:0}
.content-area{flex:1;overflow-y:auto;padding:22px 24px}

/* Safety net: guarantee column gutters render even if Bootstrap's CSS var resolution is affected by load order */
.content-area .row{margin-left:-12px;margin-right:-12px}
.content-area .row > [class*="col-"]{padding-left:12px;padding-right:12px}

/* ===== CARDS / STATS ===== */
.card-dark{background:var(--s2);border:1px solid var(--b1);border-radius:14px}
.card-dark .card-header{background:transparent;border-bottom:1px solid var(--b1);font-weight:600;font-size:14px;padding:13px 16px}
.stat-card{background:var(--s2);border:1px solid var(--b1);border-radius:14px;padding:16px 18px}
.stat-label{font-size:11px;color:var(--t3);text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center;gap:6px;margin-bottom:6px}
.stat-value{font-size:26px;font-weight:700;line-height:1}
.stat-sub{font-size:12px;color:var(--t3);margin-top:4px}
.badge-delta{font-size:10.5px;font-weight:600;padding:2px 7px;border-radius:20px}
.badge-up{background:var(--grn-lt);color:var(--grn)}
.badge-dn{background:rgba(240,80,96,.1);color:#F05060}

.badge-soft{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px}
.badge-g{background:var(--grn-lt);color:var(--grn)}
.badge-a{background:var(--amb-lt);color:var(--amb)}
.badge-b{background:var(--blu-lt);color:var(--blu)}
.badge-p{background:var(--acc-lt);color:var(--acc)}

.table-dark-custom{color:var(--t2);font-size:13px;margin-bottom:0;background:var(--s2);--bs-table-bg:var(--s2);--bs-table-color:var(--t2);--bs-table-striped-bg:var(--s3);--bs-table-striped-color:var(--t2);--bs-table-hover-bg:var(--s3);--bs-table-hover-color:var(--t1);--bs-table-border-color:var(--b1)}
.table-dark-custom thead th{font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--t3);font-weight:600;border-bottom:1px solid var(--b1);background:var(--s2);white-space:nowrap}
.table-dark-custom tbody{background:var(--s2)}
.table-dark-custom td,.table-dark-custom th{background:var(--s2);border-bottom:1px solid var(--b1);vertical-align:middle;box-shadow:none}
.table-dark-custom tr:last-child td{border-bottom:none}
.table-dark-custom tr:hover td{background:var(--s3)}
.table-dark-custom strong{color:var(--t1);font-weight:500}
.mono{font-family:var(--mono);font-size:12px;color:var(--acc)}

.btn-copy{background:none;border:1px solid var(--b2);border-radius:5px;padding:3px 8px;font-size:11px;color:var(--t3);cursor:pointer}
.btn-copy:hover{border-color:var(--acc);color:var(--acc)}

.alert-soft{border-radius:8px;font-size:12.5px;padding:10px 14px}
.alert-soft-info{background:var(--blu-lt);border:1px solid var(--blu-bd);color:#8FC4FF}
.alert-soft-success{background:var(--grn-lt);border:1px solid var(--grn-bd);color:#7FE3B8}

.due-card{background:linear-gradient(135deg,#1A2E22,#16291F);border:1px solid var(--grn-bd);border-radius:14px;padding:20px 22px}
.due-amount{font-size:32px;font-weight:700;color:#fff}

/* ===== MODALS / FORMS (Help, Request Payment) ===== */
.modal-content{background:var(--s2);border:1px solid var(--b1);border-radius:14px;color:var(--t1)}
.modal-header{border-bottom:1px solid var(--b1);padding:16px 20px}
.modal-header .modal-title{font-size:16px;font-weight:600}
.modal-body{padding:20px}
.modal-footer{border-top:1px solid var(--b1);padding:14px 20px}
.btn-close{filter:invert(1) grayscale(100%) brightness(2)}
.status-paid{color:var(--grn)}
.status-failed{color:#F05060}
.status-pending{color:var(--amb)}

::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-thumb{background:var(--b2);border-radius:2px}
