@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--bg-primary: #111318;--bg-secondary: #1a1d24;--bg-card: #21252d;--bg-elevated: #282d37;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--accent-orange: #f97316;--accent-blue: #3b82f6;--accent-blue-subtle: rgba(59, 130, 246, .15);--status-success: #22c55e;--status-warning: #eab308;--status-error: #ef4444;--border-subtle: 1px solid rgba(255, 255, 255, .06);--border-divider: 1px solid rgba(255, 255, 255, .08);--shadow-card: 0 2px 8px rgba(0, 0, 0, .3);--shadow-elevated: 0 8px 24px rgba(0, 0, 0, .4);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--transition: all .2s ease}*{box-sizing:border-box}body{margin:0;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5}h1{font-size:1.75rem;font-weight:600;letter-spacing:-.02em}h2{font-size:1.25rem;font-weight:600;letter-spacing:-.01em}h3{font-size:1rem;font-weight:500}h1,h2,h3,h4,h5{margin:0;color:var(--text-primary)}.glass-panel{background:var(--bg-card);border:var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-card);transition:var(--transition)}.glass-panel:hover{background:var(--bg-elevated);box-shadow:var(--shadow-elevated)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::selection{background:var(--accent-blue);color:#fff}.status-indicator{width:8px;height:8px;border-radius:50%;background:var(--text-muted)}.status-indicator.online{background:var(--status-success)}.status-indicator.error{background:var(--status-error)}.status-indicator.warning{background:var(--status-warning)}:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden;background:var(--bg-primary)}header{height:56px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--bg-secondary);border-bottom:var(--border-divider);flex-shrink:0}.logo-group{display:flex;align-items:center;gap:12px}.logo-icon{height:48px;width:auto;object-fit:contain;margin-right:8px}.mascot-image{width:180px;height:auto;margin-bottom:16px;opacity:.95}.brand-text{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.brand-text .siung{color:var(--accent-orange)}.brand-text .med{color:var(--accent-blue)}.brand-tagline{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-left:16px;padding-left:16px;border-left:1px solid var(--text-muted)}.header-right{display:flex;align-items:center;gap:20px}.system-time{font-size:.8rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.user-profile{display:flex;align-items:center;gap:10px}.user-name{font-size:.85rem;color:var(--text-secondary)}.avatar{width:32px;height:32px;border-radius:50%;background:var(--accent-blue);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.7rem}main{flex:1;display:grid;grid-template-columns:240px 1fr 300px;gap:1px;background:var(--bg-primary);overflow:hidden}.sidebar{background:var(--bg-secondary);display:flex;flex-direction:column;border-right:var(--border-divider);border-radius:0;box-shadow:none}.nav-section{padding:16px}.nav-title{font-size:.65rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:12px;padding:0 12px}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);color:var(--text-secondary);font-size:.875rem}.nav-item:hover{background:#ffffff0a;color:var(--text-primary)}.nav-item.active{background:var(--accent-blue-subtle);color:var(--accent-blue)}.nav-icon{font-size:1rem;width:20px;text-align:center}.main-content{display:flex;flex-direction:column;padding:20px;overflow-y:auto;background:var(--bg-primary)}.content-header{margin-bottom:20px}.page-title{font-size:1.25rem;font-weight:600}.viewer-area{flex:1;min-height:300px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px dashed rgba(255,255,255,.1);border-radius:var(--radius-lg)}.viewer-placeholder{text-align:center;color:var(--text-muted)}.viewer-placeholder-icon{font-size:3rem;margin-bottom:12px;opacity:.4}.right-panel{background:var(--bg-secondary);display:flex;flex-direction:column;gap:1px;overflow-y:auto;border-left:var(--border-divider);border-radius:0;box-shadow:none}.panel-section{padding:20px;background:var(--bg-secondary)}.panel-title{font-size:.7rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);margin-bottom:16px}.status-card{padding:14px;margin-bottom:10px;border-radius:var(--radius-md);background:var(--bg-card);border:var(--border-subtle)}.status-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.status-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted)}.status-value{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.status-detail{font-size:.75rem;color:var(--text-secondary)}.uploader-container{padding:24px;text-align:center;border:1px dashed rgba(255,255,255,.15);border-radius:var(--radius-md);background:var(--bg-card);transition:var(--transition);cursor:pointer}.uploader-container:hover{border-color:var(--accent-blue);background:var(--accent-blue-subtle)}.upload-icon{font-size:2rem;margin-bottom:12px;opacity:.6}.upload-text{font-size:.9rem;color:var(--text-primary);margin-bottom:4px}.upload-subtext{font-size:.75rem;color:var(--text-muted)}.btn-primary{width:100%;padding:12px 20px;margin-top:16px;background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:500;font-size:.85rem;cursor:pointer;transition:var(--transition)}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.launch-btn{padding:14px 28px;background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:#fff;font-weight:500;font-size:.9rem;cursor:pointer;transition:var(--transition)}.launch-btn:hover{background:#2563eb}.file-list-container{margin-top:12px;max-height:180px;overflow-y:auto}.file-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:var(--bg-elevated);border-radius:var(--radius-sm);margin-bottom:6px}.file-info{display:flex;flex-direction:column}.file-name{font-size:.85rem;color:var(--text-primary)}.file-meta{font-size:.7rem;color:var(--text-muted)}.status-badge{padding:3px 8px;border-radius:12px;font-size:.65rem;font-weight:500;text-transform:uppercase}.status-badge.success{background:#22c55e26;color:var(--status-success)}.status-badge.error{background:#ef444426;color:var(--status-error)}.status-badge.pending{background:#eab30826;color:var(--status-warning)}.status-bar{height:32px;display:flex;align-items:center;justify-content:space-between;padding:0 24px;background:var(--bg-secondary);border-top:var(--border-divider);font-size:.7rem;color:var(--text-muted)}.status-bar-left,.status-bar-right{display:flex;align-items:center;gap:16px}.status-item{display:flex;align-items:center;gap:6px}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--status-success)}.status-dot.online{background:var(--status-success)}.status-dot.offline{background:var(--status-error)}.study-list-container{background:var(--bg-card);border-radius:var(--radius-lg);padding:20px;height:calc(100vh - 180px);overflow-y:auto}.study-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.study-list-header h2{font-size:1rem;font-weight:600;color:var(--text-primary)}.btn-refresh{padding:6px 12px;background:transparent;border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-size:.8rem;transition:var(--transition)}.btn-refresh:hover{border-color:var(--accent-blue);color:var(--text-primary)}.study-list-table{width:100%;border-collapse:collapse}.study-list-table th,.study-list-table td{padding:12px 8px;text-align:left;border-bottom:1px solid rgba(255,255,255,.06)}.study-list-table th{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:500}.study-list-table td{font-size:.85rem;color:var(--text-secondary)}.study-list-table tbody tr:hover{background:#3b82f614}.btn-launch{padding:6px 12px;background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-size:.75rem;transition:var(--transition)}.btn-launch:hover{background:#2563eb}.study-list-loading,.study-list-error,.study-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:200px;gap:12px;color:var(--text-muted)}.loading-spinner{font-size:2rem;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-retry{padding:8px 16px;background:var(--accent-blue);border:none;border-radius:var(--radius-sm);color:#fff;cursor:pointer}.btn-retry:hover{background:#2563eb}.viewer-loader{position:absolute;top:0;left:0;width:100%;height:100%;background:#000;z-index:9999;display:flex;align-items:center;justify-content:center;font-family:Inter,system-ui,sans-serif}.loader-content{text-align:center;max-width:400px;width:100%;animation:fadeIn .5s ease-out}.pulse-circle{width:80px;height:80px;margin:0 auto 2rem;background:#f973161a;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 0 30px #f9731633}.pulse-circle:after{content:"";position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid rgba(249,115,22,.5);animation:pulse-ring 2s cubic-bezier(.215,.61,.355,1) infinite}.medical-icon{width:40px;height:40px;animation:heartbeat 2s ease-in-out infinite}.loading-title{color:#fff;font-size:1.5rem;font-weight:600;margin-bottom:2rem;letter-spacing:1px}.progress-container{background:#ffffff1a;height:4px;border-radius:2px;margin-bottom:1rem;overflow:hidden;position:relative}.progress-bar{height:100%;background:linear-gradient(90deg,#f97316,#fb923c);border-radius:2px;transition:width .3s ease-out;box-shadow:0 0 10px #f9731680}.status-text{color:#94a3b8;font-size:.875rem;height:1.5rem;font-weight:500}.security-badge{margin-top:3rem;display:inline-flex;align-items:center;padding:6px 12px;background:#ffffff0d;border-radius:20px;color:#64748b;font-size:.75rem;border:1px solid rgba(255,255,255,.05)}@keyframes pulse-ring{0%{transform:scale(.8);opacity:.8}to{transform:scale(2);opacity:0}}@keyframes heartbeat{0%{transform:scale(1)}14%{transform:scale(1.1)}28%{transform:scale(1)}42%{transform:scale(1.1)}70%{transform:scale(1)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
