@import"https://fonts.googleapis.com/css2?family=Rubik:wght@400;500;600;700;800&display=swap";:root{color-scheme:dark;font-family:Rubik,Segoe UI,sans-serif;--bg: #08111f;--bg-accent: #0d1830;--surface: rgba(12, 23, 43, .88);--surface-strong: rgba(16, 30, 56, .96);--surface-soft: rgba(255, 255, 255, .05);--border: rgba(146, 176, 222, .16);--border-strong: rgba(146, 176, 222, .28);--text: #f3f7ff;--text-muted: #9fb0c8;--primary: #5ea8ff;--primary-strong: #7dc3ff;--success: #28c79a;--danger: #ff6f83;--warning: #f7aa53;--shadow: 0 24px 72px rgba(0, 0, 0, .28)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{min-height:100%;scroll-behavior:smooth;overscroll-behavior:none}body{min-height:100vh;margin:0;overflow-x:hidden;overscroll-behavior:none;color:var(--text);background:radial-gradient(circle at top,rgba(94,168,255,.14),transparent 32%),radial-gradient(circle at 85% 15%,rgba(125,195,255,.06),transparent 26%),linear-gradient(180deg,#0a1222,#08111f 55%,#060d17)}button,input,textarea,select{font:inherit}button{cursor:pointer}#root{min-height:100vh}.fullscreen-state{display:grid;place-items:center;min-height:100vh;gap:16px;padding:32px;text-align:center}.fullscreen-state h1{margin:0;font-size:clamp(28px,2.6vw,48px)}.fullscreen-state p{margin:0;max-width:600px;color:var(--text-muted);font-size:clamp(15px,1.1vw,20px);line-height:1.5}.loading-orb{width:72px;height:72px;border-radius:999px;border:4px solid rgba(125,195,255,.16);border-top-color:var(--primary-strong);box-shadow:0 0 44px #5ea8ff38;animation:spin 1.05s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-screen{display:grid;place-items:center;min-height:100vh;position:relative;overflow:hidden;padding:56px 24px}.login-background{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 20%,rgba(94,168,255,.22),transparent 24%),radial-gradient(circle at 80% 12%,rgba(40,199,154,.16),transparent 20%),radial-gradient(circle at 50% 100%,rgba(94,168,255,.18),transparent 36%);filter:blur(12px);pointer-events:none}.login-card{position:relative;display:grid;gap:24px;width:min(440px,100%);padding:clamp(28px,3vw,44px);border:1px solid var(--border);border-radius:32px;background:linear-gradient(180deg,#0e1a31f5,#08111feb);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px)}.login-card h2{margin:0 0 4px;font-size:clamp(24px,2.4vw,40px);text-align:center;letter-spacing:.04em}.login-card .login-form{display:grid;gap:14px}.login-card input{width:100%;min-height:52px;padding:12px 16px;border-radius:16px;border:1px solid var(--border-strong);background:#ffffff0d;color:var(--text);font-size:16px}.login-card input:focus{outline:none;border-color:#7dc3ff70;box-shadow:0 0 0 4px #5ea8ff24}.login-card .login-error{padding:10px 14px;border-radius:12px;background:#ff6f831f;border:1px solid rgba(255,111,131,.28);color:#ffd3da;font-size:14px;text-align:center}.btn{display:inline-flex;align-items:center;justify-content:center;min-height:44px;padding:0 20px;border:0;border-radius:14px;font-weight:600;font-size:14px;transition:transform .16s ease,box-shadow .16s ease,opacity .16s ease}.btn:hover{transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:default;transform:none}.btn-primary{color:#fff;background:linear-gradient(135deg,var(--primary),var(--primary-strong));box-shadow:0 12px 24px #0000002e}.btn-ghost{color:var(--text);background:#ffffff0d;border:1px solid var(--border)}.btn-danger{color:#fff;background:linear-gradient(135deg,#d55c74,var(--danger));box-shadow:0 12px 24px #0000002e}.btn-small{min-height:36px;padding:0 14px;font-size:13px;border-radius:10px}.dashboard-shell{width:min(1600px,100%);min-height:100vh;margin:0 auto;padding:clamp(20px,2.4vw,42px);padding-bottom:clamp(48px,10vh,120px)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding:clamp(16px,1.8vw,24px);border:1px solid var(--border);border-radius:24px;background:#08111fd6;box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px)}.dashboard-header h1{margin:0;font-size:clamp(24px,2.2vw,42px);line-height:1.1}.current-user{margin-top:8px;color:var(--text-muted);font-size:13px;font-weight:600}.dashboard-header .header-actions{display:flex;flex-wrap:wrap;gap:10px}.password-panel{margin-bottom:18px}.password-panel-header{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.password-form{grid-template-columns:repeat(3,minmax(180px,1fr)) auto;align-items:center}.admin-section{display:grid;gap:18px;margin-top:28px}.section-heading{display:flex;align-items:flex-end;justify-content:space-between;gap:16px}.section-heading h2{margin:0;font-size:clamp(22px,2vw,32px)}.section-heading p{margin:6px 0 0;color:var(--text-muted)}.admin-grid{display:grid;grid-template-columns:minmax(280px,.8fr) minmax(320px,1.2fr);gap:16px}.admin-form{display:grid;gap:12px}.admin-form input,.admin-form select,.assignment-actions select{width:100%;min-height:42px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#ffffff0d;color:var(--text)}.admin-message{margin-top:12px;color:var(--text-muted);font-size:13px}.admin-list,.assignment-list{display:grid;gap:10px}.admin-list-row,.assignment-row{display:grid;gap:12px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:16px;background:#ffffff0a}.admin-list-row{grid-template-columns:minmax(0,1fr) auto auto}.admin-list-row div,.assignment-main{display:grid;gap:4px;min-width:0}.admin-list-row span,.assignment-main span,.assignment-empty{color:var(--text-muted);font-size:13px}.assignment-row{grid-template-columns:minmax(180px,.8fr) minmax(220px,1fr) minmax(240px,.9fr)}.assignment-users{display:flex;flex-wrap:wrap;gap:8px}.assignment-chip{min-height:30px;padding:0 10px;border:1px solid rgba(94,168,255,.28);border-radius:999px;color:var(--text);background:#5ea8ff1f}.assignment-actions{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}.alert-stack{position:fixed;right:clamp(16px,2vw,28px);bottom:clamp(16px,2vw,28px);z-index:1000;display:grid;gap:10px;width:min(380px,calc(100vw - 32px))}.alert-toast{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:start;padding:14px 14px 14px 16px;border-radius:18px;border:1px solid var(--border);box-shadow:0 18px 48px #00000057;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);font-size:14px;font-weight:600}.alert-toast-content{display:grid;gap:4px;line-height:1.35}.alert-toast-title{color:var(--text);font-size:13px;text-transform:uppercase;letter-spacing:.04em}.alert-toast-close{display:inline-grid;place-items:center;width:28px;height:28px;border:1px solid rgba(255,255,255,.12);border-radius:999px;background:#ffffff12;color:currentColor;font-size:18px;line-height:1}.alert-toast-close:hover{background:#ffffff1f}.alert-toast--offline{background:#39111ceb;border-color:#ff6f835c;color:#ffd9df}.alert-toast--online{background:#092d27eb;border-color:#28c79a57;color:#d8fff2}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px}.summary-card{display:grid;gap:8px;padding:20px;border-radius:20px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff0d,#070f1c1f),var(--surface);box-shadow:var(--shadow)}.summary-card .label{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);font-weight:600}.summary-card .value{font-size:clamp(28px,2.2vw,42px);font-weight:700;line-height:1}.summary-card .helper{font-size:13px;color:var(--text-muted);line-height:1.4}.summary-card--highlight{border-color:#5ea8ff47;background:linear-gradient(180deg,#5ea8ff1f,#070f1c1f),var(--surface)}.devices-section h2{margin:0 0 16px;font-size:clamp(20px,1.8vw,32px)}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.device-card{display:grid;gap:12px;padding:20px;border-radius:20px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff0a,#070f1c1a),var(--surface);box-shadow:var(--shadow);cursor:pointer;transition:transform .2s ease,border-color .2s ease,box-shadow .2s ease}.device-card:hover{transform:translateY(-2px);border-color:#5ea8ff52;box-shadow:0 28px 80px #00000052}.device-card-header{display:flex;justify-content:space-between;align-items:flex-start}.device-card-header h3{margin:0;font-size:18px}.status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:4px}.status-dot--online{background:var(--success);box-shadow:0 0 10px var(--success)}.status-dot--offline{background:var(--danger)}.device-card-meta{display:grid;gap:4px;font-size:14px;color:var(--text-muted)}.device-card-meta .status-text{font-weight:600}.device-card-meta .status-text.online{color:var(--success)}.device-card-meta .status-text.offline{color:var(--danger)}.device-card-hint{font-size:12px;color:var(--primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:0;transition:opacity .2s ease}.device-card:hover .device-card-hint{opacity:1}.no-devices{color:var(--text-muted);padding:40px;text-align:center;font-size:16px}.detail-view{animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.detail-back-bar{display:flex;align-items:center;gap:16px;margin-bottom:20px}.detail-back-bar h2{margin:0;font-size:clamp(20px,1.8vw,32px)}.detail-back-bar .device-status{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}.device-status.online{background:#28c79a29;border:1px solid rgba(40,199,154,.32);color:#d8fff2}.device-status.offline{background:#ff6f831f;border:1px solid rgba(255,111,131,.28);color:#ffd3da}.detail-period-pill{margin-left:auto;display:inline-flex;align-items:center;min-height:32px;padding:0 12px;border-radius:999px;border:1px solid rgba(94,168,255,.3);background:#5ea8ff1a;color:#dbe9ff;font-size:12px;font-weight:700;letter-spacing:.02em}.detail-period-controls{display:grid;gap:10px;margin-bottom:14px}.period-presets{display:flex;flex-wrap:wrap;gap:8px}.period-chip{min-height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease}.period-chip:hover{transform:translateY(-1px);border-color:#5ea8ff52;color:var(--text)}.period-chip--active{border-color:#5ea8ff6b;background:#5ea8ff29;color:#f4f8ff}.custom-period-form{display:flex;flex-wrap:wrap;align-items:flex-end;gap:8px}.custom-period-field{display:grid;gap:6px;color:var(--text-muted);font-size:12px;font-weight:600}.custom-period-field input{min-height:36px;padding:0 10px;border-radius:10px;border:1px solid var(--border);background:#081222d9;color:var(--text)}.custom-period-error{color:#ffc7cf;font-size:12px}.app-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.app-tab{min-height:40px;padding:0 16px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease}.app-tab:hover{transform:translateY(-1px);border-color:#5ea8ff4d;color:var(--text)}.app-tab--active{border-color:#5ea8ff6b;background:#5ea8ff29;color:#f4f8ff}.section-tabs{display:flex;flex-wrap:wrap;gap:8px}.section-tab{min-height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:.03em;transition:transform .16s ease,border-color .16s ease,background-color .16s ease,color .16s ease}.section-tab:hover{transform:translateY(-1px);border-color:#5ea8ff52;color:var(--text)}.section-tab--active{border-color:#5ea8ff6b;background:#5ea8ff29;color:#f4f8ff}.bento-card{display:grid;gap:16px;padding:clamp(16px,1.5vw,24px);border-radius:24px;border:1px solid var(--border);background:linear-gradient(180deg,#ffffff0d,#070f1c1f),var(--surface);box-shadow:var(--shadow)}.card-eyebrow{margin-bottom:4px;color:var(--primary-strong);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700}.card-title{margin:0;font-size:clamp(18px,1.4vw,28px);line-height:1.15}.card-subtitle{margin:4px 0 0;color:var(--text-muted);font-size:14px;line-height:1.45}.analytics-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;align-items:start}.grid-span-8{grid-column:span 8}.grid-span-6{grid-column:span 6}.grid-span-4{grid-column:span 4}.grid-span-12{grid-column:span 12}.hero-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.metric-card{display:grid;gap:6px;min-height:140px;padding:16px;border-radius:20px;background:linear-gradient(180deg,#5ea8ff1a,#ffffff08);border:1px solid rgba(94,168,255,.12)}.metric-label{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);font-weight:600}.metric-value{font-size:clamp(28px,2vw,44px);font-weight:700;line-height:1;color:#f7fbff}.metric-helper{font-size:13px;color:var(--text-muted);line-height:1.4}.inline-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.inline-stat{display:flex;justify-content:space-between;align-items:center;min-height:52px;padding:12px 16px;border-radius:14px;background:#ffffff0a;border:1px solid var(--border)}.inline-stat span{font-size:13px;color:var(--text-muted)}.inline-stat strong{font-size:15px;color:var(--text)}.chart-shell{position:relative;min-height:240px}.table-shell{overflow-x:auto}.table-shell--compact{max-height:360px}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th{text-align:left;padding:10px 14px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border)}.data-table td{padding:10px 14px;border-bottom:1px solid rgba(146,176,222,.08);color:var(--text)}.data-table tbody tr:hover{background:#5ea8ff0f}.data-table--compact th,.data-table--compact td{padding:8px 10px;font-size:12px}.insight-list{display:grid;gap:10px;margin:0;padding:0;list-style:none}.insight-item{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;background:#ffffff0a;border:1px solid var(--border)}.insight-item span{font-size:13px;color:var(--text-muted)}.insight-item strong{font-size:14px;color:var(--text);text-align:right}.empty-state{padding:32px;text-align:center;color:var(--text-muted);font-size:15px}.empty-state--compact{padding:20px;font-size:14px}.detail-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:16px;margin-top:16px;align-items:start}@media (max-width: 1200px){.analytics-grid .grid-span-8,.analytics-grid .grid-span-6{grid-column:span 12}.analytics-grid .grid-span-4,.detail-grid .grid-span-4{grid-column:span 6}.hero-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width: 768px){.dashboard-shell{padding:14px 14px 40px}.dashboard-header{flex-direction:column;align-items:stretch;gap:12px;margin-bottom:18px;padding:14px;border-radius:18px}.dashboard-header h1{font-size:24px}.dashboard-header .header-actions{width:100%}.dashboard-header .header-actions .btn{flex:1 1 0}.alert-stack{right:12px;bottom:12px;width:calc(100vw - 24px)}.analytics-grid .grid-span-4,.detail-grid .grid-span-4{grid-column:span 12}.analytics-grid,.detail-grid,.summary-grid,.devices-grid,.admin-grid{gap:12px}.hero-kpis{grid-template-columns:repeat(2,minmax(0,1fr))}.inline-stats{grid-template-columns:1fr}.summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.summary-card,.device-card,.bento-card{padding:14px;border-radius:18px}.summary-card .value{font-size:24px}.devices-grid,.admin-grid,.admin-list-row,.password-form,.assignment-row{grid-template-columns:1fr}.password-panel-header{flex-direction:column}.assignment-actions{grid-template-columns:1fr}.device-card{gap:10px}.device-card-hint{opacity:1;font-size:11px}.detail-back-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px}.detail-back-bar h2{width:100%;font-size:22px}.detail-period-pill{margin-left:0}.custom-period-form{align-items:stretch}.app-tabs,.section-tabs{margin-bottom:2px}.app-tab,.section-tab{min-height:34px;padding:0 12px;font-size:11px}.metric-card{min-height:112px;padding:12px;border-radius:16px}.metric-value{font-size:24px}.metric-helper,.inline-stat span,.insight-item span,.insight-item strong,.device-card-meta,.summary-card .helper{font-size:12px}.inline-stat{min-height:46px;padding:10px 12px}.chart-shell{min-height:220px}.table-shell--compact{max-height:300px}}@media (max-width: 520px){.summary-grid,.hero-kpis{grid-template-columns:1fr}}
