:root{
  --bg:#0B1028;
  --card:#121B45;
  --sidebar:#16224F;
  --border:#24316D;
  --cyan:#00E5FF;
  --blue:#00A8FF;
  --pink:#FF007F;
  --magenta:#D100FF;
  --purple:#8A2BE2;
  --orange:#FF6A00;
  --text:#FFFFFF;
  --muted:#B8C2E0;
  --success:#19F58A;
  --warning:#FFD166;
  --danger:#FF4D6D;
  --glass:rgba(18,27,69,.72);
  --glass-strong:rgba(18,27,69,.92);
  --shadow:0 24px 80px rgba(0,0,0,.38);
  --shadow-soft:0 18px 45px rgba(0,0,0,.24);
  --glow-cyan:0 0 0 1px rgba(0,229,255,.22),0 0 24px rgba(0,229,255,.22);
  --glow-pink:0 0 0 1px rgba(255,0,127,.22),0 0 24px rgba(255,0,127,.20);
  --radius:20px;
  --radius-lg:24px;
}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg)}
body{margin:0;min-height:100vh;color:var(--text);font-family:Inter,Poppins,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;background:radial-gradient(circle at 16% 4%,rgba(0,229,255,.18),transparent 34%),radial-gradient(circle at 82% 6%,rgba(255,0,127,.18),transparent 32%),linear-gradient(180deg,#0B1028 0%,#080C20 100%);overflow-x:hidden}
a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}img{max-width:100%}.bg-grid{position:fixed;inset:0;pointer-events:none;z-index:-3;background-image:linear-gradient(rgba(36,49,109,.25) 1px,transparent 1px),linear-gradient(90deg,rgba(36,49,109,.22) 1px,transparent 1px);background-size:44px 44px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.65),transparent 78%)}.bg-orb{position:fixed;width:420px;height:420px;border-radius:999px;filter:blur(70px);opacity:.35;pointer-events:none;z-index:-2}.orb-cyan{top:-120px;left:18%;background:linear-gradient(135deg,var(--cyan),var(--blue))}.orb-pink{right:-120px;top:70px;background:linear-gradient(135deg,var(--pink),var(--magenta))}
.layout{min-height:100vh}.sidebar{position:fixed;left:0;top:0;width:292px;height:100vh;padding:18px 16px;background:linear-gradient(180deg,rgba(22,34,79,.92),rgba(11,16,40,.96));border-right:1px solid rgba(36,49,109,.85);box-shadow:26px 0 90px rgba(0,0,0,.25);backdrop-filter:blur(18px);overflow:auto;z-index:60}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-thumb{background:rgba(0,229,255,.18);border-radius:999px}.sb-brand{height:68px;display:flex;align-items:center;gap:12px;margin-bottom:14px;padding:10px;border:1px solid rgba(0,229,255,.18);border-radius:24px;background:linear-gradient(135deg,rgba(0,229,255,.10),rgba(209,0,255,.08));box-shadow:var(--glow-cyan)}.sb-logo,.topbar-logo{display:inline-grid;place-items:center;font-family:Poppins,Inter,sans-serif;font-weight:900;letter-spacing:.05em}.sb-logo{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06101e;box-shadow:0 0 34px rgba(0,229,255,.42)}.sb-title b{display:block;font:800 18px/1 Poppins,Inter,sans-serif}.sb-title small{display:block;margin-top:6px;color:var(--muted);font-size:12px}.menu{display:grid;gap:7px;padding:8px 0 16px}.menu-link,.menu-group-toggle{position:relative;width:100%;display:flex;align-items:center;gap:10px;border:1px solid transparent;border-radius:16px;background:transparent;color:#DDE7FF;text-align:left;padding:11px 12px;cursor:pointer;transition:transform .18s ease,border-color .18s ease,background .18s ease,box-shadow .18s ease}.menu-link:hover,.menu-group-toggle:hover{transform:translateX(3px);border-color:rgba(0,229,255,.28);background:rgba(0,229,255,.08);box-shadow:0 0 26px rgba(0,229,255,.10)}.menu-link.active,.menu-group-toggle.active{background:linear-gradient(135deg,rgba(0,229,255,.18),rgba(0,168,255,.10));border-color:rgba(0,229,255,.48);box-shadow:var(--glow-cyan)}.menu-link.active:before,.menu-group-toggle.active:before{content:"";position:absolute;left:-7px;top:13px;bottom:13px;width:3px;border-radius:999px;background:linear-gradient(180deg,var(--cyan),var(--pink));box-shadow:0 0 16px var(--cyan)}.menu-left{display:flex;align-items:center;gap:10px;min-width:0}.menu-icon{width:28px;height:28px;display:inline-grid;place-items:center;flex:0 0 28px;border:1px solid rgba(184,194,224,.14);border-radius:11px;background:rgba(255,255,255,.035);font-size:14px;color:var(--cyan)}.menu-caret{margin-left:auto;color:var(--muted);transition:.18s ease}.menu-group.open .menu-caret{transform:rotate(180deg);color:var(--cyan)}.menu-group-children{display:none;gap:5px;margin:5px 0 8px 16px;padding:7px 0 7px 13px;border-left:1px solid rgba(0,229,255,.20)}.menu-group.open .menu-group-children{display:grid}.menu-link.child{padding:9px 10px;font-size:13px;border-radius:13px;color:#CAD7F7}.menu-link.child .menu-icon{width:22px;height:22px;flex-basis:22px;border-radius:8px;font-size:12px}.userbox{margin-top:14px;display:grid;grid-template-columns:auto 1fr;gap:10px;align-items:center;padding:13px}.userbox small{display:block;color:var(--muted);font-size:12px;margin-top:3px}.avatar-mini,.profile-chip span{display:grid;place-items:center;background:linear-gradient(135deg,var(--pink),var(--magenta));color:#fff;font-weight:900;box-shadow:0 0 26px rgba(255,0,127,.25)}.avatar-mini{width:42px;height:42px;border-radius:14px}.userbox .full{grid-column:1/-1;justify-content:center}.content{margin-left:292px;min-height:100vh}.topbar{position:sticky;top:0;z-index:50;min-height:76px;padding:14px 26px;display:grid;grid-template-columns:auto minmax(260px,620px) auto;gap:18px;align-items:center;background:rgba(11,16,40,.76);border-bottom:1px solid rgba(36,49,109,.7);backdrop-filter:blur(18px)}.topbar-left,.topbar-actions{display:flex;align-items:center;gap:12px}.topbar-brand{display:grid}.topbar-logo{height:32px;padding:0 12px;border-radius:12px;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06101e;box-shadow:0 0 26px rgba(0,229,255,.34)}.topbar-brand small{color:var(--muted);font-size:11px;margin-top:3px}.topbar-search{display:flex;align-items:center;gap:10px;height:46px;padding:0 14px;border:1px solid rgba(36,49,109,.95);border-radius:999px;background:rgba(18,27,69,.72);box-shadow:inset 0 0 28px rgba(0,229,255,.03)}.topbar-search span{color:var(--cyan)}.topbar-search input{width:100%;border:0;outline:0;background:transparent;color:var(--text)}.topbar-search input::placeholder{color:rgba(184,194,224,.7)}.icon-btn{width:42px;height:42px;display:inline-grid;place-items:center;border:1px solid rgba(36,49,109,.95);border-radius:15px;background:rgba(18,27,69,.72);color:var(--text);cursor:pointer;transition:.18s}.icon-btn:hover{border-color:rgba(0,229,255,.48);box-shadow:var(--glow-cyan);transform:translateY(-2px)}.profile-chip{height:42px;display:flex;align-items:center;gap:9px;padding:5px 10px 5px 5px;border:1px solid rgba(36,49,109,.95);border-radius:999px;background:rgba(18,27,69,.72)}.profile-chip span{width:32px;height:32px;border-radius:50%}.profile-chip b{font-size:13px}.main{padding:26px}.page-title{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.page-title h1{margin:0;font:800 30px/1.1 Poppins,Inter,sans-serif;letter-spacing:-.02em}.page-title p{margin:7px 0 0;color:var(--muted)}.glass-card,.card{position:relative;background:linear-gradient(180deg,rgba(18,27,69,.72),rgba(18,27,69,.52));border:1px solid rgba(36,49,109,.92);border-radius:var(--radius);box-shadow:var(--shadow-soft);backdrop-filter:blur(18px);overflow:hidden}.card{padding:18px}.card:before{content:"";position:absolute;inset:0;border-radius:inherit;padding:1px;background:linear-gradient(135deg,rgba(0,229,255,.32),rgba(255,0,127,.14),rgba(138,43,226,.20));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}.card:hover{box-shadow:0 22px 70px rgba(0,0,0,.32),0 0 36px rgba(0,229,255,.08);transform:translateY(-1px)}.card h3{margin:0 0 9px;color:var(--muted);font-size:13px;font-weight:700;letter-spacing:.02em}.metric{font:900 28px/1.05 Poppins,Inter,sans-serif;letter-spacing:-.03em}.metric small{font-size:12px;color:var(--muted);font-weight:600}.muted{color:var(--muted)}.mono{font-family:Consolas,"SFMono-Regular",monospace}.cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}.grid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.grid-form .full{grid-column:1/-1}.form-row{margin-bottom:14px}.form-row label,.grid-form label{display:block;color:var(--muted);font-weight:700;font-size:12px;margin:0 0 7px;text-transform:uppercase;letter-spacing:.04em}input,select,textarea{width:100%;border:1px solid rgba(36,49,109,.95);border-radius:14px;background:rgba(11,16,40,.65);color:var(--text);padding:11px 12px;outline:0;transition:.18s}select option{background:#0B1028;color:#fff}textarea{min-height:110px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:rgba(0,229,255,.58);box-shadow:var(--glow-cyan)}input[type="checkbox"],input[type="radio"]{width:auto}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(0,229,255,.42);border-radius:14px;background:linear-gradient(135deg,rgba(0,229,255,.92),rgba(0,168,255,.88));color:#06101e;padding:10px 14px;font-weight:800;cursor:pointer;transition:.18s;box-shadow:0 0 24px rgba(0,229,255,.18)}.btn:hover{transform:translateY(-2px);box-shadow:0 0 34px rgba(0,229,255,.36)}.btn.small{padding:7px 10px;border-radius:12px;font-size:12px}.btn.secondary{background:linear-gradient(135deg,rgba(255,0,127,.9),rgba(209,0,255,.82));color:#fff;border-color:rgba(255,0,127,.45);box-shadow:0 0 26px rgba(255,0,127,.16)}.btn.ghost{background:rgba(18,27,69,.55);color:var(--text);border-color:rgba(36,49,109,.9);box-shadow:none}.btn.danger{background:linear-gradient(135deg,rgba(255,77,109,.92),rgba(255,0,127,.82));color:#fff;border-color:rgba(255,77,109,.55)}.btn.warning{background:linear-gradient(135deg,rgba(255,106,0,.92),rgba(255,0,127,.78));color:#fff;border-color:rgba(255,106,0,.45)}.pill,.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:800;border:1px solid rgba(36,49,109,.95);background:rgba(18,27,69,.72);color:var(--muted)}.badge.green,.pill.green{border-color:rgba(25,245,138,.38);color:#A8FFD2;background:rgba(25,245,138,.10)}.badge.red,.pill.red{border-color:rgba(255,77,109,.42);color:#FFC2CD;background:rgba(255,77,109,.10)}.badge.yellow,.pill.yellow{border-color:rgba(255,209,102,.42);color:#FFE7AC;background:rgba(255,209,102,.10)}.badge.cyan,.pill.cyan{border-color:rgba(0,229,255,.42);color:var(--cyan);background:rgba(0,229,255,.09)}.table-wrap{overflow:auto;border:1px solid rgba(36,49,109,.95);border-radius:var(--radius);background:rgba(18,27,69,.48);box-shadow:var(--shadow-soft)}table{width:100%;border-collapse:collapse;min-width:760px}th,td{padding:13px 14px;border-bottom:1px solid rgba(36,49,109,.72);text-align:left;vertical-align:top}th{color:#DDE7FF;background:rgba(22,34,79,.72);font-size:12px;text-transform:uppercase;letter-spacing:.05em}td{color:#F4F7FF;font-size:14px}.alert{border-radius:18px;padding:13px 15px;margin:12px 0;border:1px solid rgba(36,49,109,.95);background:rgba(18,27,69,.65);box-shadow:var(--shadow-soft)}.alert.success{border-color:rgba(25,245,138,.38);color:#B9FFD8}.alert.danger{border-color:rgba(255,77,109,.45);color:#FFD0D8}.alert.warning{border-color:rgba(255,209,102,.42);color:#FFE7AC}.alert.info{border-color:rgba(0,229,255,.35);color:#CBF9FF}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:14px}.toolbar h3{margin:0}.actions{display:flex;gap:8px;flex-wrap:wrap}.router-picker{display:flex;gap:8px;align-items:center}.router-picker select{min-width:245px}.form-inline{display:flex;gap:8px;align-items:center}.form-inline select,.form-inline input{min-width:160px}.mobile-toggle{display:none}.mini-cards{grid-template-columns:repeat(2,minmax(0,1fr));margin:0}.mini-cards .card{padding:14px;box-shadow:none}.mini-cards .metric{font-size:24px}.log-list{display:grid;gap:10px}.log-list>div{border:1px solid rgba(36,49,109,.72);border-radius:16px;padding:11px;background:rgba(11,16,40,.42)}.log-list b{display:block}.log-list small{display:block;color:var(--muted);font-size:11px;margin-top:2px}.log-list p{margin:7px 0 0;color:#DDE7FF;font-size:13px}.code-editor{font-family:Consolas,"SFMono-Regular",monospace;font-size:13px;line-height:1.45}.preview-box{min-height:240px;background:#f8fafc;color:#111;border-radius:18px;padding:18px;overflow:auto}.wide-editor{grid-template-columns:1.2fr .8fr}.modal{position:fixed;inset:0;background:rgba(2,6,23,.70);display:none;align-items:flex-start;justify-content:center;z-index:9999;padding:32px 14px;overflow:auto;backdrop-filter:blur(10px)}.modal.show{display:flex}.modal-panel{width:min(760px,100%);background:linear-gradient(180deg,rgba(18,27,69,.96),rgba(11,16,40,.96));border:1px solid rgba(0,229,255,.22);border-radius:24px;box-shadow:var(--shadow),var(--glow-cyan);padding:18px;color:var(--text)}.modal-panel.wide{width:min(1120px,100%)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.modal-head h3{margin:0}.modal-close{border:1px solid rgba(36,49,109,.9);background:rgba(255,255,255,.06);color:inherit;text-decoration:none;border-radius:14px;font-size:22px;line-height:1;padding:7px 12px;cursor:pointer}.customer-mode-box,.checkline{border:1px dashed rgba(0,229,255,.22);border-radius:16px;padding:12px;background:rgba(255,255,255,.035)}.radio-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:10px 0}.radio-grid label{display:flex;align-items:center;gap:8px;border:1px solid rgba(36,49,109,.8);border-radius:14px;padding:10px;background:rgba(255,255,255,.035)}.actions.end{display:flex;justify-content:flex-end;gap:10px}.input-action{display:flex;gap:8px;align-items:center;margin-top:7px}.input-action input{margin-top:0}.input-action .btn{flex:0 0 auto;white-space:nowrap}.checkline{display:flex!important;align-items:center;gap:10px;margin-top:19px}.checkline input{width:auto;margin:0}.profile-picker-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;max-height:420px;overflow:auto}.profile-pick{width:100%;min-height:72px;border:1px solid rgba(36,49,109,.92);border-radius:16px;background:rgba(11,16,40,.62);color:var(--text);padding:11px 12px;text-align:left;cursor:pointer;transition:.18s}.profile-pick:hover{border-color:rgba(0,229,255,.55);background:rgba(0,229,255,.08);box-shadow:var(--glow-cyan)}.profile-pick b{display:block}.profile-pick small{display:block;color:var(--muted);margin-top:4px}.color-dot{display:inline-block;width:14px;height:14px;border-radius:50%;border:1px solid rgba(255,255,255,.35);vertical-align:-2px;margin-right:6px}.voucher-batch-comment{font-family:Consolas,monospace;font-size:12px;word-break:break-all}.voucher-toolbar-split{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:space-between}.voucher table,.preview-box table{max-width:100%}.preview-box .voucher{transform-origin:top left}.status-cards .stat-link,.stat-link{display:block;transition:.16s ease;border-color:rgba(36,49,109,.95)}.status-cards .stat-link:hover,.stat-link:hover{transform:translateY(-2px);border-color:rgba(0,229,255,.55);box-shadow:var(--glow-cyan)}.stat-link.active{background:linear-gradient(180deg,rgba(0,229,255,.16),rgba(138,43,226,.12));border-color:rgba(0,229,255,.65)}
.dashboard-section{margin-bottom:22px}.section-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 0 12px}.section-head h2{margin:0;font:800 18px/1.2 Poppins,Inter,sans-serif}.dashboard-row{display:grid;gap:16px}.finance-row{grid-template-columns:1.7fr repeat(4,minmax(150px,1fr))}.finance-chart-card{min-height:255px}.finance-chart-card canvas,.traffic-card canvas,.neo-chart canvas{width:100%;height:175px;display:block}.customer-voucher-row{grid-template-columns:repeat(5,minmax(0,1fr))}.mikrotik-row{grid-template-columns:1fr 1fr 1.45fr}.traffic-card select{max-width:260px}.traffic-metrics{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:4px 0 12px}.traffic-metrics span{display:inline-flex;gap:6px;border:1px solid rgba(36,49,109,.9);border-radius:999px;padding:7px 11px;background:rgba(11,16,40,.48)}.traffic-metrics b{color:#fff}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.resource-card table{min-width:0}.user-router-card .mini-cards{grid-template-columns:repeat(2,minmax(0,1fr))}.stat-card{min-height:138px;display:flex;flex-direction:column;justify-content:space-between}.stat-card .stat-top{display:flex;align-items:center;justify-content:space-between;gap:10px}.stat-icon{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,rgba(0,229,255,.18),rgba(0,168,255,.10));border:1px solid rgba(0,229,255,.24);color:var(--cyan);box-shadow:0 0 26px rgba(0,229,255,.10)}.stat-icon.pink{background:linear-gradient(135deg,rgba(255,0,127,.18),rgba(209,0,255,.10));border-color:rgba(255,0,127,.24);color:#FF9FD0}.stat-icon.orange{background:linear-gradient(135deg,rgba(255,106,0,.18),rgba(255,0,127,.10));border-color:rgba(255,106,0,.24);color:#FFC09A}.progressbar{height:9px;border-radius:999px;background:rgba(36,49,109,.9);overflow:hidden;margin-top:12px}.progressbar i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--cyan),var(--blue));box-shadow:0 0 18px rgba(0,229,255,.35)}.progressbar.pink i{background:linear-gradient(90deg,var(--pink),var(--magenta));box-shadow:0 0 18px rgba(255,0,127,.28)}.progressbar.orange i{background:linear-gradient(90deg,var(--orange),var(--pink));box-shadow:0 0 18px rgba(255,106,0,.26)}.ring{--p:0;width:92px;height:92px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--cyan) calc(var(--p)*1%),rgba(36,49,109,.8) 0);box-shadow:0 0 24px rgba(0,229,255,.16)}.ring:before{content:"";position:absolute;width:66px;height:66px;border-radius:50%;background:#121B45}.ring span{position:relative;z-index:1;font-weight:900}.dashboard-hero{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:22px}.chart-grid{display:grid;grid-template-columns:1.4fr .85fr .85fr;gap:16px}.accordion-card details{border:1px solid rgba(36,49,109,.75);border-radius:16px;padding:12px;background:rgba(11,16,40,.38);margin-top:10px}.accordion-card summary{cursor:pointer;font-weight:800}.fab{position:fixed;right:24px;bottom:24px;z-index:80;width:58px;height:58px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,var(--pink),var(--magenta));color:#fff;border:1px solid rgba(255,255,255,.18);box-shadow:0 0 35px rgba(255,0,127,.35);font-size:24px}.fab:hover{transform:translateY(-3px) scale(1.02)}.empty-state{text-align:center;padding:34px;border:1px dashed rgba(0,229,255,.22);border-radius:24px;background:rgba(18,27,69,.45)}
@media(max-width:1380px){.dashboard-hero{grid-template-columns:repeat(2,minmax(0,1fr))}.finance-row{grid-template-columns:repeat(2,minmax(0,1fr))}.finance-chart-card{grid-column:1/-1}.customer-voucher-row{grid-template-columns:repeat(3,minmax(0,1fr))}.mikrotik-row,.chart-grid{grid-template-columns:1fr}.traffic-card select{max-width:100%}}
@media(max-width:1120px){.topbar{grid-template-columns:auto 1fr;}.topbar-actions{display:none}.topbar-search{max-width:none}}
@media(max-width:1000px){.cards{grid-template-columns:repeat(2,minmax(0,1fr))}.two-col,.wide-editor{grid-template-columns:1fr}.sidebar{transform:translateX(-105%);transition:.22s ease}.content{margin-left:0}.mobile-toggle{display:inline-grid}body.sidebar-open .sidebar{transform:translateX(0)}.topbar{padding:12px 14px}.main{padding:16px}.mini-cards{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:760px){.topbar{grid-template-columns:1fr}.topbar-search{order:3}.topbar-brand small{display:none}.page-title,.section-head{display:block}.router-picker{display:block}.router-picker select{min-width:100%;margin-top:8px}.cards,.grid-form,.finance-row,.customer-voucher-row,.dashboard-hero{grid-template-columns:1fr}.quick-grid,.mini-cards{grid-template-columns:1fr}.form-inline,.input-action{display:grid;width:100%}.form-inline input,.form-inline select,.input-action .btn{min-width:100%;width:100%}.radio-grid{grid-template-columns:1fr}.modal{padding:10px}.modal-panel{border-radius:18px}.traffic-metrics{display:grid}.traffic-card .toolbar{align-items:flex-start}.traffic-card select{width:100%}.fab{right:14px;bottom:14px}}
@media print{body{background:#fff;color:#000}.sidebar,.topbar,.page-title,.btn,.fab{display:none!important}.content{margin:0}.main{padding:0}.card,.table-wrap{box-shadow:none;border-color:#ddd;background:#fff}.voucher table{page-break-inside:avoid}}
.ring{position:relative}

/* v13 cleanup */
.topbar-page-title{display:grid;gap:3px;min-width:190px}.topbar-page-title b{font:800 16px/1 Poppins,Inter,sans-serif;color:var(--text)}.topbar-page-title small{color:var(--muted);font-size:12px}.topbar-search{border:1px solid rgba(0,229,255,.22)}.topbar-search:focus-within{border-color:rgba(0,229,255,.62);box-shadow:var(--glow-cyan)}
.auth-page{display:grid;place-items:center;min-height:100vh;padding:26px;background:radial-gradient(circle at 12% 8%,rgba(0,229,255,.18),transparent 34%),radial-gradient(circle at 88% 14%,rgba(255,0,127,.18),transparent 32%),linear-gradient(180deg,#0B1028 0%,#070A19 100%)}
.auth-shell{width:min(1120px,100%);display:grid;grid-template-columns:1.05fr .8fr;gap:22px;align-items:stretch}.auth-visual{padding:38px;display:flex;flex-direction:column;justify-content:flex-end;min-height:560px;background:linear-gradient(135deg,rgba(0,229,255,.11),rgba(209,0,255,.08)),rgba(18,27,69,.64)}.auth-visual h1{font:900 clamp(32px,5vw,58px)/1 Poppins,Inter,sans-serif;letter-spacing:-.05em;margin:22px 0 12px}.auth-visual p{max-width:640px;color:var(--muted);font-size:16px;line-height:1.7}.auth-points{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.auth-points span{border:1px solid rgba(0,229,255,.28);border-radius:999px;padding:9px 13px;background:rgba(0,229,255,.07);color:#DDF9FF;font-weight:800;font-size:13px}.auth-card{padding:34px;border:1px solid rgba(36,49,109,.92);border-radius:28px;background:linear-gradient(180deg,rgba(18,27,69,.86),rgba(18,27,69,.62));box-shadow:var(--shadow);backdrop-filter:blur(18px);align-self:center}.auth-card h2{font:900 30px/1.1 Poppins,Inter,sans-serif;margin:0 0 8px}.auth-card p{color:var(--muted);margin:0 0 20px;line-height:1.6}.auth-card form{display:grid;gap:14px}.auth-card label{display:grid;gap:8px;color:var(--muted);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em}.brand-mark{display:grid;place-items:center;width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,var(--cyan),var(--blue));color:#06101e;font:900 28px/1 Poppins,Inter,sans-serif;box-shadow:0 0 42px rgba(0,229,255,.36)}.brand-mark.large{width:86px;height:86px;border-radius:28px;font-size:44px}.brand-mark.mobile{display:none;margin-bottom:18px}.btn.full{width:100%}.modal-panel.wide{max-width:980px}.modal.show{display:grid}.table-wrap code,.card code{color:#91F5FF;background:rgba(0,229,255,.08);border:1px solid rgba(0,229,255,.18);border-radius:8px;padding:2px 6px}.form-inline{display:flex;gap:10px;align-items:center}.form-inline input{min-width:260px}.actions.full,.grid-form .actions.full{grid-column:1/-1}
@media(max-width:900px){.auth-shell{grid-template-columns:1fr}.auth-visual{display:none}.brand-mark.mobile{display:grid}.auth-card{width:min(480px,100%);margin:auto;padding:24px;border-radius:24px}.auth-page{padding:16px}.topbar-page-title small{display:none}}
@media(max-width:760px){.topbar-page-title{min-width:0}.topbar-page-title b{font-size:14px}.auth-card h2{font-size:26px}.form-inline{display:grid}.form-inline input{min-width:0}.topbar{grid-template-columns:auto 1fr}.topbar-search{grid-column:1/-1}}

/* v14 header router picker */
.topbar-router-title.page-title{margin:0;padding:0;background:transparent;border:0;box-shadow:none;min-width:min(420px,42vw)}
.topbar-router-title .router-picker{margin:0;display:flex;align-items:center;gap:10px;white-space:nowrap}
.topbar-router-title .router-picker .muted{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.topbar-router-title .router-picker select{min-width:260px;max-width:360px;border-color:rgba(0,229,255,.32);background:linear-gradient(180deg,rgba(18,27,69,.82),rgba(11,16,40,.72));box-shadow:0 0 18px rgba(0,229,255,.08)}
.header-alert-stack{display:grid;gap:8px;margin:0 0 14px}
.header-alert-stack:empty{display:none}
.dashboard-intro{margin-top:0}
@media(max-width:760px){.topbar-router-title.page-title{min-width:0;width:100%}.topbar-router-title .router-picker{display:grid;gap:6px;white-space:normal}.topbar-router-title .router-picker select{min-width:0;max-width:none;width:100%}}
/* v15 System + Landing settings */
.system-rows{display:grid;gap:20px}.system-card{padding:22px}.switch-line{display:flex!important;align-items:center;gap:10px;text-transform:none!important;letter-spacing:0!important;font-size:14px!important;color:var(--text)!important}.switch-line input{width:auto}.landing-package-editor{border:1px solid rgba(36,49,109,.9);border-radius:18px;padding:16px;background:rgba(11,16,40,.35)}.landing-package-editor h3{margin:0 0 8px!important;color:var(--text)!important;font-size:16px!important}.landing-package-editor input[type="checkbox"]{width:18px;height:18px}.landing-package-editor td input:not([type="checkbox"]){min-width:120px}.toolbar .btn+a.btn{margin-left:8px}@media(max-width:720px){.system-card .grid-form{grid-template-columns:1fr}.landing-package-editor{overflow-x:auto}.toolbar{align-items:flex-start}.toolbar .btn{width:100%;margin-top:8px}.toolbar .btn+a.btn{margin-left:0}}

/* v17 Infrastructure fiber + customer map */
.infra-summary{border:1px solid rgba(0,229,255,.22);border-radius:18px;padding:12px 14px;background:linear-gradient(135deg,rgba(0,229,255,.08),rgba(209,0,255,.05));color:var(--muted)}
.infra-summary b{color:var(--text)}
.mini-map{min-height:220px;border:1px solid rgba(0,229,255,.22);border-radius:20px;overflow:hidden;background:rgba(11,16,40,.58);display:grid;place-items:center;color:var(--muted);position:relative}
.mini-map iframe,.infra-map-frame{width:100%;height:100%;min-height:220px;border:0;filter:saturate(.95) contrast(.95)}
.mini-map a{position:absolute;right:12px;bottom:12px;border:1px solid rgba(0,229,255,.28);border-radius:999px;padding:7px 11px;background:rgba(11,16,40,.82);backdrop-filter:blur(12px);font-weight:800;font-size:12px;color:#DDF9FF;box-shadow:var(--glow-cyan)}
.map-card{padding:0;overflow:hidden}.map-card .toolbar{padding:18px 18px 0}.infra-map-frame{height:420px;min-height:420px;margin-top:12px;border-top:1px solid rgba(36,49,109,.85)}
.btn.tiny{font-size:11px;padding:4px 8px;border-radius:999px;min-height:auto}
@media(max-width:760px){.infra-map-frame{height:320px;min-height:320px}.mini-map{min-height:180px}.mini-map iframe{min-height:180px}}
/* v18 report/voucher online helpers */
.progress-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;color:var(--muted,#B8C2E0)}
.progress-line{height:10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08);overflow:hidden;margin-top:7px}
.progress-line i{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#00E5FF,#00A8FF);box-shadow:0 0 18px rgba(0,229,255,.4)}
.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;margin:2px;border:1px solid rgba(255,255,255,.14);background:rgba(18,27,69,.62)}
.muted-pill{color:#B8C2E0;font-size:12px;line-height:1.35}
button:disabled,.btn:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.4)}

/* v25 minimal onboarding PSB cards */
.psb-page-title{margin-bottom:14px}
.psb-mini-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:0 0 14px}
.psb-mini-card{display:flex;align-items:center;gap:10px;min-height:66px;padding:11px 13px;border:1px solid rgba(36,49,109,.88);border-radius:16px;background:rgba(18,27,69,.52);color:var(--text);text-decoration:none;box-shadow:0 10px 34px rgba(0,0,0,.16);transition:.18s ease;position:relative;overflow:hidden}
.psb-mini-card:before{content:"";width:8px;height:36px;border-radius:999px;background:linear-gradient(180deg,var(--cyan),var(--blue));box-shadow:0 0 18px rgba(0,229,255,.28);flex:0 0 8px}
.psb-mini-card span{font-size:12px;font-weight:900;color:#DDE7FF;text-transform:uppercase;letter-spacing:.045em;min-width:82px}
.psb-mini-card b{margin-left:auto;font:900 24px/1 Poppins,Inter,sans-serif;color:#fff;letter-spacing:-.03em}
.psb-mini-card small{display:block;color:var(--muted);font-size:11px;margin-left:2px;white-space:nowrap}
.psb-mini-card:hover,.psb-mini-card.active{transform:translateY(-2px);border-color:rgba(0,229,255,.45);background:linear-gradient(135deg,rgba(0,229,255,.10),rgba(18,27,69,.55));box-shadow:0 14px 42px rgba(0,0,0,.22),0 0 24px rgba(0,229,255,.12)}
.psb-mini-card:nth-child(2):before{background:linear-gradient(180deg,var(--orange),var(--pink));box-shadow:0 0 18px rgba(255,106,0,.24)}
.psb-mini-card:nth-child(3):before{background:linear-gradient(180deg,#19f58a,var(--cyan));box-shadow:0 0 18px rgba(25,245,138,.22)}
.psb-mini-card:nth-child(4):before{background:linear-gradient(180deg,var(--pink),var(--magenta));box-shadow:0 0 18px rgba(255,0,127,.22)}
@media(max-width:1000px){.psb-mini-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:560px){.psb-mini-stats{grid-template-columns:1fr}.psb-mini-card{min-height:56px}.psb-mini-card span{min-width:88px}.psb-mini-card b{font-size:22px}}

/* v26 - Dashboard minimalis gabungan */
.dashboard-minimal{display:grid;gap:16px}.dashboard-minimal .card{padding:18px}.mini-overview-grid{display:grid;grid-template-columns:1.35fr 1fr .82fr;gap:16px;align-items:stretch}.mini-monitor-grid{display:grid;grid-template-columns:1.45fr 1fr;gap:16px}.mini-bottom-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}.mini-panel{min-height:0;overflow:hidden}.mini-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.mini-panel-head.compact{margin-bottom:12px}.mini-panel-head h2,.mini-panel-head h3,.compact-toolbar h3{margin:3px 0 0}.mini-panel-head h2{font-size:30px;line-height:1}.eyebrow{display:inline-flex;text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:900;color:var(--cyan)}.mini-ring{width:74px;height:74px;flex:0 0 auto}.mini-ring:before{width:52px;height:52px}.mini-ring span{font-size:13px}.mini-metrics{display:grid;gap:10px;margin:12px 0}.mini-metrics.three{grid-template-columns:repeat(3,minmax(0,1fr))}.mini-metrics.two{grid-template-columns:repeat(2,minmax(0,1fr))}.mini-metric-item,.mini-tile{display:block;border:1px solid rgba(36,49,109,.72);border-radius:16px;padding:12px;background:rgba(11,16,40,.32);transition:.18s ease;color:#fff}.mini-metric-item:hover,.mini-tile:hover{border-color:rgba(0,229,255,.42);box-shadow:0 0 22px rgba(0,229,255,.10);transform:translateY(-1px)}.mini-metric-item small,.mini-tile small,.mini-resource-grid small{display:block;color:var(--text-muted);font-size:11px}.mini-metric-item b,.mini-tile b,.mini-resource-grid b{display:block;margin-top:5px;font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mini-metric-item.danger b{color:#FF9FD0}.mini-split-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.service-row{grid-template-columns:repeat(4,minmax(0,1fr));margin-top:12px}.mini-tile.accent{background:linear-gradient(135deg,rgba(255,0,127,.12),rgba(209,0,255,.08));border-color:rgba(255,0,127,.24)}.mini-progress-lines{display:grid;gap:8px;margin-top:12px}.mini-progress-lines label{display:flex;justify-content:space-between;gap:10px;font-size:12px;color:var(--text-muted)}.mini-progress-lines .progressbar{margin:0;height:7px}.mini-chip-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.pill-link{display:inline-flex;align-items:center;border:1px solid rgba(36,49,109,.8);border-radius:999px;padding:7px 10px;font-size:12px;color:var(--text-muted);background:rgba(11,16,40,.35)}.pill-link:hover{color:#fff;border-color:rgba(0,229,255,.5)}.mini-canvas{width:100%;height:110px;margin-top:6px;display:block}.compact-toolbar{margin-bottom:10px}.compact-toolbar select{max-width:220px}.traffic-panel canvas{width:100%;height:150px;display:block}.traffic-metrics.compact{margin:2px 0 10px}.traffic-metrics.compact span{padding:6px 10px;font-size:12px}.mini-resource-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.compact-log{display:grid;gap:8px;max-height:160px;overflow:auto}.compact-log div{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 0;border-bottom:1px solid rgba(36,49,109,.45)}.compact-log p{display:none}.compact-actions{grid-template-columns:repeat(2,minmax(0,1fr))}.action-panel .btn{justify-content:center}.dashboard-minimal .progressbar{height:7px}.dashboard-minimal .btn.small{padding:8px 11px;border-radius:12px}.dashboard-minimal .badge{white-space:nowrap}
@media(max-width:1380px){.mini-overview-grid{grid-template-columns:1fr 1fr}.voucher-panel{grid-column:1/-1}.mini-monitor-grid,.mini-bottom-grid{grid-template-columns:1fr 1fr}.action-panel{grid-column:1/-1}.service-row{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.mini-overview-grid,.mini-monitor-grid,.mini-bottom-grid{grid-template-columns:1fr}.mini-metrics.three,.mini-split-row,.mini-resource-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.service-row{grid-template-columns:repeat(2,minmax(0,1fr))}.finance-panel .mini-panel-head{align-items:center}.compact-toolbar{display:grid;gap:10px}.compact-toolbar select{max-width:100%;width:100%}}
@media(max-width:520px){.dashboard-minimal .card{padding:14px}.mini-panel-head{display:grid}.mini-metrics.three,.mini-metrics.two,.mini-split-row,.mini-resource-grid,.service-row,.compact-actions{grid-template-columns:1fr}.mini-panel-head h2{font-size:26px}.mini-ring{width:68px;height:68px}.mini-ring:before{width:48px;height:48px}}

/* v27 - Tema web utama berbasis data-theme */
:root,
[data-theme="cyber"]{
  --bg-main:#0B0E11;
  --bg-card:#181A20;
  --bg-sidebar:#10131A;
  --bg-soft:#202530;
  --border-main:#2B3139;
  --accent:#9B51E0;
  --accent-2:#3772FF;
  --accent-hot:#D100FF;
  --text-main:#EAECEF;
  --text-secondary:#A7B0BF;
  --crypto-up:#00FFAA;
  --crypto-down:#FF3B30;
  --font-main:Urbanist,Satoshi,Inter,system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  --font-crypto:"Space Mono","Roboto Mono",Consolas,monospace;
  --bg:var(--bg-main);
  --card:var(--bg-card);
  --sidebar:var(--bg-sidebar);
  --border:var(--border-main);
  --cyan:var(--accent);
  --blue:var(--accent-2);
  --pink:var(--accent-hot);
  --magenta:var(--accent-hot);
  --purple:var(--accent);
  --orange:#FF6A00;
  --text:var(--text-main);
  --muted:var(--text-secondary);
  --text-muted:var(--text-secondary);
  --success:var(--crypto-up);
  --danger:var(--crypto-down);
  --warning:#FFB020;
  --glass:color-mix(in srgb,var(--bg-card) 78%, transparent);
  --glass-strong:color-mix(in srgb,var(--bg-card) 94%, transparent);
  --shadow:0 24px 80px rgba(0,0,0,.46);
  --shadow-soft:0 18px 45px rgba(0,0,0,.32);
  --glow-cyan:0 0 0 1px color-mix(in srgb,var(--accent) 35%, transparent),0 0 24px color-mix(in srgb,var(--accent) 27%, transparent);
  --glow-pink:0 0 0 1px color-mix(in srgb,var(--accent-hot) 35%, transparent),0 0 24px color-mix(in srgb,var(--accent-hot) 25%, transparent);
}

[data-theme="light"]{
  --bg-main:#F8F9FA;
  --bg-card:#FFFFFF;
  --bg-sidebar:#FFFFFF;
  --bg-soft:#EEF2FF;
  --border-main:#D9E0F2;
  --accent:#3772FF;
  --accent-2:#00A8FF;
  --accent-hot:#FF3B30;
  --text-main:#11142D;
  --text-secondary:#5D6680;
  --crypto-up:#00B159;
  --crypto-down:#FF3B30;
  --font-main:Inter,"Plus Jakarta Sans",system-ui,-apple-system,"Segoe UI",Arial,sans-serif;
  --font-crypto:"Roboto Mono","Space Mono",Consolas,monospace;
  --bg:var(--bg-main);--card:var(--bg-card);--sidebar:var(--bg-sidebar);--border:var(--border-main);
  --cyan:var(--accent);--blue:var(--accent);--pink:var(--accent-hot);--magenta:#8A2BE2;--purple:#6D5DF7;--orange:#FF6A00;
  --text:var(--text-main);--muted:var(--text-secondary);--text-muted:var(--text-secondary);
  --success:var(--crypto-up);--danger:var(--crypto-down);--warning:#B26A00;
  --glass:rgba(255,255,255,.78);--glass-strong:rgba(255,255,255,.96);
  --shadow:0 22px 70px rgba(17,20,45,.12);--shadow-soft:0 16px 38px rgba(17,20,45,.10);
  --glow-cyan:0 0 0 1px rgba(55,114,255,.18),0 12px 32px rgba(55,114,255,.16);
  --glow-pink:0 0 0 1px rgba(255,59,48,.16),0 12px 32px rgba(255,59,48,.12);
}

[data-theme="ice"]{
  --bg-main:#0A1128;
  --bg-card:#1C2541;
  --bg-sidebar:#111B34;
  --bg-soft:#243052;
  --border-main:#33415C;
  --accent:#00B4D8;
  --accent-2:#48CAE4;
  --accent-hot:#8A2BE2;
  --text-main:#E0E1DD;
  --text-secondary:#B9C2D6;
  --crypto-up:#48CAE4;
  --crypto-down:#F25C54;
  --font-main:"SF Pro Display",-apple-system,BlinkMacSystemFont,"Inter",system-ui,"Segoe UI",Arial,sans-serif;
  --font-crypto:"SF Mono","JetBrains Mono","Roboto Mono",Consolas,monospace;
  --bg:var(--bg-main);--card:var(--bg-card);--sidebar:var(--bg-sidebar);--border:var(--border-main);
  --cyan:var(--accent);--blue:var(--accent-2);--pink:#F25C54;--magenta:#7B61FF;--purple:#8A2BE2;--orange:#FFB703;
  --text:var(--text-main);--muted:var(--text-secondary);--text-muted:var(--text-secondary);
  --success:var(--crypto-up);--danger:var(--crypto-down);--warning:#FFD166;
  --glass:rgba(28,37,65,.74);--glass-strong:rgba(28,37,65,.94);
  --shadow:0 24px 80px rgba(0,7,25,.42);--shadow-soft:0 16px 46px rgba(0,7,25,.30);
  --glow-cyan:0 0 0 1px rgba(0,180,216,.25),0 0 26px rgba(72,202,228,.20);
  --glow-pink:0 0 0 1px rgba(242,92,84,.22),0 0 24px rgba(242,92,84,.16);
}

[data-theme="terminal"]{
  --bg-main:#000000;
  --bg-card:#0D0D0D;
  --bg-sidebar:#050505;
  --bg-soft:#101810;
  --border-main:#1F4D1F;
  --accent:#33FF33;
  --accent-2:#33FF33;
  --accent-hot:#00CC66;
  --text-main:#33FF33;
  --text-secondary:#8DFF8D;
  --crypto-up:#33FF33;
  --crypto-down:#FF0000;
  --font-main:"Fira Code","JetBrains Mono",Consolas,monospace;
  --font-crypto:"JetBrains Mono","Fira Code",Consolas,monospace;
  --bg:var(--bg-main);--card:var(--bg-card);--sidebar:var(--bg-sidebar);--border:var(--border-main);
  --cyan:var(--accent);--blue:var(--accent);--pink:#FF0000;--magenta:#33FF33;--purple:#33FF33;--orange:#FFB000;
  --text:var(--text-main);--muted:var(--text-secondary);--text-muted:var(--text-secondary);
  --success:var(--crypto-up);--danger:var(--crypto-down);--warning:#FFFF00;
  --glass:rgba(13,13,13,.82);--glass-strong:rgba(13,13,13,.96);
  --shadow:0 0 0 1px rgba(51,255,51,.14),0 0 38px rgba(51,255,51,.06);
  --shadow-soft:0 0 0 1px rgba(51,255,51,.13),0 0 24px rgba(51,255,51,.05);
  --glow-cyan:0 0 0 1px rgba(51,255,51,.38),0 0 20px rgba(51,255,51,.30);
  --glow-pink:0 0 0 1px rgba(255,0,0,.35),0 0 20px rgba(255,0,0,.22);
}

html[data-theme],body[data-theme]{background:var(--bg-main);color:var(--text-main);font-family:var(--font-main)}
body{font-family:var(--font-main);color:var(--text-main);background:radial-gradient(circle at 16% 4%,color-mix(in srgb,var(--accent) 18%, transparent),transparent 34%),radial-gradient(circle at 82% 6%,color-mix(in srgb,var(--accent-hot) 16%, transparent),transparent 32%),linear-gradient(180deg,var(--bg-main) 0%,color-mix(in srgb,var(--bg-main) 86%,#000 14%) 100%)}
[data-theme="light"] body,body[data-theme="light"]{background:radial-gradient(circle at 12% -8%,rgba(55,114,255,.12),transparent 36%),radial-gradient(circle at 86% 4%,rgba(255,59,48,.08),transparent 30%),linear-gradient(180deg,#F8F9FA 0%,#EFF3FF 100%)}
[data-theme="terminal"] body,body[data-theme="terminal"]{background:#000;background-image:linear-gradient(rgba(51,255,51,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(51,255,51,.035) 1px,transparent 1px);background-size:22px 22px;text-shadow:0 0 7px rgba(51,255,51,.20)}
.bg-grid{background-image:linear-gradient(color-mix(in srgb,var(--border-main) 45%, transparent) 1px,transparent 1px),linear-gradient(90deg,color-mix(in srgb,var(--border-main) 38%, transparent) 1px,transparent 1px)}
.orb-cyan{background:linear-gradient(135deg,var(--accent),var(--accent-2))}.orb-pink{background:linear-gradient(135deg,var(--accent-hot),var(--accent))}
.sidebar{background:linear-gradient(180deg,color-mix(in srgb,var(--bg-sidebar) 92%, transparent),color-mix(in srgb,var(--bg-main) 96%, transparent));border-right-color:var(--border-main)}
.topbar{background:color-mix(in srgb,var(--bg-main) 80%, transparent);border-bottom-color:var(--border-main)}
.sb-brand,.topbar-search,.profile-chip,.icon-btn{background:color-mix(in srgb,var(--bg-card) 76%, transparent);border-color:color-mix(in srgb,var(--border-main) 92%, transparent)}
.sb-logo,.topbar-logo,.btn:not(.ghost):not(.danger):not(.warning):not(.secondary){background:linear-gradient(135deg,var(--accent),var(--accent-2));color:color-mix(in srgb,var(--bg-main) 88%,#fff 12%)}
[data-theme="terminal"] .sb-logo,[data-theme="terminal"] .topbar-logo,[data-theme="terminal"] .btn:not(.ghost):not(.danger):not(.warning):not(.secondary){color:#000}
.menu-link,.menu-group-toggle{color:var(--text-main)}.menu-icon{color:var(--accent);border-color:color-mix(in srgb,var(--border-main) 70%, transparent);background:color-mix(in srgb,var(--bg-soft) 45%, transparent)}
.menu-link:hover,.menu-group-toggle:hover,.menu-link.active,.menu-group-toggle.active{border-color:color-mix(in srgb,var(--accent) 45%, transparent);background:color-mix(in srgb,var(--accent) 10%, transparent);box-shadow:var(--glow-cyan)}
.menu-link.active:before,.menu-group-toggle.active:before{background:linear-gradient(180deg,var(--accent),var(--accent-hot));box-shadow:0 0 16px var(--accent)}
.card,.glass-card{background:linear-gradient(180deg,color-mix(in srgb,var(--bg-card) 78%, transparent),color-mix(in srgb,var(--bg-card) 58%, transparent));border-color:color-mix(in srgb,var(--border-main) 92%, transparent);box-shadow:var(--shadow-soft)}
.card:before{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 32%, transparent),color-mix(in srgb,var(--accent-hot) 16%, transparent),color-mix(in srgb,var(--accent-2) 20%, transparent))}
.card h3,.muted,.mini-metric-item small,.mini-tile small,.mini-resource-grid small{color:var(--text-secondary)!important}.metric,.mini-metric-item b,.mini-tile b,.mini-resource-grid b{font-family:var(--font-crypto);color:var(--text-main)}
input,select,textarea{background:color-mix(in srgb,var(--bg-main) 68%, transparent);border-color:color-mix(in srgb,var(--border-main) 95%, transparent);color:var(--text-main);font-family:var(--font-main)}
select option{background:var(--bg-card);color:var(--text-main)}
input:focus,select:focus,textarea:focus{border-color:color-mix(in srgb,var(--accent) 62%, transparent);box-shadow:var(--glow-cyan)}
.table-wrap table,table{color:var(--text-main)}
th{color:var(--text-secondary)}
.mono,.metric,.mini-panel-head h2,.mini-metric-item b,.mini-tile b,.traffic-metrics b,.voucher-code-big{font-family:var(--font-crypto)}
.badge.success,.status-up,.crypto-up{color:var(--crypto-up)!important;border-color:color-mix(in srgb,var(--crypto-up) 35%, transparent);background:color-mix(in srgb,var(--crypto-up) 10%, transparent)}
.badge.danger,.status-down,.crypto-down{color:var(--crypto-down)!important;border-color:color-mix(in srgb,var(--crypto-down) 35%, transparent);background:color-mix(in srgb,var(--crypto-down) 10%, transparent)}
.alert.success{border-color:color-mix(in srgb,var(--crypto-up) 42%, transparent);background:color-mix(in srgb,var(--crypto-up) 12%, transparent);color:var(--text-main)}
.alert.danger{border-color:color-mix(in srgb,var(--crypto-down) 42%, transparent);background:color-mix(in srgb,var(--crypto-down) 12%, transparent);color:var(--text-main)}
.theme-switcher{display:flex;align-items:center}.theme-switcher select{height:42px;min-width:124px;border-radius:999px;padding:0 34px 0 13px;font-size:12px;font-weight:800;background:color-mix(in srgb,var(--bg-card) 72%, transparent);box-shadow:var(--shadow-soft);cursor:pointer}.theme-choice-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.theme-choice{position:relative;display:grid;gap:8px;padding:14px;border:1px solid color-mix(in srgb,var(--border-main) 80%, transparent);border-radius:18px;background:color-mix(in srgb,var(--bg-card) 65%, transparent);cursor:pointer;transition:.18s}.theme-choice:hover,.theme-choice.active{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 48%, transparent);box-shadow:var(--glow-cyan)}.theme-choice input{position:absolute;opacity:0;pointer-events:none}.theme-choice strong{font-size:14px}.theme-choice small{color:var(--text-secondary);line-height:1.35}.theme-preview{height:78px;border-radius:16px;padding:10px;background:var(--sample-bg);border:1px solid color-mix(in srgb,var(--sample-accent) 45%, transparent);display:grid;gap:8px;box-shadow:inset 0 0 26px rgba(0,0,0,.18)}.theme-preview i,.theme-preview b,.theme-preview em{display:block;border-radius:999px;background:var(--sample-accent)}.theme-preview i{width:38%;height:8px}.theme-preview b{width:72%;height:12px;background:var(--sample-card);border:1px solid var(--sample-accent)}.theme-preview em{width:56%;height:8px;justify-self:end}.theme-save-row{margin-top:14px}
[data-theme="light"] .card,[data-theme="light"] .glass-card,[data-theme="light"] .mini-metric-item,[data-theme="light"] .mini-tile{background:rgba(255,255,255,.88)}
[data-theme="light"] .sidebar{box-shadow:18px 0 46px rgba(17,20,45,.08)}
[data-theme="light"] .btn.ghost{color:var(--text-main);background:#fff}
[data-theme="terminal"] .card:before{display:none}[data-theme="terminal"] .btn.secondary{background:#111;color:var(--accent);border-color:var(--accent);box-shadow:var(--glow-cyan)}
@media(max-width:1100px){.theme-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.theme-switcher{display:none}}
@media(max-width:560px){.theme-choice-grid{grid-template-columns:1fr}}


/* v28 sidebar footer user card */
.sidebar{
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
}
.sidebar .menu{
  flex:1 1 auto!important;
  min-height:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
  padding-bottom:12px!important;
  margin-bottom:10px!important;
  scrollbar-width:thin;
}
.sidebar .menu::-webkit-scrollbar{width:7px}
.sidebar .menu::-webkit-scrollbar-thumb{background:color-mix(in srgb,var(--accent) 32%, transparent);border-radius:999px}
.sidebar-footer{
  flex:0 0 auto;
  position:relative;
  z-index:3;
  padding:12px 0 0;
  margin-top:auto;
  background:linear-gradient(180deg,transparent 0%,color-mix(in srgb,var(--bg-main) 86%, transparent) 30%,var(--bg-main) 100%);
}
.sidebar-user-card{
  width:100%;
  border:1px solid color-mix(in srgb,var(--border-main) 86%, transparent);
  border-radius:28px;
  padding:18px 20px;
  background:linear-gradient(145deg,color-mix(in srgb,var(--bg-card) 82%, transparent),color-mix(in srgb,var(--bg-main) 88%, transparent));
  box-shadow:0 22px 52px rgba(0,0,0,.30),0 0 24px color-mix(in srgb,var(--accent) 14%, transparent);
  backdrop-filter:blur(18px);
}
.sidebar-user-row{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:0;
}
.sidebar-user-avatar{
  width:64px;
  height:64px;
  flex:0 0 64px;
  display:grid;
  place-items:center;
  border-radius:18px;
  background:linear-gradient(135deg,var(--secondary-pink, #FF007F),var(--secondary-magenta, #D100FF));
  color:#fff;
  font:900 28px/1 var(--font-main),Inter,sans-serif;
  box-shadow:0 0 34px color-mix(in srgb,var(--secondary-pink, #FF007F) 38%, transparent);
}
.sidebar-user-meta{min-width:0;line-height:1.15}
.sidebar-user-meta b{
  display:block;
  color:var(--text-main);
  font:900 19px/1.1 var(--font-main),Inter,sans-serif;
  letter-spacing:-.02em;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-transform:uppercase;
}
.sidebar-user-meta small{
  display:block;
  margin-top:7px;
  color:var(--text-secondary, var(--muted));
  font-size:13px;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.sidebar-logout-btn{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  margin-top:16px;
  padding:13px 16px;
  border-radius:18px;
  border:1px solid color-mix(in srgb,var(--secondary-pink, #FF007F) 62%, transparent);
  background:linear-gradient(135deg,var(--secondary-pink, #FF007F),var(--secondary-magenta, #D100FF));
  color:#fff;
  text-decoration:none;
  font:900 15px/1 var(--font-main),Inter,sans-serif;
  box-shadow:0 12px 30px color-mix(in srgb,var(--secondary-pink, #FF007F) 22%, transparent);
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.sidebar-logout-btn:hover{
  transform:translateY(-2px);
  filter:saturate(1.08);
  box-shadow:0 16px 42px color-mix(in srgb,var(--secondary-pink, #FF007F) 32%, transparent);
}
[data-theme="terminal"] .sidebar-user-avatar,
[data-theme="terminal"] .sidebar-logout-btn{
  background:var(--accent);
  color:#000;
  border-color:var(--accent);
  box-shadow:0 0 24px color-mix(in srgb,var(--accent) 24%, transparent);
}
[data-theme="light"] .sidebar-user-card{
  background:linear-gradient(145deg,rgba(255,255,255,.92),rgba(248,249,250,.96));
  box-shadow:0 18px 42px rgba(17,20,45,.10);
}
@media(max-width:1000px){
  .sidebar{padding-bottom:14px!important}
  .sidebar-user-card{border-radius:24px;padding:14px}
  .sidebar-user-avatar{width:52px;height:52px;flex-basis:52px;border-radius:16px;font-size:23px}
  .sidebar-user-meta b{font-size:16px}
  .sidebar-logout-btn{padding:12px 14px;border-radius:16px}
}
@media(max-height:720px){
  .sidebar-user-card{padding:13px 14px;border-radius:22px}
  .sidebar-user-avatar{width:48px;height:48px;flex-basis:48px;font-size:22px}
  .sidebar-logout-btn{margin-top:10px;padding:11px 12px}
}

/* v29 compact sidebar footer + muted transparent glow scrollbar */
:root{
  --scrollbar-size:6px;
  --scrollbar-track:transparent;
  --scrollbar-thumb:color-mix(in srgb,var(--accent, #00E5FF) 26%, transparent);
  --scrollbar-thumb-hover:color-mix(in srgb,var(--accent, #00E5FF) 52%, transparent);
  --scrollbar-glow:0 0 10px color-mix(in srgb,var(--accent, #00E5FF) 26%, transparent);
}
*{
  scrollbar-width:thin;
  scrollbar-color:var(--scrollbar-thumb) var(--scrollbar-track);
}
*::-webkit-scrollbar{
  width:var(--scrollbar-size);
  height:var(--scrollbar-size);
}
*::-webkit-scrollbar-track{
  background:transparent;
}
*::-webkit-scrollbar-thumb{
  background:linear-gradient(180deg,var(--scrollbar-thumb),color-mix(in srgb,var(--secondary-pink, #FF007F) 20%, transparent));
  border-radius:999px;
  border:2px solid transparent;
  background-clip:padding-box;
  box-shadow:var(--scrollbar-glow);
}
*::-webkit-scrollbar-thumb:hover{
  background:linear-gradient(180deg,var(--scrollbar-thumb-hover),color-mix(in srgb,var(--secondary-pink, #FF007F) 38%, transparent));
  background-clip:padding-box;
}
*::-webkit-scrollbar-corner{
  background:transparent;
}
.sidebar .menu::-webkit-scrollbar{width:5px!important;height:5px!important}
.sidebar-footer{
  padding:8px 0 0!important;
  background:linear-gradient(180deg,transparent 0%,color-mix(in srgb,var(--bg-main) 70%, transparent) 45%,var(--bg-main) 100%)!important;
}
.sidebar-user-card{
  border-radius:18px!important;
  padding:10px 11px!important;
  box-shadow:0 12px 30px rgba(0,0,0,.22),0 0 16px color-mix(in srgb,var(--accent) 10%, transparent)!important;
}
.sidebar-user-row{gap:9px!important}
.sidebar-user-avatar{
  width:42px!important;
  height:42px!important;
  flex-basis:42px!important;
  border-radius:13px!important;
  font-size:19px!important;
  box-shadow:0 0 20px color-mix(in srgb,var(--secondary-pink, #FF007F) 26%, transparent)!important;
}
.sidebar-user-meta b{
  font-size:13px!important;
  line-height:1.05!important;
}
.sidebar-user-meta small{
  margin-top:4px!important;
  font-size:10.5px!important;
  line-height:1.25!important;
}
.sidebar-logout-btn{
  margin-top:9px!important;
  padding:9px 11px!important;
  border-radius:13px!important;
  font-size:12px!important;
  box-shadow:0 8px 20px color-mix(in srgb,var(--secondary-pink, #FF007F) 18%, transparent)!important;
}
.sidebar-logout-btn:hover{
  transform:translateY(-1px)!important;
  box-shadow:0 10px 26px color-mix(in srgb,var(--secondary-pink, #FF007F) 28%, transparent)!important;
}
[data-theme="light"]{
  --scrollbar-thumb:rgba(55,114,255,.22);
  --scrollbar-thumb-hover:rgba(55,114,255,.46);
}
[data-theme="terminal"]{
  --scrollbar-thumb:rgba(51,255,51,.24);
  --scrollbar-thumb-hover:rgba(51,255,51,.52);
}
@media(max-height:720px){
  .sidebar-user-card{padding:8px 9px!important;border-radius:16px!important}
  .sidebar-user-avatar{width:36px!important;height:36px!important;flex-basis:36px!important;font-size:17px!important}
  .sidebar-user-meta b{font-size:12px!important}
  .sidebar-user-meta small{font-size:10px!important}
  .sidebar-logout-btn{margin-top:7px!important;padding:8px 10px!important;font-size:11.5px!important}
}
@media(max-width:1000px){
  .sidebar-user-card{padding:9px 10px!important;border-radius:17px!important}
  .sidebar-user-avatar{width:38px!important;height:38px!important;flex-basis:38px!important;font-size:18px!important}
  .sidebar-user-meta b{font-size:12.5px!important}
  .sidebar-logout-btn{padding:8px 10px!important}
}

/* v30 - Light theme submenu readability + clean router picker */
.router-picker{
  display:flex;
  align-items:center;
  gap:10px;
  margin:0;
  min-width:0;
}
.router-picker .muted{
  flex:0 0 auto;
  font-size:11px;
  font-weight:900;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--text-secondary)!important;
}
.router-picker select,
.topbar-router-title .router-picker select{
  height:46px;
  min-width:260px;
  max-width:380px;
  border-radius:15px;
  padding:0 42px 0 16px;
  font-weight:800;
  letter-spacing:.01em;
  color:var(--text-main)!important;
  background:
    linear-gradient(180deg,color-mix(in srgb,var(--bg-card) 96%, transparent),color-mix(in srgb,var(--bg-soft) 42%, transparent))!important;
  border:1px solid color-mix(in srgb,var(--border-main) 92%, transparent)!important;
  box-shadow:0 10px 26px color-mix(in srgb,var(--bg-main) 18%, transparent), inset 0 1px 0 color-mix(in srgb,#fff 9%, transparent)!important;
  appearance:auto;
}
.router-picker select:hover,
.topbar-router-title .router-picker select:hover{
  border-color:color-mix(in srgb,var(--accent) 42%, transparent)!important;
  box-shadow:var(--glow-cyan)!important;
}
.router-picker select:focus,
.topbar-router-title .router-picker select:focus{
  border-color:color-mix(in srgb,var(--accent) 62%, transparent)!important;
  box-shadow:var(--glow-cyan)!important;
}
.router-picker option{background:var(--bg-card)!important;color:var(--text-main)!important}

.menu-group-children{
  border-left-color:color-mix(in srgb,var(--accent) 22%, transparent)!important;
}
.menu-link.child{
  opacity:1!important;
  color:color-mix(in srgb,var(--text-main) 78%, var(--text-secondary) 22%)!important;
  font-weight:700;
}
.menu-link.child .menu-icon{
  color:var(--accent)!important;
  background:color-mix(in srgb,var(--bg-soft) 58%, transparent)!important;
  border-color:color-mix(in srgb,var(--border-main) 78%, transparent)!important;
}
.menu-link.child:hover{
  color:var(--text-main)!important;
  background:color-mix(in srgb,var(--accent) 10%, transparent)!important;
  border-color:color-mix(in srgb,var(--accent) 35%, transparent)!important;
}
.menu-link.child.active{
  color:var(--text-main)!important;
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 17%, transparent),color-mix(in srgb,var(--accent-2) 9%, transparent))!important;
  border-color:color-mix(in srgb,var(--accent) 42%, transparent)!important;
}

[data-theme="light"] .sidebar{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(246,248,255,.96))!important;
  border-right-color:#DDE5FA!important;
}
[data-theme="light"] .menu-group-children{
  border-left-color:#D9E4FF!important;
  background:linear-gradient(180deg,rgba(55,114,255,.045),rgba(55,114,255,.015));
  border-radius:0 14px 14px 0;
}
[data-theme="light"] .menu-link,
[data-theme="light"] .menu-group-toggle{
  color:#202844!important;
}
[data-theme="light"] .menu-link.child{
  color:#5A6788!important;
  text-shadow:none!important;
}
[data-theme="light"] .menu-link.child span:last-child{
  color:inherit!important;
}
[data-theme="light"] .menu-link.child .menu-icon{
  color:#3772FF!important;
  background:#F3F6FF!important;
  border-color:#E0E8FF!important;
}
[data-theme="light"] .menu-link.child:hover{
  color:#11142D!important;
  background:#EEF4FF!important;
  border-color:#BFD0FF!important;
  box-shadow:0 8px 22px rgba(55,114,255,.10)!important;
}
[data-theme="light"] .menu-link.child.active{
  color:#11142D!important;
  background:linear-gradient(135deg,#E9F1FF,#F7FAFF)!important;
  border-color:#9DB9FF!important;
  box-shadow:0 10px 26px rgba(55,114,255,.14)!important;
}
[data-theme="light"] .menu-link.child.active .menu-icon{
  color:#FFFFFF!important;
  background:linear-gradient(135deg,#3772FF,#00A8FF)!important;
  border-color:rgba(55,114,255,.25)!important;
}
[data-theme="light"] .menu-caret{color:#6D7896!important}
[data-theme="light"] .menu-group.open .menu-caret{color:#3772FF!important}

[data-theme="light"] .router-picker .muted{color:#59637F!important}
[data-theme="light"] .router-picker select,
[data-theme="light"] .topbar-router-title .router-picker select{
  color:#11142D!important;
  background:linear-gradient(180deg,#FFFFFF,#F3F6FF)!important;
  border-color:#D7E1F7!important;
  box-shadow:0 10px 24px rgba(17,20,45,.08), inset 0 1px 0 rgba(255,255,255,.95)!important;
}
[data-theme="light"] .router-picker select:hover,
[data-theme="light"] .topbar-router-title .router-picker select:hover,
[data-theme="light"] .router-picker select:focus,
[data-theme="light"] .topbar-router-title .router-picker select:focus{
  border-color:#9DB9FF!important;
  box-shadow:0 12px 28px rgba(55,114,255,.14),0 0 0 3px rgba(55,114,255,.08)!important;
}
[data-theme="light"] .router-picker option{background:#FFFFFF!important;color:#11142D!important}

[data-theme="terminal"] .router-picker select,
[data-theme="terminal"] .topbar-router-title .router-picker select{
  background:#050505!important;
  border-color:#1F4D1F!important;
  color:#33FF33!important;
}
[data-theme="terminal"] .router-picker option{background:#000!important;color:#33FF33!important}

@media(max-width:760px){
  .router-picker{width:100%;display:grid;gap:6px}
  .router-picker select,.topbar-router-title .router-picker select{min-width:0!important;max-width:none!important;width:100%!important}
}

/* v31 Reseller portal */
.switch-mini{display:inline-flex;align-items:center;gap:8px;cursor:pointer}.switch-mini input{display:none}.switch-mini span{width:42px;height:24px;border-radius:999px;background:rgba(148,163,184,.28);border:1px solid rgba(36,49,109,.75);position:relative;transition:.18s}.switch-mini span:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:2px;border-radius:999px;background:rgba(255,255,255,.72);box-shadow:0 2px 8px rgba(0,0,0,.18);transition:.18s}.switch-mini input:checked+span{background:linear-gradient(135deg,var(--cyan),var(--blue));border-color:rgba(0,229,255,.55);box-shadow:0 0 18px rgba(0,229,255,.18)}.switch-mini input:checked+span:before{left:19px;background:#fff}.compact-dashboard-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-bottom:18px}.panel-span-2{grid-column:span 2}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.eyebrow{display:block;color:var(--accent);font-size:12px;font-weight:900;letter-spacing:.12em;text-transform:uppercase;margin-bottom:6px}.mini-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:14px}.mini-stats>div{border:1px solid rgba(36,49,109,.82);border-radius:16px;background:rgba(255,255,255,.035);padding:12px}.mini-stats b{display:block;font:800 18px/1.1 var(--font-crypto),monospace}.mini-stats span{display:block;color:var(--muted);font-size:12px;margin-top:4px}.quick-actions{display:flex;gap:10px;flex-wrap:wrap}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.form-actions{display:flex;gap:10px;align-items:center;justify-content:flex-end}.span-2{grid-column:span 2}.btn.tiny{padding:5px 8px;border-radius:10px;font-size:11px}.badge.green{color:var(--crypto-up)}.badge.red{color:var(--crypto-down)}
@media(max-width:1000px){.compact-dashboard-grid,.grid-2,.grid-3{grid-template-columns:1fr}.panel-span-2{grid-column:auto}.mini-stats{grid-template-columns:1fr}}

/* v32 Customer Portal */
.portal-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:16px;margin-bottom:16px}.portal-hero{display:flex;align-items:center;justify-content:space-between;gap:16px}.portal-hero h2{margin:.25rem 0;font-size:clamp(22px,3vw,34px)}.portal-hero p{color:var(--text-muted);margin:.25rem 0 1rem}.pill-row{display:flex;gap:8px;flex-wrap:wrap}.invoice-highlight{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.invoice-highlight h2{margin:.25rem 0}.quick-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.quick-card{padding:14px;border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--bg-card) 86%,transparent);text-decoration:none;color:var(--text-main);transition:.2s}.quick-card:hover{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 55%,transparent),0 0 22px color-mix(in srgb,var(--accent) 18%,transparent);transform:translateY(-1px)}.quick-card b{display:block}.quick-card small{color:var(--text-muted)}.info-list{display:grid;gap:10px}.info-list p{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin:0;padding:11px 0;border-bottom:1px solid color-mix(in srgb,var(--border) 58%,transparent)}.info-list p:last-child{border-bottom:0}.info-list span,.info-grid small{color:var(--text-muted);font-size:12px}.info-list b{text-align:right}.info-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.info-grid>div{padding:14px;border:1px solid var(--border);border-radius:18px;background:color-mix(in srgb,var(--bg-card) 82%,transparent)}.info-grid b{display:block;margin:6px 0}.topbar-static-title{display:flex;flex-direction:column;gap:2px}.topbar-static-title small{font-size:11px;font-weight:800;letter-spacing:.12em;color:var(--accent);text-transform:uppercase}.topbar-static-title b{font-size:16px;color:var(--text-main)}.service-status-card{position:relative;overflow:hidden}.service-status-card:before{content:"";position:absolute;inset:auto -30% -65% -30%;height:140px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 22%,transparent),transparent 70%);pointer-events:none}.compact-stats{margin-bottom:16px}@media(max-width:1100px){.portal-grid{grid-template-columns:1fr}.info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:620px){.portal-hero{align-items:flex-start;flex-direction:column}.quick-grid,.info-grid{grid-template-columns:1fr}.info-list p{display:block}.info-list b{text-align:left;display:block;margin-top:4px}}

.form-hint{display:block;margin-top:6px;font-size:11px;color:var(--text-muted,#7f8aa3);line-height:1.35}

/* v34 - Login terpisah admin/pelanggan tanpa password */
.auth-switch{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:0 0 18px;padding:6px;border:1px solid color-mix(in srgb,var(--border) 72%, transparent);border-radius:18px;background:color-mix(in srgb,var(--bg-card) 78%, transparent)}
.auth-switch a{display:flex;align-items:center;justify-content:center;min-height:38px;border-radius:13px;color:var(--muted);font-weight:900;font-size:13px;transition:.18s ease;border:1px solid transparent}
.auth-switch a:hover{color:var(--text);border-color:color-mix(in srgb,var(--accent) 25%, transparent);background:color-mix(in srgb,var(--accent) 8%, transparent)}
.auth-switch a.active{color:#fff;background:linear-gradient(135deg,var(--accent),var(--accent-hot));box-shadow:0 12px 32px color-mix(in srgb,var(--accent) 22%, transparent)}
[data-theme="light"] .auth-switch a.active{color:#fff}
.passwordless-note{padding:12px 14px;border-radius:16px;border:1px solid color-mix(in srgb,var(--accent) 24%, transparent);background:color-mix(in srgb,var(--accent) 7%, transparent);color:var(--muted);line-height:1.55}


/* v35 - Portal pelanggan minimalis dan responsif */
body.role-pelanggan{
  --customer-max:1180px;
  background:
    radial-gradient(circle at 14% -8%,color-mix(in srgb,var(--accent) 10%, transparent),transparent 32%),
    linear-gradient(180deg,var(--bg-main),color-mix(in srgb,var(--bg-main) 92%,#000 8%));
}
body.role-pelanggan .sidebar{
  width:244px;
  padding:12px 12px;
  box-shadow:14px 0 44px rgba(0,0,0,.16);
}
body.role-pelanggan .content{margin-left:244px}
body.role-pelanggan .sb-brand{
  height:56px;
  margin-bottom:10px;
  padding:8px;
  border-radius:18px;
  box-shadow:none;
}
body.role-pelanggan .sb-logo{width:38px;height:38px;border-radius:13px;font-size:15px}
body.role-pelanggan .sb-title b{font-size:15px}
body.role-pelanggan .sb-title small{font-size:10.5px;margin-top:4px}
body.role-pelanggan .menu{gap:5px;padding:6px 0 10px}
body.role-pelanggan .menu-link,
body.role-pelanggan .menu-group-toggle{
  padding:9px 10px;
  border-radius:14px;
  font-size:13px;
  box-shadow:none!important;
}
body.role-pelanggan .menu-icon{width:24px;height:24px;flex-basis:24px;border-radius:9px;font-size:12px}
body.role-pelanggan .menu-group-children{margin-left:12px;padding-left:10px}
body.role-pelanggan .sidebar-footer{padding-top:6px!important}
body.role-pelanggan .sidebar-user-card{padding:8px!important;border-radius:15px!important}
body.role-pelanggan .sidebar-user-avatar{width:34px!important;height:34px!important;flex-basis:34px!important;font-size:16px!important}
body.role-pelanggan .sidebar-user-meta b{font-size:12px!important;max-width:132px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
body.role-pelanggan .sidebar-user-meta small{font-size:9.8px!important;max-width:132px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
body.role-pelanggan .sidebar-logout-btn{padding:7px 9px!important;margin-top:7px!important;font-size:11px!important;border-radius:11px!important}
body.role-pelanggan .topbar{
  min-height:64px;
  padding:10px 18px;
  grid-template-columns:minmax(160px,auto) minmax(180px,520px) auto;
  gap:12px;
}
body.role-pelanggan .topbar-static-title small{font-size:10px;letter-spacing:.10em}
body.role-pelanggan .topbar-static-title b{font-size:15px}
body.role-pelanggan .topbar-search{height:40px;border-radius:14px;background:color-mix(in srgb,var(--bg-card) 70%, transparent)}
body.role-pelanggan .topbar-actions{gap:8px}
body.role-pelanggan .profile-chip{height:36px;padding:4px 8px 4px 4px}
body.role-pelanggan .profile-chip span{width:28px;height:28px;font-size:12px}
body.role-pelanggan .profile-chip b{font-size:12px;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
body.role-pelanggan .icon-btn{width:36px;height:36px;border-radius:12px}
body.role-pelanggan .main{
  width:min(var(--customer-max),100%);
  margin:0 auto;
  padding:18px;
}
body.role-pelanggan .header-alert-stack{margin-bottom:10px}
body.role-pelanggan .page-title{
  margin-bottom:14px;
  align-items:center;
}
body.role-pelanggan .page-title h1{
  font-size:clamp(22px,2.6vw,28px);
  letter-spacing:-.03em;
}
body.role-pelanggan .page-title p{
  margin-top:5px;
  font-size:13px;
  max-width:760px;
}
body.role-pelanggan .card{
  border-radius:18px;
  padding:15px;
  box-shadow:0 14px 34px rgba(0,0,0,.14);
  background:linear-gradient(180deg,color-mix(in srgb,var(--bg-card) 86%, transparent),color-mix(in srgb,var(--bg-card) 68%, transparent));
}
body.role-pelanggan .card:before{opacity:.45}
body.role-pelanggan .card:hover{transform:none;box-shadow:0 16px 40px rgba(0,0,0,.18)}
body.role-pelanggan .portal-grid{
  grid-template-columns:minmax(0,1.45fr) minmax(150px,.55fr) minmax(150px,.55fr);
  gap:12px;
  margin-bottom:12px;
}
body.role-pelanggan .portal-hero{
  min-height:126px;
  padding:18px;
  align-items:center;
  border-radius:22px;
}
body.role-pelanggan .portal-hero h2{font-size:clamp(21px,3.2vw,31px);line-height:1.05;margin:4px 0}
body.role-pelanggan .portal-hero p{font-size:13px;margin:4px 0 10px;color:var(--text-secondary)}
body.role-pelanggan .mini-stat{
  display:grid;
  align-content:center;
  min-height:126px;
  gap:4px;
}
body.role-pelanggan .mini-stat span{font-size:12px;color:var(--text-secondary);font-weight:800}
body.role-pelanggan .mini-stat b{font:900 clamp(20px,2.3vw,26px)/1 var(--font-crypto),monospace;color:var(--text-main);letter-spacing:-.04em}
body.role-pelanggan .mini-stat small{color:var(--text-secondary);font-size:12px}
body.role-pelanggan .grid-2{
  grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:12px;
}
body.role-pelanggan .quick-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}
body.role-pelanggan .quick-card{
  padding:12px;
  border-radius:15px;
  min-height:76px;
  display:grid;
  align-content:center;
  gap:3px;
}
body.role-pelanggan .quick-card b{font-size:13px}
body.role-pelanggan .quick-card small{font-size:11.5px;line-height:1.3}
body.role-pelanggan .invoice-highlight{
  border:1px solid color-mix(in srgb,var(--border-main) 70%, transparent);
  border-radius:16px;
  padding:12px;
  background:color-mix(in srgb,var(--bg-main) 28%, transparent);
}
body.role-pelanggan .invoice-highlight h2{font-size:clamp(21px,2.8vw,28px);line-height:1.05}
body.role-pelanggan .info-list{gap:0}
body.role-pelanggan .info-list p{
  padding:10px 0;
  gap:12px;
}
body.role-pelanggan .info-list span,
body.role-pelanggan .info-grid small{font-size:11.5px;color:var(--text-secondary)}
body.role-pelanggan .info-list b{font-size:13.5px;line-height:1.35;word-break:break-word}
body.role-pelanggan .info-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
body.role-pelanggan .info-grid>div{
  padding:12px;
  border-radius:15px;
  min-width:0;
}
body.role-pelanggan .info-grid b{font-size:14px;word-break:break-word}
body.role-pelanggan .info-grid p{font-size:12px;color:var(--text-secondary);margin:.25rem 0 0;word-break:break-word}
body.role-pelanggan .toolbar{margin-bottom:10px;gap:8px}
body.role-pelanggan .toolbar h3{font-size:13px;color:var(--text-main)}
body.role-pelanggan .btn{border-radius:12px;padding:9px 12px;font-size:12.5px}
body.role-pelanggan .btn.small{padding:6px 9px;font-size:11.5px;border-radius:10px}
body.role-pelanggan .badge{padding:4px 8px;font-size:11px}
body.role-pelanggan .table-wrap{
  border-radius:16px;
  box-shadow:none;
  overflow:auto;
  -webkit-overflow-scrolling:touch;
}
body.role-pelanggan table{min-width:680px}
body.role-pelanggan th,
body.role-pelanggan td{padding:11px 12px;font-size:13px}
body.role-pelanggan th{font-size:11px}
body.role-pelanggan .modal-panel{border-radius:20px;padding:14px}
body.role-pelanggan .grid-form{gap:12px}
body.role-pelanggan input,
body.role-pelanggan select,
body.role-pelanggan textarea{border-radius:12px;padding:10px 11px;font-size:14px}
body.role-pelanggan .passwordless-note{font-size:12.5px;border-radius:14px;padding:10px 12px}
body.role-pelanggan .service-status-card:before{height:100px;opacity:.7}

[data-theme="light"] body.role-pelanggan .card,
body.role-pelanggan[data-theme="light"] .card{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(248,250,255,.92));
  box-shadow:0 14px 34px rgba(17,20,45,.08);
}
body.role-pelanggan[data-theme="light"] .quick-card,
body.role-pelanggan[data-theme="light"] .info-grid>div,
body.role-pelanggan[data-theme="light"] .invoice-highlight{
  background:#F8FAFF;
  border-color:#E2E9FB;
}
body.role-pelanggan[data-theme="light"] th{background:#F3F6FF;color:#33405F}
body.role-pelanggan[data-theme="light"] td{color:#11142D}

@media(max-width:1240px){
  body.role-pelanggan .portal-grid{grid-template-columns:1fr 1fr}
  body.role-pelanggan .portal-hero{grid-column:1/-1}
  body.role-pelanggan .quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:1000px){
  body.role-pelanggan .sidebar{width:280px;transform:translateX(-105%)}
  body.role-pelanggan.sidebar-open .sidebar{transform:translateX(0)}
  body.role-pelanggan .content{margin-left:0}
  body.role-pelanggan .topbar{grid-template-columns:auto 1fr auto;padding:10px 12px}
  body.role-pelanggan .topbar-search{grid-column:1/-1;order:3;width:100%}
  body.role-pelanggan .main{padding:14px}
}
@media(max-width:820px){
  body.role-pelanggan .portal-grid,
  body.role-pelanggan .grid-2{grid-template-columns:1fr}
  body.role-pelanggan .mini-stat{min-height:86px}
  body.role-pelanggan .info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  body.role-pelanggan .page-title{display:grid;gap:10px}
  body.role-pelanggan .page-title .btn{width:100%}
}
@media(max-width:640px){
  body.role-pelanggan .topbar-actions .icon-btn{display:none}
  body.role-pelanggan .profile-chip b{display:none}
  body.role-pelanggan .topbar-static-title b{font-size:13px;max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  body.role-pelanggan .main{padding:12px}
  body.role-pelanggan .card{padding:13px;border-radius:16px}
  body.role-pelanggan .portal-hero{padding:14px;min-height:0}
  body.role-pelanggan .portal-hero .btn{width:100%}
  body.role-pelanggan .quick-grid,
  body.role-pelanggan .info-grid{grid-template-columns:1fr}
  body.role-pelanggan .info-list p{display:grid;gap:4px}
  body.role-pelanggan .info-list b{text-align:left}
  body.role-pelanggan .grid-form{grid-template-columns:1fr}
  body.role-pelanggan .actions.end{display:grid;grid-template-columns:1fr;gap:8px}
  body.role-pelanggan .actions.end .btn{width:100%}
  body.role-pelanggan .modal{padding:10px}
  body.role-pelanggan .table-wrap{border-radius:14px}
}
@media(max-width:420px){
  body.role-pelanggan .topbar{gap:8px}
  body.role-pelanggan .mobile-toggle{width:34px;height:34px}
  body.role-pelanggan .topbar-static-title small{font-size:9px}
  body.role-pelanggan .topbar-static-title b{max-width:140px}
  body.role-pelanggan .portal-hero h2{font-size:21px}
  body.role-pelanggan th,
  body.role-pelanggan td{padding:10px 9px;font-size:12px}
  body.role-pelanggan table{min-width:600px}
}

/* v36 - Portal pelanggan tanpa sidebar + akses cepat ditonjolkan */
body.role-pelanggan .sidebar{display:none!important}
body.role-pelanggan .content,
body.role-pelanggan .customer-content.no-sidebar{margin-left:0!important;width:100%;min-height:100vh}
body.role-pelanggan .customer-topbar{
  position:sticky;
  top:0;
  z-index:70;
  min-height:66px;
  padding:10px clamp(12px,2.4vw,28px);
  grid-template-columns:minmax(160px,280px) minmax(180px,560px) auto;
  gap:12px;
  border-bottom:1px solid color-mix(in srgb,var(--border-main) 75%, transparent);
  background:color-mix(in srgb,var(--bg-main) 84%, transparent);
  backdrop-filter:blur(18px);
}
.customer-brand-mini{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-width:0;
  color:var(--text-main);
  text-decoration:none;
}
.customer-brand-mini span{
  width:38px;
  height:38px;
  flex:0 0 38px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 58%,#00a8ff));
  color:color-mix(in srgb,var(--bg-main) 85%,#000);
  font:900 16px/1 var(--font-main),sans-serif;
  box-shadow:0 0 24px color-mix(in srgb,var(--accent) 28%, transparent);
}
.customer-brand-mini b{
  font-size:14px;
  letter-spacing:-.02em;
  white-space:nowrap;
}
body.role-pelanggan .desktop-only{display:flex}
body.role-pelanggan .customer-logout-top{
  border-color:color-mix(in srgb,var(--crypto-down) 36%, var(--border-main));
  color:var(--crypto-down);
  background:color-mix(in srgb,var(--crypto-down) 8%, transparent);
}
.customer-quick-nav{
  position:sticky;
  top:66px;
  z-index:62;
  display:flex;
  gap:9px;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  padding:10px clamp(12px,2.4vw,28px);
  border-bottom:1px solid color-mix(in srgb,var(--border-main) 52%, transparent);
  background:linear-gradient(180deg,color-mix(in srgb,var(--bg-main) 92%, transparent),color-mix(in srgb,var(--bg-main) 75%, transparent));
  backdrop-filter:blur(16px);
}
.customer-quick-nav::-webkit-scrollbar{height:4px}
.customer-nav-item{
  display:inline-flex;
  align-items:center;
  gap:8px;
  flex:0 0 auto;
  min-height:40px;
  padding:9px 13px;
  border:1px solid color-mix(in srgb,var(--border-main) 72%, transparent);
  border-radius:999px;
  background:color-mix(in srgb,var(--bg-card) 62%, transparent);
  color:var(--text-secondary);
  text-decoration:none;
  transition:transform .16s ease,border-color .16s ease,background .16s ease,box-shadow .16s ease,color .16s ease;
}
.customer-nav-item span{color:var(--accent);font-weight:900}
.customer-nav-item b{font-size:12.5px;white-space:nowrap}
.customer-nav-item:hover,
.customer-nav-item.active{
  color:var(--text-main);
  border-color:color-mix(in srgb,var(--accent) 60%, transparent);
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 18%, var(--bg-card)),color-mix(in srgb,var(--bg-card) 70%, transparent));
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 25%, transparent),0 0 24px color-mix(in srgb,var(--accent) 14%, transparent);
  transform:translateY(-1px);
}
body.role-pelanggan .main{
  width:min(1240px,100%);
  margin:0 auto;
  padding:clamp(14px,2.4vw,24px);
}
.customer-shortcuts.featured{
  display:grid;
  grid-template-columns:1.35fr repeat(4,minmax(0,1fr));
  gap:10px;
  margin:0 0 14px;
}
.shortcut-tile{
  position:relative;
  min-height:92px;
  padding:14px;
  display:grid;
  align-content:center;
  gap:4px;
  border:1px solid color-mix(in srgb,var(--border-main) 78%, transparent);
  border-radius:18px;
  background:linear-gradient(180deg,color-mix(in srgb,var(--bg-card) 88%, transparent),color-mix(in srgb,var(--bg-card) 64%, transparent));
  color:var(--text-main);
  text-decoration:none;
  overflow:hidden;
  box-shadow:0 14px 34px rgba(0,0,0,.12);
  transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease;
}
.shortcut-tile:before{
  content:"";
  position:absolute;
  inset:auto -24% -50% -24%;
  height:92px;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 16%, transparent),transparent 68%);
  pointer-events:none;
}
.shortcut-tile span{font-size:20px;color:var(--accent);font-weight:900}
.shortcut-tile b{font-size:14px;letter-spacing:-.02em;position:relative}
.shortcut-tile small{font-size:12px;color:var(--text-secondary);position:relative}
.shortcut-tile.primary{
  min-height:100px;
  border-color:color-mix(in srgb,var(--accent) 58%, transparent);
  background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 24%, var(--bg-card)),color-mix(in srgb,var(--bg-card) 76%, transparent));
  box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 22%, transparent),0 18px 48px rgba(0,0,0,.16),0 0 28px color-mix(in srgb,var(--accent) 14%, transparent);
}
.shortcut-tile.primary b{font-size:17px}
.shortcut-tile:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 64%, transparent);box-shadow:0 18px 46px rgba(0,0,0,.18),0 0 24px color-mix(in srgb,var(--accent) 14%, transparent)}
body.role-pelanggan .portal-grid{grid-template-columns:minmax(0,1.35fr) minmax(145px,.55fr) minmax(145px,.55fr)}
body.role-pelanggan .grid-2{grid-template-columns:1.15fr .85fr}
body.role-pelanggan .quick-grid.compact{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:12px}
body.role-pelanggan .customer-help-card .muted{font-size:13px;line-height:1.55}
@media(max-width:980px){
  body.role-pelanggan .customer-topbar{grid-template-columns:1fr auto;grid-template-areas:"brand actions" "search search";gap:10px}
  body.role-pelanggan .customer-topbar .topbar-left{grid-area:brand}
  body.role-pelanggan .customer-topbar .topbar-search{grid-area:search;width:100%}
  body.role-pelanggan .customer-topbar .topbar-actions{grid-area:actions}
  body.role-pelanggan .desktop-only{display:none!important}
  .customer-quick-nav{top:112px}
  .customer-shortcuts.featured{grid-template-columns:repeat(3,minmax(0,1fr))}
  .shortcut-tile.primary{grid-column:span 2}
  body.role-pelanggan .portal-grid{grid-template-columns:1fr}
  body.role-pelanggan .grid-2{grid-template-columns:1fr}
}
@media(max-width:640px){
  body.role-pelanggan .customer-topbar{min-height:auto;padding:9px 12px}
  .customer-brand-mini b{font-size:13px}
  .customer-brand-mini span{width:34px;height:34px;flex-basis:34px;border-radius:12px;font-size:14px}
  body.role-pelanggan .profile-chip b{display:none}
  body.role-pelanggan .customer-logout-top{display:none}
  .customer-quick-nav{top:104px;padding:9px 12px;gap:7px}
  .customer-nav-item{min-height:36px;padding:8px 11px;border-radius:14px}
  .customer-nav-item b{font-size:12px}
  body.role-pelanggan .main{padding:12px}
  .customer-shortcuts.featured{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
  .shortcut-tile,.shortcut-tile.primary{grid-column:auto;min-height:84px;padding:12px;border-radius:16px}
  .shortcut-tile.primary{grid-column:1/-1;min-height:88px}
  .shortcut-tile span{font-size:18px}.shortcut-tile b{font-size:13px}.shortcut-tile.primary b{font-size:15px}.shortcut-tile small{font-size:11.5px}
}
@media(max-width:390px){
  .customer-shortcuts.featured{grid-template-columns:1fr}
  .customer-nav-item{gap:6px;padding-inline:10px}
}


/* v39 - Locked compact sidebar sizes for every non-customer portal role */
:root{
  --sidebar-fixed-width:248px;
  --sidebar-compact-padding-x:11px;
  --sidebar-compact-padding-y:12px;
  --sidebar-brand-height:54px;
  --sidebar-menu-row-height:38px;
  --sidebar-child-row-height:34px;
  --sidebar-footer-compact-height:86px;
}
body:not(.role-pelanggan) .sidebar{
  width:var(--sidebar-fixed-width)!important;
  min-width:var(--sidebar-fixed-width)!important;
  max-width:var(--sidebar-fixed-width)!important;
  height:100vh!important;
  height:100dvh!important;
  max-height:100vh!important;
  max-height:100dvh!important;
  padding:var(--sidebar-compact-padding-y) var(--sidebar-compact-padding-x)!important;
  box-sizing:border-box!important;
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  flex:0 0 var(--sidebar-fixed-width)!important;
}
body:not(.role-pelanggan) .content{
  margin-left:var(--sidebar-fixed-width)!important;
}
body:not(.role-pelanggan) .sb-brand{
  flex:0 0 var(--sidebar-brand-height)!important;
  height:var(--sidebar-brand-height)!important;
  min-height:var(--sidebar-brand-height)!important;
  max-height:var(--sidebar-brand-height)!important;
  margin:0 0 9px!important;
  padding:7px 8px!important;
  border-radius:17px!important;
  gap:9px!important;
  overflow:hidden!important;
}
body:not(.role-pelanggan) .sb-logo{
  width:36px!important;
  height:36px!important;
  min-width:36px!important;
  flex:0 0 36px!important;
  border-radius:12px!important;
  font-size:14px!important;
}
body:not(.role-pelanggan) .sb-title{
  min-width:0!important;
  overflow:hidden!important;
}
body:not(.role-pelanggan) .sb-title b{
  font-size:14px!important;
  line-height:1.05!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
body:not(.role-pelanggan) .sb-title small{
  margin-top:4px!important;
  font-size:10px!important;
  line-height:1.15!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
body:not(.role-pelanggan) .sidebar .menu{
  flex:1 1 auto!important;
  min-height:0!important;
  height:auto!important;
  display:block!important;
  gap:0!important;
  padding:2px 0 8px!important;
  margin:0!important;
  overflow-y:auto!important;
  overflow-x:hidden!important;
}
body:not(.role-pelanggan) .menu-group{
  margin:0 0 4px!important;
}
body:not(.role-pelanggan) .menu-link,
body:not(.role-pelanggan) .menu-group-toggle{
  width:100%!important;
  min-height:var(--sidebar-menu-row-height)!important;
  height:var(--sidebar-menu-row-height)!important;
  max-height:var(--sidebar-menu-row-height)!important;
  padding:7px 9px!important;
  margin:0 0 4px!important;
  border-radius:13px!important;
  gap:8px!important;
  font-size:12.5px!important;
  line-height:1.1!important;
  box-sizing:border-box!important;
  overflow:hidden!important;
  transform:none!important;
}
body:not(.role-pelanggan) .menu-link:hover,
body:not(.role-pelanggan) .menu-group-toggle:hover{
  transform:none!important;
}
body:not(.role-pelanggan) .menu-left{
  min-width:0!important;
  gap:8px!important;
  overflow:hidden!important;
}
body:not(.role-pelanggan) .menu-left > span:last-child,
body:not(.role-pelanggan) .menu-link > span:last-child{
  min-width:0!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
body:not(.role-pelanggan) .menu-icon{
  width:24px!important;
  height:24px!important;
  min-width:24px!important;
  flex:0 0 24px!important;
  border-radius:9px!important;
  font-size:11px!important;
}
body:not(.role-pelanggan) .menu-caret{
  flex:0 0 auto!important;
  margin-left:auto!important;
  font-size:12px!important;
}
body:not(.role-pelanggan) .menu-group-children{
  margin:2px 0 6px 12px!important;
  padding:5px 0 4px 9px!important;
  display:none;
  gap:0!important;
}
body:not(.role-pelanggan) .menu-group.open .menu-group-children{
  display:block!important;
}
body:not(.role-pelanggan) .menu-link.child{
  min-height:var(--sidebar-child-row-height)!important;
  height:var(--sidebar-child-row-height)!important;
  max-height:var(--sidebar-child-row-height)!important;
  padding:6px 8px!important;
  margin:0 0 4px!important;
  border-radius:11px!important;
  font-size:12px!important;
}
body:not(.role-pelanggan) .menu-link.child .menu-icon{
  width:20px!important;
  height:20px!important;
  min-width:20px!important;
  flex-basis:20px!important;
  border-radius:7px!important;
  font-size:10px!important;
}
body:not(.role-pelanggan) .sidebar-footer{
  flex:0 0 auto!important;
  min-height:auto!important;
  max-height:var(--sidebar-footer-compact-height)!important;
  padding:7px 0 0!important;
  margin:0!important;
  overflow:hidden!important;
}
body:not(.role-pelanggan) .sidebar-user-card{
  min-height:auto!important;
  max-height:78px!important;
  padding:8px 9px!important;
  border-radius:15px!important;
  overflow:hidden!important;
}
body:not(.role-pelanggan) .sidebar-user-row{
  min-height:34px!important;
  gap:8px!important;
}
body:not(.role-pelanggan) .sidebar-user-avatar{
  width:34px!important;
  height:34px!important;
  min-width:34px!important;
  flex:0 0 34px!important;
  border-radius:11px!important;
  font-size:16px!important;
}
body:not(.role-pelanggan) .sidebar-user-meta{
  min-width:0!important;
  overflow:hidden!important;
}
body:not(.role-pelanggan) .sidebar-user-meta b{
  max-width:100%!important;
  font-size:12px!important;
  line-height:1.05!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
body:not(.role-pelanggan) .sidebar-user-meta small{
  max-width:100%!important;
  margin-top:3px!important;
  font-size:9.5px!important;
  line-height:1.15!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
}
body:not(.role-pelanggan) .sidebar-logout-btn{
  margin-top:6px!important;
  min-height:28px!important;
  height:28px!important;
  padding:6px 9px!important;
  border-radius:10px!important;
  font-size:11px!important;
  line-height:1!important;
}
body:not(.role-pelanggan) .topbar{
  min-height:66px!important;
  padding:10px 18px!important;
}
@media(max-width:1000px){
  body:not(.role-pelanggan) .sidebar{
    width:min(var(--sidebar-fixed-width),82vw)!important;
    min-width:min(var(--sidebar-fixed-width),82vw)!important;
    max-width:min(var(--sidebar-fixed-width),82vw)!important;
    transform:translateX(-105%);
    transition:transform .22s ease;
  }
  body:not(.role-pelanggan).sidebar-open .sidebar{
    transform:translateX(0)!important;
  }
  body:not(.role-pelanggan) .content{
    margin-left:0!important;
  }
}
@media(max-height:720px){
  body:not(.role-pelanggan) .sb-brand{
    --sidebar-brand-height:48px;
    margin-bottom:6px!important;
  }
  body:not(.role-pelanggan) .menu-link,
  body:not(.role-pelanggan) .menu-group-toggle{
    min-height:34px!important;
    height:34px!important;
    max-height:34px!important;
    padding:5px 8px!important;
    font-size:12px!important;
  }
  body:not(.role-pelanggan) .menu-link.child{
    min-height:30px!important;
    height:30px!important;
    max-height:30px!important;
    font-size:11.5px!important;
  }
  body:not(.role-pelanggan) .sidebar-user-card{
    max-height:70px!important;
    padding:7px 8px!important;
  }
  body:not(.role-pelanggan) .sidebar-user-avatar{
    width:30px!important;height:30px!important;min-width:30px!important;flex-basis:30px!important;font-size:14px!important;
  }
  body:not(.role-pelanggan) .sidebar-logout-btn{
    height:25px!important;min-height:25px!important;margin-top:5px!important;font-size:10.5px!important;
  }
}
/* v40 central access, sales, teknisi */
.check-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin:10px 0 14px}.check-grid .checkline{margin-top:0;text-transform:none;letter-spacing:0;font-size:13px}.check-grid .checkline span{display:grid;gap:2px}.check-grid .checkline small{font-weight:500}.access-matrix table input[type="checkbox"]{width:18px;height:18px}.role-sales .quick-grid,.role-teknisi .quick-grid{grid-template-columns:repeat(2,minmax(0,1fr))}@media(max-width:760px){.check-grid,.role-sales .quick-grid,.role-teknisi .quick-grid{grid-template-columns:1fr}}

/* v41 billing/isolir compact menu */
.compact-title{align-items:center;gap:12px}.desktop-actions{display:flex;gap:8px;flex-wrap:wrap}.billing-mini-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin:0 0 16px}.mini-stat-card{display:flex;flex-direction:column;gap:4px;min-height:76px;padding:12px 14px;border:1px solid rgba(36,49,109,.72);border-radius:16px;background:rgba(255,255,255,.045);text-decoration:none;color:var(--text-main);box-shadow:0 12px 28px rgba(0,0,0,.12);transition:.18s ease}.mini-stat-card:hover,.mini-stat-card.active{transform:translateY(-1px);border-color:color-mix(in srgb,var(--accent) 55%,transparent);box-shadow:0 0 24px color-mix(in srgb,var(--accent) 18%,transparent)}.mini-stat-card small{font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}.mini-stat-card b{font:900 22px/1 var(--font-crypto),monospace;letter-spacing:-.04em;color:var(--text-main)}.mini-stat-card span{font-size:12px;color:var(--muted);font-weight:700}.mini-stat-card.success b{color:var(--crypto-up)}.mini-stat-card.warning b,.mini-stat-card.accent b{color:var(--accent)}.mini-stat-card.danger b{color:var(--crypto-down)}.compact-card{border-radius:18px}.quick-action-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.slim-table table td,.slim-table table th{padding:9px 10px}.badge.gray{color:var(--muted);background:rgba(148,163,184,.12);border-color:rgba(148,163,184,.18)}.badge.yellow{color:#f59e0b;background:rgba(245,158,11,.12);border-color:rgba(245,158,11,.22)}
@media(max-width:1100px){.billing-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-action-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:620px){.billing-mini-grid,.quick-action-grid{grid-template-columns:1fr}.desktop-actions{width:100%}.desktop-actions .btn{flex:1}.mini-stat-card{min-height:66px}.mini-stat-card b{font-size:20px}}

/* v47 - Manual captcha untuk login */
.manual-captcha{
  display:grid;
  grid-template-columns: 128px 1fr;
  gap:10px;
  align-items:center;
}
.captcha-code{
  height:52px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:18px;
  border:1px solid color-mix(in srgb, var(--accent) 45%, transparent);
  background:linear-gradient(135deg, color-mix(in srgb, var(--accent) 22%, transparent), color-mix(in srgb, var(--bg-card) 92%, transparent));
  color:var(--text-main);
  font-family:var(--font-crypto, monospace);
  font-size:22px;
  font-weight:800;
  letter-spacing:5px;
  user-select:none;
  box-shadow:0 0 22px color-mix(in srgb, var(--accent) 18%, transparent);
}
.manual-captcha input{
  text-transform:uppercase;
  letter-spacing:2px;
  font-family:var(--font-crypto, monospace);
  font-weight:700;
}
@media (max-width: 520px){
  .manual-captcha{ grid-template-columns:1fr; }
  .captcha-code{ width:100%; }
}
