@import "https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600;14..32,700;14..32,800&family=Fira+Code:wght@300;400;500&display=swap";*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#f4f7fa;--surface:#fff;--surface2:#f8fafc;--surface3:#eff3f8;--surface4:#fff;--surface5:#f1f5f9;--border:#cbd5e1;--accent:#2563eb;--accent2:#3b82f6;--accent3:#dc2626;--warn:#d97706;--text:#1e293b;--text2:#475569;--text3:#64748b;--radius:8px;--font:"Inter", system-ui, -apple-system, sans-serif;--mono:"Fira Code", monospace;--shadow:0 1px 3px #0000000d, 0 1px 2px #00000008}html,body,#root{background:var(--bg);height:100%;color:var(--text);font-family:var(--font)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--surface3);border-radius:3px}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;width:260px;min-width:260px;padding:0;display:flex;overflow:hidden}.main{background:var(--bg);flex-direction:column;flex:1;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid var(--border);padding:24px 20px 20px}.logo-title{letter-spacing:0;color:var(--accent);font-size:20px;font-weight:700}.logo-sub{color:var(--text3);letter-spacing:.5px;font-size:10px;font-family:var(--mono);margin-top:4px}.nav{flex-direction:column;flex:1;gap:4px;padding:20px 12px;display:flex;overflow-y:auto}.nav-label{letter-spacing:.5px;color:var(--text3);font-size:10px;font-family:var(--mono);padding:12px 12px 4px;font-weight:500}.nav-item{cursor:pointer;color:var(--text2);border:1px solid #0000;border-radius:6px;align-items:center;gap:12px;padding:8px 12px;font-size:13px;font-weight:500;transition:all .2s;display:flex}.nav-item:hover{background:var(--surface2);color:var(--text)}.nav-item.active{background:var(--surface3);color:var(--accent);border-color:var(--border)}.nav-icon{text-align:center;opacity:.7;width:20px;font-size:16px}.nav-badge{background:var(--accent3);color:#fff;font-size:10px;font-family:var(--mono);border-radius:12px;margin-left:auto;padding:1px 6px}.sidebar-user{border-top:1px solid var(--border);cursor:pointer;align-items:center;gap:12px;padding:16px;display:flex}.avatar{background:var(--surface3);width:38px;height:38px;color:var(--accent);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:flex}.user-name{color:var(--text);font-size:13px;font-weight:600}.user-role{color:var(--text3);font-size:11px;font-family:var(--mono)}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 28px;display:flex}.page-title{color:var(--text);font-size:20px;font-weight:700}.page-sub{color:var(--text2);font-size:12px;font-family:var(--mono);margin-top:2px}.topbar-actions{align-items:center;gap:12px;display:flex}.page{flex:1;padding:28px 32px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card-label{letter-spacing:.5px;color:var(--text3);font-size:10px;font-family:var(--mono);margin-bottom:6px;font-weight:500}.card-value{color:var(--text);font-size:28px;font-weight:700}.card-sub{color:var(--text2);margin-top:4px;font-size:11px}.stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-accent{border-top:2px solid var(--accent)}.stat-blue{border-top:2px solid var(--accent2)}.stat-warn{border-top:2px solid var(--warn)}.stat-red{border-top:2px solid var(--accent3)}.btn{cursor:pointer;font-family:var(--font);border:none;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 2px 8px #2563eb33}.btn-secondary{background:var(--surface2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent);background:#fff}.btn-ghost{color:var(--text2);border:1px solid var(--border);background:0 0}.btn-ghost:hover{color:var(--text);background:var(--surface2);border-color:var(--border)}.btn-danger{background:var(--accent3);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-sm{padding:4px 10px;font-size:11px}.btn-icon{border-radius:6px;justify-content:center;width:34px;height:34px;padding:0}.input-group{flex-direction:column;gap:6px;display:flex}.input-label{color:var(--text2);font-size:11px;font-family:var(--mono);letter-spacing:.5px;font-weight:500}.input,select.input,textarea.input{background:var(--surface);border:1px solid var(--border);color:var(--text);font-family:var(--font);border-radius:6px;outline:none;width:100%;padding:8px 12px;font-size:13px;transition:border-color .2s}.input:focus,select.input:focus,textarea.input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #2563eb1a}select.input option{background:var(--surface2)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13px}thead tr{border-bottom:1px solid var(--border);background:var(--surface2)}th{text-align:left;color:var(--text2);letter-spacing:.5px;font-size:11px;font-family:var(--mono);white-space:nowrap;padding:12px 14px;font-weight:600}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}tbody tr{cursor:pointer;transition:background .15s}tbody tr:hover{background:var(--surface2)}tbody tr:last-child td{border-bottom:none}.badge{font-size:10px;font-weight:500;font-family:var(--mono);white-space:nowrap;border-radius:20px;align-items:center;gap:4px;padding:2px 8px;display:inline-flex}.badge-green{color:#0d9488;background:#0d948814;border:1px solid #0d948833}.badge-blue{color:var(--accent);background:#2563eb14;border:1px solid #2563eb33}.badge-red{color:var(--accent3);background:#dc262614;border:1px solid #dc262633}.badge-warn{color:var(--warn);background:#d9770614;border:1px solid #d9770633}.badge-gray{color:var(--text2);background:var(--surface2);border:1px solid var(--border)}.form-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.form-grid .span2{grid-column:span 2}.form-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.search-row{align-items:center;gap:12px;margin-bottom:20px;display:flex}.search-wrap{flex:1;position:relative}.search-icon{color:var(--text3);font-size:14px;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{padding-left:36px!important}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{font-size:16px;font-weight:600}.section-sub{color:var(--text2);font-size:11px;font-family:var(--mono);margin-top:2px}.patients-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.patient-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;box-shadow:var(--shadow);padding:20px;transition:all .2s}.patient-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.patient-card-header{align-items:center;gap:12px;margin-bottom:14px;display:flex}.patient-avatar{background:var(--surface3);width:44px;height:44px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;font-weight:600;display:flex}.patient-name{font-size:14px;font-weight:600}.patient-meta{color:var(--text2);font-size:11px;font-family:var(--mono);margin-top:2px}.patient-stats{grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px;display:grid}.patient-stat{text-align:center}.ps-val{color:var(--accent);font-size:18px;font-weight:700}.ps-lbl{color:var(--text3);font-size:9px;font-family:var(--mono)}.live-wrapper{aspect-ratio:16/9;border-radius:var(--radius);border:1px solid var(--border);background-color:#000;position:relative;overflow:hidden}.live-background{object-fit:cover;z-index:0;width:100%;height:100%;position:absolute;top:0;left:0}.live-badge{z-index:2;background:var(--accent3);color:#fff;border-radius:4px;align-items:center;gap:5px;padding:3px 10px;font-size:10px;font-weight:600;animation:1.5s infinite pulse-badge;display:flex;position:absolute;top:14px;left:14px}@keyframes pulse-badge{0%,to{opacity:1}50%{opacity:.6}}.live-dot{background:#fff;border-radius:50%;width:7px;height:7px}.live-placeholder{color:var(--text3);font-family:var(--mono);text-align:center;font-size:13px}.metrics-live{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-top:12px;display:grid}.metric-item{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);text-align:center;padding:16px 12px;transition:all .2s;position:relative}.metric-item:hover{border-color:var(--accent);background:var(--surface);box-shadow:var(--shadow)}.metric-val{font-size:28px;font-weight:700;font-family:var(--mono);margin-bottom:8px}.metric-label{cursor:help;display:inline-block;position:relative}.metric-abbr{color:var(--text2);letter-spacing:.5px;background:var(--surface3);border-radius:20px;padding:2px 8px;font-size:12px;font-weight:700;display:inline-block}.metric-tooltip{visibility:hidden;opacity:0;background-color:var(--surface);width:220px;color:var(--text);text-align:center;border:1px solid var(--border);z-index:10;font-size:11px;font-weight:400;font-family:var(--font);pointer-events:none;white-space:normal;word-wrap:break-word;border-radius:8px;padding:8px 12px;line-height:1.4;transition:opacity .2s,visibility .2s;position:absolute;bottom:130%;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0000001a}.metric-tooltip:after{content:"";border-style:solid;border-width:6px;border-color:var(--border) transparent transparent transparent;margin-left:-6px;position:absolute;top:100%;left:50%}.metric-label:hover .metric-tooltip{visibility:visible;opacity:1}.tabs{border-bottom:1px solid var(--border);gap:4px;margin-bottom:24px;display:flex}.tab{cursor:pointer;color:var(--text2);border-bottom:2px solid #0000;padding:10px 18px;font-size:13px;font-weight:500;transition:all .2s}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.notif-panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);z-index:100;width:320px;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 4px 12px #0000001a}.notif-header{border-bottom:1px solid var(--border);background:var(--surface2);padding:12px 16px;font-size:13px;font-weight:600}.notif-item{border-bottom:1px solid var(--border);cursor:pointer;padding:12px 16px;transition:background .15s}.notif-item:hover{background:var(--surface2)}.notif-item:last-child{border-bottom:none}.notif-name{font-size:12px;font-weight:600}.notif-msg{color:var(--text2);margin-top:2px;font-size:11px}.notif-time{color:var(--text3);font-size:10px;font-family:var(--mono);margin-top:4px}.notif-unread{background:#2563eb0a}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{background:radial-gradient(at 20% 80%,#2563eb0a 0%,#0000 60%);position:absolute;inset:0}.login-card{background:var(--surface);border:1px solid var(--border);width:400px;box-shadow:var(--shadow);border-radius:12px;padding:40px;position:relative}.login-logo{color:var(--accent);margin-bottom:4px;font-size:28px;font-weight:700}.login-sub{color:var(--text3);font-size:11px;font-family:var(--mono);margin-bottom:28px}.login-form{flex-direction:column;gap:16px;display:flex}.login-divider{border:none;border-top:1px solid var(--border);margin:16px 0 8px}.login-incn{color:var(--text3);text-align:center;font-size:11px;font-family:var(--mono)}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.chart-title{margin-bottom:16px;font-size:14px;font-weight:600}.chart-sub{color:var(--text2);font-size:10px;font-family:var(--mono);margin-top:4px}.two-col{grid-template-columns:1fr 1fr;gap:20px;display:grid}.three-col{grid-template-columns:2fr 1fr;gap:20px;display:grid}.session-row{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:14px;padding:12px 16px;transition:all .2s;display:flex}.session-row:hover{border-color:var(--accent);background:var(--surface2)}.session-date{font-size:11px;font-family:var(--mono);color:var(--text2);min-width:90px}.session-info{flex:1}.session-title{font-size:13px;font-weight:600}.session-meta{color:var(--text2);font-size:11px;font-family:var(--mono)}.session-scores{align-items:center;gap:16px;display:flex}.score-item{text-align:right}.score-val{color:var(--accent);font-size:16px;font-weight:700;font-family:var(--mono)}.score-lbl{color:var(--text3);font-size:9px;font-family:var(--mono)}.progress-wrap{background:var(--surface3);border-radius:4px;height:6px;overflow:hidden}.progress-fill{border-radius:4px;height:100%;transition:width .6s}.detail-grid{grid-template-columns:280px 1fr;align-items:start;gap:24px;display:grid}.info-list{flex-direction:column;gap:0;display:flex}.info-row{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:10px 0;display:flex}.info-row:last-child{border-bottom:none}.info-key{color:var(--text2);font-size:11px;font-family:var(--mono);font-weight:500}.info-val{font-size:13px;font-weight:500}.alert{border:1px solid;border-radius:8px;align-items:flex-start;gap:10px;padding:12px 16px;font-size:13px;display:flex}.alert-warn{color:var(--warn);background:#d9770614;border-color:#d9770633}.alert-green{color:#0d9488;background:#0d948814;border-color:#0d948833}.empty{text-align:center;color:var(--text3);padding:60px 20px}.empty-icon{opacity:.5;margin-bottom:12px;font-size:40px}.empty-text{color:var(--text2);margin-bottom:8px;font-size:14px}.empty-sub{font-size:12px;font-family:var(--mono)}@keyframes fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:.35s both fadeUp}.modal-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:200;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;width:520px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 10px 25px #0000001a}.modal-title{margin-bottom:20px;font-size:18px;font-weight:700}.rec-up{color:#0d9488;background:#0d94880d;border:1px solid #0d948833}.rec-keep{color:var(--warn);background:#d977060d;border:1px solid #d9770633}.rec-down{color:var(--accent3);background:#dc26260d;border:1px solid #dc262633}
