*{box-sizing:border-box;margin:0;padding:0}body{background:#0f1117;color:#e0e0e0;font-family:Segoe UI,sans-serif}.center-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;color:#888}.login-card{background:#1a1d27;border-radius:14px;padding:36px 32px;width:340px;display:flex;flex-direction:column;box-shadow:0 12px 40px #0006}.login-card h1{font-size:22px;color:#fff;text-align:center}.login-sub{color:#888;font-size:13px;text-align:center;margin:6px 0 24px}.login-card label{font-size:12px;color:#888;margin:12px 0 5px}.login-card input{background:#13151f;border:1px solid #2a2d3a;border-radius:8px;padding:10px 12px;color:#e0e0e0;font-size:14px}.login-card input:focus{outline:none;border-color:#a29bfe}.login-card button{margin-top:24px;background:#6c5ce7;color:#fff;border:none;border-radius:8px;padding:12px;font-size:14px;font-weight:600;cursor:pointer}.login-card button:disabled{opacity:.6;cursor:default}.login-error{color:#ff6b6b;font-size:12px;margin-top:12px;text-align:center}.page{padding:24px;max-width:1400px;margin:0 auto}.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.topbar-left{display:flex;align-items:center;gap:14px}.topbar h1{font-size:20px;color:#fff;font-weight:600}.topbar-right{display:flex;align-items:center;gap:14px}.user-email{font-size:12px;color:#888}.btn-ghost{background:#1a1d27;border:1px solid #333;color:#aaa;border-radius:8px;padding:7px 14px;font-size:13px;cursor:pointer}.btn-ghost:hover{background:#222633}.btn-primary{background:#6c5ce7;border:none;color:#fff;border-radius:8px;padding:8px 18px;font-size:13px;font-weight:600;cursor:pointer}.btn-primary:disabled{opacity:.6;cursor:default}.btn-edit{background:none;border:none;cursor:pointer;font-size:14px;margin-left:8px;opacity:.6}.btn-edit:hover{opacity:1}.device-heading h1{font-size:20px;color:#fff;display:flex;align-items:center}.device-sub{font-size:12px;color:#777;margin-top:3px}.mono{font-family:Consolas,monospace}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:200}.modal{background:#1a1d27;border:1px solid #2a2d3a;border-radius:14px;padding:28px;width:360px;display:flex;flex-direction:column}.modal h3{color:#fff;font-size:16px;margin-bottom:18px}.modal label{font-size:12px;color:#888;margin:12px 0 5px}.modal input{background:#13151f;border:1px solid #2a2d3a;border-radius:8px;padding:10px 12px;color:#e0e0e0;font-size:14px}.modal input:focus{outline:none;border-color:#6c5ce7}.modal-id{font-size:11px;color:#555;margin-top:16px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.loading,.empty-state{color:#666;text-align:center;padding:60px;font-size:14px;line-height:1.7}.conn-status{font-size:13px;color:#888;display:flex;align-items:center}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px;background:#888}.dot.on{background:#2ecc71;animation:pulse 1.5s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.device-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}.device-card{background:#1a1d27;border:1px solid #232735;border-radius:14px;padding:18px;cursor:pointer;transition:all .15s}.device-card:hover{border-color:#6c5ce7;transform:translateY(-2px)}.device-card.offline{opacity:.65}.device-card.alert{border-color:#ff6b6b44}.dc-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.dc-title{display:flex;flex-direction:column;gap:3px;min-width:0}.dc-name{font-size:15px;font-weight:700;color:#fff}.dc-id{font-size:10px;color:#666;font-family:Consolas,monospace;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dc-dot{width:9px;height:9px;border-radius:50%;background:#555}.dc-dot.on{background:#2ecc71;box-shadow:0 0 8px #2ecc71}.dc-status{font-size:14px;color:#ffe66d;margin-bottom:14px}.dc-metrics{display:flex;gap:20px;margin-bottom:14px}.dc-val{font-size:26px;font-weight:700}.dc-val.heart{color:#ff6b6b}.dc-val.breath{color:#4ecdc4}.dc-unit{font-size:11px;color:#666;margin-left:4px}.dc-foot{display:flex;justify-content:space-between;font-size:11px;color:#666;padding-top:10px;border-top:1px solid #232735}.dc-online.on{color:#2ecc71}.dc-ago{color:#777}.status-bar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}.card{background:#1a1d27;border-radius:12px;padding:16px 22px;min-width:140px}.card .label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:1px}.card .value{font-size:28px;font-weight:700;margin-top:4px}.card.heart .value{color:#ff6b6b}.card.breath .value{color:#4ecdc4}.card.presence .value{color:#ffe66d}.card.move .value{color:#a29bfe}.tabs{display:flex;gap:8px;margin-bottom:20px}.tab{padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:1px solid #333;background:#1a1d27;color:#666}.tab.active{background:#2a2d3a;color:#fff;border-color:#555}.charts{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:800px){.charts{grid-template-columns:1fr}}.chart-box{background:#1a1d27;border-radius:12px;padding:16px}.chart-box h2{font-size:13px;color:#aaa;margin-bottom:12px}.chart-h{position:relative;height:240px}.history-ctrl{display:flex;justify-content:flex-end;margin-bottom:16px}select{background:#1a1d27;color:#ccc;border:1px solid #333;border-radius:6px;padding:5px 10px;font-size:12px;cursor:pointer}.session-select{min-width:320px}.realtime-label{font-size:11px;color:#555;text-align:right;margin-bottom:8px}.report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.date-range{font-size:12px;color:#666}.report-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:800px){.report-grid{grid-template-columns:1fr}}.report-section{background:#1a1d27;border-radius:12px;padding:20px}.report-section.full{grid-column:1 / -1}.report-section h3{font-size:14px;font-weight:700;color:#fff;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid #2a2d3a}.report-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid #1e2130;font-size:13px}.report-row:last-child{border-bottom:none}.rkey{color:#888}.rval{font-weight:600;color:#e0e0e0}.rval.good{color:#2ecc71}.rval.warn{color:#ffe66d}.rval.bad{color:#ff6b6b}.rval.info{color:#4ecdc4}.no-data{color:#555;font-size:12px;padding:8px 0}.efficiency-bar{height:8px;background:#2a2d3a;border-radius:4px;margin:8px 0;overflow:hidden}.efficiency-fill{height:100%;border-radius:4px;transition:width .5s}.alert-badge{display:inline-block;font-size:10px;padding:2px 7px;border-radius:10px;margin-left:6px;font-weight:700}.alert-badge.red{background:#ff6b6b33;color:#ff6b6b}.hypnogram-wrap{position:relative;height:260px;margin-top:8px}.hypnogram-tooltip{position:fixed;background:#2a2d3a;border:1px solid #444;border-radius:6px;padding:6px 12px;font-size:12px;color:#e0e0e0;pointer-events:none;display:none;z-index:100;white-space:nowrap}
