:root{--primary: #647eff;--primary-hover: #535bf2;--primary-light: rgba(100, 126, 255, .1);--bg-color: #0f172a;--bg-secondary: #1e293b;--card-bg: rgba(30, 41, 59, .8);--text-main: #f8fafc;--text-muted: #94a3b8;--text-dark: #64748b;--success: #10b981;--success-bg: rgba(16, 185, 129, .15);--warning: #f59e0b;--warning-bg: rgba(245, 158, 11, .15);--error: #ef4444;--error-bg: rgba(239, 68, 68, .15);--border-color: rgba(255, 255, 255, .1);--border-light: rgba(255, 255, 255, .05);--sidebar-width: 260px;--header-height: 64px;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-main);background-color:var(--bg-color);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body,#root{height:100%;width:100%;overflow:hidden}body{background-color:var(--bg-color);color:var(--text-main)}h1,h2,h3,h4,h5,h6{color:var(--text-main);font-weight:600;line-height:1.3}h1{font-size:2rem;background:linear-gradient(135deg,#42d392,#647eff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}h2{font-size:1.25rem}h3{font-size:1rem}.text-muted{color:var(--text-muted)}.mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:.875em}.capitalize{text-transform:capitalize}.glass-card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid var(--border-color);padding:1.5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}button{cursor:pointer;border:none;font-family:inherit;font-size:inherit;transition:all .2s ease}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:8px;font-weight:500;font-size:.875rem;background:var(--bg-secondary);color:var(--text-main);border:1px solid var(--border-color)}.btn:hover{background:#ffffff1a}.btn-primary{background:var(--primary);border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-success{background:var(--success-bg);color:var(--success);border-color:transparent}.btn-success:hover{background:#10b98140}.btn-danger{background:var(--error-bg);color:var(--error);border-color:transparent}.btn-danger:hover{background:#ef444440}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-icon{padding:.375rem;background:transparent;color:var(--text-muted);border-radius:6px}.btn-icon:hover{background:#ffffff1a;color:var(--text-main)}.btn-icon.success{color:var(--success)}.btn-icon.small{padding:.25rem}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .75rem;border-radius:999px;font-size:.75rem;font-weight:600;text-transform:uppercase}.status-paid,.status-active{background:var(--success-bg);color:var(--success)}.status-pending{background:var(--warning-bg);color:var(--warning)}.status-failed,.status-blocked{background:var(--error-bg);color:var(--error)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-dot.online{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.offline{background:var(--text-muted)}.table-container{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;text-align:left}.data-table th{padding:1rem;font-weight:600;color:var(--text-muted);font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color)}.data-table td{padding:1rem;border-bottom:1px solid var(--border-light)}.data-table tbody tr:hover{background:#ffffff05}input,select{font-family:inherit;font-size:inherit}input[type=text],input[type=email],input[type=password],input[type=search]{padding:.625rem 1rem;background:#0003;border:1px solid var(--border-color);border-radius:8px;color:var(--text-main);width:100%;outline:none;transition:border-color .2s}input:focus{border-color:var(--primary)}input::placeholder{color:var(--text-dark)}select{padding:.375rem .75rem;background:#0003;border:1px solid var(--border-color);border-radius:6px;color:var(--text-main);outline:none;cursor:pointer}select:focus{border-color:var(--primary)}.toggle-switch{position:relative;display:inline-block;width:48px;height:24px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--bg-secondary);border-radius:24px;border:1px solid var(--border-color);transition:.3s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:2px;bottom:2px;background:var(--text-muted);border-radius:50%;transition:.3s}.toggle-switch input:checked+.toggle-slider{background:var(--primary);border-color:var(--primary)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px);background:#fff}.app-layout{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0}.sidebar-header{padding:1.5rem;border-bottom:1px solid var(--border-color)}.sidebar-logo{font-size:1.5rem;font-weight:700}.sidebar-logo span{color:var(--primary)}.sidebar-subtitle{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.sidebar-nav{flex:1;padding:1rem .75rem;overflow-y:auto}.nav-list{list-style:none;display:flex;flex-direction:column;gap:.25rem}.nav-item a{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:8px;text-decoration:none;color:var(--text-muted);font-weight:500;transition:all .2s}.nav-item a:hover{background:#ffffff0d;color:var(--text-main)}.nav-item a.active{background:var(--primary);color:#fff}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden}.app-header{height:var(--header-height);padding:0 2rem;display:flex;align-items:center;justify-content:flex-end;border-bottom:1px solid var(--border-color);flex-shrink:0}.user-menu{position:relative}.user-menu-button{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:transparent;border-radius:8px;cursor:pointer;transition:background .2s}.user-menu-button:hover{background:#ffffff0d}.user-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;background:var(--primary);display:flex;align-items:center;justify-content:center}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-info{text-align:left}.user-name{font-weight:500;font-size:.875rem}.user-role{font-size:.75rem;color:var(--text-muted)}.user-dropdown{position:absolute;top:calc(100% + .5rem);right:0;width:200px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:.5rem;box-shadow:0 10px 40px #0000004d;z-index:100}.dropdown-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.625rem .75rem;background:transparent;color:var(--text-main);border-radius:8px;text-align:left;font-size:.875rem}.dropdown-item:hover{background:#ffffff0d}.dropdown-item.danger{color:var(--error)}.dropdown-divider{height:1px;background:var(--border-color);margin:.5rem 0}.page-wrapper{flex:1;overflow-y:auto;padding:2rem}.page-container{display:flex;flex-direction:column;gap:1.5rem;max-width:1400px;margin:0 auto}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem}.page-header h1{margin-bottom:.25rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}.stat-card{display:flex;align-items:flex-start;gap:1rem}.stat-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-content{display:flex;flex-direction:column;gap:.25rem}.stat-title{font-size:.8125rem;color:var(--text-muted)}.stat-value{font-size:1.5rem;font-weight:700}.analytics-filters{display:flex;gap:.75rem;flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff0a;border:1px solid var(--border-color);border-radius:999px;color:var(--text-muted)}.filter-chip select{background:transparent;border:none;color:var(--text-main);font-size:.875rem;outline:none}.analytics-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.5rem}.analytics-card{display:flex;flex-direction:column;gap:1.25rem}.analytics-card-header{display:flex;align-items:center;justify-content:space-between;gap:1rem}.analytics-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.metric-item{padding:.75rem 1rem;border-radius:12px;border:1px solid var(--border-light);background:#ffffff05}.metric-label{display:block;font-size:.8125rem;color:var(--text-muted);margin-bottom:.25rem}.metric-value{font-size:1.25rem;font-weight:600}.trend-chart{display:grid;grid-template-columns:repeat(auto-fit,minmax(48px,1fr));gap:.75rem;align-items:end;min-height:180px}.trend-bar{display:flex;flex-direction:column;align-items:center;gap:.35rem;height:100%}.trend-bar-fill{width:100%;max-width:36px;border-radius:999px;background:linear-gradient(180deg,#647eff,#647eff66);min-height:8px;transition:height .3s ease}.trend-label{font-size:.75rem;color:var(--text-muted)}.trend-value{font-size:.75rem;color:var(--text-main)}.screen-metrics{display:flex;flex-direction:column;gap:.75rem}.screen-row{display:grid;grid-template-columns:1fr 1.5fr;gap:1rem;align-items:center}.screen-info{display:flex;flex-direction:column;gap:.25rem}.screen-name{font-weight:600}.screen-sub{font-size:.8125rem;color:var(--text-muted)}.screen-bar{width:100%;height:8px;background:#ffffff14;border-radius:999px;overflow:hidden}.screen-bar-fill{height:100%;background:linear-gradient(90deg,#42d392,#647eff);border-radius:inherit}.device-ranking{display:flex;flex-direction:column;gap:.75rem}.device-rank-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;border-radius:12px;border:1px solid var(--border-light);background:#ffffff05}.filters-bar{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem}.search-input{position:relative;flex:1;max-width:400px}.search-input .search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);color:var(--text-muted)}.search-input input{padding-left:2.75rem}.filter-group{display:flex;align-items:center;gap:.75rem;color:var(--text-muted)}.filter-tabs{display:flex;gap:.5rem}.filter-tab{padding:.5rem 1rem;background:transparent;color:var(--text-muted);border-radius:8px;font-size:.875rem;font-weight:500}.filter-tab:hover{background:#ffffff0d}.filter-tab.active{background:var(--primary);color:#fff}.devices-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.device-card{display:flex;flex-direction:column;gap:1rem}.device-header{display:flex;align-items:center;justify-content:space-between}.device-icon{width:48px;height:48px;border-radius:12px;background:var(--primary-light);color:var(--primary);display:flex;align-items:center;justify-content:center}.device-status{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-muted)}.device-name h3{font-size:1.125rem;margin-bottom:.125rem}.nickname-display,.nickname-edit{display:flex;align-items:center;gap:.5rem}.nickname-edit input{flex:1;padding:.5rem .75rem;font-size:.9375rem}.nickname-actions{display:flex;gap:.25rem}.device-model-small{font-size:.8125rem;color:var(--text-muted)}.device-info{display:flex;flex-direction:column;gap:.5rem;font-size:.875rem}.info-row{display:flex;justify-content:space-between}.info-row .label{color:var(--text-muted)}.device-footer{display:flex;align-items:center;justify-content:space-between;padding-top:1rem;border-top:1px solid var(--border-light);margin-top:auto}.auth-status{font-size:.8125rem;font-weight:500}.auth-status.authorized{color:var(--success)}.auth-status.unauthorized{color:var(--error)}.users-list{display:flex;flex-direction:column;gap:1rem}.user-card{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;align-items:center;gap:1rem}.user-card .user-info{display:flex;align-items:center;gap:1rem;text-align:left}.user-card .user-avatar{width:48px;height:48px}.user-details h3{margin-bottom:.125rem}.user-date{font-size:.75rem;margin-top:.25rem}.user-actions{display:flex;gap:.5rem;justify-content:flex-end}.role-select{padding:.375rem .75rem}.admin-badge{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-light);color:var(--primary);border-radius:8px;font-size:.8125rem;font-weight:500}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--primary);color:#fff}.avatar-placeholder.large{width:80px;height:80px;border-radius:50%}.settings-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.settings-section{display:flex;flex-direction:column}.settings-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;color:var(--primary)}.settings-header h2{color:var(--text-main)}.settings-content{flex:1}.profile-info{display:flex;align-items:center;gap:1.5rem}.profile-avatar{width:80px;height:80px;border-radius:50%;overflow:hidden}.profile-avatar img{width:100%;height:100%;object-fit:cover}.profile-details h3{font-size:1.25rem;margin-bottom:.25rem}.profile-badges{display:flex;gap:.5rem;margin-top:.75rem}.role-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:500;background:var(--primary-light);color:var(--primary)}.role-badge.admin{background:var(--warning-bg);color:var(--warning)}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.setting-info{display:flex;flex-direction:column;gap:.125rem}.setting-label{font-weight:500}.setting-description{font-size:.8125rem}.theme-toggle{display:flex;gap:.5rem}.theme-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:transparent;color:var(--text-muted);border:1px solid var(--border-color);border-radius:8px;font-size:.875rem}.theme-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.theme-btn:disabled{opacity:.5;cursor:not-allowed}.info-grid{display:flex;flex-direction:column;gap:1rem}.info-item{display:flex;justify-content:space-between;padding-bottom:.75rem;border-bottom:1px solid var(--border-light)}.info-item:last-child{border-bottom:none;padding-bottom:0}.info-item .label{color:var(--text-muted)}.info-item .value{font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:var(--text-muted)}.empty-state h3{margin-top:1rem;color:var(--text-main)}.empty-state p{margin-top:.5rem}.loading-spinner{display:flex;align-items:center;justify-content:center;padding:4rem;color:var(--text-muted)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-color) 0%,var(--bg-secondary) 100%)}.login-card{width:100%;max-width:400px;text-align:center}.login-logo{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.login-logo span{color:var(--primary)}.login-subtitle{color:var(--text-muted);margin-bottom:2rem}.login-btn{width:100%;padding:.875rem 1.5rem;font-size:1rem;justify-content:center}.login-btn img{width:20px;height:20px}.unauthorized-container{min-height:100vh;display:flex;align-items:center;justify-content:center}.unauthorized-card{text-align:center;max-width:400px}.unauthorized-icon{width:80px;height:80px;border-radius:50%;background:var(--warning-bg);color:var(--warning);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.analytics-grid,.settings-grid{grid-template-columns:1fr}.user-card{grid-template-columns:2fr 1fr 1fr}.user-card .user-actions{grid-column:span 3;justify-content:flex-start}}@media(max-width:768px){:root{--sidebar-width: 200px}.stats-grid{grid-template-columns:1fr}.filters-bar{flex-wrap:wrap}.search-input{max-width:none;order:-1;width:100%}.user-card{grid-template-columns:1fr;gap:.75rem}.user-card .user-actions{grid-column:auto}.page-header{flex-direction:column;align-items:flex-start}.analytics-metrics,.screen-row{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:radial-gradient(1200px 600px at 10% -10%,rgba(100,126,255,.18),transparent),radial-gradient(900px 600px at 110% 10%,rgba(66,211,146,.18),transparent),linear-gradient(135deg,var(--bg-color) 0%,#0c1328 100%);position:relative;overflow:auto}.login-shell{width:min(1120px,100%);display:grid;grid-template-columns:1.2fr .8fr;gap:2.5rem;align-items:stretch}.login-hero{background:linear-gradient(145deg,#1e293be6,#0f172ae6);border:1px solid var(--border-color);border-radius:20px;padding:2.5rem;display:flex;flex-direction:column;justify-content:space-between;min-height:560px;box-shadow:0 30px 80px #00000059}.login-hero-inner{display:flex;flex-direction:column;gap:2rem}.login-brand h1{font-size:2.75rem;margin-bottom:.5rem}.login-badge{display:inline-flex;align-items:center;justify-content:center;padding:.25rem .75rem;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase;background:#647eff33;color:var(--primary);border:1px solid rgba(100,126,255,.4);border-radius:999px;margin-bottom:1rem}.login-hero-features{display:grid;gap:.75rem;font-size:.95rem}.feature-item{display:flex;align-items:flex-start;gap:.75rem;color:var(--text-main)}.feature-dot{width:10px;height:10px;border-radius:999px;margin-top:.35rem;background:linear-gradient(135deg,#42d392,#647eff);box-shadow:0 0 0 4px #647eff26}.login-hero-card{display:grid;gap:1rem}.hero-stat{background:#0f172ab3;border:1px solid var(--border-light);border-radius:14px;padding:1.25rem 1.5rem}.hero-stat h3{margin-bottom:.35rem}.login-panel{display:flex;align-items:center}.login-card{width:100%;background:#0f172ad9;border:1px solid var(--border-color);border-radius:20px;padding:2.5rem;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);box-shadow:0 24px 60px #00000059}.login-header{text-align:left;margin-bottom:1.5rem}.login-header h2{font-size:1.75rem;margin-bottom:.35rem}.login-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;background:var(--bg-color);border-radius:10px;padding:.25rem}.login-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;border:none;background:transparent;color:var(--text-muted);font-size:.875rem;font-weight:500;border-radius:8px;cursor:pointer;transition:all .2s ease}.login-tab:hover{color:var(--text-main)}.login-tab.active{background:var(--primary);color:#fff}.login-alert{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.login-alert.error{background:var(--error-bg);color:var(--error);border:1px solid var(--error)}.login-alert.success{background:var(--success-bg);color:var(--success);border:1px solid var(--success)}.login-form{display:flex;flex-direction:column;gap:1rem}.login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.login-form label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;font-weight:500;color:var(--text-muted)}.login-form input{width:100%;padding:.875rem 1rem;background:#0f172a99;border:1px solid var(--border-color);border-radius:8px;color:var(--text-main);font-size:.9375rem;transition:all .2s ease}.login-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.login-form input:disabled{opacity:.6;cursor:not-allowed}.login-form input::placeholder{color:var(--text-dark)}.login-btn{width:100%;padding:.875rem 1rem;margin-top:.5rem;font-size:.9375rem}.login-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0;color:var(--text-dark);font-size:.8125rem}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.875rem 1rem;background:#fffffff2;color:#1f2937;border:none;border-radius:8px;font-size:.9375rem;font-weight:500;cursor:pointer;transition:all .2s ease}.btn-google:hover:not(:disabled){background:#f5f5f5;transform:translateY(-1px)}.btn-google:disabled{opacity:.6;cursor:not-allowed}.login-info{margin-top:1.5rem;padding:1rem;background:var(--primary-light);border-radius:8px;font-size:.8125rem;color:var(--primary);text-align:center;line-height:1.5}.login-footer{text-align:center;margin-top:1.5rem;font-size:.75rem}@media(max-width:960px){.login-shell{grid-template-columns:1fr}.login-hero{min-height:auto;order:2}.login-panel{order:1}}@media(max-width:640px){.login-page{padding:1.25rem}.login-card,.login-hero{padding:1.75rem}.login-hero-card{display:none}}.pending-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:linear-gradient(135deg,var(--bg-color) 0%,#1a1f3a 100%)}.pending-container{text-align:center;max-width:480px}.pending-icon{display:inline-flex;align-items:center;justify-content:center;width:120px;height:120px;background:var(--warning-bg);color:var(--warning);border-radius:50%;margin-bottom:2rem}.pending-container h1{font-size:2rem;margin-bottom:1rem}.pending-message{font-size:1.125rem;margin-bottom:.5rem}.pending-container .text-muted{line-height:1.6;margin-bottom:2rem}.pending-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-outline{background:transparent;border:1px solid var(--border-color);color:var(--text-main)}.btn-outline:hover{background:var(--bg-secondary);border-color:var(--text-muted)}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg-color);color:var(--text-muted)}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
