:root{--color-bg:#f4f6f8;--color-surface:#fff;--color-border:#dce1e7;--color-border-light:#eef0f4;--color-text-primary:#1a2332;--color-text-secondary:#5a6a7e;--color-accent:#1a5fa8;--color-accent-hover:#154d8c;--color-danger:#c0392b;--radius:4px;--shadow-sm:0 1px 3px #00000014;--font-sans:system-ui, -apple-system, "Segoe UI", sans-serif;--font-mono:ui-monospace, "SFMono-Regular", Consolas, monospace;--font-size-sm:.875rem;--font-size-base:.9375rem}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg);-webkit-font-smoothing:antialiased}button,input,select{font-family:inherit}.cancer-selector{border-left:1px solid var(--color-border);align-items:center;gap:10px;margin-left:4px;padding:0 0 0 16px;display:flex}.cancer-selector__label{font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}.cancer-selector__dropdown{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);width:240px;color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;outline:none;padding:7px 10px;transition:border-color .12s}.cancer-selector__dropdown:focus{border-color:var(--color-accent)}.cancer-selector__dropdown:disabled{cursor:not-allowed;color:var(--color-text-secondary);background:#f4f6f8}.cancer-selector__search-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius);font-size:var(--font-size-sm);cursor:pointer;border:none;padding:8px 22px;font-weight:600;transition:background .15s}.cancer-selector__search-btn:hover:not(:disabled){background:var(--color-accent-hover)}.cancer-selector__search-btn:disabled{opacity:.5;cursor:not-allowed}.filter-section{border-bottom:1px solid var(--color-border)}.filter-section__toggle{cursor:pointer;width:100%;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;background:0 0;border:none;justify-content:space-between;align-items:center;padding:10px 16px;font-weight:600;transition:background .1s;display:flex}.filter-section__toggle:hover{background:#f4f6f8}.filter-section__chevron{color:var(--color-text-secondary);flex-shrink:0;transition:transform .2s}.filter-section--open .filter-section__chevron{transform:rotate(180deg)}.filter-section__body{max-height:0;transition:max-height .2s;overflow:hidden}.filter-section--open .filter-section__body{max-height:5000px}.filter-section__inner{padding:4px 16px 12px}.filter-panel{background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;height:100%;display:flex}.filter-panel__header{border-bottom:1px solid var(--color-border);font-weight:600;font-size:var(--font-size-sm);color:var(--color-text-primary);align-items:center;gap:8px;padding:14px 16px 12px;display:flex}.filter-panel__badge{background:var(--color-accent);color:#fff;border-radius:10px;padding:1px 7px;font-size:.7rem;font-weight:600}.filter-pills{border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:5px;padding:8px 12px 10px;display:flex}.filter-pill{color:var(--color-accent);background:#1a5fa814;border:1px solid #1a5fa859;border-radius:20px;align-items:center;gap:3px;max-width:100%;padding:3px 4px 3px 9px;font-size:.72rem;display:inline-flex}.filter-pill__label{white-space:nowrap;text-overflow:ellipsis;max-width:190px;overflow:hidden}.filter-pill__clear{width:16px;height:16px;color:var(--color-accent);cursor:pointer;background:#1a5fa826;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:.85rem;line-height:1;transition:background .12s;display:inline-flex}.filter-pill__clear:hover{background:#1a5fa84d}.filter-panel__sections{flex:1;overflow-y:auto}.filter-panel__footer{border-top:1px solid var(--color-border);padding:12px 16px}.filter-panel__search-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius);width:100%;font-size:var(--font-size-sm);cursor:pointer;border:none;padding:10px;font-weight:600;transition:background .15s}.filter-panel__search-btn:hover{background:var(--color-accent-hover)}.filter-field{margin-bottom:10px}.filter-field__label{color:var(--color-text-secondary);margin-bottom:4px;font-size:.75rem;font-weight:500;display:block}.filter-panel__group+.filter-panel__group{margin-top:14px}.filter-panel__group-heading{color:var(--color-text-primary);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--color-border);margin-bottom:6px;padding:6px 0 4px;font-size:.7rem;font-weight:700}.widget-input,.widget-select,.widget-textarea{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-surface);outline:none;padding:6px 10px;font-family:inherit;transition:border-color .12s}.widget-textarea{resize:vertical;min-height:60px;line-height:1.35}.widget-input:focus,.widget-select:focus,.widget-textarea:focus{border-color:var(--color-accent)}.widget-range{gap:8px;display:flex}.widget-range-item{flex-direction:column;flex:1;gap:3px;display:flex}.widget-range-label{color:var(--color-text-secondary);font-size:.7rem}.widget-multi-choice{flex-direction:column;gap:5px;max-height:160px;display:flex;overflow-y:auto}.widget-checkbox-label{font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;align-items:center;gap:7px;display:flex}.widget-checkbox-label input[type=checkbox]{accent-color:var(--color-accent);cursor:pointer;width:14px;height:14px}.widget-toggle-group{border:1px solid var(--color-border);border-radius:var(--radius);display:flex;overflow:hidden}.widget-toggle-btn{background:var(--color-surface);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;border:none;flex:1;padding:6px 0;transition:background .12s,color .12s}.widget-toggle-btn+.widget-toggle-btn{border-left:1px solid var(--color-border)}.widget-toggle-btn:hover:not(.widget-toggle-btn--active){background:#f4f6f8}.widget-toggle-btn--active{background:var(--color-accent);color:#fff}.filter-panel__skeleton{flex-direction:column;gap:12px;padding:16px;display:flex}.filter-panel__skeleton-item{background:var(--color-border);border-radius:4px;height:14px;animation:1.2s ease-in-out infinite shimmer}.widget-tagselect{position:relative}.widget-tagselect__control{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;flex-wrap:wrap;align-items:center;gap:4px;min-height:32px;padding:4px 26px 4px 6px;transition:border-color .12s;display:flex}.widget-tagselect__control--open,.widget-tagselect__control:focus{border-color:var(--color-accent);outline:none}.widget-tagselect__placeholder{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding-left:4px}.widget-tagselect__tag{color:var(--color-accent);background:#e8f0fa;border:1px solid #c4d8ef;border-radius:4px;align-items:center;gap:4px;padding:2px 4px 2px 8px;font-size:.72rem;font-weight:600;line-height:1.4;display:inline-flex}.widget-tagselect__tag-x{color:var(--color-accent);cursor:pointer;background:0 0;border:none;border-radius:3px;padding:0 3px;font-size:.85rem;line-height:1}.widget-tagselect__tag-x:hover{background:#d3e3f6}.widget-tagselect__caret{color:var(--color-text-secondary);pointer-events:none;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.widget-tagselect__menu{z-index:1000;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);max-height:220px;position:fixed;overflow-y:auto;box-shadow:0 4px 14px #0000001f}.widget-tagselect__option{font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer;align-items:center;gap:8px;padding:7px 10px;display:flex}.widget-tagselect__option:hover{background:#f0f5fc}.widget-tagselect__option--selected{color:var(--color-accent);font-weight:600}.widget-tagselect__check{width:14px;color:var(--color-accent);font-size:.8rem}.patient-table-wrapper{flex-direction:column;height:100%;display:flex}.patient-table-container{flex:1;position:relative;overflow:auto}.patient-table-overlay{z-index:20;background:#ffffffb3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.patient-table{border-collapse:separate;border-spacing:0;white-space:nowrap;table-layout:fixed;font-size:.8125rem}.patient-table__section-row th{z-index:6;text-align:left;text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--color-border);border-right:6px solid var(--color-bg);padding:7px 14px;font-size:.72rem;font-weight:700;position:sticky;top:0}.patient-table__section-row th:last-child{border-right:none}.patient-table__section-header--pinned{z-index:8!important;position:sticky!important}.patient-table__section-header--collapsed{padding:9px 6px!important}.section-header-inner{justify-content:space-between;align-items:center;gap:6px;min-width:0;display:flex}.patient-table__section-header--collapsed .section-header-inner{gap:4px}.patient-table__section-header--collapsed .section-header-label{font-size:.65rem}.section-header-label{white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;overflow:hidden}.section-toggle{cursor:pointer;background:#ffffff80;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;padding:0;transition:background .12s;display:inline-flex}.section-toggle:hover{background:#fffffff2}.group-chevron{transition:transform .2s}.group-chevron--collapsed{transform:rotate(-90deg)}.patient-table__column-row th{z-index:5;background:var(--color-surface);text-align:left;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em;color:var(--color-text-secondary);border-bottom:2px solid var(--color-border);border-right:1px solid var(--color-border-light);padding:8px 10px;font-size:.7rem;font-weight:600;position:sticky;top:30px;overflow:hidden}.patient-table__column-label{-webkit-line-clamp:3;white-space:normal;overflow-wrap:break-word;-webkit-box-orient:vertical;line-height:1.3;display:-webkit-box;overflow:hidden}.patient-table__column-header--group-end{border-right:6px solid var(--color-bg)!important}.patient-table__column-header--pinned{background:var(--color-surface);z-index:7!important;position:sticky!important}.patient-table__column-header--collapsed{min-width:90px!important;padding:8px 6px!important}.row-num-header{vertical-align:middle;position:sticky;top:0;left:0;z-index:9!important;text-align:right!important;color:var(--color-text-secondary)!important;border-right:1px solid var(--color-border)!important;background:#eef2f7!important}.patient-table td{border-bottom:1px dashed var(--color-border-light);border-right:1px solid var(--color-border-light);color:var(--color-text-primary);vertical-align:top;background:var(--color-surface);padding:8px 10px;overflow:hidden}.cell-clamp{-webkit-line-clamp:2;line-clamp:2;white-space:normal;word-break:break-word;-webkit-box-orient:vertical;max-height:2.7em;line-height:1.35;display:-webkit-box;overflow:hidden}.cell--number .cell-clamp,.cell--number_range .cell-clamp{font-variant-numeric:tabular-nums}.patient-table td.cell--group-end{border-right:6px solid var(--color-bg)}.patient-table td.cell--pinned{z-index:3;background:var(--color-surface);position:sticky}.patient-table td.cell--collapsed{background:#fafbfc;min-width:90px!important;padding:10px 6px!important}.patient-table tbody tr:hover td,.patient-table tbody tr:hover td.cell--pinned{background:#f7f9fc}.patient-table tbody tr:hover td.row-num{background:#eef2f7}.row-num{color:var(--color-text-secondary);text-align:right;border-right:1px solid var(--color-border);font-size:.75rem;font-weight:500;position:sticky;left:0;z-index:4!important;background:#fafbfc!important;padding-left:6px!important;padding-right:10px!important}.patient-table-empty{text-align:center;color:var(--color-text-secondary);padding:48px 16px}.patient-table-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:24px 20px}.pagination{border-top:1px solid var(--color-border);justify-content:center;align-items:center;gap:4px;padding:12px 20px;display:flex}.pagination__btn{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);min-width:34px;height:34px;color:var(--color-text-primary);font-size:var(--font-size-sm);cursor:pointer;padding:0 10px;transition:background .12s,border-color .12s}.pagination__btn:hover:not(:disabled){border-color:var(--color-accent);color:var(--color-accent)}.pagination__btn--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.pagination__btn:disabled{opacity:.4;cursor:not-allowed}.pagination__ellipsis{color:var(--color-text-secondary);padding:0 4px}.export-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.export-modal{background:var(--color-surface);border-radius:10px;width:380px;padding:28px 32px 24px;box-shadow:0 8px 32px #0000002e}.export-modal__title{color:var(--color-text-primary);margin-bottom:16px;font-size:1rem;font-weight:700}.export-modal__status{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:12px}.export-progress-track{background:var(--color-border);border-radius:4px;height:8px;margin-bottom:8px;overflow:hidden}.export-progress-fill{background:var(--color-accent);border-radius:4px;min-width:4px;height:100%;transition:width .3s}.export-modal__counts{color:var(--color-text-secondary);justify-content:space-between;margin-bottom:20px;font-size:.75rem;display:flex}.export-modal__pct{color:var(--color-accent);font-weight:600}.export-modal__success{color:var(--color-text-primary);font-size:var(--font-size-sm);flex-direction:column;align-items:center;gap:10px;padding:12px 0 20px;display:flex}.export-modal__error{font-size:var(--font-size-sm);color:var(--color-danger);background:#fdf2f2;border-radius:4px;margin-bottom:20px;padding:10px 12px}.export-modal__actions{justify-content:flex-end;gap:8px;display:flex}.export-btn{border-radius:var(--radius);font-size:var(--font-size-sm);cursor:pointer;border:none;padding:8px 20px;font-weight:600;transition:background .12s}.export-btn--primary{background:var(--color-accent);color:#fff}.export-btn--primary:hover{background:var(--color-accent-hover)}.export-btn--cancel{background:var(--color-border);color:var(--color-text-primary)}.export-btn--cancel:hover{background:#cdd2d8}.login-page{background:linear-gradient(135deg,#1a5fa8 0%,#7a3eb1 100%);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:#fff;border-radius:12px;flex-direction:column;gap:14px;width:100%;max-width:380px;padding:32px 28px;display:flex;box-shadow:0 16px 40px #0000002e}.login-logo{-webkit-user-select:none;user-select:none;width:120px;height:auto;margin:0 auto 4px;display:block}.login-title{color:#1a1a1a;margin:0;font-size:22px;font-weight:700}.login-subtitle{color:#666;margin:0 0 12px;font-size:13px}.login-field{color:#333;flex-direction:column;gap:6px;font-size:13px;display:flex}.login-field span{font-weight:500}.login-field input{border:1px solid #d0d4dc;border-radius:6px;outline:none;padding:10px 12px;font-size:14px;transition:border-color .12s,box-shadow .12s}.login-field input:focus{border-color:#1a5fa8;box-shadow:0 0 0 3px #1a5fa826}.login-field input:disabled{color:#888;background:#f5f5f7}.login-error{color:#a3262e;background:#fdecec;border:1px solid #f5c2c2;border-radius:6px;padding:8px 12px;font-size:13px}.login-submit{color:#fff;cursor:pointer;background:#1a5fa8;border:none;border-radius:6px;margin-top:6px;padding:11px 14px;font-size:14px;font-weight:600;transition:background-color .12s}.login-submit:hover:not(:disabled){background:#154d8a}.login-submit:disabled{cursor:not-allowed;background:#9bb3cc}.app{background:var(--color-bg);flex-direction:column;height:100vh;display:flex}.app-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:14px;padding:8px 20px;display:flex}.app-logo{-webkit-user-select:none;user-select:none;width:auto;height:26px;display:block}.app-title{color:var(--color-accent);letter-spacing:-.3px;white-space:nowrap;margin:0;font-size:1.1rem;font-weight:700}.app-header-right{align-items:center;gap:10px;margin-left:auto;display:flex}.app-patient-count{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap;font-weight:700}.app-sort{align-items:center;gap:6px;display:flex}.app-sort__label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;font-size:.7rem;font-weight:600}.app-sort__select{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;outline:none;padding:5px 8px;font-size:.75rem}.app-sort__select:focus{border-color:var(--color-accent)}.app-sort__order{background:var(--color-surface);color:var(--color-accent);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;padding:4px 9px;font-size:.85rem;font-weight:700;line-height:1.2;transition:background .12s,border-color .12s}.app-sort__order:hover{border-color:var(--color-accent);background:#f4f7fb}.app-toolbar-btn{background:var(--color-surface);color:var(--color-accent);border:1px solid var(--color-accent);border-radius:var(--radius);cursor:pointer;white-space:nowrap;padding:5px 14px;font-size:.75rem;font-weight:600;transition:background .12s}.app-toolbar-btn:hover:not(:disabled){background:#f0f5fc}.app-toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.app-logout{border:1px solid var(--color-border);color:var(--color-text,#333);cursor:pointer;background:0 0;border-radius:6px;flex-shrink:0;padding:6px 12px;font-size:12px;font-weight:500;transition:background-color .12s,border-color .12s}.app-logout:hover{background:#f5f5f7;border-color:#b0b0b8}.app-body{flex:1;display:flex;position:relative;overflow:hidden}.app-sidebar{background:var(--color-surface);flex-direction:column;flex-shrink:0;width:320px;transition:width .16s;display:flex;overflow:hidden}.app-sidebar-scroll{flex:1;overflow-y:auto}.app-sidebar--collapsed{width:0}.app-sidebar-collapse{border:none;border-top:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary,#555);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;gap:6px;padding:9px 12px;font-size:13px;font-weight:500;transition:background-color .12s;display:flex}.app-sidebar-collapse:hover{background:#f5f5f7}.app-sidebar-collapse__icon{font-size:15px;line-height:1}.app-sidebar-expand{z-index:5;border:1px solid var(--color-border);background:var(--color-surface);width:26px;height:34px;color:var(--color-text-secondary,#555);cursor:pointer;box-shadow:var(--shadow-sm);border-left:none;border-radius:0 8px 8px 0;justify-content:center;align-items:center;padding:0;font-size:16px;transition:background-color .12s;display:flex;position:absolute;bottom:16px;left:0}.app-sidebar-expand:hover{background:#f5f5f7}.app-content{background:var(--color-surface);border-left:1px solid var(--color-border);flex-direction:column;flex:1;display:flex;overflow:hidden}.app-error{color:var(--color-danger);font-size:var(--font-size-sm);padding:16px 20px}@media (width<=1500px){.app-header{gap:10px}.app-header-right{gap:8px}.app-sort__label{display:none}}@media (width<=1320px){.app-title{display:none}.cancer-selector{margin-left:0;padding-left:10px}.cancer-selector__dropdown{width:190px}.app-patient-count{font-size:.72rem}}@media (width<=1140px){.cancer-selector__label{display:none}.app-toolbar-btn,.app-logout{padding:5px 9px}}@media (width<=768px){.app-body{flex-direction:column}.app-sidebar{width:100%;max-height:50vh}.app-sidebar--collapsed{width:100%;max-height:0}.app-content{border-left:none;border-right:none;border-radius:0;margin:0}}
