*,:before,:after{box-sizing:border-box}:root{color:#1f2937;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f2f4f7;font-family:Inter,Segoe UI,Tahoma,sans-serif}body{background:#f2f4f7;min-width:320px;margin:0}#app{min-height:100vh}.dashboard-page{grid-template-columns:158px 1fr;min-height:100vh;transition:grid-template-columns .2s;display:grid}.dashboard-page.sidebar-collapsed{grid-template-columns:64px 1fr}.sidebar{background:#f4f4f5;border-right:1px solid #d8dee6;padding:12px 8px}.sidebar-head{justify-content:space-between;align-items:center;margin:4px 4px 10px;display:flex}.sidebar-title{color:#222;margin:0;font-size:20px;font-weight:500}.sidebar-toggle-btn{color:#334155;cursor:pointer;background:#fff;border:1px solid #d4dbe4;border-radius:6px;place-items:center;width:28px;height:28px;display:grid}.menu{flex-direction:column;gap:3px;display:flex}.menu-item{color:#4b5563;cursor:pointer;text-align:left;background:0 0;border:0;border-radius:6px;align-items:center;gap:9px;padding:8px 10px;font-size:12px;text-decoration:none;display:flex}.dashboard-page.sidebar-collapsed .menu-item{justify-content:center;padding:8px 6px}.menu-item.active{color:#f8fafc;background:#2f556e}.menu-item:hover{background:#e8edf3}.menu-item.active:hover{background:#284a60}.content{padding:10px 14px}.topbar{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.topbar h1{color:#2b2b2b;margin:0;font-size:26px;font-weight:500}.topbar-right{align-items:center;gap:8px;display:flex}.open-site-btn{color:#2f3743;cursor:pointer;background:#fff;border:1px solid #d4dbe4;border-radius:4px;align-items:center;gap:6px;padding:7px 10px;font-size:12px;display:inline-flex}.topbar-user-wrap{position:relative}.user-icon-btn{color:#374151;cursor:pointer;background:#fff;border:1px solid #d4dbe4;border-radius:50%;place-items:center;width:29px;height:29px;display:grid}.user-icon-btn[aria-expanded=true]{color:#2f556e;border-color:#2f556e}.user-menu-dropdown{z-index:100;background:#fff;border:1px solid #dbe2ea;border-radius:8px;min-width:220px;padding:0;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 8px 24px #0f172a1f}.user-menu-name{color:#1e293b;border-bottom:1px solid #e7edf4;margin:0;padding:12px 14px 10px;font-size:14px;font-weight:600;line-height:1.35}.user-menu-logout{text-align:left;color:#b91c1c;cursor:pointer;background:0 0;border:0;width:100%;padding:10px 14px 12px;font-family:inherit;font-size:13px;display:block}.user-menu-logout:hover{background:#fef2f2}.metrics-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.metric-card{background:#fff;border:1px solid #dbe2ea;border-radius:6px;align-items:center;gap:10px;min-height:82px;padding:12px 14px;display:flex}.metric-icon{color:#59667a;background:#f3f6fa;border:1px solid #e3eaf1;border-radius:6px;flex-shrink:0;place-items:center;width:30px;height:30px;display:grid}.metric-card h3{color:#2f343c;margin:0 0 3px;font-size:32px;font-weight:600;line-height:1}.metric-card p{color:#757b84;margin:0;font-size:12px}.stats-section h2{color:#292f36;margin:0 0 10px;font-size:31px;font-weight:500}.stats-section+.stats-section{margin-top:16px}.charts-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.chart-card{background:#fff;border:1px solid #dbe2ea;border-radius:6px;padding:10px 12px 12px}.chart-card h3{color:#3a3f46;margin:0 0 8px;font-size:19px;font-weight:500}.chart-empty{color:#64748b;place-items:center;min-height:250px;margin:0;font-size:14px;display:grid}.dashboard-message{color:#475569;margin:0 0 12px;font-size:14px}.dashboard-message.error{color:#b91c1c}.simple-legend{justify-content:center;gap:18px;display:flex}.simple-legend-item{color:#4b5563;align-items:center;gap:6px;font-size:12px;display:inline-flex}.dot{border-radius:2px;width:10px;height:10px}.users-summary{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:12px;display:grid}.users-table{border-collapse:collapse;width:100%}.users-table th,.users-table td{text-align:left;border-bottom:1px solid #e7edf4;padding:10px 8px;font-size:13px}.users-table th{color:#6b7280;font-weight:600}.user-status{color:#334155;background:#e2e8f0;border-radius:999px;align-items:center;padding:4px 9px;font-size:12px;font-weight:600;display:inline-flex}.user-status.активен{color:#166534;background:#dcfce7}.user-status.ожидает{color:#92400e;background:#fef3c7}.user-status.заблокирован{color:#991b1b;background:#fee2e2}.users-message{color:#475569;margin:4px 0 10px;font-size:13px}.users-message.error{color:#b91c1c}.user-action-btn{color:#1e293b;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;padding:4px 10px;font-size:12px}.user-action-btn:hover{background:#eef2f7}.modal-overlay{z-index:1000;background:#0f172a59;place-items:center;padding:16px;display:grid;position:fixed;inset:0}.modal-card{background:#fff;border:1px solid #dbe2ea;border-radius:10px;width:min(640px,100%);padding:16px}.modal-card h3{margin:0 0 12px;font-size:20px}.modal-grid{grid-template-columns:1fr 1fr;gap:8px 14px;margin-bottom:14px;display:grid}.modal-grid p{margin:0;font-size:14px}.modal-close-btn{color:#1e293b;cursor:pointer;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;padding:6px 12px;font-size:13px}@media (width<=1200px){.dashboard-page{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #d8dee6;border-right:0}.menu{grid-template-columns:repeat(3,minmax(0,1fr));display:grid}}@media (width<=900px){.topbar{flex-direction:column;align-items:flex-start;gap:10px}.metrics-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.users-summary,.charts-grid{grid-template-columns:1fr}}@media (width<=560px){.metrics-grid,.modal-grid{grid-template-columns:1fr}}.login-page{background:linear-gradient(160deg,#e8edf3 0%,#f2f4f7 45%,#dce6ee 100%);place-items:center;min-height:100vh;padding:24px 16px;display:grid}.login-card{background:#fff;border:1px solid #dbe2ea;border-radius:10px;width:min(400px,100%);padding:28px 26px 26px;box-shadow:0 12px 40px #0f172a14}.login-title{color:#2f556e;text-align:center;margin:0;font-size:26px;font-weight:600}.login-subtitle{color:#64748b;text-align:center;margin:8px 0 22px;font-size:14px}.login-form{flex-direction:column;gap:14px;display:flex}.login-field{color:#475569;flex-direction:column;gap:6px;font-size:13px;display:flex}.login-field input{color:#1e293b;background:#fff;border:1px solid #cbd5e1;border-radius:6px;width:100%;padding:10px 12px;font-size:14px}.login-password-wrap{align-items:center;display:flex;position:relative}.login-password-wrap input{padding-right:42px}.login-password-toggle{color:#64748b;cursor:pointer;background:0 0;border:0;border-radius:6px;place-items:center;width:34px;height:34px;display:grid;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.login-password-toggle:hover{color:#2f556e;background:#f1f5f9}.login-field input:focus{border-color:#2f556e;outline:none;box-shadow:0 0 0 2px #2f556e26}.login-error{color:#b91c1c;margin:0;font-size:13px}.login-submit{color:#f8fafc;cursor:pointer;background:#2f556e;border:0;border-radius:6px;margin-top:4px;padding:11px 16px;font-size:14px;font-weight:600}.login-submit:hover{background:#284a60}
