:root{--color-primary: #3b82f6;--color-primary-dark: #2563eb;--color-primary-light: #eff6ff;--color-accent-teal: #0d9488;--color-accent-teal-light: #ccfbf1;--color-accent-teal-dark: #0f766e;--color-background: #f7f8fa;--color-surface: #ffffff;--color-border: #dfe1e6;--color-border-light: #ebecf0;--color-text-primary: #172b4d;--color-text-secondary: #5e6c84;--color-text-tertiary: #6b7280;--color-text-inverse: #ffffff;--color-heading: #1a1a2e;--color-text-body: #374151;--color-text-light: #9ca3af;--color-border-default: #e5e7eb;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow-card: 0 2px 8px rgba(0,0,0,.08), 0 8px 24px rgba(0,0,0,.06);--shadow-card-light: 0 4px 12px rgba(0, 0, 0, .1);--space-sm: 8px;--space-lg: 24px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--font-family: "IBM Plex Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-family-mono: "IBM Plex Mono", "SF Mono", Monaco, monospace;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-family);background:var(--color-background);color:var(--color-text-primary);line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh}*{scrollbar-width:thin;scrollbar-color:#c1c8d4 var(--color-background)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:#c1c8d4;border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:#a0aab8}img{max-width:100%;height:auto}*:focus-visible{outline:3px solid var(--color-primary);outline-offset:2px}button{font-family:inherit;cursor:pointer;border:none;background:none;font-size:inherit}.container{width:100%;max-width:1440px;margin:0 auto;padding:0 var(--space-lg)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:10px 20px;font-size:13px;font-weight:500;border-radius:5px;border:none;transition:background .1s ease;text-decoration:none;white-space:nowrap;cursor:pointer}.btn:disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark)}.btn-primary:active:not(:disabled){background:#1d4ed8}.btn-secondary{background:var(--color-surface);color:var(--color-text-body);border:1px solid var(--color-border-default);box-shadow:0 1px 2px #0000000a}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db;color:var(--color-heading)}.btn-ghost{background:var(--color-primary-light);color:#1e40af;border:none}.btn-ghost:hover:not(:disabled){background:#dbeafe}.btn-ghost:active:not(:disabled){background:#bfdbfe}.btn-sm{padding:6px 12px;font-size:12px;height:32px}.btn-lg{padding:14px 28px;font-size:15px}.hidden{display:none!important}@keyframes spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}:root{--d-bg-subtle: #f9fafb;--d-bg-muted: #f3f4f6;--d-text-heading: #111827;--d-text-secondary: #4b5563}.splash-screen{position:fixed;inset:0;background:var(--color-background);display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .2s ease}.splash-screen.hidden{opacity:0;pointer-events:none}.splash-brand{display:flex;flex-direction:column;align-items:center;gap:20px}.splash-logo{width:96px;height:96px;object-fit:contain}.splash-spinner{width:36px;height:36px;border:3px solid var(--color-border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.header{background:var(--color-surface);border-bottom:1px solid var(--color-border-default);position:sticky;top:0;z-index:100}.header>.container{max-width:100%;padding:0 clamp(8px,2vw,24px)}#dashboardView.patient-view .header{border-bottom:none}#dashboardView.patient-view .main-content{background:linear-gradient(180deg,#f0f4f8 0%,var(--color-background) 280px)}.header-content{display:flex;justify-content:space-between;align-items:center;padding:10px 0;gap:var(--space-lg)}.header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:0;overflow:hidden}.header-logo-img{height:32px;width:auto;max-width:120px;object-fit:contain;border-radius:0}.header-title{font-size:16px;font-weight:600;color:var(--color-heading);letter-spacing:-.01em;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-brand-text{display:flex;flex-direction:column;min-width:0;overflow:hidden}.user-info{display:flex;align-items:center;gap:16px}.role-toggle{display:flex;align-items:center;gap:6px;background:var(--d-bg-muted);padding:5px;border-radius:var(--radius-md)}.role-label{font-size:10px;color:var(--color-text-tertiary);font-weight:600;padding-left:10px}.role-btn{padding:8px 14px;border:none;background:transparent;color:var(--color-text-tertiary);font-size:12px;font-weight:600;border-radius:7px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.role-btn svg{width:14px;height:14px;flex-shrink:0}.role-btn:hover{color:var(--color-text-body);background:#fff9}.role-btn.active[data-role=patient]{background:#dbeafe;color:#1d4ed8}.role-btn.active[data-role=provider]{background:#d1fae5;color:#047857}.role-indicator{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:20px;font-size:10px;font-weight:600;margin-left:8px}.role-indicator.patient{background:#dbeafe;color:#1d4ed8}.role-indicator.provider{background:#d1fae5;color:#047857}.role-indicator-mobile{display:none}.avatar{width:40px;height:40px;border-radius:50%;object-fit:cover}.user-details{display:none}.user-name{font-weight:600;color:var(--color-heading);font-size:13px}.user-email{font-size:11px;color:#8893a7;margin-top:1px;font-family:var(--font-family-mono)}.profile-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:13px;font-weight:600;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background var(--transition-fast);padding:0;line-height:1;letter-spacing:.02em}.profile-avatar:hover{background:var(--color-primary-dark)}.profile-avatar:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.profile-menu{position:fixed;background:var(--color-surface);border-radius:10px;box-shadow:0 4px 20px #0000001f;border:1px solid var(--color-border-default);min-width:240px;z-index:200;opacity:0;visibility:hidden;transform:translateY(-4px);transition:opacity var(--transition-fast),transform var(--transition-fast),visibility var(--transition-fast);pointer-events:none;overflow:hidden}.profile-menu.open{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}.profile-menu-info{padding:16px 20px}.profile-menu-name{font-size:15px;font-weight:600;color:var(--color-heading)}.profile-menu-email{font-size:12px;color:var(--color-text-tertiary);margin-top:2px;word-break:break-all}.profile-menu-mrn{font-size:12px;color:var(--color-text-light);margin-top:2px}.profile-menu-divider{height:1px;background:var(--d-bg-muted)}.profile-menu-item{display:block;width:100%;padding:12px 20px;border:none;background:none;font-size:14px;font-weight:500;color:var(--color-text-body);text-align:left;cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast)}.profile-menu-item:hover{background:#fef2f2;color:#dc2626}.profile-menu-links{padding:4px 20px 8px;display:flex;flex-wrap:wrap;gap:0}.profile-menu-link{display:block;padding:6px 0;font-size:13px;color:var(--color-text-tertiary);text-decoration:none;width:100%}.profile-menu-link:hover{color:var(--color-primary)}.profile-menu-backdrop{position:fixed;inset:0;background:#0006;z-index:199;opacity:0;visibility:hidden;transition:opacity var(--transition-fast),visibility var(--transition-fast)}.profile-menu-backdrop.open{opacity:1;visibility:visible}.main-content{padding:28px 0;min-height:calc(100vh - 200px);background:var(--color-background)}#dashboardView:not(.patient-view) .welcome-section{background:linear-gradient(135deg,#1e3a5f,#1a5276 40%,#0e7c6b);border-radius:14px;padding:36px 32px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:var(--shadow-card)}.welcome-section:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 20%,rgba(255,255,255,.08) 0%,transparent 50%),radial-gradient(circle at 15% 80%,rgba(255,255,255,.05) 0%,transparent 40%);pointer-events:none}.welcome-left{flex:1;min-width:0;position:relative}.welcome-brand{display:flex;flex-direction:column;align-items:flex-end;gap:6px;position:relative;flex-shrink:0}.welcome-brand-powered{font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;color:#ffffff8c}.welcome-brand-name{font-size:15px;font-weight:600;color:#ffffffe0;line-height:1.3;text-align:right}#dashboardView .welcome-section h1{color:#fff;position:relative}#dashboardView .subtitle{color:#ffffffbf}#dashboardView:not(.patient-view) .subtitle{margin-top:8px;position:relative}.welcome-section{margin:0 0 28px}.welcome-section h1{font-size:clamp(24px,2.5vw + 14px,36px);font-weight:700;color:var(--color-heading);margin:0;line-height:1.15;letter-spacing:-.03em;overflow-wrap:break-word;word-break:break-word}.subtitle{font-size:clamp(13px,1vw + 8px,16px);color:var(--color-text-tertiary);font-weight:400;margin-top:4px;line-height:1.4}.welcome-patient-info{font-size:12px;color:#ffffff80;margin-top:6px;font-weight:500;letter-spacing:.02em}.study-count{font-size:13px;color:var(--color-text-tertiary);margin-top:4px}.study-count-num,.study-count-years{font-family:var(--font-family-mono);font-weight:600;letter-spacing:-.02em}#dashboardView.patient-view .welcome-section{background:linear-gradient(135deg,#1e3a5f,#1a5276 40%,#0e7c6b);border-radius:14px;padding:32px 36px;color:#fff;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:space-between;gap:24px;box-shadow:var(--shadow-card)}#dashboardView.patient-view .subtitle-time{font-weight:500;color:#fffffff2}#dashboardView.patient-view .study-count{color:#ffffffa6}#dashboardView.patient-view .study-count-num,#dashboardView.patient-view .study-count-years{color:#ffffffd9}.welcome-context{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#ffffff80;margin-bottom:4px}#dashboardView:not(.patient-view) .welcome-context{position:relative}#dashboardView.patient-view .welcome-row{display:flex;flex-direction:column;gap:2px;position:relative}.patient-hint{display:none}#dashboardView.patient-view .patient-hint{display:flex;align-items:flex-start;gap:14px;max-width:820px;margin:0 auto 12px;padding:16px 20px;background:var(--color-primary-light);border:1px solid rgba(59,130,246,.1);border-radius:var(--radius-lg);font-size:13px;color:var(--color-text-secondary);line-height:1.5;box-shadow:var(--shadow-card)}#dashboardView.patient-view .patient-hint .hint-icon{flex-shrink:0;width:40px;height:40px;background:#ffffffb3;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--color-primary)}#dashboardView.patient-view .patient-hint .hint-text{display:flex;flex-direction:column;gap:2px}#dashboardView.patient-view .patient-hint .hint-text strong{font-size:14px;font-weight:600;color:var(--color-heading)}#dashboardView.patient-view .patient-hint .hint-text span{font-size:13px;color:var(--color-text-tertiary)}.info-banner{background:var(--color-primary-light);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:16px;display:flex;gap:14px;align-items:center;font-size:13px;color:var(--color-text-body);box-shadow:var(--shadow-card)}.info-icon{font-size:18px;flex-shrink:0;line-height:1;opacity:.9}.info-banner strong{color:var(--color-heading)}.info-banner a{color:var(--color-primary);text-decoration:none;font-weight:600;transition:color var(--transition-fast)}.info-banner a:hover{color:var(--color-primary-dark);text-decoration:underline}.filter-section.patient-mode{display:none}.filter-section{background:var(--color-surface);border-radius:10px;box-shadow:var(--shadow-card);border:1px solid #e8eaee;padding:24px;margin-bottom:24px}.filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.filter-header h3{font-size:14px;font-weight:600;color:var(--color-heading);display:flex;align-items:center;gap:8px}.filter-header h3:before{content:"";width:3px;height:14px;background:var(--color-primary);border-radius:2px}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:16px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-group label{font-size:11px;font-weight:600;color:var(--color-text-tertiary)}.filter-input,.filter-select{padding:10px 12px;border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:13px;color:var(--color-heading);background:#fafbfc;transition:all var(--transition-fast);font-family:inherit}.filter-input:hover,.filter-select:hover{border-color:#d1d5db;background:#fff}.filter-input:focus,.filter-select:focus{outline:none;border-color:var(--color-primary);background:#fff;box-shadow:0 0 0 3px #3b82f626,0 0 0 1px var(--color-primary)}.filter-input::placeholder{color:var(--color-text-light)}:is(.filter-group,.custom-date-range).input-warning .filter-input{border-color:#f59e0b;background:#fffbeb}.filter-group.input-warning .filter-input:focus{border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b26}:is(.filter-group,.custom-date-range).input-warning:after{content:attr(data-warning);display:block;font-size:11px;color:#b45309;margin-top:4px;font-weight:500}.custom-date-range.input-warning:after{grid-column:span 2}.custom-date-range{display:grid;grid-template-columns:1fr 1fr;gap:16px;grid-column:span 2}.filter-actions{display:flex;gap:12px;padding-top:16px;border-top:1px solid var(--d-bg-muted);align-items:center;flex-wrap:wrap}.filter-actions-left{display:flex;gap:10px;flex:1}.filter-actions-right{display:flex;gap:10px;align-items:center}.sort-label{font-size:12px;color:var(--color-text-tertiary);font-weight:500}.active-filters{display:flex;flex-wrap:wrap;gap:8px;padding-top:12px}.active-filters.hidden{display:none}.filter-chip{display:inline-flex;align-items:center;gap:6px;background:var(--color-primary-light);border:1px solid #bfdbfe;color:#1e40af;border-radius:16px;padding:4px 10px;font-size:12px;font-weight:500;line-height:1}.filter-chip .chip-remove{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border:none;background:none;color:#1e40af;cursor:pointer;padding:0;border-radius:50%;font-size:14px;line-height:1}.filter-chip .chip-remove:hover{background:#bfdbfe;color:#1e3a8a}.combobox-wrapper{position:relative}.combobox-wrapper .filter-input{width:100%}.combobox-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--color-surface);border:1px solid var(--color-border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-card-light);z-index:100;margin-top:4px}.combobox-dropdown.hidden{display:none}.combobox-option{padding:8px 12px;cursor:pointer;font-size:13px;color:var(--color-text-body)}.combobox-option:hover,.combobox-option.highlighted{background:#f5f7fa}.combobox-option.selected{background:var(--color-primary-light);color:var(--color-primary)}.studies-container{background:var(--color-surface);border-radius:10px;box-shadow:var(--shadow-card);border:1px solid #e8eaee;overflow:hidden;position:relative;width:100%;max-width:100%}.table-wrapper{width:100%;max-width:100%;position:relative}table{width:100%;max-width:100%;border-collapse:collapse;table-layout:fixed}th:first-child,td:first-child{padding-left:24px}th:last-child,td:last-child{padding-right:24px}thead{background:var(--color-surface);border-bottom:1px solid #d4d9e1}.th-patient-name{width:16%}.th-description{width:20%}.th-patient-id{width:9%}.th-date{width:10%}.th-images{width:5%}.th-institution{width:18%}.th-modality{width:8%}.th-view,.th-download{width:7%}.th-view,.th-download,.cell-view,.cell-download{text-align:center;overflow:visible}.study-row .btn{height:30px;padding:0 12px;font-size:12px}.study-row .btn .btn-icon{width:22px;height:22px;min-width:22px;min-height:22px;flex-shrink:0}#dashboardView:not(.patient-view) .cell-view .btn,#dashboardView:not(.patient-view) .cell-download .btn{background:none;border:none;box-shadow:none;padding:6px;min-width:0;color:var(--color-text-secondary);transition:color var(--transition-fast)}#dashboardView:not(.patient-view) .cell-view .btn{color:var(--color-primary)}#dashboardView:not(.patient-view) .cell-view .btn:hover{color:var(--color-primary-dark)}#dashboardView:not(.patient-view) .cell-download .btn:hover{color:var(--color-text-body)}#dashboardView:not(.patient-view) .cell-download .btn .btn-label{display:none}.action-buttons .btn{white-space:nowrap}th{text-align:left;padding:12px;font-weight:600;font-size:11px;color:var(--color-text-tertiary);white-space:nowrap}td{padding:14px 12px;border-bottom:1px solid var(--d-bg-muted);font-size:13px;color:var(--color-text-body)}.study-row>td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#studiesList tr:hover{background:var(--d-bg-subtle)}.loading-row:hover{background:transparent}#studiesList tr:last-child td{border-bottom:none}.cell-patient-name{font-weight:600;white-space:nowrap}.cell-description{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.cell-patient-id{font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:0}.study-row>.cell-modality{font-weight:600;font-size:11px;letter-spacing:.03em;overflow:visible;text-overflow:clip;white-space:nowrap;min-width:min-content}.cell-modality span{display:inline-block;border-radius:var(--radius-sm);padding:2px 7px;font-size:11px;line-height:1.4;margin:1px 2px;background:#f1f5f9;border:1px solid #e2e8f0;color:var(--color-text-secondary)}.cell-modality span[data-mod=CT]{background:#dbeafe;border-color:#93c5fd;color:#1e3a8a}.cell-modality span[data-mod=MR]{background:#ede9fe;border-color:#c4b5fd;color:#4c1d95}.cell-modality span[data-mod=US]{background:#ccfbf1;border-color:#5eead4;color:#134e4a}.cell-modality span[data-mod=PT]{background:#fef3c7;border-color:#fcd34d;color:#78350f}.cell-modality span[data-mod=NM]{background:#ffe4e6;border-color:#fda4af;color:#881337}.cell-modality span[data-mod=CR],.cell-modality span[data-mod=DX]{background:#e2e8f0;border-color:#94a3b8;color:#334155}.cell-modality span[data-mod=XA]{background:#fce7f3;border-color:#f9a8d4;color:#831843}.cell-modality span[data-mod=MG]{background:#e0e7ff;border-color:#a5b4fc;color:#312e81}.cell-modality span[data-mod=OT]{background:var(--d-bg-muted);border-color:#d1d5db;color:var(--d-text-secondary)}.cell-modality span[data-mod=RF]{background:#d1fae5;border-color:#6ee7b7;color:#064e3b}.cell-date{white-space:nowrap;min-width:min-content;color:var(--color-text-body)}.date-time,.date-friendly,.th-referring,.cell-referring{display:none}.cell-images{white-space:nowrap;min-width:min-content;color:var(--color-text-tertiary);font-variant-numeric:tabular-nums}.cell-institution{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text-tertiary);font-size:12px;min-width:0}.cell-actions{white-space:nowrap}.action-buttons{display:flex;gap:6px;flex-wrap:nowrap;justify-content:center}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:24px;padding:14px 24px;border-top:1px solid #d4d9e1;background:var(--color-surface)}.pagination-info{color:var(--color-text-tertiary);font-size:13px;font-weight:500}.empty-state,.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 24px;color:var(--color-text-tertiary)}.loading-row .loading-cell{padding:0;border:none}.loading-row .loading-cell .loading{position:absolute;inset:45px 0 0;min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-surface);z-index:10}.loading-state{display:flex;align-items:center;justify-content:center;gap:12px;padding:48px 24px}.loading-spinner{width:20px;height:20px;border:2px solid var(--color-border-default);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}.loading-text{font-size:14px;color:var(--color-text-tertiary)}.empty-state-icon{font-size:40px;margin-bottom:16px;opacity:.5}.empty-state-icon-svg{margin-bottom:16px;opacity:.7}.empty-state h3{font-size:16px;font-weight:600;color:var(--color-heading);margin-bottom:8px}.empty-state p{font-size:14px;color:var(--color-text-tertiary);max-width:400px;margin:0 auto;line-height:1.5}.patient-support-card{display:none}#dashboardView.patient-view .patient-support-card{display:flex;align-items:flex-start;gap:14px;max-width:820px;margin:28px auto 0;padding:20px 24px;background:linear-gradient(135deg,#fefce8,#fff7ed);border:1px solid rgba(217,119,6,.12);border-radius:var(--radius-lg);font-size:13px;line-height:1.5;box-shadow:var(--shadow-card)}#dashboardView.patient-view .patient-support-card .support-icon{flex-shrink:0;width:44px;height:44px;background:#ffffffb3;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#d97706}#dashboardView.patient-view .patient-support-card .support-text{display:flex;flex-direction:column;gap:3px}#dashboardView.patient-view .patient-support-card .support-text strong{font-size:14px;font-weight:600;color:var(--color-heading)}#dashboardView.patient-view .patient-support-card .support-text span{color:var(--color-text-tertiary)}#dashboardView.patient-view .patient-support-card .support-text a{color:#d97706;font-weight:500;text-decoration:none}#dashboardView.patient-view .patient-support-card .support-text a:hover{text-decoration:underline}.empty-state-patient{background:#f0fdfa;border:1px dashed var(--color-accent-teal);border-radius:var(--radius-lg);padding:48px 32px;max-width:820px;margin:0 auto}.empty-state-patient .empty-state-icon-svg{opacity:.8}.empty-state-patient h3{color:var(--color-accent-teal-dark)}.empty-state-contact{margin-top:16px;font-size:13px;color:var(--color-text-light);padding-top:16px;border-top:1px solid var(--color-accent-teal-light)}.empty-state-contact a{color:var(--color-primary);text-decoration:none;font-weight:600}.empty-state-contact a:hover{text-decoration:underline}.spinner{border:2px solid var(--color-border-default);border-top:2px solid var(--color-primary);border-radius:50%;width:32px;height:32px;animation:spin .7s linear infinite;margin:0 auto 16px}.error-box{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid rgba(239,68,68,.2);color:#dc2626;padding:16px 20px;border-radius:10px;margin:20px}.error-box h3{margin-bottom:8px;font-size:14px;font-weight:600}.error-box p{margin:6px 0;font-size:13px;line-height:1.5;color:#b91c1c}@media(hover:hover){.study-row:hover{background:#f5f7fa;transition:background var(--transition-fast)}}.study-expansion-row{background:#f8fafc}.study-expansion-row>td{padding:0;border-bottom:1px solid var(--color-border-default);overflow:hidden}.study-expansion-panel{animation:fadeIn .15s ease-out;contain:layout style}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes cardEnter{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.expansion-content{padding:20px 24px;display:flex;flex-direction:column;gap:24px}.expansion-section{background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border-default);padding:16px 20px}.expansion-section-title{font-size:11px;font-weight:600;color:var(--color-text-tertiary);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--d-bg-muted)}.study-details-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px 24px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:11px;font-weight:500;color:var(--color-text-light)}.detail-value{font-size:13px;color:var(--color-heading);font-weight:500;display:flex;align-items:center;gap:6px}.detail-value.uid-value{font-family:var(--font-family-mono);font-size:12px;color:var(--color-text-tertiary)}.series-table-wrapper{overflow-x:auto;max-width:100%}.series-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.series-table thead{background:transparent;border-bottom:none}.series-table thead th{text-align:left;padding:0 20px 10px 0;font-weight:500;font-size:11px;color:var(--color-text-light);text-transform:none;letter-spacing:0;border-bottom:1px solid var(--color-border-default);white-space:nowrap}.series-table thead th:last-child{padding-right:0}.series-table td{padding:10px 20px 10px 0;color:var(--color-text-body);vertical-align:middle;border-bottom:1px solid var(--d-bg-muted)}.series-table td:last-child{padding-right:0}.series-table tbody tr:last-child td{border-bottom:none}.series-row{transition:background-color var(--transition-fast)}.series-row:hover td{background:#f8fafc}.series-row:first-child td{padding-top:14px}.series-number{font-weight:600;color:var(--color-heading);font-variant-numeric:tabular-nums}.series-description{color:var(--color-heading);font-weight:500}.series-modality{color:var(--color-text-tertiary);font-size:12px}.series-instances{color:var(--color-text-tertiary);font-variant-numeric:tabular-nums}.series-uid{display:inline-flex;align-items:center;gap:6px}.uid-truncated{font-family:var(--font-family-mono);font-size:11px;color:#b0b7c3;letter-spacing:-.01em}.priors-card-list{display:flex;flex-direction:column;gap:8px}.prior-card{padding:10px 14px;border-radius:6px;border:1px solid #f0f0f0;background:#fafbfc;transition:background var(--transition-fast)}.prior-card:hover{background:#f0f7ff}.prior-card-info{display:flex;flex-direction:column;gap:2px}.prior-card-date{font-size:12px;font-weight:600;color:var(--color-heading)}.prior-card-description{font-size:13px;color:var(--color-text-secondary)}.prior-card-meta{font-size:11px;color:var(--color-text-tertiary)}.prior-card-actions{display:flex;align-items:center;gap:6px;margin-top:8px}.prior-card-actions .btn{background:none;border:none;box-shadow:none;padding:4px 0;min-width:0;font-size:13px;font-weight:600;color:#1a5276;cursor:pointer;transition:color var(--transition-fast)}@media(hover:hover){.prior-card-actions .btn:hover{background:none;color:#0e3a5e;text-decoration:underline}}.prior-card-actions .download-prior-btn .btn-label{display:none}.expansion-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:24px;color:var(--color-text-tertiary);font-size:13px}.expansion-loading .loading-spinner{width:16px;height:16px}.expansion-error{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px;background:#fef2f2;border-radius:6px;color:#dc2626;font-size:13px}.expansion-empty{text-align:center;padding:24px;color:var(--color-text-light);font-size:13px}.login-page{display:flex;flex-direction:column;min-height:100vh;background:var(--color-background)}.login-content{flex:1;display:flex;align-items:center;justify-content:center;padding:clamp(12px,5vw,48px) clamp(6px,3vw,24px)}.welcome-box{max-width:480px;text-align:center}.welcome-logo{display:inline-flex;align-items:center;justify-content:center;margin-bottom:clamp(16px,4vw,28px)}.welcome-logo-img{max-width:100%;max-height:clamp(80px,20vw,160px);width:auto;height:auto;object-fit:contain}.welcome-title{font-size:clamp(18px,4.5vw,30px);color:var(--color-text-primary);margin-bottom:12px;font-weight:700;letter-spacing:-.03em;line-height:1.2}.welcome-subtitle{font-size:clamp(11px,2.2vw,15px);color:var(--color-text-secondary);margin-bottom:clamp(14px,4vw,28px);line-height:1.6}.terms-box{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:clamp(10px,2.5vw,20px) clamp(10px,3vw,24px);margin-bottom:clamp(14px,4vw,28px);text-align:left;box-shadow:var(--shadow-sm)}#agreeBtn{width:100%;border-radius:var(--radius-md);box-shadow:0 2px 8px #3b82f64d}.terms-box h3{font-size:clamp(11px,2.2vw,14px);color:var(--color-text-primary);margin-bottom:12px;font-weight:600}.terms-box p{font-size:clamp(10px,2vw,13px);color:var(--color-text-secondary);line-height:1.6;margin-bottom:14px}.terms-links{display:flex;gap:clamp(8px,2vw,16px);flex-wrap:wrap}.terms-link{color:var(--color-primary);text-decoration:none;font-size:clamp(10px,2vw,13px);font-weight:600;transition:color var(--transition-fast)}.terms-link:hover{color:var(--color-primary-dark);text-decoration:underline}.footer{background:var(--color-background);border-top:1px solid var(--color-border);padding:20px 0;margin-top:auto}.footer-content{text-align:center}.footer-links{display:flex;justify-content:center;gap:28px;margin-bottom:12px;flex-wrap:wrap}.footer-link{color:var(--color-text-secondary);text-decoration:none;font-size:13px;font-weight:500;transition:color var(--transition-fast)}.footer-link:hover{color:var(--color-primary)}.footer-text{color:var(--color-text-tertiary);font-size:12px;margin-top:6px}.footer-brand{font-weight:600;color:var(--color-text-secondary)}#dashboardView.patient-view .footer{border-top:none;padding:24px 0}#dashboardView.patient-view .footer-links{gap:8px}#dashboardView.patient-view .footer-link{position:relative}#dashboardView.patient-view .footer-link+.footer-link:before{content:"\b7";color:var(--color-border-default);font-size:18px;margin-right:8px;vertical-align:middle}.modal-overlay{position:fixed;inset:0;background:#1a1a2e99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease-out}.modal-content{background:var(--color-surface);border-radius:var(--radius-md);max-width:520px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #0003;animation:modalSlideUp .25s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal-header-clean{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;border-bottom:1px solid var(--color-border-default);background:var(--d-bg-subtle)}.modal-header-error{background:#fef2f2;border-bottom-color:#fecaca}.modal-title-clean{margin:0;font-size:17px;font-weight:600;color:var(--d-text-heading);letter-spacing:-.01em}.modal-close-btn{background:none;border:none;font-size:24px;color:var(--color-text-light);cursor:pointer;padding:0;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.modal-close-btn:hover{color:var(--d-text-secondary);background:#0000000d}.modal-body-clean{padding:24px;overflow-y:auto;color:var(--color-text-body);font-size:14px;line-height:1.6}.legal-content section{margin-bottom:20px}.legal-content section:last-child{margin-bottom:0}.legal-content h3{font-size:14px;font-weight:600;color:var(--d-text-heading);margin:0 0 8px}.legal-content p{margin:0;color:var(--d-text-secondary);font-size:13px}.modal-warning-section{background:#fffbeb;border:1px solid #fcd34d;border-radius:6px;padding:14px 16px;margin-top:20px}.modal-warning-section h3{color:#92400e}.modal-warning-section p{color:#a16207}.support-content .support-intro{margin:0 0 20px;font-size:14px;color:var(--color-text-body)}.support-content section{margin-bottom:20px}.support-content section:last-child{margin-bottom:0}.support-content h3{font-size:13px;font-weight:600;color:var(--d-text-heading);margin:0 0 10px;text-transform:uppercase;letter-spacing:.02em}.support-content p{margin:0;color:var(--d-text-secondary);font-size:13px}.contact-info{background:var(--d-bg-subtle);border:1px solid var(--color-border-default);border-radius:6px;padding:12px 14px}.contact-row{display:flex;padding:6px 0}.contact-row:first-child{padding-top:0}.contact-row:last-child{padding-bottom:0}.contact-label{width:90px;flex-shrink:0;font-weight:500;color:var(--color-text-tertiary);font-size:13px}.contact-value{color:var(--d-text-heading);font-size:13px}.contact-value a{color:#2563eb;text-decoration:none}.contact-value a:hover{text-decoration:underline}.modal-error-content p{margin:0;color:#991b1b;font-size:14px}.modal-footer-clean{padding:16px 24px;border-top:1px solid var(--color-border-default);background:var(--d-bg-subtle);display:flex;justify-content:flex-end}.modal-footer-clean .btn{min-width:80px}.dashboard-wrapper{display:flex;flex-direction:column;min-height:100vh}.dashboard-main{flex:1}@media(max-width:768px){.container{padding:0 clamp(0px,calc(5.7vw - 20px),16px)}.header-content{padding:12px 0}.header-title{font-size:15px}.role-toggle{padding:3px}.role-label{display:none}.role-btn{padding:6px 10px;font-size:11px}.role-btn svg{width:12px;height:12px}.header-logo-img{height:36px}.welcome-logo-img{max-width:200px;max-height:80px}.filter-section{padding:16px}.filter-row{grid-template-columns:1fr}.custom-date-range{grid-column:span 1}.filter-actions{flex-direction:column;gap:10px}.filter-actions-left,.filter-actions-right{width:100%}.filter-actions-left{flex-direction:column}th,td{padding:12px 14px;font-size:12px}.action-buttons{flex-direction:column}.action-buttons .btn{width:100%}.info-banner{padding:12px 14px;font-size:12px}.study-details-grid{grid-template-columns:1fr}.expansion-content{padding:16px}.series-table-wrapper{margin:0 -16px;padding:0}.series-table th,.series-table td{padding:8px 10px;font-size:12px}.series-description{max-width:120px}}@media(min-width:577px)and (max-width:768px){.filter-row{grid-template-columns:repeat(2,1fr)}.custom-date-range{grid-column:span 2}.cell-institution{max-width:100px}}@media print{.header,.filter-section,.info-banner,.footer,.action-buttons{display:none!important}}@media(hover:none),(pointer:coarse){.th-download,.cell-download,.th-images,.cell-images{display:none!important}#dashboardView.patient-view tr.study-row{grid-template-areas:"date      view" "desc      view" "inst      view" "referring view";grid-template-columns:1fr auto}.th-patient-name{width:18%}.th-description{width:22%}.th-patient-id{width:10%}.th-date{width:12%}.th-institution{width:18%}.th-modality,.th-view{width:10%}.btn{min-height:44px;min-width:44px}.study-row .btn{min-height:34px;min-width:0}.filter-input,.filter-select{min-height:44px;padding:12px 14px;font-size:16px}.study-row td{padding:14px 16px}.pagination-controls button{min-width:44px;min-height:44px}.study-row{cursor:pointer}.footer-link,.terms-link{padding:8px 12px;display:inline-block}.modal-overlay{padding:12px}.modal-content{max-height:90vh}.modal-header-clean{padding:14px 18px}.modal-title-clean{font-size:16px}.modal-close-btn{width:36px;height:36px;font-size:28px}.modal-body-clean{padding:18px;font-size:14px}.legal-content h3{font-size:14px}.legal-content p{font-size:13px}.modal-footer-clean{padding:12px 18px}.modal-footer-clean .btn{min-height:44px;font-size:15px}.detail-item{min-height:44px;padding:8px 0}.detail-value{min-height:28px}.series-table td{padding:12px 16px 12px 0}.series-row:first-child td{padding-top:16px}}@media(min-width:577px){#dashboardView.patient-view .studies-container table{display:block}#dashboardView.patient-view .studies-container thead{display:none}#dashboardView.patient-view .studies-container tbody{display:flex;flex-direction:column;gap:8px;max-width:820px;margin:0 auto;padding:0 0 24px}#dashboardView.patient-view .filter-section{display:none}#dashboardView.patient-view .pagination-controls{max-width:820px;margin:0 auto;border-top:none;padding-top:0}#dashboardView.patient-view .welcome-section{max-width:820px;margin:0 auto 28px}#dashboardView.patient-view .welcome-row h1{margin:0}#dashboardView.patient-view .study-count{font-size:14px}#dashboardView.patient-view tr.study-row{display:grid;grid-template-areas:"date      date      date" "desc      desc      desc" "inst      inst      inst" "referring referring referring" "divider   divider   divider" "view      download  .";grid-template-columns:auto auto 1fr;gap:4px 12px;background:var(--color-surface);border-radius:2px 10px 10px 2px;padding:14px 18px 0 16px;box-shadow:var(--shadow-card);border:1px solid #e8e6e1;border-left:3px solid #6bb5a8;cursor:default;transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease;animation:cardEnter .3s ease both;animation-delay:calc(var(--card-index, 0) * 40ms)}#dashboardView.patient-view tr.study-row>td{display:block;padding:0;border:none}#dashboardView.patient-view tr.study-row:after{content:"";grid-area:divider;border-top:1px solid #e5e5e2;margin-top:10px}#dashboardView.patient-view tr.study-row .cell-date{grid-area:date;font-size:13px;font-weight:600;color:#1f2937;letter-spacing:.01em}#dashboardView.patient-view tr.study-row .cell-date .date-only{display:none}#dashboardView.patient-view tr.study-row .cell-date .date-friendly{display:inline}#dashboardView.patient-view tr.study-row .cell-description{grid-area:desc;font-size:15px;font-weight:600;color:var(--color-text-body);line-height:1.3;white-space:normal;word-wrap:break-word;overflow-wrap:break-word}#dashboardView.patient-view tr.study-row .cell-modality{display:none}#dashboardView.patient-view tr.study-row .cell-institution{grid-area:inst;font-size:12px;font-weight:500;color:var(--color-text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.01em}#dashboardView.patient-view tr.study-row .cell-institution[data-empty],#dashboardView.patient-view tr.study-row .cell-images{display:none}#dashboardView.patient-view tr.study-row .cell-view{grid-area:view;display:flex;align-items:center;padding:6px 0}#dashboardView.patient-view tr.study-row .action-buttons{display:flex;align-items:center;gap:16px;flex-direction:row}#dashboardView.patient-view tr.study-row .cell-view .btn,#dashboardView.patient-view tr.study-row .cell-download .btn{font-size:13px;font-weight:600;padding:4px 0;background:none;color:#1a5276;border:none;box-shadow:none;display:inline-flex;align-items:center;gap:6px;line-height:1;cursor:pointer;transition:color var(--transition-fast)}@media(hover:hover){#dashboardView.patient-view tr.study-row .cell-view .btn:hover,#dashboardView.patient-view tr.study-row .cell-download .btn:hover{color:#0e3a5e}}#dashboardView.patient-view tr.study-row .cell-referring{grid-area:referring;display:block;font-size:12px;font-weight:500;color:var(--color-text-tertiary);line-height:1.3;letter-spacing:.01em}#dashboardView.patient-view tr.study-row .cell-referring:not([data-empty]):before{content:"Referring Physician: "}#dashboardView.patient-view tr.study-row .cell-referring[data-empty]{display:none}#dashboardView.patient-view tr.study-row .cell-download{grid-area:download;display:flex;align-items:center;padding:6px}#dashboardView.patient-view tr.study-row .cell-patient-name,#dashboardView.patient-view tr.study-row .cell-patient-id,#dashboardView.patient-view .study-expansion-row{display:none}#dashboardView.patient-view .studies-container tbody:has(.empty-state-patient){max-width:none;padding:0}#dashboardView.patient-view tr:has(.empty-state-patient){display:block}#dashboardView.patient-view tr:has(.empty-state-patient) td{display:block}#dashboardView.patient-view .info-banner{max-width:820px;margin:0 auto 12px;background:#fffbeb;border:1px solid #fde68a;border-left:3px solid #d97706;border-radius:2px 8px 8px 2px}#dashboardView.patient-view .studies-container{background:none;box-shadow:none;border-radius:0;border:none}}@media(max-width:576px){html,body{overflow-x:clip;max-width:100vw}.container{max-width:100%;overflow-x:hidden}.header{padding:0;overflow:hidden}.header-content{padding:12px 16px;gap:12px;flex-wrap:nowrap;max-width:100%;align-items:center}.header-brand{flex:1;min-width:0;gap:12px;overflow:hidden}.header-logo-img{width:40px;height:40px;flex-shrink:0;border-radius:var(--radius-md)}.header-title{font-size:17px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-info{gap:6px;flex-shrink:0}.user-details{display:none}.profile-menu{position:fixed;inset:auto 0 0;border-radius:16px 16px 0 0;min-width:100%;transform:translateY(100%);box-shadow:0 -4px 20px #00000026;border:none}.profile-menu.open{transform:translateY(0)}.profile-menu:before{content:"";display:block;width:36px;height:4px;background:#d1d5db;border-radius:2px;margin:10px auto 6px}.profile-menu-info{padding:12px 20px 16px}.profile-menu-item{padding:16px 20px;min-height:52px;font-size:15px}.role-toggle{display:none}.role-indicator-mobile{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--radius-lg);font-size:10px;font-weight:600;flex-shrink:0}.role-indicator-mobile.patient{background:#dbeafe;color:#1d4ed8}.role-indicator-mobile.provider{background:#d1fae5;color:#047857}.role-indicator-mobile svg{width:12px;height:12px}#logoutBtn{padding:6px 10px;font-size:11px;flex-shrink:0;white-space:nowrap}.avatar{display:none}.footer{padding:12px 0}.footer-links{display:none}.footer-text:last-child{display:none}.footer-text{margin-top:0;font-size:11px}.welcome-section{margin:16px 16px 12px}#dashboardView:not(.patient-view) .welcome-section{flex-direction:column;align-items:flex-start;gap:16px}#dashboardView .welcome-brand{flex-direction:row;flex-wrap:wrap;align-items:baseline;gap:0 5px;opacity:.6}.info-banner{padding:12px;font-size:12px;border-radius:10px;margin:0 16px 12px;gap:10px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;border:1px solid var(--color-border-default);background:var(--color-surface);line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.info-banner>div{min-width:0;word-wrap:break-word;overflow-wrap:break-word}.info-banner .info-icon{font-size:14px;flex-shrink:0}.info-banner a{word-break:break-all}.filter-section{padding:14px;margin:0 16px 12px;border-radius:10px;box-shadow:0 1px 3px #00000014,0 1px 2px #0000000a;border:1px solid var(--color-border-default)}.filter-header{margin-bottom:0;cursor:pointer}.filter-header h3{font-size:13px;font-weight:600;color:var(--color-heading);display:flex;align-items:center;justify-content:space-between;width:100%}.filter-header h3:before{display:none}.filter-header h3:after{content:"\25bc";font-size:8px;color:var(--color-text-light);transition:transform .2s ease}.filter-section.collapsed .filter-header h3:after{transform:rotate(-90deg)}.filter-section.collapsed .filter-row,.filter-section.collapsed .custom-date-range,.filter-section.collapsed .filter-actions,.filter-section.collapsed .active-filters{display:none}.filter-row{display:flex;flex-direction:column;gap:14px;margin-bottom:10px;margin-top:12px}.filter-group{gap:4px}.filter-group label{font-size:12px;font-weight:500;color:var(--color-text-tertiary)}.filter-input,.filter-select{padding:10px 12px;font-size:16px;border-radius:6px}.custom-date-range{display:flex;flex-direction:column;gap:10px;grid-column:auto;margin-top:10px}.filter-actions{flex-direction:column;gap:8px;padding-top:10px;border-top:1px solid var(--d-bg-muted);margin-top:4px}.filter-actions-left{display:flex;flex-direction:row;gap:8px;width:100%}.filter-actions-left .btn{flex:1;justify-content:center;padding:12px;font-size:14px;min-height:44px}.filter-actions-right{width:100%;flex-direction:column;gap:4px}.filter-actions-right .sort-label{font-size:11px}.filter-actions-right .filter-select{width:100%;padding:10px 12px;font-size:13px}.filter-chip .chip-remove{width:24px;height:24px;font-size:16px}.main-content{padding:12px 0}.studies-container{background:transparent;box-shadow:none;border-radius:0;border:none}.table-wrapper{overflow-x:visible}.studies-container thead{display:none}.studies-container table{display:block}.studies-container tbody{display:flex;flex-direction:column;gap:8px;padding:0 16px 16px}tr.study-row{display:grid;grid-template-areas:"description modality" "patient patient" "date date" "institution institution" "referring referring";grid-template-columns:1fr auto;grid-template-rows:auto auto auto auto auto;gap:2px 10px;background:var(--color-surface);border-radius:10px;position:relative;padding:12px 32px 12px 14px;box-shadow:0 1px 2px #0000000a,0 1px 4px #0000000f;border:none;cursor:pointer;transition:background var(--transition-fast),box-shadow var(--transition-fast)}tr.study-row:after{content:"\203a";position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:20px;font-weight:300;color:#c7c7cc;line-height:1}tr.study-row:active{background:#f0f1f3;box-shadow:0 0 #0000}tr.study-row>td{display:block;padding:0;border:none}tr.study-row .cell-description{grid-area:description;font-size:15px;font-weight:500;color:var(--color-heading);max-width:100%;white-space:normal;overflow:hidden;text-overflow:ellipsis;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}tr.study-row .cell-patient-name{grid-area:patient;font-size:12px;font-weight:500;color:var(--color-text-body);display:block;line-height:1.3;padding-bottom:6px;margin-bottom:2px;border-bottom:1px solid var(--d-bg-muted)}tr.study-row .cell-date{grid-area:date;font-size:13px;color:var(--color-text-tertiary);font-weight:400;line-height:1.3;margin-top:2px}tr.study-row .cell-modality{grid-area:modality;display:flex;flex-wrap:wrap;gap:4px;font-size:10px;align-self:start;justify-self:end;line-height:1.3;padding:0;background:none}tr.study-row .cell-images{display:none}tr.study-row .cell-institution{grid-area:institution;display:block;font-size:12px;color:var(--d-text-secondary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}tr.study-row .cell-institution[data-empty]{display:none}tr.study-row .cell-referring{grid-area:referring;display:block;font-size:12px;color:var(--color-text-tertiary);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}tr.study-row .cell-referring:not([data-empty]):before{content:"Referring Physician: "}tr.study-row .cell-referring[data-empty],tr.study-row .cell-view,tr.study-row .cell-download,tr.study-row .cell-patient-id,tr.study-row .cell-actions{display:none}#dashboardView.patient-view .welcome-section{padding:24px 20px;border-radius:var(--radius-lg);margin:0 16px 12px;flex-direction:column;align-items:flex-start;gap:16px}#dashboardView.patient-view .welcome-brand{flex-direction:row;flex-wrap:wrap;align-items:baseline;gap:0 5px;opacity:.6}#dashboardView.patient-view .patient-hint{margin:0 16px 12px;font-size:12px;padding:12px 14px}#dashboardView.patient-view .study-count{font-size:13px}#dashboardView.patient-view .studies-container tbody{padding-top:4px}#dashboardView.patient-view tr.study-row{grid-template-areas:"date" "description" "institution" "referring";grid-template-columns:1fr;gap:2px;border-left:3px solid #6bb5a8;border-radius:2px 10px 10px 2px;box-shadow:0 1px 3px #0000000f,0 1px 2px #0000000a;animation:cardEnter .3s ease both;animation-delay:calc(var(--card-index, 0) * 40ms)}#dashboardView.patient-view tr.study-row .cell-referring{font-size:12px}#dashboardView.patient-view tr.study-row .cell-referring:not([data-empty]):before{content:"Referring Physician: ";font-weight:500;color:var(--color-text-light)}#dashboardView.patient-view tr.study-row .cell-date{font-size:13px;font-weight:600;color:#1f2937;margin-top:0}#dashboardView.patient-view tr.study-row .cell-date .date-only{display:none}#dashboardView.patient-view tr.study-row .cell-date .date-friendly{display:inline}#dashboardView.patient-view tr.study-row .cell-description{font-size:15px;font-weight:500;color:var(--color-text-body)}#dashboardView.patient-view tr.study-row .cell-patient-name,#dashboardView.patient-view tr.study-row .cell-modality{display:none}.study-expansion-row{display:block;margin-top:-6px;margin-bottom:6px}.study-expansion-row>td{display:block;padding:0}.study-expansion-panel{background:#f8fafc;border:1px solid var(--color-border-default);border-top:none;border-radius:0 0 10px 10px;margin:0}.expansion-content{padding:10px;gap:10px}.expansion-section{padding:10px}.expansion-section-title{font-size:9px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-bottom:6px}.study-details-grid{grid-template-columns:1fr;gap:0}.detail-item{display:flex;flex-direction:row;justify-content:space-between;align-items:baseline;padding:5px 0;border-bottom:1px solid var(--d-bg-muted)}.detail-item:last-child{border-bottom:none}.detail-label{font-size:11px;color:var(--color-text-tertiary);flex-shrink:0}.detail-value{font-size:12px;text-align:right;word-break:break-word;max-width:60%}.detail-value.uid-value{font-size:10px;font-family:var(--font-family-mono)}.detail-item:has(.uid-value){display:none}.series-table-wrapper{margin:0;padding:0;max-height:200px;overflow-y:auto;overflow-x:hidden;border:1px solid var(--color-border-default);border-radius:6px;background:var(--color-surface)}.series-table{display:block;width:100%}.series-table thead{display:none}.series-table tbody{display:flex;flex-direction:column;gap:0}.series-row{display:flex;align-items:center;gap:10px;background:var(--color-surface);padding:8px 10px;border-radius:0;border:none;border-bottom:1px solid var(--d-bg-muted)}.series-row:last-child{border-bottom:none}.series-row td{padding:0;border:none;background:transparent!important}.series-number{display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:var(--color-primary);background:#e6f2ff;border-radius:3px;min-width:22px;height:22px;padding:0 4px;flex-shrink:0}.series-description{font-size:12px;font-weight:500;color:var(--color-heading);flex:1;min-width:0;max-width:calc(100% - 60px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.series-modality{display:none}.series-instances{font-size:11px;color:var(--color-text-light);flex-shrink:0;white-space:nowrap}.series-instances:before{content:none}.series-instances:after{content:" img"}.series-uid{display:none}.expansion-empty{font-size:12px;padding:16px}.expansion-loading{padding:16px;font-size:12px}.expansion-loading .loading-spinner{width:14px;height:14px}.loading-row{display:block!important;padding:0 12px}.loading-row td{display:block;padding:0}.loading-row .loading-cell .loading,.loading-row .loading-cell .loading-state{position:static;min-height:200px;border-radius:10px;border:1px solid var(--color-border-default)}tr:has(>td>.empty-state){display:block!important}tr:has(>td>.empty-state) td{display:block;padding:0}.empty-state{border-radius:10px;border:1px solid var(--color-border-default);margin:0;padding:32px 20px}.pagination-controls{display:flex;flex-direction:row;flex-wrap:nowrap;justify-content:center;align-items:center;gap:12px;padding:10px 12px;background:none;border-top:none;margin:0;border-radius:0;box-shadow:none}.pagination-info{order:0;text-align:center;padding:0;background:transparent;border-radius:0;font-size:12px;color:var(--color-text-light);width:auto;margin-bottom:0;white-space:nowrap}.pagination-controls .btn{flex:none;min-width:0;max-width:none;padding:6px 14px;font-size:13px}tr.study-row .action-buttons .btn,tr.study-row .cell-download .btn{padding:8px 6px;font-size:11px;min-width:0;min-height:36px}tr.study-row .action-buttons{justify-content:center}.login-content{padding:24px 20px}.welcome-box{max-width:100%}.welcome-logo-img{max-width:220px;max-height:88px}.welcome-title{font-size:22px;line-height:1.2;margin-bottom:8px}.welcome-subtitle{font-size:14px;line-height:1.5;margin-bottom:24px}.terms-box{border-radius:var(--radius-lg);padding:18px 20px}.terms-box h3{font-size:13px;margin-bottom:10px}.terms-box p{font-size:13px;line-height:1.5;margin-bottom:16px}.terms-links{gap:0;flex-direction:column}.terms-link{font-size:14px;padding:10px 0;border-bottom:1px solid var(--color-border-light)}.terms-link:last-child{border-bottom:none}#agreeBtn{width:100%;padding:16px 24px;font-size:17px;border-radius:10px;min-height:52px}}@media(max-width:360px){.header-content{padding:5px 0;gap:4px}.header-brand{gap:4px;min-width:0;flex:1}.header-logo-img{width:24px;height:24px}.header-title{font-size:10px;line-height:1.2}.user-info{gap:4px}#logoutBtn{padding:4px 6px;font-size:9px}.role-indicator-mobile{padding:2px 5px;font-size:8px;border-radius:var(--radius-md)}.role-indicator-mobile svg{width:9px;height:9px}.welcome-section{margin:12px 10px 8px}.info-banner{margin:0 10px 8px;padding:10px;font-size:11px;gap:8px}.info-banner .info-icon{display:none}.filter-section{margin:0 10px 8px;padding:10px}.filter-header h3{font-size:12px}.filter-row{gap:8px;margin-top:10px}.filter-group label{font-size:10px}.filter-input,.filter-select{padding:8px 10px;font-size:14px}.filter-actions{gap:6px;padding-top:8px}.filter-actions-left{gap:6px}.filter-actions-left .btn{padding:8px 6px;font-size:11px}.studies-container tbody{padding:0 10px 10px;gap:6px}tr.study-row{padding:10px 28px 10px 12px;gap:2px 6px;border-radius:var(--radius-md)}tr.study-row .cell-description{font-size:13px;line-height:1.25}tr.study-row .cell-patient-name{font-size:11px;line-height:1.3}tr.study-row .cell-date{font-size:11px}tr.study-row .cell-modality span{font-size:9px;padding:1px 4px}tr.study-row .cell-institution,tr.study-row .cell-referring{font-size:10px}tr.study-row:after{font-size:18px;right:8px}#dashboardView.patient-view tr.study-row{padding:10px 26px 10px 12px}#dashboardView.patient-view tr.study-row .cell-date{font-size:12px}#dashboardView.patient-view tr.study-row .cell-description{font-size:13px}.expansion-content{padding:8px;gap:6px}.expansion-section{padding:8px}.expansion-section-title{font-size:9px;margin-bottom:4px;padding-bottom:3px}.study-expansion-panel{margin:0}.detail-item{padding:3px 0}.detail-label{font-size:9px}.detail-value{font-size:10px;max-width:50%}.series-table-wrapper{max-height:140px}.series-row{padding:5px 6px;gap:6px}.series-number{font-size:9px;min-width:18px;height:18px;padding:0 3px}.series-description{font-size:10px}.series-instances{font-size:9px}.pagination-controls{padding:10px 6px;gap:6px;margin:0 6px 6px}.pagination-info{font-size:10px;padding:5px 8px}.pagination-controls .btn{padding:6px 10px;font-size:10px}.footer{padding:10px 0}.footer-text{font-size:10px}.welcome-title{font-size:20px}.welcome-subtitle{font-size:13px}.terms-box{padding:14px 16px}.terms-box h3,.terms-box p{font-size:12px}.terms-link{font-size:13px;padding:8px 0}#agreeBtn{padding:14px 20px;font-size:16px;min-height:48px}}@media(min-width:1024px)and (max-width:1366px){.container{max-width:1200px}.filter-row{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.custom-date-range{grid-column:span 2}}@media(max-width:1000px){.th-institution,.cell-institution,.th-images,.cell-images{display:none}.th-patient-name{width:22%}.th-description{width:23%}.th-patient-id{width:10%}.th-date{width:14%}.th-modality{width:13%}.th-view{width:7%}.th-download{width:11%}}@media(max-width:900px){.th-modality,.cell-modality,.th-patient-id,.cell-patient-id{display:none}.th-patient-name{width:25%}.th-description{width:35%}.th-date{width:16%}.th-view{width:10%}.th-download{width:14%}th,td{padding:12px 10px}.cell-patient-name{font-size:13px}.cell-description{font-size:12px}.cell-view .btn .btn-label{display:none}}@media(max-width:700px){th,td{padding:10px 8px}th{font-size:11px}.cell-patient-name{font-size:12px}.cell-description{font-size:11px}}@media(max-width:650px)and (min-width:577px){th,td{padding:8px 6px;font-size:11px}th{font-size:10px}.cell-patient-name,.cell-description{font-size:11px}.action-buttons{flex-direction:column;gap:4px}.action-buttons .btn,.cell-download .btn{padding:6px;font-size:10px;justify-content:center;white-space:nowrap;min-width:0}}@media(max-width:1000px)and (hover:none),(max-width:1000px)and (pointer:coarse){.th-patient-name{width:24%}.th-description{width:30%}.th-patient-id{width:11%}.th-date{width:15%}.th-modality{width:11%}.th-view{width:9%}}@media(max-width:900px)and (hover:none),(max-width:900px)and (pointer:coarse){.th-patient-name{width:28%}.th-description{width:42%}.th-date{width:18%}.th-view{width:12%}}@media(max-width:576px)and (hover:none),(max-width:576px)and (pointer:coarse){.role-btn{min-width:36px;min-height:36px}#logoutBtn{min-height:36px;min-width:36px}.series-row{min-height:40px}}:root{--v-accent: #38bdf8;--v-accent-hover: #6ec8ff;--v-accent-bg: rgba(56, 189, 248, .15);--v-accent-bg-hover: rgba(56, 189, 248, .25);--v-accent-bar: rgba(56, 189, 248, .8);--v-accent-bar-glow: #38bdf8;--v-accent-08: rgba(56, 189, 248, .08);--v-accent-10: rgba(56, 189, 248, .1);--v-accent-15: rgba(56, 189, 248, .15);--v-accent-20: rgba(56, 189, 248, .2);--v-accent-30: rgba(56, 189, 248, .3);--v-accent-40: rgba(56, 189, 248, .4);--v-accent-50: rgba(56, 189, 248, .5);--v-surface: #1e1e2e;--v-surface-alt: #1a1a24;--v-border: rgba(255, 255, 255, .08);--v-hover: rgba(255, 255, 255, .06)}.viewer-container,.viewer-container *{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.15) transparent}.viewer-container ::-webkit-scrollbar{width:6px;height:6px}.viewer-container ::-webkit-scrollbar-track{background:transparent;margin:2px}.viewer-container ::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:10px;border:1px solid transparent;background-clip:padding-box}.viewer-container ::-webkit-scrollbar-thumb:hover{background:#ffffff40}.viewer-container ::-webkit-scrollbar-thumb:active{background:#ffffff59}.viewer-container ::-webkit-scrollbar-corner{background:transparent}.viewport-container ::-webkit-scrollbar,.viewport-grid ::-webkit-scrollbar,.viewport-cell ::-webkit-scrollbar{width:4px;height:4px}.viewport-container ::-webkit-scrollbar-thumb,.viewport-grid ::-webkit-scrollbar-thumb,.viewport-cell ::-webkit-scrollbar-thumb{background:#ffffff1f;border-radius:var(--radius-sm)}.viewport-container ::-webkit-scrollbar-thumb:hover,.viewport-grid ::-webkit-scrollbar-thumb:hover,.viewport-cell ::-webkit-scrollbar-thumb:hover{background:#fff3}.viewer-container{position:fixed;inset:0;background:#000;z-index:2000;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden;overscroll-behavior:none}.viewer-header{background:#0a0c14;padding:10px clamp(8px,2vw,16px);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--v-border);flex-shrink:0;gap:16px}.viewer-brand{display:flex;align-items:center;gap:clamp(3px,.8vw,6px);flex-shrink:0}.viewer-brand-icon{width:32px;height:32px;flex-shrink:0;object-fit:contain;border-radius:6px}.viewer-brand-name{font-size:16px;font-weight:600;color:#fffffff2;letter-spacing:-.02em}.brand-tm{font-size:.75em;font-weight:400;opacity:.6;position:relative;top:-.25em;margin-left:1px}.viewer-header-buttons{display:flex;align-items:center;gap:8px;flex-shrink:0}.viewer-header-info{display:flex;align-items:center;gap:0;font-size:13px;color:#fff9;padding:0;min-width:0;overflow:hidden;flex:1;justify-content:center}.info-bar-name{font-weight:600;font-size:15px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:280px;flex-shrink:1}.info-bar-field{color:#ffffffa6;font-size:14px;white-space:nowrap;flex-shrink:0}.info-bar-field span{color:#fffffff2;font-weight:600;margin-left:3px;font-family:var(--font-family-mono, "IBM Plex Mono", monospace);letter-spacing:.3px}.info-bar-sep{width:3px;height:3px;background:#ffffff40;border-radius:50%;flex-shrink:0;margin:0 10px}.viewer-close-btn,.viewer-info-btn{background:var(--v-hover);color:#fffc;border:1px solid rgba(255,255,255,.12);border-radius:6px;cursor:pointer;transition:all var(--transition-fast);width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.viewer-close-btn:hover,.viewer-info-btn:hover{background:#ffffff1a;color:#fffffff2;border-color:#fff3}.viewer-help-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.viewer-help-modal{background:var(--v-surface);border:1px solid var(--v-accent-15);border-radius:var(--radius-md);max-width:520px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 24px 48px #0009,0 0 0 1px #0000004d}.viewer-help-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--v-border);background:var(--v-surface-alt)}.viewer-help-header h2{margin:0;font-size:15px;font-weight:600;color:var(--v-accent);letter-spacing:.3px}.viewer-help-close{background:none;border:none;color:#fff6;font-size:22px;cursor:pointer;padding:0;line-height:1;transition:color .15s}.viewer-help-close:hover{color:#fff}.viewer-help-body{padding:20px;overflow-y:auto;color:#ffffffb3;font-size:13px}.viewer-help-intro{margin:0 0 16px;line-height:1.5;color:#ffffffd9}.viewer-help-body h3{margin:20px 0 10px;font-size:11px;font-weight:600;color:var(--v-accent);text-transform:uppercase;letter-spacing:.8px}.viewer-help-body h3:first-of-type{margin-top:0}.viewer-help-table{width:100%;border-collapse:collapse;margin-bottom:4px}.viewer-help-table tr{border-bottom:1px solid var(--v-border)}.viewer-help-table tr:last-child{border-bottom:none}.viewer-help-table tr.header{background:var(--v-accent-08)}.viewer-help-table th{padding:7px 10px;text-align:left;font-weight:600;font-size:10px;color:var(--v-accent);text-transform:uppercase;letter-spacing:.5px}.viewer-help-table th:first-child{padding-left:4px}.viewer-help-table td{padding:7px 10px;color:#ffffffb3;font-size:12px}.viewer-help-table td:first-child{padding-left:4px}.viewer-help-table td.dim{color:#ffffff59;text-align:right;font-variant-numeric:tabular-nums}.viewer-help-table.shortcut-table td:first-child{width:120px;color:#ffffffe6}.viewer-help-table.preset-table td:first-child{width:50px}.viewer-help-table kbd{display:inline-block;padding:2px 7px;font-family:inherit;font-size:11px;font-weight:500;color:var(--v-accent-hover);background:var(--v-accent-08);border:1px solid var(--v-accent-15);border-radius:4px;min-width:22px;text-align:center;line-height:1.4}.dicom-tags-modal{background:var(--v-surface);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);max-width:700px;width:100%;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000080}.dicom-tags-body{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.dicom-tags-controls{display:flex;gap:12px;padding:16px 20px;border-bottom:1px solid var(--v-border);flex-shrink:0}.dicom-tags-filter{flex:1;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:8px 12px;color:#fff;font-size:13px;outline:none}.dicom-tags-filter:focus{border-color:var(--v-accent-50);background:var(--v-border)}.dicom-tags-filter::placeholder{color:#fff6}.dicom-tags-tabs{display:flex;gap:4px;flex-shrink:0}.dicom-tab{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);padding:8px 16px;color:#ffffffb3;font-size:13px;cursor:pointer;transition:all var(--transition-fast)}.dicom-tab:hover{background:#ffffff1a;color:#fff}.dicom-tab.active{background:var(--v-accent-bg);border-color:var(--v-accent-30);color:var(--v-accent)}.dicom-tags-content{flex:1;overflow-y:auto;padding:0}.dicom-tags-table{width:100%;border-collapse:collapse;font-size:12px}.dicom-tags-table thead{position:sticky;top:0;background:var(--v-surface);z-index:1}.dicom-tags-table th{padding:10px 12px;text-align:left;font-weight:600;font-size:11px;color:var(--v-accent-hover);text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.1)}.dicom-tags-table td{padding:8px 12px;color:#d4d4d4;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:top}.dicom-tags-table tr:hover td{background:#ffffff08}.dicom-tags-table .tag-id{font-family:var(--font-family-mono);color:var(--v-accent);width:90px;flex-shrink:0}.dicom-tags-table .tag-name{color:#b0b0b0;width:180px}.dicom-tags-table .tag-value{color:#fff;word-break:break-all;max-width:300px;overflow:hidden;text-overflow:ellipsis}.dicom-tags-table .dim{color:#888;font-style:italic}.viewer-body{display:grid;grid-template-columns:clamp(120px,18vw,260px) 1fr;flex:1;overflow:hidden;min-height:0}.viewer-series-panel{background:#0a0c14;border-right:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;overflow:hidden;position:relative;z-index:10;min-width:0}.viewer-series-panel::-webkit-scrollbar{display:none}.series-list{overflow-y:auto;scrollbar-width:none;flex:1;padding:clamp(10px,1.5vw,16px) clamp(6px,1vw,10px);display:grid;grid-template-columns:1fr 1fr;align-content:start;gap:clamp(8px,1.2vw,14px);min-width:0;overflow-x:hidden}.series-list::-webkit-scrollbar{display:none}.series-thumbnail{cursor:pointer;padding:clamp(5px,.6vw,8px);border-radius:5px;transition:background var(--transition-fast);min-width:0}.series-thumbnail:hover{background:#ffffff0a}.series-thumbnail.active{background:#ffffff0d;outline:1px solid rgba(255,255,255,.15);outline-offset:-1px}.series-thumbnail.dragging{opacity:.5;transform:scale(.95)}@media(min-width:481px){.series-thumbnail{cursor:grab}.series-thumbnail:active{cursor:grabbing}}.series-thumb-img{width:100%;aspect-ratio:1;background:#000;border-radius:var(--radius-sm);border:1px solid var(--v-hover);display:flex;align-items:center;justify-content:center;overflow:hidden}.series-thumb-img canvas{max-width:100%;max-height:100%;object-fit:contain}.series-thumb-img .thumb-placeholder{color:#ffffff26;font-size:18px;font-weight:600}.series-thumbnail .series-info{font-size:12px;color:#fffc;margin-top:6px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500;max-width:100%}.series-thumbnail.skeleton{cursor:default;pointer-events:none}.series-thumbnail.skeleton .skeleton-img{width:100%;aspect-ratio:1;background:#ffffff08;border-radius:var(--radius-sm);position:relative;overflow:hidden}.series-thumbnail.skeleton .skeleton-img:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);animation:skeleton-shimmer 1.5s infinite}.skeleton-text{height:10px;border-radius:3px;background:#ffffff0a;margin-top:8px;margin-inline:auto}.skeleton-text-wide{width:75%}.skeleton-text-narrow{width:40%;margin-top:6px}@keyframes skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.viewer-main{display:flex;flex-direction:column;background:#000;position:relative;min-height:0;min-width:0;overflow:hidden}.viewer-toolbar{background:#0a0c14;padding:10px 16px;display:flex;align-items:center;gap:clamp(8px,1.5vw,24px);border-bottom:1px solid var(--v-hover);flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;position:relative;z-index:500;flex-shrink:0;scrollbar-width:none}.viewer-toolbar::-webkit-scrollbar{display:none}.mode-toggle{display:flex;background:var(--v-hover);border-radius:5px;gap:1px}.mode-toggle .toolbar-btn{border-color:transparent;border-radius:var(--radius-sm);min-width:0}.mode-toggle .toolbar-btn span{display:inline;line-height:16px}.mode-toggle .toolbar-btn:disabled,.mode-toggle .toolbar-btn.mobile-disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.viewer-toolbar.fusion-mode #modeButtonsGroup{display:none}.loading-status-bar{padding:10px 14px;display:flex;flex-direction:row;align-items:center;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:#ffffff59;flex-shrink:0;position:relative;overflow:hidden;background:#ffffff08;border-top:1px solid var(--v-border);transition:color .5s cubic-bezier(.4,0,.2,1)}.loading-status-bar:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:var(--v-border);transition:background .5s cubic-bezier(.4,0,.2,1),box-shadow .5s cubic-bezier(.4,0,.2,1)}.loading-status-bar.loading{color:#ffffffd9}.loading-status-bar.loading:after{background:var(--v-accent-10);box-shadow:0 0 6px #38bdf80f}.loading-status-bar.ready{animation:status-ready-text 2s cubic-bezier(.4,0,.2,1) forwards}.loading-status-bar.ready:after{animation:status-ready-border 2s cubic-bezier(.4,0,.2,1) forwards}@keyframes status-ready-text{0%{color:#4ade80f2}40%{color:#4ade8099}to{color:#ffffff59}}@keyframes status-ready-border{0%{background:#4ade8033;box-shadow:0 0 6px #4ade801f}40%{background:#4ade8014;box-shadow:0 0 3px #4ade800a}to{background:var(--v-border);box-shadow:none}}.status-icon{width:14px;height:14px;flex-shrink:0;position:relative;margin-right:6px}.status-spinner{position:absolute;inset:1px;border:1.5px solid var(--v-accent-15);border-top-color:var(--v-accent);border-radius:50%;box-sizing:border-box;opacity:0;animation:status-spin .8s linear infinite;transition:opacity .4s cubic-bezier(.4,0,.2,1)}.loading-status-bar.loading .status-spinner{opacity:1}@keyframes status-spin{to{transform:rotate(360deg)}}.status-check{position:absolute;inset:0;width:14px;height:14px;opacity:0;transform:scale(.6);transition:opacity .4s cubic-bezier(.4,0,.2,1),transform .5s cubic-bezier(.2,.8,.3,1.2)}.status-check-circle{stroke:#4ade80;fill:none;stroke-dasharray:44;stroke-dashoffset:44;transition:stroke-dashoffset .5s cubic-bezier(.4,0,.2,1)}.status-check-mark{stroke:#4ade80;fill:none;stroke-dasharray:14;stroke-dashoffset:14;transition:stroke-dashoffset .35s cubic-bezier(.4,0,.2,1) .25s}.loading-status-bar.ready .status-check{opacity:1;transform:scale(1);filter:drop-shadow(0 0 2px rgba(74,222,128,.3))}.loading-status-bar.ready .status-check-circle,.loading-status-bar.ready .status-check-mark{stroke-dashoffset:0}.loading-status-bar.loading .status-check{opacity:0;transform:scale(.6)}.loading-status-bar.loading .status-check-circle{stroke-dashoffset:44;transition:none}.loading-status-bar.loading .status-check-mark{stroke-dashoffset:14;transition:none}.status-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:left}.loading-status-bar.ready .status-text{animation:status-text-enter .4s cubic-bezier(.4,0,.2,1)}@keyframes status-text-enter{0%{opacity:0;transform:translateY(3px)}to{opacity:1;transform:translateY(0)}}.viewer-toast{position:absolute;bottom:24px;left:50%;transform:translate(-50%) translateY(8px);background:#0f172ae6;border:1px solid rgba(255,255,255,.1);color:#ffffffd9;font-size:15px;padding:14px 28px;border-radius:10px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none;opacity:0;transition:opacity var(--transition-base),transform var(--transition-base);z-index:20;white-space:nowrap}.viewer-toast.visible{opacity:1;transform:translate(-50%) translateY(0)}.toolbar-select{background:var(--v-accent-08);color:#ffffffe6;border:1px solid var(--v-accent-bg-hover);border-radius:var(--radius-sm);padding:4px 8px;font-size:11px;cursor:pointer;outline:none;transition:all var(--transition-fast)}.toolbar-select:hover{background:var(--v-accent-bg);border-color:var(--v-accent-40)}.toolbar-select:focus{border-color:var(--v-accent);box-shadow:0 0 0 2px var(--v-accent-bg)}.toolbar-select option{background:#1a1a2e;color:#fff;padding:6px}.toolbar-select-preset{min-width:80px;font-weight:500}.colormap-swatch{width:36px;height:14px;border-radius:3px;border:1px solid rgba(255,255,255,.15);flex-shrink:0;box-shadow:0 1px 3px #0000004d,inset 0 1px #ffffff1a}.fusion-only.hidden,#layoutDropdown.hidden{display:none!important}@media(max-width:1100px){.viewer-toolbar{padding:5px 10px}.toolbar-btn{padding:7px}.toolbar-btn span{display:none}.toolbar-select-preset{min-width:70px}.colormap-swatch{width:28px;height:12px}}@media(max-width:700px){.viewer-toolbar{padding:4px 8px}.toolbar-btn{padding:6px}.toolbar-btn svg{width:15px;height:15px}.toolbar-select-preset{min-width:60px;font-size:9px}.colormap-swatch{width:24px;height:10px}#toolDicomTags,#layoutDropdown{display:none}}.toolbar-btn{background:transparent;color:#ffffffa6;border:1px solid transparent;padding:6px 10px;border-radius:5px;font-size:13px;line-height:1;font-weight:500;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;flex-shrink:0;white-space:nowrap;touch-action:manipulation;transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.toolbar-btn svg{width:16px;height:16px;flex-shrink:0;opacity:.85}.toolbar-btn:hover{color:#ffffffe6;background:var(--v-hover)}.toolbar-btn.active{color:var(--v-accent);background:var(--v-accent-08);border-color:var(--v-accent-40)}.toolbar-btn.active svg{opacity:1}.annotation-dropdown-content{min-width:160px}.annotation-option{display:flex;align-items:center;gap:10px;padding:8px 12px;cursor:pointer;color:#ffffffb3;font-size:12px;border-radius:var(--radius-sm)}.annotation-option:hover{background:var(--v-hover);color:#fff}.annotation-option.active{color:var(--v-accent)}.annotation-option svg{width:16px;height:16px;flex-shrink:0}.annotation-divider{height:1px;background:#ffffff1a;margin:4px 0}.annotation-option-clear{color:#f87171}.annotation-option-clear:hover{background:#dc354533;color:#fca5a5}#toolAnnotate.active{background:#008cff33;color:var(--v-accent)}#fusionDropdown.hidden{display:none}.toolbar-dropdown{position:relative}.toolbar-dropdown-content{display:none;position:fixed;background:var(--v-surface-alt);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);box-shadow:0 8px 32px #00000080;z-index:2500;min-width:140px;padding:4px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.toolbar-dropdown.open .toolbar-dropdown-content{display:block}.layout-option,.colormap-option{display:flex;align-items:center;gap:10px;cursor:pointer;color:#fffc;font-size:12px;transition:all var(--transition-fast);border-radius:6px}.layout-option{padding:10px 12px}.layout-option:hover,.colormap-option:hover{background:var(--v-border);color:#fff}.layout-option.active,.colormap-option.active{color:var(--v-accent)}.layout-grid-icon{display:grid;gap:2px;width:16px;height:16px}.layout-grid-icon div{background:currentColor;border-radius:2px;opacity:.8}.fusion-only{display:none}.fusion-only.visible{display:flex}.colormap-dropdown-content{min-width:160px}.colormap-option{padding:8px 12px}.colormap-preview{width:40px;height:12px;border-radius:3px;border:1px solid rgba(255,255,255,.2)}.colormap-preview.hot_iron{background:linear-gradient(to right,#000010,#00f,red,#ff0)}.colormap-preview.red_hot{background:linear-gradient(to right,#000,maroon,red,#ff8000,#ff0)}.colormap-divider{height:1px;background:#ffffff26;margin:4px 8px}.colormap-section-label{padding:4px 12px 2px;font-size:10px;color:#ffffff8c;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.colormap-preview.s_pet{background:linear-gradient(to right,#000,#00f,#0f0,#ff0,#ff9200,red,#000)}.colormap-preview.ge_256{background:linear-gradient(to right,#000,navy,#0080ff,#00ff80,#80ff00,#ff0,#ff8000,red)}.colormap-preview.ge{background:linear-gradient(to right,#000,#00f,#0f0,#ff0,red)}.colormap-preview.siemens{background:linear-gradient(to right,#000,#00f,#0ff,#0f0,#ff0,#ff8000,red)}.viewport-container{flex:1;position:relative;background:#000;overflow:hidden;min-height:0;min-width:0;max-width:100%;max-height:100%}.viewport-grid{position:absolute;inset:0;display:grid;gap:1px;background:var(--v-surface-alt)}.viewport-cell{position:relative;background:#000;overflow:hidden;cursor:pointer;min-height:0;min-width:0;container-type:size}.viewport-cell:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:100;border:1px solid transparent;transition:all .2s ease}.viewport-cell.active:after{border:2px solid rgba(0,170,255,.7)}.viewport-cell.drag-over:after{border:2px dashed var(--v-accent-bar);background:var(--v-accent-10)}.viewport-cell .viewport{position:absolute;top:0;left:0;width:100%;height:100%;background:#000;cursor:default!important}.viewport-cell-label{position:absolute;top:4px;left:4px;background:#0009;color:#ffffffe6;font-size:12px;font-weight:500;padding:2px 8px;border-radius:3px;z-index:10;pointer-events:none}.viewport-cell-empty{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#ffffff40;font-size:13px;pointer-events:none}.viewport-cell-empty.skeleton{background:#ffffff04;overflow:hidden}.viewport-cell-empty.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.02) 50%,transparent 100%);animation:skeleton-shimmer 2s infinite}.viewport-cell-overlay{position:absolute;color:#fff;font-size:10px;line-height:1.45;font-family:var(--font-family-mono);text-shadow:0 0 4px rgba(0,0,0,1),0 1px 4px rgba(0,0,0,.8);pointer-events:none;z-index:10;font-weight:500;letter-spacing:.01em}.viewport-cell-overlay-tl{top:6px;left:8px}.viewport-cell-overlay-tr{top:6px;right:8px;text-align:right;max-width:50%;overflow:hidden;text-overflow:ellipsis}.viewport-cell-overlay-br{bottom:6px;right:8px;text-align:right}.viewport-cell-overlay-bl{bottom:6px;left:8px}.viewport-pet{position:absolute;inset:0;z-index:1;pointer-events:none}.viewport-ct .svg-layer{z-index:2}.fusion-opacity-control{display:flex;align-items:center;gap:6px;padding:0 8px}.fusion-opacity-control label{font-size:11px;color:#ccc;white-space:nowrap}.fusion-opacity-control input[type=range]{width:80px;height:4px;cursor:pointer;accent-color:#4a9eff}.fusion-opacity-value{font-size:11px;color:#ccc;min-width:28px;text-align:right}.viewport-cell.light-bg .viewport-cell-overlay{color:#000000d9;text-shadow:0 0 3px rgba(255,255,255,.6)}.viewport-cell.light-bg .cell-study-date.prior-study{color:#b46e00}.viewport-cell-overlay-tl>div:empty,.viewport-cell-overlay-tr>div:empty,.viewport-cell-overlay-bl>div:empty,.viewport-cell-overlay-br>div:empty{display:none}.orientation-marker{position:absolute;color:#ffffffd9;font-size:13px;font-family:var(--font-family-mono);font-weight:600;text-shadow:0 0 4px rgba(0,0,0,1),0 1px 4px rgba(0,0,0,.8);pointer-events:none;z-index:10}.orientation-marker:empty{display:none}.orientation-top{top:6px;left:50%;transform:translate(-50%)}.orientation-bottom{bottom:6px;left:50%;transform:translate(-50%)}.orientation-left{left:6px;top:50%;transform:translateY(-50%)}.orientation-right{right:6px;top:50%;transform:translateY(-50%)}.viewport-cell.light-bg .orientation-marker{color:#000000b3;text-shadow:0 0 3px rgba(255,255,255,.6)}@container (max-height: 280px){.vp-exam,.vp-institution,.vp-study-time{display:none}}@container (max-height: 200px){.vp-patient-details,.vp-series-num,.vp-tilt,.vp-thk-sp,.vp-kvp,.vp-ma,.vp-msec,.vp-dfov{display:none}}@container (max-height: 140px){.vp-slice-info,.vp-patient-name{display:none}}@container (max-width: 200px){.vp-exam,.vp-institution,.vp-study-time,.vp-patient-details,.vp-series-num,.vp-slice-info,.vp-tilt,.vp-thk-sp,.vp-kvp,.vp-ma,.vp-msec,.vp-dfov{display:none}}.prefetch-progress,.fusion-progress,.mpr-progress{position:absolute;top:0;left:0;right:0;height:5px;background:transparent;opacity:1;transition:opacity .5s cubic-bezier(.4,0,.2,1);pointer-events:none;overflow:hidden}.prefetch-progress{z-index:50}.fusion-progress,.mpr-progress{z-index:200}.prefetch-progress.hidden,.fusion-progress.hidden,.mpr-progress.hidden{opacity:0;pointer-events:none}.prefetch-progress-bar,.fusion-progress-bar,.mpr-progress-bar{height:100%;width:0%;background:var(--v-accent-bar);position:relative;transition:width .15s linear}.prefetch-progress-bar:after,.fusion-progress-bar:after,.mpr-progress-bar:after{content:"";position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,transparent 30%,rgba(186,230,253,.7) 50%,transparent 70%,transparent 100%);background-size:200% 100%;animation:barShimmer 2.5s ease-in-out infinite}@keyframes barShimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.prefetch-progress-bar.complete,.fusion-progress-bar.complete,.mpr-progress-bar.complete{background:var(--v-accent-bar-glow);transition:width .15s cubic-bezier(.4,0,.2,1),background .4s cubic-bezier(.4,0,.2,1)}.prefetch-progress-bar.complete:after,.fusion-progress-bar.complete:after,.mpr-progress-bar.complete:after{animation:none;opacity:0;transition:opacity .3s cubic-bezier(.4,0,.2,1)}.viewer-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#ffffffb3;text-align:center;pointer-events:none;z-index:50}.viewer-loading .spinner,.study-spinner,.fusion-compare-loading-spinner{border:2px solid rgba(255,255,255,.1);border-top-color:var(--v-accent);border-radius:50%}.viewer-loading .spinner{width:40px;height:40px;animation:spin .7s linear infinite;margin:0 auto 12px}.viewport-cell,.viewport,.viewport-container,.viewport-grid{touch-action:none;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}@media(hover:none),(pointer:coarse){.toolbar-btn{min-width:44px;min-height:44px}.series-thumbnail{min-height:44px}.layout-option,.annotation-option{min-height:44px;padding:12px 14px}.viewer-close-btn{width:32px;height:32px;min-height:32px;min-width:32px}}.mobile-viewer-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:var(--v-accent-bg);border-bottom:1px solid var(--v-accent-30);color:#ffffffe6;font-size:12px}.mobile-banner-icon{flex-shrink:0}.mobile-banner-text{flex:1}.mobile-banner-close{background:transparent;border:none;color:#fff9;font-size:18px;cursor:pointer;padding:4px 8px;line-height:1}.mobile-banner-close:hover{color:#fff}.toolbar-btn.mobile-disabled{opacity:.4;cursor:not-allowed;pointer-events:none}.toolbar-btn.mobile-disabled:after{content:"";position:absolute;inset:0}.series-panel-toggle{display:none;background:transparent;border:none;color:#ffffffa6;padding:10px;cursor:pointer;border-radius:var(--radius-sm);min-width:44px;min-height:44px;align-items:center;justify-content:center;touch-action:manipulation}.series-panel-toggle:hover,.series-panel-toggle.active{color:var(--v-accent);background:var(--v-accent-10)}@media(min-width:1024px)and (max-width:1366px){.viewer-body{grid-template-columns:clamp(140px,15vw,230px) 1fr}.info-bar-name{font-size:14px}.info-bar-field{font-size:13px}}@media(max-width:1023px)and (min-width:768px){.viewer-brand{padding-right:12px}.viewer-brand-name{font-size:14px}.viewer-body{grid-template-columns:clamp(120px,18vw,200px) 1fr}.series-list,.study-thumbnails-inner{grid-template-columns:1fr}.info-bar-sep{margin:0 8px}.info-bar-name{font-size:13px}.info-bar-field{font-size:12px}.study-date{font-size:13px}.study-desc{font-size:11px}}@media(max-width:767px)and (min-width:481px){.viewer-brand{padding-right:10px}.viewer-brand-name{font-size:13px}.viewer-body{grid-template-columns:clamp(100px,18vw,160px) 1fr}.series-list,.study-thumbnails-inner{grid-template-columns:1fr}.series-thumbnail .series-info{font-size:9px}.viewer-header-info{font-size:10px}.info-bar-sep{margin:0 6px}.info-bar-name{font-size:12px}.info-bar-field{display:none}.info-bar-field+.info-bar-sep{display:none}.study-date{font-size:12px}.study-desc{font-size:10px}.series-panel-toggle{display:flex}}@media(max-width:480px){.viewer-toolbar{padding:4px 6px}.toolbar-btn{padding:8px;min-width:44px;min-height:44px}.toolbar-btn svg{width:16px;height:16px}#annotationDropdown{display:none}}@media(max-width:360px){.viewer-container{height:100vh;height:100dvh}.viewer-header{padding:clamp(4px,1vw,5px) clamp(6px,2vw,8px);gap:clamp(4px,1.5vw,6px)}.viewer-brand-name{font-size:clamp(10px,3vw,11px)}.viewer-close-btn{width:28px;height:28px;min-height:28px;min-width:28px}.viewer-series-panel{height:clamp(35vh,50vw,40vh);max-height:clamp(240px,75vw,280px);border-radius:10px 10px 0 0}.series-list{padding:clamp(16px,5vw,18px) clamp(8px,3vw,10px) clamp(8px,3vw,10px);gap:clamp(6px,2vw,8px)}.series-thumbnail{padding:clamp(4px,1.3vw,5px)}.series-thumbnail .series-info{font-size:10px;margin-top:4px}.series-panel-toggle{padding:6px}.toolbar-dropdown-content{max-width:calc(100vw - 12px)}.viewport-cell-overlay{font-size:9px}.toolbar-select-preset{min-width:48px}.colormap-swatch{width:14px;height:8px}.header-brand-line{padding:8px 10px}.header-title{font-size:clamp(11px,3.5vw,12px)}.header-info-row{padding:0 10px;font-size:10px}.thumbnail-scroll-container{padding:4px 6px;gap:4px}.mobile-thumbnail .thumb-label{display:none}}.viewer-header-mobile,.thumbnail-strip{display:none}@media(max-width:480px),(orientation:landscape)and (max-height:480px)and (min-width:481px){:root{--m-brand-pad: 8px 0;--m-brand-min-h: 44px;--m-brand-gap: 0;--m-icon-w: 40px;--m-icon-h: 40px;--m-title-size: 17px;--m-swipe-icon: 56px;--m-swipe-text-size: 15px;--m-swipe-gap: 16px}.viewer-header-desktop,.viewer-series-panel,.viewer-toolbar{display:none!important}.viewer-header-mobile{display:flex;flex-direction:column;background:#0d0d12;border-bottom:1px solid var(--v-border);flex-shrink:0}.header-brand-line{display:flex;align-items:center;justify-content:space-between;padding:var(--m-brand-pad);min-height:var(--m-brand-min-h);gap:var(--m-brand-gap)}.header-brand-icon{width:var(--m-icon-w);height:var(--m-icon-h);flex-shrink:0;object-fit:contain;border-radius:var(--radius-md)}.viewer-header-mobile .header-title{font-size:var(--m-title-size);font-weight:600;color:#ffffffe6;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1;max-width:none}.header-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin-right:6px;background:transparent;border:1px solid rgba(255,255,255,.12);border-radius:50%;cursor:pointer;flex-shrink:0;margin-left:12px;touch-action:manipulation;transition:background var(--transition-fast),border-color var(--transition-fast)}.header-close-btn svg{width:14px;height:14px;stroke:#ffffff80;transition:stroke var(--transition-fast)}.header-close-btn:hover{background:var(--v-hover);border-color:#fff3}.header-close-btn:hover svg{stroke:#fffc}.header-close-btn:active{background:#ffffff1a;border-color:#ffffff40}.header-close-btn:active svg{stroke:#fff}.header-info-row{display:flex;align-items:baseline;justify-content:space-between;padding:0 16px;font-family:var(--font-family);font-size:14px;line-height:1.6;color:#fff9}.header-info-row:last-child{padding-bottom:8px}.info-primary{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex-shrink:1;color:#fffffff2;font-weight:600}.info-primary.info-dim{color:#ffffffa6;font-weight:500}.info-secondary{flex-shrink:0;white-space:nowrap;margin-left:12px;color:#ffffff80;font-size:12px}.info-secondary>span{margin-left:8px}.info-secondary>span:first-child{margin-left:0}.info-label{color:#ffffff59;text-transform:uppercase;font-size:10px;letter-spacing:.04em;margin-right:3px}.viewer-main{flex:1;display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.thumbnail-strip{display:block;background:#0d0d12;overflow:hidden}.thumbnail-scroll-container::-webkit-scrollbar{display:none}.mobile-thumbnail{flex-shrink:0;position:relative;display:flex;align-items:center;justify-content:center;padding:0;border-radius:6px;cursor:pointer;overflow:hidden;touch-action:manipulation}.mobile-thumbnail.active{border-color:var(--v-accent)}.mobile-thumbnail.active .thumb-badge{background:var(--v-accent-bar);color:#fff}.mobile-thumbnail .thumb-label{display:none}.mobile-swipe-hint{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--m-swipe-gap);background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:200;opacity:1;transition:opacity .4s ease-out}.mobile-swipe-hint.hidden{display:none}.mobile-swipe-hint.fading{opacity:0}.mobile-swipe-hint .swipe-icon{width:var(--m-swipe-icon);height:var(--m-swipe-icon);stroke:#ffffffe6;animation:swipeHintBounce 1.5s ease-in-out infinite}.mobile-swipe-hint .swipe-text{font-size:var(--m-swipe-text-size);font-weight:500;color:#ffffffe6;text-align:center;padding:0 24px}@keyframes swipeHintBounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.loading-status-bar{font-size:9px;padding:5px 10px}}@media(max-width:480px){.viewer-header-mobile{order:-2}.viewer-container{display:flex;flex-direction:column;overflow:hidden;height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}.viewer-body{grid-template-columns:1fr;flex:1;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden}.viewer-main{max-width:100%;max-height:100%}.viewport-container{flex:1;min-height:200px;min-width:0;width:100%;max-width:100%;max-height:100%;overflow:hidden;position:relative}.viewport-grid{position:absolute;inset:0;width:100%;height:100%;max-width:100%;max-height:100%;overflow:hidden}.viewport-cell{min-height:0;min-width:0;max-width:100%;max-height:100%;overflow:hidden}.viewport-cell .viewport{width:100%;height:100%;max-width:100%;max-height:100%}.viewport-cell canvas{max-width:100%;max-height:100%;display:block}.viewport-cell-overlay{font-size:9px}.mobile-viewer-banner{padding:8px 12px;font-size:11px;gap:8px}.thumbnail-strip{height:10dvh;border-bottom:1px solid var(--v-border);flex-shrink:0;order:-1}.thumbnail-scroll-container{display:flex;gap:6px;padding:6px 10px;height:100%;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scrollbar-width:none}.mobile-thumbnail{width:calc(10dvh - 18px);height:calc(10dvh - 18px);background:#ffffff08;border:1px solid var(--v-border);scroll-snap-align:start;transition:all var(--transition-fast)}.mobile-thumbnail:hover{background:var(--v-hover);border-color:#ffffff26}.mobile-thumbnail.active{background:var(--v-accent-10)}.mobile-thumbnail canvas,.mobile-thumbnail .thumb-placeholder{width:100%;height:100%;background:#000;border-radius:5px;display:flex;align-items:center;justify-content:center}.mobile-thumbnail .thumb-placeholder{color:#ffffff26;font-size:14px;font-weight:600}.mobile-thumbnail .thumb-badge{position:absolute;top:3px;left:3px;min-width:18px;height:18px;background:#000000b3;color:#ffffffd9;font-size:10px;font-weight:600;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none;z-index:1}.mobile-thumbnail.skeleton{background:#ffffff08;border-color:#ffffff0d;cursor:default;overflow:hidden}.mobile-thumbnail.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 50%,transparent 100%);animation:skeleton-shimmer 1.5s infinite}.viewport-cell-overlay-tl{top:4px;left:6px}.viewport-cell-overlay-tr{top:4px;right:24px}.viewport-cell-overlay-br{bottom:4px;right:24px}.viewport-cell-overlay-bl{bottom:4px;left:6px}.thumbnail-strip:has(.mobile-fusion-layout){height:12dvh}.thumbnail-scroll-container:has(.mobile-fusion-layout){overflow-x:hidden;scroll-snap-type:none;gap:8px;padding:8px 10px}.mobile-fusion-layout{flex:1;min-width:0;height:100%;background:#ffffff08;border:1px solid var(--v-border);border-radius:6px;padding:6px;cursor:pointer;display:flex;flex-direction:column;gap:4px;touch-action:manipulation;transition:all var(--transition-fast)}.mobile-fusion-layout:hover{background:var(--v-hover);border-color:#ffffff26}.mobile-fusion-layout.active{border-color:var(--v-accent);background:var(--v-accent-08)}.mobile-fusion-layout .layout-card-preview{flex:1;min-height:0;aspect-ratio:unset;display:flex}.mobile-fusion-layout .layout-card-preview>*{flex:1;min-height:0}.mobile-fusion-layout .layout-card-name{flex-shrink:0;font-size:10px;color:#fff9;text-align:center;white-space:nowrap;margin-top:0}.mobile-fusion-layout.active .layout-card-name{color:var(--v-accent)}.mobile-fusion-layout .preview-box{font-size:0}.loading-status-bar{flex-shrink:0}}@media(orientation:landscape)and (max-height:480px)and (min-width:481px){:root{--m-brand-pad: 6px 16px;--m-brand-min-h: 36px;--m-brand-gap: 10px;--m-icon-w: 32px;--m-icon-h: 32px;--m-title-size: 15px;--m-swipe-icon: 44px;--m-swipe-text-size: 14px;--m-swipe-gap: 12px}.viewer-container{display:grid;grid-template-rows:auto 1fr;grid-template-columns:10dvw 1fr;grid-template-areas:"header header" "thumbs viewport";height:100vh;height:100dvh;overflow:hidden;padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}.viewer-header-mobile{grid-area:header}.viewer-body{grid-area:viewport;display:flex;flex-direction:column;min-height:0;min-width:0;overflow:hidden}.thumbnail-strip{grid-area:thumbs;width:auto;height:auto;border-right:1px solid var(--v-border);border-bottom:none}.thumbnail-scroll-container{display:flex;flex-direction:column;gap:6px;padding:6px;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.mobile-thumbnail{width:calc(10dvw - 18px);height:calc(10dvw - 18px);border:2px solid transparent;background:var(--v-hover)}.mobile-thumbnail canvas,.mobile-thumbnail .thumb-placeholder{width:100%;height:100%;object-fit:cover;border-radius:var(--radius-sm)}.mobile-thumbnail .thumb-badge{position:absolute;top:2px;left:2px;min-width:16px;height:16px;background:#000000b3;color:#ffffffd9;font-size:10px;font-weight:600;border-radius:3px;display:flex;align-items:center;justify-content:center;padding:0 3px;pointer-events:none;z-index:1}.thumbnail-scroll-container:has(.mobile-fusion-layout){height:100%;overflow-y:hidden}.mobile-fusion-layout{flex:1;min-height:0;width:100%;background:#ffffff08;border:1px solid var(--v-border);border-radius:5px;padding:4px;cursor:pointer;display:flex;flex-direction:column;gap:2px;touch-action:manipulation;transition:all var(--transition-fast)}.mobile-fusion-layout.active{border-color:var(--v-accent);background:var(--v-accent-08)}.mobile-fusion-layout .layout-card-preview{flex:1;min-height:0;aspect-ratio:unset;display:flex}.mobile-fusion-layout .layout-card-preview>*{flex:1;min-height:0}.mobile-fusion-layout .layout-card-name{flex-shrink:0;font-size:8px;color:#fff9;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:0;line-height:1.2}.mobile-fusion-layout.active .layout-card-name{color:var(--v-accent)}.mobile-fusion-layout .preview-box{font-size:0}.header-info-row{padding:0 8px;font-size:10px}.viewport-cell-overlay-tl{top:4px;left:6px}.viewport-cell-overlay-tr{top:4px;right:24px}.viewport-cell-overlay-br{bottom:4px;right:24px}.viewport-cell-overlay-bl{bottom:4px;left:6px}}.fusion-layout-section{flex-shrink:0;display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:4px 10px 10px;background:#ffffff0a;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 -8px 24px #00000080}.fusion-layout-section.hidden{display:none}.fusion-layout-card{display:flex;flex-direction:column;align-items:center;gap:5px;padding:6px 4px;border-radius:5px;cursor:pointer;opacity:.45;transition:opacity var(--transition-fast)}.fusion-layout-card:hover{opacity:.7}.fusion-layout-card.active{opacity:1}.layout-card-preview{flex-shrink:0;width:100%;aspect-ratio:4 / 3;display:flex}.preview-grid-1x3,.preview-grid-2x2,.preview-grid-2x3,.preview-grid-1x4,.preview-grid-1x5{display:grid;gap:2px;width:100%;height:100%;grid-template-rows:1fr}.preview-grid-1x3{grid-template-columns:1fr 1fr 1fr}.preview-grid-2x2{grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr}.preview-grid-2x3{grid-template-columns:1fr 1fr 1fr;grid-template-rows:1fr 1fr}.preview-grid-1x4{grid-template-columns:1fr 1fr 1fr 1fr}.preview-grid-1x5{grid-template-columns:1fr 1fr 1fr 1fr 1fr}.preview-box{border-radius:2px;font-size:0}.preview-box.ct-only{background:#64748b80}.preview-box.fused{background:var(--v-accent-50)}.preview-box.pet-mip,.preview-box.pet-only{background:#e2e8f059}.fusion-layout-card.active .preview-box.ct-only{background:#64748bb3}.fusion-layout-card.active .preview-box.fused{background:#38bdf8b3}.fusion-layout-card.active .preview-box.pet-mip,.fusion-layout-card.active .preview-box.pet-only{background:#e2e8f080}.layout-card-name{font-size:11px;color:#ffffff80;font-weight:500;text-align:center}.fusion-layout-card.active .layout-card-name{color:#ffffffd9}@media(max-width:1023px){.fusion-layout-card{gap:4px;padding:4px 2px}.layout-card-name{font-size:10px}.preview-box{border-radius:2px}}@media(max-width:767px){.fusion-layout-card{gap:6px;padding:6px 8px;border-radius:6px}.fusion-layout-card .layout-card-preview{width:40px;height:28px}.fusion-layout-card .layout-card-name{font-size:11px}}.cine-player{position:absolute;bottom:0;left:0;right:0;height:36px;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;padding:0 12px;gap:12px;z-index:15;border-top:1px solid rgba(255,255,255,.1)}.cine-player.hidden{display:none}.cine-play-btn{width:28px;height:28px;background:var(--v-accent-bg);border:1px solid var(--v-accent-30);border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--v-accent);transition:all var(--transition-fast);flex-shrink:0}.cine-play-btn:hover{background:var(--v-accent-bg-hover);border-color:var(--v-accent-50);box-shadow:0 0 8px var(--v-accent-30)}.cine-play-btn:active{background:#38bdf859;transform:scale(.95)}.cine-icon{display:block}.cine-icon.hidden{display:none}.cine-frame-counter{color:#e2e8f0;font-size:12px;font-family:var(--font-family-mono);min-width:70px;text-align:center;flex-shrink:0}.cine-speed-control{display:flex;align-items:center;gap:8px;flex:1;max-width:180px}.cine-speed-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:#ffffff26;border-radius:2px;cursor:pointer}.cine-speed-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:var(--v-accent);border-radius:50%;cursor:pointer;box-shadow:0 0 4px var(--v-accent-40);transition:transform .1s ease}.cine-speed-slider::-webkit-slider-thumb:hover{transform:scale(1.15);box-shadow:0 0 8px #38bdf899}.cine-speed-slider::-moz-range-thumb{width:14px;height:14px;background:var(--v-accent);border-radius:50%;cursor:pointer;border:none;box-shadow:0 0 4px var(--v-accent-40)}.cine-fps-label{color:#94a3b8;font-size:11px;min-width:45px;text-align:right;flex-shrink:0}@media(max-width:600px){.cine-player{height:32px;padding:0 8px;gap:8px}.cine-play-btn{width:24px;height:24px}.cine-frame-counter{font-size:11px;min-width:60px}.cine-speed-control{max-width:120px}.cine-fps-label{font-size:10px;min-width:35px}}.annotation-context-menu{position:fixed;z-index:9000;background:var(--v-surface-alt);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-md);box-shadow:0 8px 24px #0009;padding:4px;min-width:120px;display:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.annotation-context-menu.visible{display:block}.annotation-context-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;border-radius:6px;color:#fffc;font-size:12px;font-weight:500;cursor:pointer;transition:background .12s ease,color .12s ease}.annotation-context-menu-item:hover{background:var(--v-border);color:#fff}.annotation-context-menu-delete{color:#f87171}.annotation-context-menu-delete:hover{background:#f8717126;color:#fca5a5}.study-section{grid-column:1 / -1;min-width:0;border-radius:6px;background:#ffffff08;border:1px solid rgba(255,255,255,.07)}.study-header{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:5px;cursor:pointer;transition:background var(--transition-fast);user-select:none}.study-section.expanded .study-header{border-radius:5px 5px 0 0}.study-header:hover{background:#ffffff0d}.study-chevron{flex-shrink:0;margin-left:auto;color:#fff6;transition:transform .2s ease}.study-section.expanded .study-chevron{transform:rotate(90deg)}.study-label{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}.study-date{font-size:clamp(12px,1.2vw,15px);font-weight:600;color:#ffffffd9}.study-desc{font-size:clamp(10px,1vw,13px);color:#ffffff8c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.current-study-section{border-color:#ffffff1a}.current-study-section .study-date{color:var(--v-accent)}.current-study-section .study-date.current-study-highlight{color:#f59e0b}.study-thumbnails{display:grid;grid-template-rows:0fr}.study-section.expanded .study-thumbnails{grid-template-rows:1fr}.study-thumbnails-inner{overflow:hidden;min-height:0;display:grid;grid-template-columns:1fr 1fr;gap:clamp(6px,1vw,10px);padding:0 10px}.study-section.expanded .study-thumbnails-inner{padding:4px 10px 10px}.study-section.expanded .study-thumbnails-inner{max-height:45vh;overflow-y:auto}@media(max-width:1200px){.study-thumbnails-inner{grid-template-columns:1fr}}.study-loading{display:flex;align-items:center;justify-content:center;padding:20px 0}.study-spinner{width:20px;height:20px;animation:status-spin .8s linear infinite}.prior-thumbnail{opacity:.8}.prior-thumbnail:hover{opacity:1}.study-empty{text-align:center;padding:12px 0;font-size:11px;color:#ffffff59}.cell-study-date.prior-study{color:#f59e0b}.nudge-offset{color:#ffffffd9;font-weight:600}.study-actions{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.compare-prior-btn,.open-newtab-btn{appearance:none;display:inline-flex;flex-direction:row;align-items:center;gap:5px;padding:2px 7px;font-size:clamp(9px,.9vw,11px);font-weight:500;color:#fff9;background:var(--v-hover);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm);cursor:pointer;transition:color var(--transition-fast),background var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast);white-space:nowrap}.compare-prior-btn svg,.open-newtab-btn svg{flex-shrink:0}.compare-prior-btn:hover:not(:disabled),.open-newtab-btn:hover{color:var(--v-accent);background:#ffffff1a;border-color:var(--v-accent)}.compare-prior-btn:disabled{opacity:.3;cursor:default}.compare-prior-btn.loading{opacity:.5}.compare-prior-btn.loading svg{display:none}.compare-prior-btn.loading:before{content:"";width:10px;height:10px;border:1.5px solid rgba(255,255,255,.2);border-top-color:#ffffffb3;border-radius:50%;animation:compare-btn-spin .8s linear infinite}@keyframes compare-btn-spin{to{transform:rotate(360deg)}}.current-study-highlight{color:#f59e0b}.fusion-tab-bar,.compare-tab-bar{display:flex;align-items:stretch;background:#0d0f18;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.fusion-tab-bar-tabs,.compare-tab-bar-tabs{display:flex;flex:1;min-width:0}.fusion-tab,.compare-tab{flex:1;padding:9px 10px;font-size:13px;font-weight:500;color:#ffffffa6;cursor:pointer;white-space:nowrap;background:transparent;border:none;border-right:1px solid var(--v-border);border-top:2px solid transparent;text-align:center;transition:color .15s,background .15s,border-color .15s}.fusion-tab:last-child,.compare-tab:last-child{border-right:none}.fusion-tab:hover,.compare-tab:hover{color:#fff;background:var(--v-hover)}.fusion-tab.active,.compare-tab.active{color:var(--v-accent);background:var(--v-accent-08);border-top-color:var(--v-accent)}.compare-floating-actions{position:fixed;bottom:16px;right:16px;display:flex;gap:6px;align-items:center;z-index:600}.compare-floating-btn{display:flex;align-items:center;gap:5px;padding:6px 12px;border:1px solid rgba(255,255,255,.15);border-radius:5px;background:#0a0c14;color:#ffffffa6;font-size:13px;font-weight:500;cursor:pointer;box-shadow:0 2px 6px #00000080;transition:background .15s,color .15s,border-color .15s}.compare-floating-btn svg{width:16px;height:16px;flex-shrink:0;opacity:.85}.compare-floating-btn:hover{color:#fff;border-color:#ffffff4d}.compare-floating-btn:active{opacity:.7}.compare-floating-secondary{border-color:#ffffff1a}.viewer-series-panel.compare-hidden{display:none}.viewer-body.fusion-compare-active{grid-template-columns:1fr}.panel-header{display:flex;align-items:center;justify-content:center;width:100%;min-width:0;padding:10px 14px;flex-shrink:0;border:none;border-bottom:1px solid var(--v-border);background:#ffffff08;color:#ffffffb3;cursor:pointer;transition:background .15s,color .15s;position:relative}.panel-header:hover{background:#ffffff12;color:#ffffffe6}.panel-header:hover .panel-header-chevron{color:#ffffffe6}.panel-header:active{background:#ffffff1a}.panel-header-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.panel-header-chevron{position:absolute;right:calc(clamp(6px,1vw,10px) + 10px);width:14px;height:14px;transition:transform .25s ease-out}.viewer-body.panel-collapsed{grid-template-columns:28px 1fr}.viewer-series-panel.panel-collapsed>*:not(.panel-header){display:none}.viewer-series-panel.panel-collapsed .panel-header{flex-direction:column;align-items:center;justify-content:flex-start;padding:10px 0;height:100%;border-bottom:none;gap:8px}.viewer-series-panel.panel-collapsed .panel-header-label{writing-mode:vertical-lr;transform:rotate(180deg)}.viewer-series-panel.panel-collapsed .panel-header-chevron{position:static;transform:rotate(180deg);order:-1}.compare-more-overlay{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;background:#000;position:relative;z-index:10}.compare-more-progress{position:absolute;top:0;left:0;right:0;height:5px;overflow:hidden;z-index:200;pointer-events:none}.compare-more-message{color:#ffffffb3;text-align:center}.fusion-compare-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;background:#000;gap:14px}.fusion-compare-loading-spinner{width:40px;height:40px;animation:status-spin .8s linear infinite}.fusion-compare-loading-message{color:#ffffffb3;text-align:center}.viewer-body.mtv-panel-open{grid-template-columns:clamp(120px,18vw,260px) 1fr 220px}.viewer-body.mtv-panel-open.panel-collapsed{grid-template-columns:28px 1fr 220px}.viewer-body.mtv-panel-open.fusion-compare-active{grid-template-columns:1fr 220px}@media(min-width:1024px)and (max-width:1366px){.viewer-body.mtv-panel-open{grid-template-columns:clamp(140px,15vw,230px) 1fr 200px}}@media(max-width:1023px)and (min-width:768px){.viewer-body.mtv-panel-open{grid-template-columns:clamp(120px,18vw,200px) 1fr 180px}}.mtv-sidebar{background:#0a0c14;border-left:1px solid rgba(255,255,255,.1);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:12px;color:#ddd;user-select:none;overflow:hidden;min-width:0}.mtv-sidebar.hidden{display:none}.mtv-sidebar-header{padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.1);font-weight:600;font-size:11px;color:#aaa;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.mtv-sidebar-toggle,.mtv-sidebar-clear{background:none;border:1px solid rgba(255,255,255,.15);border-radius:3px;color:#888;font-size:10px;padding:2px 8px;cursor:pointer;transition:color .15s,border-color .15s}.mtv-sidebar-toggle:hover{color:#fff;border-color:#fff6}.mtv-sidebar-clear:hover{color:#f66;border-color:#f66}.mtv-sidebar-body{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none}.mtv-sidebar-body::-webkit-scrollbar{display:none}.mtv-lesion-card{padding:10px 12px;cursor:pointer;transition:background .1s;border-left:3px solid transparent;border-bottom:1px solid rgba(255,255,255,.06)}.mtv-lesion-card:hover{background:#ffffff0d}.mtv-lesion-card.selected{background:#ffffff12;border-left-color:currentColor}.mtv-lesion-head{display:flex;align-items:center;gap:6px;margin-bottom:6px}.mtv-lesion-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.mtv-lesion-id{font-weight:700;font-size:13px}.mtv-lesion-delete{background:none;border:none;color:#555;font-size:14px;cursor:pointer;padding:0 2px;line-height:1;margin-left:auto;flex-shrink:0;transition:color .15s}.mtv-lesion-delete:hover{color:#f66}.mtv-lesion-metrics{display:grid;grid-template-columns:auto 1fr;gap:4px 10px;font-size:11px;color:#aaa}.mtv-lesion-metrics .mtv-metric-val{color:#eee;font-weight:600;font-family:SF Mono,Consolas,Monaco,monospace;font-size:11px;text-align:right}.mtv-study-tag{font-size:9px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.3px;margin-left:auto;margin-right:4px}.mtv-sidebar-totals{flex-shrink:0;padding:8px 12px;border-top:1px solid rgba(255,255,255,.12);font-size:11px;color:#aaa;display:none}.mtv-sidebar-totals.visible{display:block}.mtv-sidebar-totals b{color:#eee;font-weight:600;font-family:SF Mono,Consolas,Monaco,monospace}.mtv-sidebar-actions{display:flex;gap:6px;padding:8px 12px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.mtv-sidebar-actions .mtv-sidebar-toggle,.mtv-sidebar-actions .mtv-sidebar-clear{flex:1}.volume3d-toolbar{position:absolute;top:8px;right:8px;z-index:20;display:flex;gap:6px;align-items:center;padding:6px 10px;background:#000000a6;backdrop-filter:blur(8px);border-radius:6px;border:1px solid var(--v-border);pointer-events:auto}.volume3d-preset-select{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:4px 8px;font-size:12px;cursor:pointer;outline:none}.volume3d-preset-select:hover{background:#ffffff26}.volume3d-preset-select option{background:#1e1e2e;color:#fff}.volume3d-btn{background:#ffffff1a;color:#ccc;border:1px solid rgba(255,255,255,.15);border-radius:4px;padding:4px 10px;font-size:12px;cursor:pointer;transition:background .15s,color .15s}.volume3d-btn:hover{background:#fff3;color:#fff}.volume3d-btn.active{background:var(--v-accent-30);color:var(--v-accent);border-color:var(--v-accent-40)}
