:root{--bg-main:#050b14;--bg-sidebar:#07111f;--bg-card:#101827;--bg-card-soft:#132033;--border-soft:rgba(125,154,190,.18);--text-main:#f8fafc;--text-muted:#9aa8bb;--accent-blue:#2f8cff;--accent-cyan:#38bdf8;--accent-green:#22c55e;--accent-orange:#f59e0b;--accent-red:#ef4444;--accent-purple:#8b5cf6;--accent-yellow:#eab308}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:radial-gradient(circle at 15% 8%,rgba(56,189,248,.09),transparent 26%),linear-gradient(135deg,#060b13 0%,#07111d 46%,#03070e 100%);color:var(--text-main);font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;font-size:14px}a{color:inherit;text-decoration:none}svg{width:19px;height:19px;fill:currentColor}.app-shell{display:grid;grid-template-columns:282px 1fr;min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;padding:22px 14px 16px;background:linear-gradient(180deg,rgba(8,18,32,.98),rgba(5,11,20,.98));border-right:1px solid rgba(88,121,161,.2);box-shadow:18px 0 60px rgba(0,0,0,.2);display:flex;flex-direction:column;gap:16px}.brand{display:grid;gap:2px;padding:0 12px 12px}.brand-main{font-size:28px;font-weight:950;letter-spacing:.035em;line-height:1}.brand-main span,.sidebar-footer span{color:#218bff}.brand-sub{text-transform:uppercase;letter-spacing:.31em;font-size:10px;color:#b7c5d9}.side-nav{display:grid;gap:5px;overflow:auto;padding-right:3px}.side-nav a{height:39px;border-radius:10px;padding:0 12px;display:flex;align-items:center;gap:12px;color:#cad5e3;position:relative}.side-nav a:hover{background:rgba(47,140,255,.12)}.side-nav a.active{background:linear-gradient(135deg,#1268e3,#0b49a9);color:#fff;box-shadow:0 12px 28px rgba(18,104,227,.32),inset 0 1px rgba(255,255,255,.14)}.side-nav span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.nav-badge{margin-left:auto;min-width:25px;height:25px;border-radius:99px;background:#ef334c;color:#fff;display:grid;place-items:center;font-size:12px}.nav-badge.orange{background:#f97316}.receiver-card{border:1px solid rgba(74,222,128,.18);background:linear-gradient(180deg,rgba(14,33,42,.72),rgba(8,18,31,.8));border-radius:9px;padding:13px;display:grid;gap:5px;color:#b7c5d9}.receiver-card strong{color:#4ade80}.receiver-card small{color:#9fb0c5}.pulse{width:14px;height:14px;border-radius:99px;border:2px solid #22c55e;box-shadow:0 0 0 6px rgba(34,197,94,.1)}.side-user{display:grid;grid-template-columns:38px 1fr 28px;gap:10px;align-items:center;padding:10px 11px;border:1px solid var(--border-soft);border-radius:10px;background:rgba(16,24,39,.72)}.mini-avatar,.avatar{display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,#e8f2ff,#7fb2ff);color:#11417a;font-weight:900}.mini-avatar{width:36px;height:36px}.side-user small,.top-user small{display:block;color:var(--text-muted);font-size:12px}.sidebar-footer{text-align:center;color:#dbeafe;display:grid;gap:3px;margin-top:0}.sidebar-footer strong{font-size:22px;letter-spacing:.04em}.sidebar-footer small{text-transform:uppercase;letter-spacing:.18em;color:#aab8cb;font-size:10px}.sidebar-footer em{font-style:normal;color:#738297;font-size:12px;margin-top:8px}.main{min-width:0}.topbar{height:68px;border-bottom:1px solid rgba(88,121,161,.2);background:rgba(7,14,25,.76);backdrop-filter:blur(14px);display:flex;align-items:center;gap:16px;padding:0 24px;position:sticky;top:0;z-index:5}.icon-button{width:38px;height:38px;border:1px solid rgba(148,163,184,.16);border-radius:10px;background:rgba(16,24,39,.62);color:#dbeafe;display:grid;place-items:center;position:relative}.search{flex:1;max-width:500px;height:40px;border:1px solid rgba(148,163,184,.16);border-radius:10px;color:#6f7f94;display:flex;align-items:center;padding:0 15px;background:rgba(11,18,32,.72)}.scope-badge{border:1px solid rgba(56,189,248,.32);color:#9ee4ff;border-radius:99px;padding:7px 12px;background:rgba(56,189,248,.08);font-size:12px;font-weight:800}.top-actions{display:flex;gap:10px;margin-left:auto}.has-badge b{position:absolute;right:-5px;top:-7px;width:20px;height:20px;border-radius:99px;color:#fff;font-size:11px;display:grid;place-items:center}.has-badge.red b{background:#ef334c}.has-badge.blue b{background:#2f8cff}.top-user{height:68px;border-left:1px solid rgba(148,163,184,.16);padding-left:18px;display:flex;align-items:center;gap:11px}.avatar{width:42px;height:42px}.chevron{color:#9fb0c5;font-size:20px}.menu-button{display:grid}.content{padding:24px;max-width:1680px;margin:0 auto}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:20px}.page-head h1{margin:0;font-size:28px;letter-spacing:-.01em}.page-head p{margin:4px 0 0;color:#aab8cb;font-size:15px}.page-head time{color:#b6c5d8;margin-top:9px}.stats-grid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:13px;margin-bottom:16px}.stat-card,.panel{border:1px solid var(--border-soft);background:linear-gradient(180deg,rgba(19,32,51,.88),rgba(12,22,36,.92));border-radius:8px;box-shadow:0 18px 50px rgba(0,0,0,.22),inset 0 1px rgba(255,255,255,.04)}.stat-card{height:134px;padding:18px 16px;display:flex;gap:15px;align-items:center;overflow:hidden;position:relative}.stat-card:after{content:"";position:absolute;inset:auto -30px -50px auto;width:120px;height:120px;border-radius:50%;background:currentColor;opacity:.08}.stat-icon{width:58px;height:58px;border-radius:50%;display:grid;place-items:center;color:var(--accent-blue);background:radial-gradient(circle,rgba(47,140,255,.26),rgba(47,140,255,.12));box-shadow:inset 0 0 0 1px rgba(255,255,255,.08)}.stat-card span{font-weight:800;color:#dbeafe;font-size:13px}.stat-card strong{display:block;font-size:31px;line-height:1;margin:9px 0 5px}.stat-card small{color:var(--accent-blue);font-weight:800}.tone-green .stat-icon,.tone-green small{color:var(--accent-green)}.tone-orange .stat-icon,.tone-orange small,.tone-amber .stat-icon,.tone-amber small{color:var(--accent-orange)}.tone-red .stat-icon,.tone-red small{color:var(--accent-red)}.tone-purple .stat-icon,.tone-purple small{color:var(--accent-purple)}.dashboard-grid{display:grid;gap:13px;margin-bottom:13px}.main-row{grid-template-columns:1.05fr 1.08fr 1.18fr}.cards-row,.bottom-row{grid-template-columns:repeat(3,minmax(0,1fr))}.panel{padding:17px;min-width:0}.panel-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:13px}.panel-title h2{margin:0;font-size:17px}.panel-title a{background:linear-gradient(135deg,#1268e3,#0b49a9);padding:7px 12px;border-radius:7px;font-weight:900;font-size:12px}.donut-premium{display:grid;grid-template-columns:190px 1fr;gap:16px;align-items:center;position:relative;min-height:240px}.donut{width:174px;height:174px;border-radius:50%;background:conic-gradient(#ef4444 0 18%,#f59e0b 18% 43%,#eab308 43% 60%,#8b5cf6 60% 72%,#2f8cff 72% 90%,#22c55e 90%);box-shadow:0 18px 45px rgba(0,0,0,.24)}.donut:after{content:"";position:absolute;width:88px;height:88px;left:43px;top:76px;border-radius:50%;background:#101827;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06)}.donut-center{position:absolute;left:56px;top:100px;text-align:center}.donut-center span{color:#9fb0c5}.donut-center strong{display:block;font-size:29px}.legend{display:grid;gap:11px}.legend span{display:grid;grid-template-columns:16px 1fr auto;gap:7px;align-items:center;color:#c9d5e5}.legend b{font-weight:500;color:#b5c4d7}.dot{width:10px;height:10px;border-radius:3px;display:inline-block}.green{background:#22c55e}.yellow{background:#eab308}.orange{background:#f59e0b}.red{background:#ef4444}.purple{background:#8b5cf6}.blue{background:#2f8cff}.bars{display:grid;gap:15px}.bar-row div{display:flex;justify-content:space-between;margin-bottom:8px;color:#dbeafe}.bar-row b{font-weight:500}.bar-row em{font-style:normal;color:#9fb0c5;margin-left:14px}.bar-row{position:relative}.bar-row:after{content:"";display:block;height:10px;border-radius:99px;background:rgba(148,163,184,.07)}.bar-row i{display:block;height:10px;border-radius:99px;position:absolute;bottom:0;left:0;background:#2f8cff}.bar-row.tone-red i{background:#ef4444}.bar-row.tone-orange i{background:#f97316}.bar-row.tone-yellow i{background:#eab308}.bar-row.tone-blue i{background:#2f8cff}.bar-row.tone-purple i{background:#8b5cf6}.compact-list{gap:0}.event-item,.mini-row{display:grid;grid-template-columns:18px 1fr 52px 82px;gap:12px;align-items:center;padding:10px 0;border-top:1px solid rgba(148,163,184,.12)}.event-item strong,.mini-row strong{display:block;font-size:14px}.event-item span,.mini-row span{display:block;color:#aab8cb;font-size:12px;margin-top:2px}.event-dot{width:12px;height:12px;border-radius:99px;background:#ef4444;box-shadow:0 0 0 5px rgba(239,68,68,.1)}time{color:#b6c5d8}mark{border:0;border-radius:6px;color:#fff;font-weight:900;font-size:12px;padding:6px 10px;text-align:center;background:#334155}.ok{background:#1d66c9}.danger{background:#dc2626}.warning{background:#d97706}.planned{background:#2f944d}.mini-row{grid-template-columns:1fr 58px 88px;border-left:3px solid #ef4444;padding-left:12px}.mini-row.battery{border-left-color:#f59e0b}.mini-row.tests{border-left-color:#ef4444}.mini-row.planned{border-left-color:#60a5fa}.availability{height:18px;background:rgba(148,163,184,.1);border-radius:99px;overflow:hidden;margin:28px 0 14px}.availability span{display:block;height:100%;background:linear-gradient(90deg,#22c55e,#4ade80)}.availability-labels{display:flex;gap:16px;align-items:center;color:#c9d5e5}.availability-labels b{margin-left:auto;color:#4ade80;font-size:18px}.map-fake{height:135px;border-radius:8px;overflow:hidden;position:relative;background:linear-gradient(rgba(56,189,248,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(56,189,248,.08) 1px,transparent 1px),radial-gradient(circle at 30% 40%,rgba(56,189,248,.14),transparent 18%),radial-gradient(circle at 70% 55%,rgba(239,68,68,.16),transparent 18%),#0b1524;background-size:28px 28px,28px 28px,auto,auto,auto}.pin{position:absolute;width:31px;height:31px;border-radius:50% 50% 50% 0;transform:rotate(-45deg);display:grid;place-items:center;background:#2f8cff;color:#fff;font-weight:900;box-shadow:0 10px 24px rgba(0,0,0,.28)}.pin::first-letter{transform:rotate(45deg)}.p1{left:16%;top:28%}.p2{left:44%;top:52%;background:#f97316}.p3{left:72%;top:24%;background:#ef4444}.p4{left:58%;top:62%}.fault-row,.data-table>div,.settings-list p,.site-card{border:1px solid rgba(148,163,184,.12);background:rgba(7,13,24,.28);border-radius:8px;padding:11px}.fault-row{display:grid;grid-template-columns:120px 1.4fr 1fr 1fr 90px 70px 120px;gap:12px;align-items:center;margin-bottom:8px}.severity{border-radius:6px;padding:7px 10px;font-size:12px;text-align:center;font-weight:900;color:white;background:#334155}.severity.danger{background:#dc2626}.severity.warning{background:#d97706}.severity.info{background:#2563eb}.fault-row button{border:0;border-radius:7px;background:#1268e3;color:white;height:32px;font-weight:900}.site-cards,.data-table{display:grid;gap:9px}.site-card{display:grid;gap:4px}.site-card span,.site-card small,.data-table span{color:#9fb0c5}.site-card em{color:#fbbf24;font-style:normal}.data-table>div{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr auto;gap:12px;align-items:center}.data-table.dense>div{grid-template-columns:170px 80px 100px 140px 1fr}.settings-list p{display:grid;grid-template-columns:220px 1fr}.login-body{display:grid;place-items:center;padding:24px}.login-card{width:min(430px,100%);padding:34px;border:1px solid var(--border-soft);border-radius:18px;background:linear-gradient(180deg,rgba(18,31,51,.94),rgba(7,13,24,.95));box-shadow:0 30px 100px rgba(0,0,0,.45)}.login-card h1{margin:24px 0 4px}.login-card p,.login-card small{color:var(--text-muted)}.login-card label{display:grid;gap:8px;margin:16px 0;color:#cbd5e1}.login-card input{height:44px;border-radius:10px;border:1px solid var(--border-soft);background:#0b1220;color:white;padding:0 12px}.login-card button{width:100%;height:46px;margin-top:8px;border:0;border-radius:8px;background:#1268e3;color:white;font-weight:900}.login-error{background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.35);padding:10px;border-radius:8px;color:#fecaca}
@media(max-width:1420px){.stats-grid{grid-template-columns:repeat(3,1fr)}.main-row,.cards-row,.bottom-row{grid-template-columns:1fr}.donut-premium{grid-template-columns:190px 1fr}}@media(max-width:860px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;z-index:20;width:282px;transform:translateX(-105%);transition:.2s}.sidebar-open .sidebar{transform:none}.search,.scope-badge,.top-actions{display:none}.content{padding:16px}.stats-grid{grid-template-columns:1fr}.topbar{padding:0 14px}.top-user{margin-left:auto}.page-head{display:block}.event-item,.mini-row,.fault-row,.data-table>div,.settings-list p{grid-template-columns:1fr}.donut-premium{grid-template-columns:1fr}.donut-center{display:none}}@media(max-width:520px){.top-user div{display:none}.stat-card{height:118px}.page-head h1{font-size:25px}.brand-main{font-size:24px}}
.head-actions{display:flex;align-items:center;gap:14px}.tenant-filter select{height:38px;border-radius:9px;border:1px solid rgba(148,163,184,.22);background:#0b1524;color:#dbeafe;padding:0 12px;font-weight:800}.client-service-note{margin-top:12px;color:#9fb0c5;line-height:1.55}
.primary-action{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:8px;background:linear-gradient(135deg,#1268e3,#0b49a9);color:#fff;padding:10px 14px;font-weight:900}.filters{display:flex;gap:10px;margin-bottom:14px}.filters input,.filters select,.form-grid input,.form-grid select,.form-grid textarea,.modules-grid select{border:1px solid rgba(148,163,184,.18);background:#0b1524;color:#dbeafe;border-radius:8px;min-height:40px;padding:0 10px}.filters button{border:0;border-radius:8px;background:#1268e3;color:#fff;padding:0 14px;font-weight:900}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-grid label{display:grid;gap:7px;color:#cbd5e1}.form-grid .wide{grid-column:1/-1}.form-grid textarea{min-height:90px;padding:10px}.check{display:flex!important;align-items:center;gap:10px}.tenants-table>div{grid-template-columns:1.5fr .8fr 1fr 1.3fr .7fr .8fr .7fr .7fr .5fr}.modules-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.modules-grid label{display:grid;grid-template-columns:1fr 1fr 90px;gap:10px;align-items:center;border:1px solid rgba(148,163,184,.12);border-radius:8px;padding:10px;background:rgba(7,13,24,.28)}.one-time-password code{display:block;margin-top:10px;padding:14px;border-radius:8px;background:#07111f;color:#7dd3fc;font-size:20px}@media(max-width:1100px){.form-grid,.modules-grid{grid-template-columns:1fr}.tenants-table>div{grid-template-columns:1fr}}
.backoffice-banner{border:1px solid rgba(245,158,11,.35);background:rgba(245,158,11,.14);color:#fed7aa;border-radius:8px;padding:11px 14px;margin-bottom:14px;display:flex;gap:14px;align-items:center}.backoffice-banner a{margin-left:auto;background:#d97706;color:#fff;padding:7px 10px;border-radius:7px;font-weight:900}.module-checks{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.module-checks label{border:1px solid rgba(148,163,184,.16);border-radius:8px;padding:9px;background:rgba(7,13,24,.28)}.readonly label{grid-template-columns:1fr auto}.head-actions{display:flex;gap:8px;flex-wrap:wrap}@media(max-width:900px){.module-checks{grid-template-columns:1fr}.backoffice-banner{display:grid}}
.success-box{border:1px solid rgba(34,197,94,.35);background:rgba(34,197,94,.12);color:#bbf7d0;border-radius:8px;padding:12px}.backoffice-banner{border:1px solid rgba(245,158,11,.35);background:rgba(245,158,11,.14);color:#fed7aa;border-radius:8px;padding:11px 14px;margin-bottom:14px;display:flex;gap:14px;align-items:center}.backoffice-banner a{margin-left:auto;background:#d97706;color:#fff;padding:7px 10px;border-radius:7px;font-weight:900}
