:root{font-family:Inter,Segoe UI,system-ui,sans-serif;color:#101828;background:#eef2f6;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.62}.app-container{min-height:100vh}.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(#10182852,#1018286b),url(https://images.unsplash.com/photo-1542751371-adc38448a05e?auto=format&fit=crop&w=1800&q=80) center / cover}.login-panel{width:min(420px,100%);padding:28px;background:#ffffffeb;border:1px solid rgba(255,255,255,.72);border-radius:8px;box-shadow:0 24px 80px #10182842;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.login-brand{display:flex;gap:14px;align-items:center;margin-bottom:28px}.brand-mark,.app-logo{display:grid;place-items:center;width:44px;height:44px;border-radius:8px;background:#101828;color:#fff;font-weight:800}.login-brand h1,.topbar h1,.panel h2{margin:0;letter-spacing:0}.login-brand h1{font-size:1.5rem}.login-brand p,.eyebrow{margin:0;color:#667085}.login-form,.stack{display:grid;gap:16px}.field{display:grid;gap:7px;color:#344054;font-size:.92rem;font-weight:650}.field input,.password-drawer input{width:100%;border:1px solid #d0d5dd;border-radius:6px;background:#fff;color:#101828;padding:10px 12px;outline:none}.field input:focus,.password-drawer input:focus{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d429}.dashboard-shell{min-height:100vh;display:grid;grid-template-columns:76px 1fr;background:#eef2f6}.sidebar{position:sticky;top:0;height:100vh;display:flex;flex-direction:column;align-items:center;gap:26px;padding:18px 12px;background:#101828;color:#d0d5dd}.sidebar nav{display:grid;gap:8px;width:100%}.sidebar button{border:0;width:100%;padding:10px 0;border-radius:6px;background:transparent;color:#98a2b3;font-size:.78rem;font-weight:750;text-align:center}.sidebar button.active,.sidebar button:hover{background:#1d2939;color:#fff}.section-anchor{scroll-margin-top:22px;min-width:0}.workspace{padding:24px;display:grid;gap:18px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px}.topbar h1{font-size:clamp(1.55rem,2vw,2rem)}.eyebrow{font-size:.76rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.topbar-actions,.button-row,.inline-field{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.sync-label,.count-pill{color:#667085;font-size:.88rem}.primary-action,.secondary-action,.ghost-action,.danger-action,.icon-button{border:1px solid transparent;border-radius:6px;min-height:38px;padding:9px 14px;font-weight:750}.primary-action{background:#101828;color:#fff}.secondary-action,.ghost-action,.icon-button{background:#fff;border-color:#d0d5dd;color:#344054}.danger-action{background:#fff1f3;border-color:#fecdd3;color:#be123c}.icon-button{width:38px;padding:0}.metric-grid,.layout-grid,.chart-grid{display:grid;gap:16px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.layout-grid{grid-template-columns:minmax(320px,.88fr) minmax(420px,1.32fr);align-items:start}.chart-grid{grid-template-columns:1.15fr .85fr}.insights-panel{min-width:0}.insights-heading{align-items:flex-start}.player-tabs{display:flex;gap:8px;overflow-x:auto;padding-bottom:8px;margin-bottom:14px}.player-tabs button{min-width:180px;display:grid;gap:3px;border:1px solid #d0d5dd;border-radius:8px;background:#fff;color:#344054;padding:10px 12px;text-align:left}.player-tabs button.active{border-color:#06b6d4;box-shadow:0 0 0 3px #06b6d424}.player-tabs strong,.player-tabs span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-tabs span{color:#667085;font-size:.8rem}.player-insight-summary{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:10px;margin-bottom:14px}.player-insight-summary div{min-width:0;display:grid;gap:5px;padding:12px;border:1px solid #e4e7ec;border-radius:8px;background:#f9fafb}.player-insight-summary span{color:#667085;font-size:.78rem;font-weight:750}.player-insight-summary strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#101828;font-size:.95rem}.insight-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.insight-card{min-width:0;padding:14px;border:1px solid #e4e7ec;border-radius:8px;background:#fcfcfd}.insight-card h3{margin:0 0 12px;color:#344054;font-size:.95rem;letter-spacing:0}.insight-list,.preference-list{display:grid;gap:10px}.insight-row,.preference-row{display:grid;gap:6px;min-width:0}.insight-row-head{display:flex;justify-content:space-between;gap:10px;min-width:0}.insight-row-head strong,.preference-row strong,.preference-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.insight-row-head strong,.preference-row strong{color:#101828;font-size:.88rem}.insight-row-head span,.insight-row small,.preference-row span,.preference-row small{color:#667085;font-size:.78rem}.bar-track{height:7px;overflow:hidden;border-radius:999px;background:#eaecf0}.bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#06b6d4,#22c55e)}.routine-bar-track{height:9px;overflow:hidden;border-radius:999px;background:#eaecf0}.routine-bar-fill{display:flex;height:100%;min-width:4px;overflow:hidden;border-radius:inherit}.routine-online{height:100%;background:#06b6d4}.routine-ingame{height:100%;background:#22c55e}.metric-tile,.panel{background:#fff;border:1px solid #e4e7ec;border-radius:8px;box-shadow:0 1px 2px #1018280a}.metric-tile{min-height:104px;padding:18px;display:grid;align-content:space-between;border-top:3px solid #101828}.metric-tile span{color:#667085;font-weight:700}.metric-tile strong{font-size:2rem}.accent-green{border-top-color:#22c55e}.accent-cyan{border-top-color:#06b6d4}.accent-red{border-top-color:#ef4444}.panel{padding:18px}.panel-heading{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.panel h2{font-size:1.05rem}.chip-list{display:flex;flex-wrap:wrap;gap:8px;min-height:38px}.chip{display:inline-flex;align-items:center;gap:8px;max-width:100%;border:1px solid #d0d5dd;border-radius:6px;background:#f9fafb;color:#344054;padding:7px 10px}.chip span{overflow-wrap:anywhere}.chip b{color:#be123c}.empty-text,.empty-panel{color:#667085;font-size:.92rem}.password-drawer{display:grid;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid #e4e7ec}.player-list{display:grid;gap:8px}.player-row{display:grid;grid-template-columns:10px minmax(150px,1.3fr) minmax(130px,.9fr) minmax(110px,.7fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid #e4e7ec;border-radius:8px;background:#fcfcfd}.status-dot{width:10px;height:10px;border-radius:50%;background:#98a2b3}.status-dot.online,.state-badge.online{background:#dcfce7;color:#166534}.status-dot.ingame,.state-badge.ingame{background:#cffafe;color:#155e75}.status-dot.offline,.state-badge.offline{background:#fee2e2;color:#991b1b}.status-dot.online,.status-dot.ingame,.status-dot.offline{color:transparent}.status-dot.online{background:#22c55e}.status-dot.ingame{background:#06b6d4}.status-dot.offline{background:#ef4444}.player-main,.player-state{display:grid;gap:4px;min-width:0}.player-main strong,.player-main span,.player-state small,.player-row time{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-main span,.player-state small,.player-row time{color:#667085;font-size:.84rem}.state-badge{width:fit-content;border-radius:999px;padding:3px 8px;font-size:.78rem;font-weight:800}.tabs{display:inline-flex;padding:3px;border-radius:6px;background:#f2f4f7}.tab{min-height:30px;border:none;border-radius:5px;background:transparent;color:#667085;padding:5px 9px;font-size:.82rem;font-weight:800}.tab.active{background:#fff;color:#101828;box-shadow:0 1px 2px #1018281f}.chart-container{height:340px;min-height:340px}.notice{margin:0;border-radius:6px;padding:10px 12px;font-size:.9rem}.notice.error{background:#fff1f3;color:#be123c;border:1px solid #fecdd3}.notice.success{background:#ecfdf3;color:#027a48;border:1px solid #bbf7d0}@media (max-width: 1120px){.layout-grid,.chart-grid,.insight-grid,.player-insight-summary{grid-template-columns:1fr}}@media (max-width: 820px){.dashboard-shell{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;justify-content:space-between}.sidebar nav{display:flex;width:auto;overflow-x:auto}.sidebar button{min-width:56px;padding-inline:10px}.workspace{padding:16px}.topbar{align-items:flex-start;flex-direction:column}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.player-row{grid-template-columns:10px 1fr auto}.player-state,.player-row time{grid-column:2 / -1}.danger-action{grid-column:3;grid-row:1}}@media (max-width: 520px){.metric-grid{grid-template-columns:1fr}.panel-heading,.inline-field{align-items:stretch;flex-direction:column}.inline-field input,.inline-field button,.primary-action,.secondary-action,.ghost-action{width:100%}}
