body{margin:0;min-width:320px;min-height:100vh;background:#ececef}#root{width:100%;min-height:100vh}:root{--bg: #f2f2f3;--surface: #ffffff;--surface-muted: #f8f8f9;--surface-strong: #ececef;--text: #1f2124;--text-muted: #5f636a;--border: #d7d9dd;--border-strong: #c1c4ca;--accent: #4a4e57;--accent-hover: #3f434b;--danger: #bf4b4b;--radius: 12px;--radius-sm: 8px;--shadow: 0 6px 20px rgba(20, 21, 24, .08)}html,body{width:100%;margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--bg);color:var(--text)}*{box-sizing:inherit}.app{display:flex;flex-direction:column;width:min(1680px,calc(100vw - 20px));min-width:0;margin:0 auto 10px;gap:8px}.app-header{background:linear-gradient(145deg,#353941,#2b2f36);color:#f2f3f5;padding:1rem .5rem .75rem;min-height:72px;text-align:center;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center;word-break:break-word;box-sizing:border-box;border-radius:var(--radius);box-shadow:var(--shadow)}.app-header h1{font-size:1.2rem;font-weight:700;margin-bottom:.25rem;line-height:1.2;word-break:break-word}.app-header p{font-size:.8rem;opacity:.9;margin:0;line-height:1.2;word-break:break-word}.app-main{flex:1 1 auto;min-height:0;min-width:0;margin:0;padding:0;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.app-footer{background-color:var(--surface-strong);padding:.0625rem;text-align:center;color:var(--text-muted);border-top:1px solid var(--border);flex-shrink:0;font-size:.7rem;border-radius:var(--radius)}.file-upload-section{display:flex;flex-direction:row;align-items:stretch;gap:.25rem;padding:.25rem;background-color:transparent;border-bottom:1px solid var(--border);flex-shrink:0;width:100%;height:auto;min-height:unset;margin:0;border-radius:var(--radius);background:var(--surface-strong);box-shadow:var(--shadow)}.upload-column{flex:1 1 0%;display:flex;flex-direction:column}.upload-column h3{margin-bottom:.125rem;color:var(--text);font-size:.9rem}.file-upload-container{width:100%;display:flex;flex-direction:column;justify-content:flex-start}.file-upload-area{border:2px dashed var(--border-strong);border-radius:var(--radius);padding:.25rem;text-align:center;background-color:var(--surface);transition:all .3s ease;cursor:pointer;min-height:100px;height:auto;display:flex;align-items:center;justify-content:center;overflow:visible;width:100%;box-sizing:border-box}.file-upload-area:hover{border-color:var(--accent);background-color:var(--surface-muted)}.file-upload-area.drag-over{border-color:var(--accent);background-color:#efeff1;transform:scale(1.02)}.upload-prompt{display:flex;flex-direction:column;align-items:center;gap:.125rem}.upload-prompt h3{margin:0;color:#333;font-size:.9rem}.upload-prompt p{color:#666;margin:0;font-size:.7rem}.supported-formats{color:#999;font-size:.7rem}.browse-button{background-color:var(--accent);color:#fff;border:none;padding:.3rem .5rem;border-radius:var(--radius-sm);cursor:pointer;transition:background-color .3s ease;font-weight:500;font-size:.7rem}.browse-button:hover{background-color:var(--accent-hover)}.file-info{display:flex;align-items:center;gap:.125rem;width:100%;padding:.125rem;background-color:var(--surface-muted);border-radius:var(--radius-sm);border:1px solid var(--border)}.file-icon{color:var(--accent)}.file-details{flex:1;text-align:left;display:flex;flex-direction:column}.file-name{font-weight:600;color:#333;margin-bottom:.03125rem;font-size:.7rem}.file-dimensions{color:#666;font-size:.6rem;margin-bottom:.03125rem}.file-type{color:var(--accent);font-size:.6rem;font-weight:500;text-transform:uppercase}.clear-button{background:none;border:none;color:#999;cursor:pointer;padding:.0625rem;border-radius:1px;transition:all .3s ease}.clear-button:hover{color:#e74c3c;background-color:#fef2f2}.loading-overlay{position:fixed;inset:0;background-color:#1011128c;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:1000}.spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-message{position:absolute;top:.25rem;left:.25rem;right:.25rem;background-color:#f4e6e6;border:1px solid #d8b6b6;color:#8c3636;padding:.125rem;border-radius:3px;display:flex;align-items:center;gap:.0625rem;font-size:.7rem;z-index:20}.viewer-section{display:grid;grid-template-columns:1fr 280px;gap:.5rem;min-height:0;min-width:0;padding:.125rem;border-radius:var(--radius);background:var(--surface-strong);box-shadow:var(--shadow)}.viewer-container{background-color:var(--surface);border-radius:var(--radius);padding:.125rem;box-shadow:var(--shadow);display:flex;justify-content:center;align-items:center;height:100%;min-height:512px;min-width:512px;overflow-x:auto;overflow-y:auto;position:relative}.controls-sidebar{background-color:var(--surface);border-radius:var(--radius);padding:.25rem;box-shadow:var(--shadow);height:100%;overflow-y:auto;display:flex;flex-direction:column;min-width:260px}.viewer-controls{display:flex;flex-direction:column;gap:.25rem}.control-section{border-bottom:1px solid #e0e0e0;padding-bottom:.25rem}.control-section:last-child{border-bottom:none;padding-bottom:0}.control-section h4{margin-bottom:.3rem;color:#333;font-size:.95rem;font-weight:600}.slice-controls{display:flex;flex-direction:column;gap:.0625rem}.slice-slider{width:100%;height:4px;border-radius:1px;background:#e0e0e0;outline:none;-webkit-appearance:none;appearance:none}.slice-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:#667eea;cursor:pointer}.slice-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.slice-info{text-align:center;color:#666;font-size:.8rem}.window-level-controls{display:flex;flex-direction:column;gap:.125rem}.control-group{display:flex;align-items:center;gap:.0625rem}.control-group label{min-width:48px;font-size:.82rem;color:#666}.control-slider{flex:1;height:4px;border-radius:1px;background:#e0e0e0;outline:none;-webkit-appearance:none;appearance:none}.control-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:13px;height:13px;border-radius:50%;background:#667eea;cursor:pointer}.control-slider::-moz-range-thumb{width:13px;height:13px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.control-group span{min-width:34px;text-align:right;font-size:.8rem;color:#666}.view-controls{display:flex;align-items:center;gap:.125rem;justify-content:center}.view-mode-controls{display:flex;gap:.0625rem;justify-content:center}.mode-button{background-color:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.25rem .4rem;cursor:pointer;transition:all .3s ease;color:var(--text-muted);font-weight:500;min-width:20px;display:flex;align-items:center;justify-content:center;font-size:.7rem}.mode-button:hover,.mode-button.active{background-color:var(--accent);color:#fff;border-color:var(--accent)}.control-button{background-color:var(--surface-muted);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.25rem .35rem;cursor:pointer;transition:all .3s ease;color:var(--text-muted)}.control-button:hover{background-color:var(--accent);color:#fff;border-color:var(--accent)}.zoom-level{font-weight:600;color:#333;min-width:30px;text-align:center;font-size:.7rem}.file-info{display:flex;flex-direction:column;gap:.0625rem;font-size:.7rem}.file-info div{display:flex;justify-content:space-between}.file-info strong{color:#333}@media (max-width: 1200px){.viewer-section{grid-template-columns:1fr}.controls-sidebar{order:-1}}@media (max-width: 768px){.file-upload-section{grid-template-columns:1fr}.app-header h1{font-size:1rem}.viewer-container{min-height:150px}}canvas{max-width:100%;max-height:100%;border-radius:2px;object-fit:contain}.mpr-viewer{display:flex;align-items:center;justify-content:center;background-color:#fff;border-radius:4px;padding:.125rem;box-shadow:0 1px 2px #0000001a}.mpr-grid{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:.125rem;width:100%;height:100%;max-width:600px;max-height:500px}.mpr-view{display:flex;flex-direction:column;align-items:center;gap:.0625rem}.mpr-view h4{margin:0;color:#333;font-size:.8rem;font-weight:600}.mpr-view canvas{border:1px solid #e0e0e0;border-radius:1px}
