:root{--bg:#080c14;--card:rgba(255,255,255,0.04);--card-hover:rgba(255,255,255,0.07);--border:rgba(255,255,255,0.08);--accent:#3b82f6;--accent2:#8b5cf6;--accent3:#06b6d4;--green:#10b981;--red:#ef4444;--gold:#f59e0b;--t1:#f1f5f9;--t2:#94a3b8;--t3:#475569;--sw:260px;--r:16px;}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{background:var(--bg);color:var(--t1);font-family:'Inter',-apple-system,sans-serif;min-height:100vh;overflow-x:hidden;}
::-webkit-scrollbar{width:4px;height:4px;}::-webkit-scrollbar-track{background:transparent;}::-webkit-scrollbar-thumb{background:rgba(99,102,241,.4);border-radius:99px;}

/* BG */
.bg-grid{position:fixed;inset:0;z-index:0;background-image:linear-gradient(rgba(59,130,246,.03)1px,transparent 1px),linear-gradient(90deg,rgba(59,130,246,.03)1px,transparent 1px);background-size:40px 40px;pointer-events:none;}
.bg-orb{position:fixed;border-radius:50%;filter:blur(120px);pointer-events:none;z-index:0;}
.orb1{width:600px;height:600px;background:rgba(59,130,246,.07);top:-200px;left:-100px;}
.orb2{width:500px;height:500px;background:rgba(139,92,246,.06);bottom:-100px;right:-100px;}
.orb3{width:400px;height:400px;background:rgba(6,182,212,.05);top:40%;left:40%;}

/* LOGIN */
.login-screen{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background:var(--bg);}
.login-card{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:20px;padding:40px;width:100%;max-width:420px;backdrop-filter:blur(20px);}
.login-logo{text-align:center;margin-bottom:28px;}
.logo-icon-lg{width:56px;height:56px;border-radius:16px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:900;color:#fff;margin:0 auto 12px;box-shadow:0 0 30px rgba(59,130,246,.4);}
.login-title{font-size:22px;font-weight:800;}
.login-sub{font-size:12px;color:var(--t3);margin-top:4px;letter-spacing:.5px;}
.login-btn{width:100%;justify-content:center;padding:12px;margin-top:20px;font-size:14px;}
.login-hint{text-align:center;font-size:11px;color:var(--t3);margin-top:12px;}
.login-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:var(--red);padding:10px 14px;border-radius:8px;font-size:13px;margin-bottom:12px;}

/* SIDEBAR */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sw);background:rgba(8,12,20,.97);border-right:1px solid var(--border);backdrop-filter:blur(24px);z-index:100;display:flex;flex-direction:column;transition:transform .3s ease;}
.sidebar-logo{padding:24px 20px 18px;border-bottom:1px solid var(--border);}
.logo-badge{display:flex;align-items:center;gap:12px;}
.logo-icon{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;color:#fff;box-shadow:0 0 16px rgba(59,130,246,.4);}
.logo-text{font-size:13px;font-weight:700;}
.logo-sub{font-size:10px;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;}
.nav-section{padding:14px 10px 6px;}
.nav-label{font-size:10px;font-weight:600;color:var(--t3);letter-spacing:1px;text-transform:uppercase;padding:0 10px 6px;}
.nav-item{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;cursor:pointer;transition:all .2s;color:var(--t2);font-size:13px;font-weight:500;position:relative;user-select:none;}
.nav-item:hover{background:var(--card);color:var(--t1);}
.nav-item.active{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(139,92,246,.1));color:#fff;border:1px solid rgba(59,130,246,.2);}
.nav-item.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:3px;background:linear-gradient(180deg,#3b82f6,#8b5cf6);border-radius:99px;}
.nav-icon{width:18px;text-align:center;font-size:14px;}
.nav-badge{margin-left:auto;font-size:10px;font-weight:700;background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;padding:2px 6px;border-radius:99px;}
.live-pulse{animation:pulse-badge 2s infinite;}
@keyframes pulse-badge{0%,100%{opacity:1;}50%{opacity:.6;}}
.sidebar-bottom{margin-top:auto;padding:14px 10px;border-top:1px solid var(--border);}
.user-card{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:9px;background:var(--card);cursor:pointer;}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;}
.user-name{font-size:12px;font-weight:600;}
.user-role{font-size:10px;color:var(--t3);}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 5px var(--green);animation:pdot 2s infinite;margin-left:auto;}
@keyframes pdot{0%,100%{opacity:1;}50%{opacity:.5;}}

/* TOPBAR */
.topbar{position:fixed;top:0;left:var(--sw);right:0;height:60px;background:rgba(8,12,20,.9);border-bottom:1px solid var(--border);backdrop-filter:blur(24px);z-index:90;display:flex;align-items:center;padding:0 24px;gap:12px;}
.topbar-title{font-size:15px;font-weight:700;}
.topbar-sub{font-size:11px;color:var(--t3);margin-top:1px;}
.topbar-spacer{flex:1;}
.live-badge{display:flex;align-items:center;gap:6px;padding:5px 11px;border-radius:99px;background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);font-size:11px;font-weight:600;color:var(--green);}
.live-badge.disconnected{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.25);color:var(--red);}
.topbar-btn{min-width:34px;height:34px;border-radius:9px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;font-size:14px;color:var(--t2);position:relative;padding:0 8px;}
.topbar-btn:hover{background:var(--card-hover);color:var(--t1);}
.notif-count{position:absolute;top:-5px;right:-5px;width:15px;height:15px;border-radius:50%;background:var(--red);font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg);}
.menu-toggle-btn{display:none;}

/* NOTIF PANEL */
.notif-panel{position:fixed;top:68px;right:16px;width:320px;background:rgba(12,18,30,.97);border:1px solid var(--border);border-radius:14px;z-index:200;backdrop-filter:blur(20px);box-shadow:0 16px 48px rgba(0,0,0,.5);max-height:420px;overflow-y:auto;}
.notif-panel-header{padding:14px 16px;font-size:13px;font-weight:700;border-bottom:1px solid var(--border);}
.notif-item{display:flex;gap:10px;padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;}
.notif-item:hover{background:rgba(255,255,255,.02);}
.notif-icon-wrap{width:32px;height:32px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.notif-title{font-size:12px;font-weight:600;}
.notif-desc{font-size:11px;color:var(--t2);margin-top:2px;}
.notif-time{font-size:10px;color:var(--t3);margin-top:3px;}

/* MAIN */
.main{margin-left:var(--sw);padding-top:60px;min-height:100vh;position:relative;z-index:1;}
.page{display:none;padding:24px;}
.page.active{display:block;}

/* SECTION */
.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px;}
.section-title{font-size:17px;font-weight:700;}
.section-sub{font-size:12px;color:var(--t3);margin-top:2px;}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:7px;padding:8px 15px;border-radius:9px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:none;font-family:inherit;white-space:nowrap;}
.btn-primary{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;box-shadow:0 4px 14px rgba(59,130,246,.3);}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(59,130,246,.4);}
.btn-outline{background:var(--card);color:var(--t2);border:1px solid var(--border);}
.btn-outline:hover{background:var(--card-hover);color:var(--t1);}
.btn-danger{background:rgba(239,68,68,.15);color:var(--red);border:1px solid rgba(239,68,68,.2);}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-bottom:20px;}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;position:relative;overflow:hidden;transition:all .3s;cursor:default;}
.kpi-card:hover{background:var(--card-hover);border-color:rgba(59,130,246,.2);transform:translateY(-2px);box-shadow:0 8px 28px rgba(0,0,0,.3);}
.kpi-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent),transparent);opacity:0;transition:opacity .3s;}
.kpi-card:hover::before{opacity:1;}
.kpi-glow{position:absolute;top:-20px;right:-20px;width:80px;height:80px;border-radius:50%;filter:blur(28px);opacity:.35;pointer-events:none;}
.kpi-label{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;}
.kpi-value{font-size:24px;font-weight:800;line-height:1;margin-bottom:7px;font-variant-numeric:tabular-nums;}
.kpi-icon{position:absolute;top:18px;right:16px;font-size:18px;opacity:.12;}
.kpi-delta{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:600;padding:2px 7px;border-radius:99px;}
.delta-up{background:rgba(16,185,129,.1);color:var(--green);border:1px solid rgba(16,185,129,.2);}
.delta-dn{background:rgba(239,68,68,.1);color:var(--red);border:1px solid rgba(239,68,68,.2);}
.delta-neu{background:rgba(148,163,184,.1);color:var(--t2);border:1px solid rgba(148,163,184,.15);}

/* GLASS CARD */
.glass-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:22px;position:relative;overflow:hidden;}
.glass-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;gap:10px;flex-wrap:wrap;}
.card-title{font-size:14px;font-weight:700;}
.card-sub{font-size:11px;color:var(--t3);margin-top:2px;}

/* GRIDS */
.chart-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;margin-bottom:20px;}
.chart-row3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:20px;}
.two-col-grid{display:grid;grid-template-columns:2fr 1fr;gap:18px;}
.chart-wrap{position:relative;height:250px;}

/* TABS */
.tabs{display:flex;gap:3px;background:var(--card);border:1px solid var(--border);border-radius:9px;padding:3px;width:fit-content;}
.tab{padding:6px 13px;border-radius:6px;font-size:11px;font-weight:600;cursor:pointer;color:var(--t3);transition:all .2s;}
.tab.active{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;}

/* TICKER */
.ticker{background:rgba(59,130,246,.06);border:1px solid rgba(59,130,246,.12);border-radius:9px;padding:9px 16px;margin-bottom:20px;overflow:hidden;position:relative;}
.ticker-inner{display:flex;gap:36px;animation:tick 30s linear infinite;white-space:nowrap;width:max-content;}
@keyframes tick{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
.ticker-item{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:500;}
.ticker-name{color:var(--t2);}
.ticker-val{color:var(--t1);font-weight:700;}
.ticker-up{color:var(--green);font-weight:700;}
.ticker-dn{color:var(--red);font-weight:700;}
.ticker-label{position:absolute;left:0;top:0;bottom:0;width:70px;background:linear-gradient(90deg,rgba(8,12,20,1)60%,transparent);display:flex;align-items:center;z-index:2;padding-left:12px;font-size:10px;font-weight:700;letter-spacing:.8px;color:var(--accent);text-transform:uppercase;}

/* SAAS CARDS */
.saas-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:15px;margin-bottom:20px;}
.saas-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;cursor:pointer;transition:all .3s;position:relative;overflow:hidden;}
.saas-card:hover{border-color:rgba(59,130,246,.3);transform:translateY(-3px);box-shadow:0 12px 36px rgba(0,0,0,.4);}
.sc-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;}
.sc-logo{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;color:#fff;margin-bottom:7px;}
.sc-name{font-size:13px;font-weight:700;}
.sc-owner{font-size:11px;color:var(--t3);}
.sc-rev{font-size:20px;font-weight:800;}
.sc-rev-label{font-size:10px;color:var(--t3);}
.sc-divider{height:1px;background:var(--border);margin:12px 0;}
.sc-row{display:flex;justify-content:space-between;margin-bottom:8px;}
.sc-lbl{font-size:11px;color:var(--t3);}
.sc-val{font-size:12px;font-weight:700;}
.sc-bar{height:5px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;margin-top:10px;}
.sc-fill{height:100%;border-radius:99px;transition:width 1.2s ease;}
.sc-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;}
.growth-pill{display:flex;align-items:center;gap:3px;font-size:12px;font-weight:700;}
.g-up{color:var(--green);}
.g-dn{color:var(--red);}

/* TABLE */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead tr{border-bottom:1px solid var(--border);}
th{text-align:left;padding:9px 12px;font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;}
tbody tr{border-bottom:1px solid rgba(255,255,255,.03);transition:background .15s;cursor:pointer;}
tbody tr:hover{background:rgba(255,255,255,.025);}
td{padding:11px 12px;vertical-align:middle;white-space:nowrap;}
.td-saas{display:flex;align-items:center;gap:9px;}
.t-logo{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:800;flex-shrink:0;}
.t-name{font-weight:600;font-size:13px;}
.t-domain{font-size:10px;color:var(--t3);}

/* BADGES */
.badge{padding:2px 7px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.2px;text-transform:uppercase;white-space:nowrap;}
.badge-green{background:rgba(16,185,129,.12);color:var(--green);border:1px solid rgba(16,185,129,.2);}
.badge-blue{background:rgba(59,130,246,.12);color:#60a5fa;border:1px solid rgba(59,130,246,.2);}
.badge-yellow{background:rgba(245,158,11,.12);color:var(--gold);border:1px solid rgba(245,158,11,.2);}
.badge-red{background:rgba(239,68,68,.12);color:var(--red);border:1px solid rgba(239,68,68,.2);}
.badge-purple{background:rgba(139,92,246,.12);color:#a78bfa;border:1px solid rgba(139,92,246,.2);}
.status-dot{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:4px;}
.s-on{background:var(--green);box-shadow:0 0 5px var(--green);}
.s-pend{background:var(--gold);}
.s-off{background:var(--red);}

/* SPLIT BAR */
.split-wrap{display:flex;align-items:center;gap:6px;}
.split-bar{width:48px;height:4px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;}
.split-fill{height:100%;border-radius:99px;}

/* LIVE FEED */
.live-feed{height:320px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;}
.feed-item{display:flex;gap:9px;padding:9px 10px;border-radius:9px;background:rgba(255,255,255,.02);border:1px solid var(--border);animation:feedIn .3s ease;}
@keyframes feedIn{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.feed-icon{font-size:14px;flex-shrink:0;margin-top:1px;}
.feed-body .feed-title{font-size:12px;font-weight:600;}
.feed-body .feed-desc{font-size:11px;color:var(--t2);margin-top:2px;}
.feed-body .feed-time{font-size:10px;color:var(--t3);margin-top:3px;}

/* PARTNERS GRID */
.partners-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px;}
.partner-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:18px;cursor:pointer;transition:all .3s;}
.partner-card:hover{border-color:rgba(139,92,246,.3);transform:translateY(-2px);}
.pc-header{display:flex;align-items:center;gap:11px;margin-bottom:14px;}
.pc-avatar{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0;}
.pc-name{font-size:14px;font-weight:700;}
.pc-company{font-size:11px;color:var(--t3);}
.pc-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;}
.pstat{text-align:center;padding:8px;background:rgba(255,255,255,.02);border-radius:8px;}
.pstat-val{font-size:15px;font-weight:800;}
.pstat-lbl{font-size:10px;color:var(--t3);margin-top:2px;}
.pc-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);}

/* FORMS */
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-label{font-size:10px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.5px;}
.form-input{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:8px;padding:8px 11px;font-size:13px;color:var(--t1);outline:none;transition:all .2s;font-family:inherit;width:100%;}
.form-input:focus{border-color:rgba(59,130,246,.4);background:rgba(59,130,246,.05);}
.form-select{-webkit-appearance:none;cursor:pointer;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px;}
.search-input{width:180px!important;font-size:12px;padding:7px 11px;}

/* REV PREVIEW */
.rev-preview{display:flex;align-items:center;justify-content:space-around;padding:14px;border-radius:10px;background:rgba(255,255,255,.02);border:1px solid var(--border);margin:14px 0;}
.rev-block{text-align:center;}
.rev-val{font-size:20px;font-weight:800;}
.rev-lbl{font-size:10px;color:var(--t3);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:2px;}
.rev-div{width:1px;height:36px;background:var(--border);}

/* API PAGE */
.api-endpoint-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;background:rgba(255,255,255,.02);border:1px solid var(--border);margin-bottom:7px;cursor:pointer;transition:all .2s;}
.api-endpoint-item:hover{background:var(--card-hover);}
.method-badge{padding:2px 7px;border-radius:5px;font-size:10px;font-weight:800;min-width:46px;text-align:center;letter-spacing:.3px;}
.m-get{background:rgba(16,185,129,.15);color:var(--green);}
.m-post{background:rgba(59,130,246,.15);color:#60a5fa;}
.m-put{background:rgba(245,158,11,.15);color:var(--gold);}
.m-delete{background:rgba(239,68,68,.15);color:var(--red);}
.ep-path{font-size:12px;font-weight:600;font-family:monospace;color:var(--t1);}
.ep-desc{font-size:11px;color:var(--t3);margin-left:auto;}
.ws-log{background:rgba(0,0,0,.35);border-radius:9px;padding:14px;height:180px;overflow-y:auto;font-family:monospace;font-size:12px;line-height:1.7;}
.api-tester{padding-top:4px;}
.api-response{background:rgba(0,0,0,.35);border-radius:9px;padding:14px;margin-top:12px;font-family:monospace;font-size:12px;color:var(--t2);max-height:280px;overflow-y:auto;white-space:pre-wrap;word-break:break-all;}

/* PAYOUT ITEMS */
.payout-item{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid rgba(255,255,255,.04);}
.payout-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0;}
.payout-info{flex:1;}
.payout-name{font-size:13px;font-weight:600;}
.payout-date{font-size:11px;color:var(--t3);}
.payout-amt{font-size:14px;font-weight:800;}
.payout-in{color:var(--green);}
.payout-out{color:var(--red);}

/* AI */
.ai-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:20px;}
.ai-card{background:linear-gradient(135deg,rgba(59,130,246,.08),rgba(139,92,246,.06));border:1px solid rgba(99,102,241,.2);border-radius:var(--r);padding:16px;position:relative;overflow:hidden;}
.ai-label{font-size:10px;font-weight:700;color:#8b5cf6;letter-spacing:.8px;text-transform:uppercase;margin-bottom:6px;}
.ai-score{font-size:26px;font-weight:900;color:#a78bfa;margin:4px 0;}
.ai-text{font-size:12px;color:var(--t1);line-height:1.6;}
.ai-chat{background:rgba(0,0,0,.3);border-radius:10px;padding:14px;min-height:100px;margin-bottom:10px;display:flex;flex-direction:column;gap:10px;max-height:280px;overflow-y:auto;}
.ai-msg{padding:9px 13px;border-radius:10px;font-size:13px;line-height:1.6;max-width:85%;}
.ai-msg-bot{background:rgba(59,130,246,.1);border:1px solid rgba(59,130,246,.15);color:var(--t1);}
.ai-msg-user{background:rgba(139,92,246,.15);border:1px solid rgba(139,92,246,.2);color:var(--t1);align-self:flex-end;}
.ai-suggestions{display:flex;gap:7px;flex-wrap:wrap;}
.ai-chip{padding:5px 11px;border-radius:99px;background:rgba(139,92,246,.12);border:1px solid rgba(139,92,246,.2);font-size:11px;color:#a78bfa;cursor:pointer;transition:all .2s;}
.ai-chip:hover{background:rgba(139,92,246,.2);}

/* MAP */
.world-map-wrap svg{width:100%;height:auto;}
.map-legend{display:flex;gap:14px;margin-top:10px;flex-wrap:wrap;}
.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--t3);}
.legend-dot{width:7px;height:7px;border-radius:50%;}

/* PLATFORM CONTROLS */
.ctrl-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:9px;background:rgba(255,255,255,.02);border:1px solid var(--border);margin-bottom:10px;cursor:pointer;transition:all .2s;}
.ctrl-item:hover{background:var(--card-hover);}

/* MODAL */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);z-index:500;display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-card{background:rgba(12,18,30,.98);border:1px solid var(--border);border-radius:18px;padding:28px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;}

/* FAB */
.fab{display:none;position:fixed;bottom:22px;right:22px;width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;color:#fff;font-size:18px;cursor:pointer;z-index:200;box-shadow:0 4px 18px rgba(59,130,246,.5);}

/* RESPONSIVE */
@media(max-width:1200px){.kpi-grid{grid-template-columns:repeat(3,1fr);}.chart-grid{grid-template-columns:1fr;}.two-col-grid{grid-template-columns:1fr;}}
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr);}.chart-row3{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0;}
  .topbar{left:0;}
  .fab{display:flex;align-items:center;justify-content:center;}
  .menu-toggle-btn{display:flex;}
  .kpi-grid{grid-template-columns:1fr 1fr;}
  .kpi-value{font-size:20px;}
  .chart-row3{grid-template-columns:1fr;}
  .search-input{width:140px!important;}
  .saas-cards{grid-template-columns:1fr;}
  .partners-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){.kpi-grid{grid-template-columns:1fr;}.page{padding:14px;}}

/* ANIMATIONS */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}
.fade-in{animation:fadeIn .4s ease forwards;}
@keyframes shimmer{0%{background-position:-200% 0;}100%{background-position:200% 0;}}

/* SUCCESS / ERROR ALERTS */
.alert{padding:10px 14px;border-radius:9px;font-size:13px;font-weight:500;margin-top:8px;}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.2);color:var(--green);}
.alert-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:var(--red);}

/* SUB ANALYTICS */
.sub-row{display:flex;align-items:center;gap:14px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.04);}
.sub-plan{width:80px;font-size:12px;font-weight:600;}
.sub-bar-wrap{flex:1;height:8px;background:rgba(255,255,255,.06);border-radius:99px;overflow:hidden;}
.sub-bar-fill{height:100%;border-radius:99px;}
.sub-val{font-size:12px;font-weight:700;min-width:60px;text-align:right;}
.sub-count{font-size:11px;color:var(--t3);min-width:60px;text-align:right;}
