:root{--bg: #f6f8fc;--panel: #ffffff;--panel-soft: #fbfcff;--ink: #172033;--muted: #667085;--line: #e6eaf2;--accent: #1a73e8;--accent-strong: #1557b0;--accent-soft: #edf4ff;--success-soft: #ecfdf5;--shadow: 0 16px 40px rgba(31, 42, 68, .07);--shadow-soft: 0 4px 18px rgba(31, 42, 68, .05)}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-size:13px;line-height:1.5;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,sans-serif}button,input,select,textarea{font:inherit}button{min-height:34px;border:0;border-radius:10px;background:var(--accent);color:#fff;padding:0 14px;font-weight:600;font-size:13px;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,background .16s ease}button:hover:not(:disabled){transform:translateY(-1px);box-shadow:var(--shadow-soft)}button.secondary{background:#fff;border:1px solid var(--line);color:var(--ink)}button.danger{background:#fff4f2;border:1px solid #ffc9c2;color:#b42318}button.link-button{min-height:0;height:auto;background:transparent;color:var(--accent);border:0;padding:0;justify-content:flex-start;font-weight:700;text-align:left}button.active{background:var(--accent)}button:disabled{opacity:.6;cursor:wait}.app-shell{width:100%;min-height:100vh;display:flex;flex-direction:column;margin:0;padding:0}.topnav{position:sticky;top:0;z-index:100;height:48px;display:flex;align-items:center;gap:0;padding:0 24px;border-bottom:1px solid var(--line);background:#ffffffeb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);flex-shrink:0}.topnav-brand{display:flex;align-items:baseline;gap:8px;flex-shrink:0;margin-right:20px}.topnav-brand strong{font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap}.topnav-brand span{font-size:12px;color:var(--muted);white-space:nowrap}.topnav-nav{display:flex;align-items:center;gap:2px;flex:1;overflow-x:auto;scrollbar-width:none}.topnav-nav::-webkit-scrollbar{display:none}.topnav-nav button{min-height:32px;padding:0 12px;background:transparent;color:var(--muted);font-size:13px;font-weight:600;border-radius:8px;white-space:nowrap;flex-shrink:0}.topnav-nav button:hover:not(:disabled){background:var(--accent-soft);color:var(--accent);transform:none;box-shadow:none}.topnav-nav button.active{background:var(--accent-soft);color:var(--accent)}.topnav-actions{display:flex;align-items:center;gap:10px;margin-left:12px;flex-shrink:0}.scan-btn{min-height:30px;padding:0 12px;font-size:12px;border-radius:8px;white-space:nowrap}.content-shell{width:100%;max-width:1600px;margin:0 auto;padding:20px 24px 36px}.global-toolbar{display:flex;align-items:center;flex-wrap:nowrap;gap:8px;padding:0;border:none;border-radius:0;background:transparent;box-shadow:none;margin:0}.global-toolbar label,.range-row label{display:flex;align-items:center;gap:6px;color:var(--muted);font-size:12px;font-weight:600;white-space:nowrap}.global-toolbar label select{min-height:28px;width:auto;padding:3px 8px;font-size:12px;border-radius:8px}.global-toolbar>span{color:var(--muted);font-size:12px;white-space:nowrap}.custom-range{display:flex;align-items:center;gap:6px}.custom-range input{width:130px;min-height:28px;font-size:12px}.hero{min-height:220px;border-radius:8px;background:linear-gradient(100deg,#0f766ef0,#16201de0),radial-gradient(circle at 90% 10%,#f4c95d,transparent 30%);color:#fff;display:flex;align-items:end;justify-content:space-between;gap:24px;padding:34px;box-shadow:var(--shadow)}.hero p{margin:0 0 10px;font-weight:800}h1,h2{margin:0;letter-spacing:0}h1{font-size:1.5rem;line-height:1.1}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.page-header h1{font-size:1.4rem;line-height:1.15}.page-header p{color:var(--muted);margin:4px 0 0;font-size:13px}.stat-strip{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px}.stat-strip-item{min-width:104px;border:1px solid var(--line);border-radius:16px;background:var(--panel);padding:9px 12px;box-shadow:var(--shadow-soft)}.stat-strip-item span{display:block;color:var(--muted);font-size:.78rem;font-weight:700}.stat-strip-item strong{display:block;margin-top:3px;font-size:1.05rem}.overview-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;align-items:start}.overview-main,.overview-side{display:grid;gap:12px}.overview-card{padding:14px 16px;background:linear-gradient(180deg,#fff,#fbfdff)}.overview-list{display:grid}.overview-row{display:grid;grid-template-columns:minmax(110px,.9fr) minmax(120px,1fr) minmax(100px,.7fr);gap:8px;align-items:center;min-height:38px;border-top:1px solid var(--line)}.overview-row:first-child{border-top:0}.overview-row span,.overview-row time{color:var(--muted)}.overview-row strong{font-size:.95rem;color:var(--ink)}.compact-timeline{max-height:360px}.compact-timeline li{grid-template-columns:100px minmax(0,1fr) 130px;align-items:center;border-left:0;border-top:1px solid var(--line);padding:10px 0}.compact-timeline li:first-child{border-top:0}.empty-row{color:var(--muted);display:block}.overview-alerts{display:grid;gap:8px}.alert-row{display:grid;grid-template-columns:12px minmax(0,1fr);gap:10px;align-items:flex-start;border-top:1px solid var(--line);padding:11px 0}.alert-row:first-child{border-top:0}.alert-row div{display:grid;gap:3px}.dot{width:9px;height:9px;border-radius:999px;margin-top:6px}.dot.red{background:#d93025}.dot.orange{background:#f29900}.dot.yellow{background:#fbbc04}.quick-links{display:grid;gap:8px}.quick-links button{text-align:left}.subtle-warning{margin:0 0 16px;border:1px solid #fde68a;background:#fffbeb;color:#92400e;border-radius:12px;padding:11px 14px;line-height:1.55;font-weight:700}.hero span{display:block;margin-top:14px;color:#ffffffdb;line-height:1.6}.stats,.charts,.grid{display:grid;gap:12px;margin-top:12px}.stats{grid-template-columns:repeat(4,minmax(0,1fr))}.stats div,.panel{background:var(--panel);border:1px solid var(--line);border-radius:22px;box-shadow:var(--shadow)}.stats div{padding:18px}.stats span,.panel-title span,small{color:var(--muted)}.stats strong{display:block;margin-top:8px;font-size:2rem}.charts{grid-template-columns:repeat(3,minmax(0,1fr))}.grid{grid-template-columns:minmax(0,1.25fr) minmax(360px,.75fr);align-items:start}.panel{padding:16px}.panel-title{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:12px}.panel-title-right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.filter-toggle{font-size:.82rem;padding:6px 12px;min-height:unset;white-space:nowrap}.filters{display:grid;grid-template-columns:1fr 180px;gap:10px;margin-bottom:14px}input,select,textarea{width:100%;min-height:34px;border:1px solid var(--line);border-radius:10px;padding:5px 10px;background:#fff;font-size:13px}.table-wrap{overflow:auto;max-height:680px}table{width:100%;min-width:760px;border-collapse:collapse}th,td{padding:8px 10px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top;font-size:13px}th{color:var(--muted);font-size:.84rem}small{display:block;margin-top:4px;max-width:540px;word-break:break-all}.chart-panel svg{width:100%;height:190px;border:1px solid var(--line);border-radius:18px;background:#fff}.blood-trend{margin-top:0}.marker-tabs{display:flex;flex-wrap:wrap;gap:8px;padding:4px;border:1px solid var(--line);border-radius:18px;background:#f8fbff}.marker-tabs button{min-height:28px;padding:0 10px;border-radius:8px;background:transparent;color:var(--muted);box-shadow:none;font-size:12px}.marker-tabs button.active{background:#fff;color:var(--accent);border:1px solid #d6e5ff;box-shadow:0 6px 18px #1a73e81f}.trend-layout{display:grid;grid-template-columns:1fr;gap:20px;align-items:start}.chart-shell{position:relative}.large-chart{width:100%;height:auto;aspect-ratio:286 / 100;display:block;border:1px solid var(--line);border-radius:22px;background:linear-gradient(180deg,#f8fbfff5,#fffffffa);box-shadow:inset 0 1px #fffc}.large-chart circle{stroke-width:.8;cursor:pointer}.large-chart circle.key-point{stroke-width:.8}.event-marker{cursor:pointer}.event-flag-line{stroke:#8b5cf6;stroke-width:.6;stroke-dasharray:1.5 1;opacity:.3}.event-flag-dot{fill:#8b5cf6;stroke:#fff;stroke-width:.4;opacity:.6}.event-flag-shape{fill:#8b5cf6;stroke:#fff;stroke-width:.35}.trend-meta{display:flex;justify-content:space-between;gap:12px;margin-top:12px;color:var(--muted);align-items:center;flex-wrap:wrap}.chart-tooltip{position:absolute;z-index:2;min-width:150px;transform:translate(-50%,calc(-100% - 12px));border:1px solid var(--line);border-radius:16px;background:#fff;box-shadow:var(--shadow);padding:10px 12px;pointer-events:none;display:grid;gap:4px}.chart-tooltip span{color:var(--muted);font-weight:700}.axis-line{stroke:#b8c2d6;stroke-width:1}.grid-line{stroke:#e7edf7;stroke-width:.5;opacity:.4}.x-tick line{stroke:#b8c2d6;stroke-width:.7}.event-filters{display:flex;flex-wrap:wrap;gap:8px;margin:-4px 0 16px}.event-filters label{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);border-radius:999px;padding:6px 10px;background:var(--panel-soft);color:var(--muted);font-size:.86rem;font-weight:700}.event-filters input{width:16px;min-height:16px}.range-row{display:flex;justify-content:flex-end;margin:-4px 0 16px}.event-callout{display:grid;gap:8px;margin-top:10px;border:1px solid var(--line);border-left:4px solid #8b5cf6;border-radius:18px;padding:12px;background:#fff}.event-callout p{margin:0;line-height:1.5}.event-associations{display:grid;gap:8px;margin-top:16px}.event-associations article{border:1px solid var(--line);border-radius:16px;padding:10px;display:grid;gap:4px;background:var(--panel-soft)}.analysis-panel,.quality-panel{margin-top:0}.reparse-result{padding:.4rem .75rem;background:var(--surface2, #f0fdf4);border:1px solid var(--ok, #16a34a);border-radius:6px;font-size:.82rem;color:var(--ok, #15803d);margin-bottom:.75rem}.quality-overview{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}.quality-overview div{border:1px solid var(--line);border-radius:12px;padding:12px;background:#fff}.quality-overview span{color:var(--muted);display:block;font-weight:800;margin-bottom:6px}.quality-overview strong{font-size:1.3rem}.quality-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px}.quality-list{display:grid;gap:10px}.quality-list.tall{max-height:420px;overflow:auto}.quality-list article{border:1px solid var(--line);border-radius:12px;padding:12px;background:#fff;display:grid;gap:5px}.suspicious-list article{border-color:#ffc9c2;border-left:4px solid #b42318;background:#fffaf9}.duplicate-list{grid-template-columns:repeat(2,minmax(0,1fr))}.disclaimer{margin:0 0 14px;border:1px solid #ffc9c2;background:#fff4f2;color:#8f1d14;border-radius:12px;padding:12px;line-height:1.55;font-weight:700}.metric-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.metric-grid.five{grid-template-columns:repeat(5,minmax(0,1fr))}.metric-box{border:1px solid var(--line);border-radius:12px;padding:12px;background:#fff;display:grid;gap:6px}.metric-box span{color:var(--muted);font-weight:700}.metric-box strong{font-size:1.05rem}.dashboard-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:16px;margin-top:8px}.mini-list{max-height:340px}.alert-list{display:grid;gap:10px;max-height:340px;overflow:auto}.alert-list article{border:1px solid #ffc9c2;border-left:4px solid #b42318;background:#fffaf9;border-radius:12px;padding:12px;display:grid;gap:4px}.trend-meta strong{color:var(--ink)}.source-section{display:grid;gap:12px;border-top:1px solid var(--line);padding-top:18px}.source-section-head{display:flex;justify-content:space-between;gap:14px;align-items:center}.source-section-head h3{margin:0 0 3px}.source-section-head span,.pagination-controls span{color:var(--muted);font-size:.9rem;font-weight:700}.pagination-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.pagination-controls button{min-height:34px;padding:0 12px}.source-list{display:grid;gap:10px;max-height:none;overflow:visible}.source-list article{border:1px solid var(--line);border-radius:16px;padding:14px;background:var(--panel-soft);display:grid;gap:5px;box-shadow:0 1px #1f2a4408}.source-list article>span{color:var(--ink);font-weight:700}.source-list article.corrected{border-color:#f0b429;background:#fffaf0}.source-list article.discarded-card,.quality-list article.discarded-card{border-color:#fca5a5;background:#fff5f5;opacity:.75}.source-head,.event-row,.inline-actions,.value-pair{display:flex;align-items:center;flex-wrap:wrap;gap:8px}.source-head{justify-content:space-between}.tag{width:fit-content;border-radius:999px;background:var(--accent-soft);color:var(--accent);padding:4px 9px;font-size:.78rem;font-weight:700}.muted-tag{background:#f3f4f6;color:var(--muted)}.danger-tag{background:#fff4f2;color:#b42318}.value-pair{color:var(--muted);font-size:.9rem}.ocr-tag{background:#fff7ed;color:#c2410c}tr.row-needs-ocr td{background:#fff9f5}.mrd-manual-form{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:16px}.mrd-manual-form h3{margin:0 0 4px;font-size:1rem}.form-hint{color:var(--muted);font-size:.85rem;margin:0 0 12px}.form-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:10px}.form-row label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;font-weight:600;color:var(--muted);flex:1;min-width:120px}.form-row label input,.form-row label select{font-size:.92rem;padding:6px 8px;border:1px solid var(--border);border-radius:6px;background:#fff;font-weight:400;color:var(--text)}.scan-result-banner{display:flex;flex-wrap:wrap;align-items:center;gap:10px;padding:10px 14px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;margin-bottom:12px;font-size:.88rem}.scan-result-banner.error-banner{background:#fff5f5;border-color:#fca5a5}.scan-result-banner .ok-badge{color:#166534;font-weight:600}.scan-result-banner .ocr-badge{color:#c2410c;font-weight:600}.scan-result-banner .skip-badge{color:var(--muted)}.scan-result-banner .ocr-detail{font-size:.82rem;width:100%}.scan-result-banner .ocr-detail ul{margin:4px 0 0 16px;padding:0}.scan-result-banner .ocr-detail li{margin:2px 0}.mrd-upload-panel{display:flex;flex-direction:column;gap:12px}.upload-top{display:flex;flex-direction:column;gap:10px}.upload-notice{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;font-size:.88rem}.upload-notice strong{font-size:.9rem}.ocr-notice{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}.warn-notice{background:#fefce8;border:1px solid #fde68a;color:#854d0e}.ok-notice{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.upload-preview-form{display:flex;flex-direction:column;gap:10px}.upload-rows{display:flex;flex-direction:column;gap:8px}.upload-row{display:flex;flex-wrap:wrap;gap:8px;align-items:flex-end;padding:10px;background:#f8fafc;border:1px solid var(--border);border-radius:6px}.upload-row label{display:flex;flex-direction:column;gap:3px;font-size:.82rem;font-weight:600;color:var(--muted);flex:1;min-width:90px}.upload-row label input,.upload-row label select{padding:5px 7px;border:1px solid var(--border);border-radius:5px;font-size:.88rem;background:#fff}.file-label{display:flex;flex-direction:column;gap:4px;font-size:.85rem;font-weight:600;color:var(--muted)}.ocr-btn{font-size:.78rem!important;padding:3px 8px!important;margin-left:6px}.status-cell{white-space:nowrap;vertical-align:middle}.ocr-file-row{display:flex;align-items:center;gap:8px;margin:3px 0}.note{margin:0;color:#8a5a00;line-height:1.5}.correction-form{display:grid;grid-template-columns:120px 120px minmax(180px,1fr);gap:8px}.correction-form .inline-actions{grid-column:1 / -1}.inline-actions button{min-height:34px;padding:0 11px;font-size:.9rem}.treatment-panel{margin-top:0}.treatment-panel>.panel-title select{width:min(220px,100%)}.event-form{display:grid;grid-template-columns:150px 180px minmax(220px,1fr);gap:10px;margin-bottom:16px}.immune-form{grid-template-columns:145px 130px 110px 100px minmax(150px,1fr);margin-top:16px}.manual-form{display:grid;grid-template-columns:150px 120px 120px minmax(180px,1fr);gap:10px;margin:12px 0 22px}.event-timeline{max-height:560px}.event-timeline li{background:#fff;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;padding:12px}.empty-state{margin:0;color:var(--muted);border:1px dashed var(--line);border-radius:18px;padding:22px;background:var(--panel-soft);text-align:center}.modal-backdrop{position:fixed;inset:0;z-index:20;background:#17211f80;display:grid;place-items:center;padding:22px}.modal{width:min(1180px,100%);max-height:calc(100vh - 44px);overflow:auto}.detail-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:12px}.detail-grid div{border:1px solid var(--line);border-radius:12px;padding:12px;background:#fff}.detail-grid span{display:block;color:var(--muted);margin-bottom:6px}.path-text{color:var(--muted);word-break:break-all;line-height:1.5}.compact-table{max-height:280px;margin:10px 0}.backup-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.8fr);gap:18px}.command-box{border:1px solid var(--line);border-radius:12px;background:#f8fafc;padding:14px;color:var(--ink);font-weight:800;overflow:auto}.download-list{display:grid;gap:10px}.download-button{min-height:44px;display:flex;align-items:center;border:1px solid var(--line);border-radius:12px;padding:0 14px;background:#fff;color:var(--accent);font-weight:800;text-decoration:none}h3{margin:18px 0 8px}svg path{fill:none;stroke:#ccd7d2;stroke-width:1.2}svg .trend{stroke-width:1;stroke-linecap:round;stroke-linejoin:round}svg circle{outline:none}.chart-controls{display:flex;align-items:center;justify-content:flex-end;min-height:24px;margin-bottom:6px}.chart-reset-btn{font-size:12px;min-height:26px;padding:0 10px;border-radius:8px}.chart-hint{font-size:11px;color:var(--muted);opacity:.7}.chime-view-toggle{display:flex;gap:2px;margin-left:8px}.chime-view-toggle button{font-size:11px;min-height:22px;padding:0 8px;border-radius:6px}.chime-view-toggle button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.immune-info-card{margin-top:10px;border:1px solid var(--line);border-radius:10px;background:var(--panel-soft);overflow:hidden}.immune-info-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:9px 14px;background:none;border:none;cursor:pointer;font-size:13px;color:var(--ink);text-align:left}.immune-info-toggle:hover{background:var(--accent-soft)}.immune-info-name{font-weight:600;color:var(--ink)}.immune-info-ref{font-size:12px;color:var(--muted);margin-left:4px}.immune-info-chevron{margin-left:auto;font-size:11px;color:var(--muted)}.immune-info-body{padding:0 14px 12px;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--line)}.immune-info-current{display:flex;align-items:center;gap:10px;padding:7px 10px;margin-top:6px;background:var(--success-soft);border-radius:7px;font-size:13px;flex-wrap:wrap}.immune-info-current.out-of-range{background:#fff7ed}.immune-info-current strong{color:var(--ink)}.immune-info-norm{font-size:12px;color:var(--muted)}.immune-info-warn{font-size:12px;color:#c2410c;font-weight:600}.immune-info-meaning{margin:4px 0 0;font-size:12.5px;color:var(--ink);line-height:1.5}.immune-info-clinical{margin:2px 0 0;font-size:12px;color:var(--muted);line-height:1.5}.immune-info-calc{font-size:11px;color:var(--muted)}.abs-legend{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted);margin:4px 0 0}.abs-legend-solid{display:inline-block;width:8px;height:8px;border-radius:50%}.abs-legend-hollow{display:inline-block;width:8px;height:8px;border-radius:50%;border:1.5px dashed;background:#fff;margin-left:8px}svg text{fill:var(--muted)}svg .chart-subtitle{fill:#7c3aed}svg .review-pt-label{fill:#f97316}svg .event-flag-shape{fill:#8b5cf6;stroke:#fff;stroke-width:.35}svg .axis-line,svg .grid-line,svg .x-tick line{fill:none}.timeline{display:grid;gap:12px;margin:0;padding:0;list-style:none;max-height:800px;overflow:auto}.timeline li{border-left:3px solid var(--accent);padding-left:12px;display:grid;gap:4px}time{color:var(--muted);font-size:.86rem}.error{color:#b42318;background:#fff4f2;border:1px solid #ffc9c2;padding:12px;border-radius:12px}footer{color:var(--muted);font-size:12px;line-height:1.6;margin-top:24px;padding-top:12px;border-top:1px solid var(--line)}.event-form-v16{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.event-advanced{display:flex;flex-direction:column;gap:8px;padding:10px 12px;background:var(--panel-soft);border:1px solid var(--line);border-radius:8px}.event-item{background:#fff;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:12px;padding:12px;display:flex;flex-direction:column;gap:4px}.event-item.duplicate-candidate{border-left-color:#f97316;border-color:#fed7aa}.event-item.discarded-item{opacity:.5;border-left-color:#9ca3af}.duplicate-warning{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:#c2410c;background:#fff7ed;border:1px solid #fed7aa;border-radius:6px;padding:6px 10px;margin-bottom:4px}.event-drugs{font-size:12px;color:#374151}.event-desc,.event-meta{font-size:12px;color:var(--muted)}.event-side-effects{font-size:12px;color:#c2410c}.discarded-label{font-size:11px;color:#6b7280;font-style:italic}.tag-ocr{background:#ede9fe;color:#6d28d9;border-color:#ddd6fe}.tag-scan{background:#ecfdf5;color:#065f46;border-color:#a7f3d0}.tag-manual{background:#f3f4f6;color:#374151;border-color:#d1d5db}.tag-setting{background:#fef3c7;color:#92400e;border-color:#fde68a}.discharge-ocr-panel{margin-bottom:16px}.discharge-preview{padding:12px;background:var(--panel-soft);border:1px solid var(--line);border-radius:8px;display:flex;flex-direction:column;gap:8px}.discharge-preview h4{margin:0 0 4px;font-size:13px;font-weight:600}.discharge-treatment-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;padding:5px 8px;background:#fff;border:1px solid var(--line);border-radius:6px;margin-bottom:4px;font-size:12px}@media(max-width:1100px){.topnav-nav{gap:0}.topnav-nav button{padding:0 8px;font-size:12px}.content-shell{padding:16px 16px 28px}.overview-layout{grid-template-columns:1fr}}@media(max-width:820px){.topnav{height:auto;flex-wrap:wrap;padding:8px 16px;gap:6px}.topnav-nav{order:3;width:100%;padding-bottom:4px}.topnav-actions{margin-left:auto}.page-header,.panel-title{align-items:stretch;flex-direction:column}.stats,.charts,.overview-row,.compact-timeline li,.trend-layout,.grid,.metric-grid,.metric-grid.five,.dashboard-grid,.quality-overview,.quality-grid,.duplicate-list,.backup-grid,.event-form,.immune-form,.correction-form,.manual-form,.detail-grid{grid-template-columns:1fr}.correction-form .inline-actions{grid-column:auto}.panel{padding:14px}.filters{grid-template-columns:1fr}}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#e8f0fe,#f8faff)}.login-card{background:#fff;border-radius:16px;box-shadow:0 4px 32px #1a73e81f;padding:2.5rem 2rem;width:min(380px,92vw);display:flex;flex-direction:column;gap:.5rem}.login-title{font-size:1.5rem;font-weight:700;color:var(--accent, #1a73e8);margin:0}.login-subtitle{color:var(--muted, #5f6368);margin:0 0 1rem;font-size:.9rem}.login-form{display:flex;flex-direction:column;gap:.75rem}.login-form label{font-size:.85rem;color:var(--muted, #5f6368);font-weight:500}.login-form input[type=password]{padding:.6rem .75rem;border:1px solid var(--line, #dadce0);border-radius:8px;font-size:1rem;outline:none;transition:border-color .15s}.login-form input[type=password]:focus{border-color:var(--accent, #1a73e8)}.login-error{color:#c62828;font-size:.82rem;margin:0}.login-btn{margin-top:.5rem;padding:.65rem;background:var(--accent, #1a73e8);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.6;cursor:not-allowed}.logout-btn{padding:.35rem .75rem;font-size:.8rem;border:1px solid var(--line, #dadce0);border-radius:6px;background:transparent;color:var(--muted, #5f6368);cursor:pointer;white-space:nowrap}.logout-btn:hover{background:var(--surface2, #f1f3f4);color:var(--text, #202124)}.role-badge{padding:.2rem .55rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap}.family-badge{background:#fef3c7;color:#92400e}.doctor-badge{background:#dbeafe;color:#1e40af}.admin-badge{background:#f0fdf4;color:#166534}.user-display-name{font-size:.82rem;color:var(--muted, #5f6368);white-space:nowrap;max-width:7rem;overflow:hidden;text-overflow:ellipsis}.doctor-notes-panel{margin-top:1.25rem}.doctor-notes-list{list-style:none;padding:0;margin:0 0 1rem;display:flex;flex-direction:column;gap:.75rem}.doctor-note-item{background:var(--surface2, #f8f9fa);border-radius:6px;padding:.65rem .85rem;position:relative}.doctor-note-meta{display:flex;gap:.5rem;align-items:center;margin-bottom:.3rem}.doctor-note-date{font-size:.75rem;color:var(--muted)}.doctor-note-author{font-size:.75rem;font-weight:600;color:var(--accent, #1a73e8)}.doctor-note-content{font-size:.9rem;white-space:pre-wrap;line-height:1.5}.doctor-note-item .small-btn{position:absolute;top:.5rem;right:.5rem;font-size:.7rem;padding:.15rem .4rem}.doctor-notes-form{display:flex;flex-direction:column;gap:.5rem}.doctor-notes-form textarea{resize:vertical}
