@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";.test-samples{border-top:1px solid #0000000f;width:100%;margin-top:16px;padding-top:14px}.test-samples-label{color:var(--text-muted);letter-spacing:.02em;margin:0 0 10px;font-size:.72rem;font-weight:500}.test-sample-grid{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.test-sample-btn{background:var(--surface-alt);color:var(--text);border:1px solid var(--panel-border);cursor:pointer;border-radius:10px;min-height:34px;padding:6px 14px;font-family:inherit;font-size:.78rem;font-weight:500;transition:background .12s,border-color .12s}.test-sample-btn:hover{border-color:var(--accent);background:#e8e3d7}.test-sample-btn[data-load-all]{background:var(--accent-bg);color:var(--accent);border-color:#0000;font-weight:600}.test-sample-btn[data-load-all]:hover{background:#b58e5e2e}:root{--bg:#f7f4eb;--surface:#fffcf5;--surface-alt:#f0ede3;--panel-border:#00000012;--accent:#b58e5e;--accent-strong:#d0af7f;--accent-bg:#b58e5e1a;--text:#2a2a2a;--text-dim:#8a8a8a;--text-muted:#b5b5b5;--danger:#cc5d5d;--warning:#bb8d39;--canvas-bg:#ebe8de;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;font-family:Inter,system-ui,sans-serif}*{box-sizing:border-box}html,body{min-height:100%;margin:0}body{background:var(--bg);min-height:100vh}#app{min-height:100vh;display:grid;overflow:hidden}#viewerShell{height:100dvh;display:grid;position:relative;overflow:hidden}#dropPanel{justify-content:center;align-items:center;min-height:100dvh;padding:24px;display:flex;overflow-y:auto}#dropPanelInner{text-align:center;justify-items:center;gap:10px;width:100%;max-width:520px;display:grid}#heroBanner{width:100%;line-height:0}#heroBanner img{width:100%;height:auto;display:block}#dropzone{background:var(--surface);border:1.5px dashed #d9cbb5;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;width:100%;min-height:180px;padding:28px 24px;transition:border-color .15s,background .15s;display:flex}#dropzone.dragging{border-color:var(--accent);background:#faf7ef}.drop-icon svg{width:56px;height:56px}.drop-text{color:var(--text);margin:12px 0 4px;font-size:.9rem;font-weight:600}.drop-hint{color:var(--text-muted);margin:0;font-size:.7rem}.drop-actions{gap:8px;margin-top:12px;display:flex}button{cursor:pointer;color:#fffdf7;background:var(--accent);-webkit-user-select:none;user-select:none;border:0;border-radius:999px;min-height:40px;padding:0 20px;font-family:inherit;font-size:.88rem;font-weight:600;transition:filter .15s,opacity .15s}button:hover:not(:disabled){filter:brightness(1.06)}button:active:not(:disabled){filter:brightness(.96)}button:disabled{opacity:.35;cursor:not-allowed}button.primary{background:linear-gradient(180deg, var(--accent-strong), var(--accent));color:#fff;box-shadow:0 6px 16px #b58e5e2e}#openFolderButton{background:var(--surface-alt);color:var(--text);border:1px solid var(--panel-border);box-shadow:none}#openFolderButton:hover{background:#e8e3d7}#networkSearchRoot{width:100%;margin-top:16px}.network-search-card{text-align:left;border-top:1px solid #0000000f;width:100%;padding-top:16px}.network-search-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.network-search-eyebrow{color:var(--text-muted);margin:0 0 4px;font-size:.72rem}.network-search-header h2{margin:0;font-size:1rem}.network-search-subtitle{color:var(--text-dim);margin:6px 0 0;font-size:.8rem}.network-search-refresh{background:var(--surface-alt);min-height:34px;color:var(--text);border:1px solid var(--panel-border);padding:0 14px}.network-search-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.network-search-action{background:var(--surface-alt);min-height:34px;color:var(--text);border:1px solid var(--panel-border);padding:0 14px}.network-search-action:disabled,.network-search-form button:disabled{opacity:.6;cursor:not-allowed}.network-search-pull{white-space:nowrap}.network-search-form{gap:8px;margin-bottom:10px;display:flex}.network-search-input{min-height:40px;font:inherit;color:var(--text);background:#fffdf7;border:1px solid #00000014;border-radius:999px;flex:1;padding:0 16px}.network-search-status{color:var(--text-dim);margin-bottom:12px;font-size:.78rem}.network-search-status[data-tone=error]{color:var(--danger)}.network-search-status[data-tone=success]{color:#5b8a5b}.network-search-columns{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;display:grid}.network-search-columns h3{color:var(--text-dim);margin:0 0 8px;font-size:.78rem}.network-item{border:1px solid var(--panel-border);width:100%;color:var(--text);box-shadow:none;background:#fffdf8;border-radius:14px;flex-direction:column;align-items:flex-start;gap:2px;margin-bottom:8px;padding:12px 14px;display:flex}.network-item strong,.network-item span,.network-item small{color:inherit}.network-item strong{font-size:.86rem}.network-item span{font-size:.8rem}.network-item small,.network-empty,.network-default-tip{color:var(--text-dim);font-size:.72rem}.network-empty,.network-default-tip{margin:0 0 8px}@media (width<=820px){.network-search-header,.network-search-form{flex-direction:column}.network-search-columns{grid-template-columns:1fr}}#dicomdirOverlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000059;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}#dicomdirPanel{background:var(--surface);border-radius:16px;flex-direction:column;width:min(500px,100vw - 32px);max-height:min(600px,100vh - 48px);display:flex;overflow:hidden;box-shadow:0 16px 48px #00000026}#dicomdirHeader{border-bottom:1px solid #0000000f;align-items:center;gap:8px;padding:16px 20px 12px;display:flex}#dicomdirHeader h3{margin:0;font-size:.95rem;font-weight:700}#dicomdirCount{color:var(--text-muted);margin-left:auto;font-size:.72rem}#dicomdirTree{flex:1;padding:8px 12px;font-size:.8rem;line-height:1.6;overflow-y:auto}.dicomdir-patient{color:var(--text);padding:6px 0 2px;font-weight:700}.dicomdir-study{color:var(--text-dim);padding-left:16px}.dicomdir-series{align-items:center;gap:6px;padding-left:32px;display:flex}.dicomdir-series label{cursor:pointer;flex:1;align-items:center;gap:5px;padding:2px 0;display:flex}.dicomdir-series input[type=checkbox]{accent-color:var(--accent);flex-shrink:0;width:14px;height:14px;margin:0}#dicomdirFooter{border-top:1px solid #0000000f;justify-content:flex-end;gap:8px;padding:12px 20px 18px;display:flex}#dicomdirFooter button{min-height:34px;padding:0 18px;font-size:.82rem}#viewerLayout{background:var(--canvas-bg);flex-direction:row;min-height:0;display:flex;overflow:hidden}#viewerSidebar{background:#0e1419;border-right:1px solid #1a2a33;flex-direction:column;flex-shrink:0;display:flex}#viewerStage{background:#0e1419;flex:1;min-width:0;position:relative;overflow:hidden}#viewerStage canvas{display:block;position:absolute;top:0;left:0}#playbackControls{-webkit-backdrop-filter:blur(12px);z-index:10;-webkit-user-select:none;user-select:none;background:#ffffffeb;border:1px solid #00000012;border-radius:999px;align-items:center;gap:4px;padding:6px 14px;display:flex;position:absolute;bottom:14px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000014}#playbackControls button{min-height:28px;color:var(--text-dim);background:0 0;border:0;border-radius:6px;padding:0 8px;font-size:.78rem;transition:background .12s,color .12s}#playbackControls button:hover:not(:disabled){color:var(--text);background:#0000000f}#playbackControls button:disabled{opacity:.25}#playbackControls button.speed-btn{border-radius:4px;justify-content:center;align-items:center;min-width:22px;min-height:22px;padding:0 4px;font-size:.8rem;display:inline-flex}#playbackControls button.speed-btn:hover:not(:disabled){background:var(--accent-bg);color:var(--accent)}#playbackControls button.loop-btn{background:#0000000f;border-radius:4px;justify-content:center;align-items:center;min-width:24px;min-height:22px;padding:0 4px;font-size:.75rem;display:inline-flex}#playbackControls button.loop-btn.active{background:var(--accent-bg);color:var(--accent)}.playback-separator{background:#00000014;width:1px;height:16px;margin:0 4px}#speedDisplay{color:var(--text-dim);text-align:center;min-width:24px;font-size:.65rem;font-weight:700}#sliceCounter{color:var(--text-dim);text-align:center;min-width:48px;margin-left:4px;font-size:.68rem;font-weight:600}.float-button{z-index:20;-webkit-backdrop-filter:blur(8px);width:36px;height:36px;min-height:0;color:var(--text-dim);background:#ffffffeb;border:1px solid #00000012;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.2rem;font-weight:400;transition:background .15s,color .15s;display:flex;position:fixed;top:16px;right:16px;box-shadow:0 2px 8px #0000000f}.float-button:hover{color:var(--text);background:#fff}#loadProgressWrap{z-index:30;background:var(--surface);border:1px solid var(--panel-border);border-radius:16px;align-items:center;gap:10px;padding:16px 24px;display:flex;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 8px 24px #0000001a}#loadProgress{appearance:none;background:#00000014;border-radius:999px;width:120px;height:4px}#loadProgress::-webkit-progress-bar{background:#00000014;border-radius:999px}#loadProgress::-webkit-progress-value{background:var(--accent);border-radius:999px}#loadProgressText{color:var(--text-dim);text-align:right;min-width:28px;font-size:.72rem;font-weight:600}#messageBox{z-index:100;text-align:center;border-radius:14px;max-width:560px;padding:10px 18px;font-size:.82rem;font-weight:600;line-height:1.5;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000014}#messageBox.message-error{color:#b14545;background:#fef2f2;border:1px solid #cc5d5d33}#messageBox.message-warning{color:#8b6b2e;background:#fffaf0;border:1px solid #bb8d3940}#viewport{cursor:grab;touch-action:none}#viewport.middle-zooming{cursor:nesw-resize}#viewport.window-dragging{cursor:crosshair}#viewport:active{cursor:grabbing}#viewerShell.cinema-mode #playbackControls{opacity:0;transition:opacity .3s}#viewerShell.cinema-mode #playbackControls:hover{opacity:1}#seriesInfo{color:#8a9aa5;-webkit-user-select:none;user-select:none;background:#0e1419;border-top:1px solid #1a2a33;align-items:center;gap:12px;min-height:30px;padding:6px 16px;font-family:system-ui,sans-serif;font-size:.78rem;display:flex}.sidebar-pending-series{cursor:pointer;opacity:.82;background:#121a22;border:1px solid #1e2a33;flex-direction:column;align-items:center;width:130px;height:130px;padding:0;font-family:system-ui,sans-serif;transition:background .15s,border-color .15s;display:flex;position:relative}.sidebar-pending-series:hover{opacity:1;background:#1a2530;border-color:#4a8bbf}.sidebar-pending-placeholder{color:#4a8bbf;letter-spacing:.05em;background:#121a22;justify-content:center;align-items:center;width:100%;height:100%;font-size:1.6rem;font-weight:700;display:flex}.sidebar-pending-placeholder.has-canvas{background:#1a2530}.sidebar-pending-series .sidebar-thumb-label{color:#c4d0d9;text-align:center;white-space:nowrap;text-overflow:ellipsis;background:#0e1419d9;padding:2px 4px;font-size:.65rem;position:absolute;bottom:0;left:0;right:0;overflow:hidden}.sidebar-pending-loading{color:#8a9aa5;text-align:center;-webkit-user-select:none;user-select:none;padding:4px 6px;font-size:.7rem}#thumbSidebar{scroll-behavior:auto;background:#0e1419;flex-direction:column;flex-shrink:0;align-items:center;gap:8px;width:180px;min-height:0;padding:10px 8px;display:flex;overflow:hidden auto}#thumbSidebar::-webkit-scrollbar{width:3px}#thumbSidebar::-webkit-scrollbar-track{background:0 0}#thumbSidebar::-webkit-scrollbar-thumb{background:#2a3a44;border-radius:2px}.sidebar-thumb{cursor:pointer;background:#15202a;border:2px solid #0000;border-radius:8px;flex:none;width:130px;height:130px;transition:border-color .12s,background .12s;position:relative;overflow:hidden}.sidebar-thumb:hover{border-color:#4a6a7a}.sidebar-thumb.active{background:#b58e5e14;border-color:#b58e5e}.sidebar-thumb.active:before{content:"";z-index:2;background:#b58e5e;border-radius:0 2px 2px 0;width:3px;height:80%;position:absolute;top:10%;left:0}.sidebar-thumb.active .sidebar-thumb-label{color:#fff;background:#b58e5ed9}.sidebar-thumb canvas{image-rendering:auto;width:100%;height:100%;display:block}.sidebar-thumb-label{color:#c4d0d9;pointer-events:none;background:#000000bf;border-radius:3px;padding:1px 5px;font-family:system-ui,sans-serif;font-size:.58rem;font-weight:600;line-height:1.3;position:absolute;bottom:2px;left:2px}@media (width<=768px){#dropPanel{justify-content:flex-start;align-items:flex-start;padding:12px 12px 18px;overflow-y:auto}#dropPanelInner{gap:8px;width:min(100%,560px);padding-top:4px}#heroBanner{margin-top:2px}#heroBanner img{display:block}#dropzone{width:100%;min-height:140px;padding:20px 18px}.drop-icon svg{width:44px;height:44px}.drop-text{font-size:.85rem}.drop-actions{flex-direction:column;width:100%}.drop-actions button{width:100%}.test-sample-grid{flex-direction:column}.test-sample-btn{width:100%;max-width:280px}#viewerLayout{flex-direction:column}#viewerStage{order:1}#thumbSidebar{border-top:1px solid #1a2a33;border-left:none;flex-direction:row;flex-shrink:0;order:2;gap:5px;width:100%;height:96px;padding:6px 8px;overflow:auto hidden}.sidebar-thumb{flex:none;width:84px;height:84px}#playbackControls{gap:3px;padding:5px 10px}#playbackControls button{min-width:32px;min-height:32px;padding:0 9px;font-size:.82rem}#playbackControls button.speed-btn,#playbackControls button.loop-btn{min-width:26px;min-height:26px;font-size:.85rem}#speedDisplay{min-width:28px;font-size:.7rem}#sliceCounter{min-width:52px;font-size:.72rem}.float-button{width:32px;height:32px;font-size:1rem;top:10px;right:10px}}
