.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;padding:40px;width:100%;max-width:440px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:35px}.medical-icon{width:60px;height:60px;color:#667eea;margin-bottom:15px}.login-header h1{font-size:28px;color:#2d3748;margin-bottom:8px;font-weight:700}.login-header p{color:#718096;font-size:15px}.form-group{margin-bottom:25px}.form-group label{display:block;margin-bottom:8px;color:#2d3748;font-weight:600;font-size:14px}.form-group input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;transition:all .3s ease;background:#f7fafc}.form-group input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{opacity:.6;cursor:not-allowed}.error-message{background:#fed7d7;color:#c53030;padding:12px 16px;border-radius:10px;margin-bottom:20px;font-size:14px;border-left:4px solid #c53030}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 4px 15px #667eea66}.login-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea80}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.7;cursor:not-allowed}.login-footer{margin-top:30px;padding-top:25px;border-top:1px solid #e2e8f0}.privacy-notice{display:flex;align-items:center;justify-content:center;gap:8px;color:#718096;font-size:13px}.lock-icon{width:18px;height:18px;color:#667eea}.viewer-container{width:100%;min-height:100vh;background:#f7fafc;display:flex;flex-direction:column}.viewer-header{background:#fff;padding:20px 30px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:12px}.header-icon{width:32px;height:32px;color:#667eea}.viewer-header h1{font-size:24px;color:#2d3748;font-weight:700}.header-right{display:flex;align-items:center;gap:15px}.user-email{color:#718096;font-size:14px}.logout-button{padding:10px 20px;background:#e53e3e;color:#fff;border:none;border-radius:8px;font-weight:600;transition:all .2s ease}.logout-button:hover{background:#c53030;transform:translateY(-1px)}.viewer-content{display:flex;flex:1;overflow:hidden}.sidebar{width:320px;background:#fff;border-right:1px solid #e2e8f0;display:flex;flex-direction:column;overflow-y:auto}.files-section{padding:25px;flex:1}.files-section h2{font-size:16px;color:#2d3748;margin-bottom:15px;font-weight:600}.files-list{display:flex;flex-direction:column;gap:15px}.file-group{margin-bottom:15px}.folder-header{width:100%;display:flex;align-items:center;gap:10px;padding:12px 14px;background:linear-gradient(135deg,#667eea1a,#764ba21a);border:none;border-radius:8px;border-left:3px solid #667eea;cursor:pointer;transition:all .2s ease;margin-bottom:8px}.folder-header:hover{background:linear-gradient(135deg,#667eea26,#764ba226);transform:translate(2px)}.folder-icon{width:20px;height:20px;color:#667eea;flex-shrink:0}.folder-name{font-size:13px;font-weight:700;color:#667eea;text-transform:uppercase;letter-spacing:.5px;flex:1;text-align:left}.folder-count{font-size:12px;color:#718096;font-weight:600}.expand-icon{width:16px;height:16px;color:#667eea;transition:transform .2s ease;flex-shrink:0}.expand-icon.expanded{transform:rotate(180deg)}.file-list-items{display:flex;flex-direction:column;gap:6px;padding-left:10px}.no-files{color:#a0aec0;font-size:14px;text-align:center;padding:20px}.file-item{background:#f7fafc;border-radius:8px;overflow:hidden;transition:all .2s ease}.file-item:hover{background:#edf2f7}.file-item.active{background:#e6f2ff;border:2px solid #667eea}.file-name{width:100%;padding:10px 12px;background:transparent;border:none;text-align:left;display:flex;align-items:center;gap:8px;color:#2d3748;font-size:13px}.file-number{min-width:30px;padding:2px 8px;background:#edf2f7;border-radius:4px;font-size:11px;font-weight:600;color:#4a5568;flex-shrink:0}.file-name-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-icon{width:18px;height:18px;color:#667eea;flex-shrink:0}.pagination-controls{display:flex;flex-direction:column;gap:8px;margin-top:12px}.show-more,.show-less{width:100%;padding:10px;background:#edf2f7;border:none;border-radius:6px;color:#667eea;font-size:13px;font-weight:600;transition:all .2s ease;cursor:pointer}.show-more:hover,.show-less:hover{background:#e2e8f0;color:#5568d3}.show-less{background:#fef5e7;color:#d69e2e}.show-less:hover{background:#feebc8;color:#c97a1e}.viewer-main{flex:1;padding:30px;overflow-y:auto;display:flex;flex-direction:column;gap:20px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:#a0aec0}.empty-icon{width:120px;height:120px;margin-bottom:20px;opacity:.5}.empty-state h2{font-size:24px;color:#4a5568;margin-bottom:10px}.empty-state p{font-size:16px}.viewer-tools{display:flex;gap:20px;background:#fff;padding:20px 25px;border-radius:12px;box-shadow:0 2px 8px #0000001a;flex-wrap:wrap;align-items:flex-start}.tool-section{display:flex;flex-direction:column;gap:8px}.tool-label{font-size:11px;font-weight:700;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.tool-group{display:flex;gap:8px;flex-wrap:wrap}.viewer-tools button{padding:10px 16px;background:#edf2f7;color:#2d3748;border:1px solid #cbd5e0;border-radius:8px;font-weight:600;font-size:14px;transition:all .2s ease;cursor:pointer;white-space:nowrap}.viewer-tools button:hover{background:#e2e8f0;border-color:#667eea;color:#667eea;transform:translateY(-1px)}.viewer-tools button.active{background:#667eea;color:#fff;border-color:#667eea}.viewer-tools button.active:hover{background:#5568d3}.viewer-tools button.playing{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.reset-button{background:#e53e3e!important;color:#fff!important;border:none!important;margin-left:auto}.reset-button:hover{background:#c53030!important;color:#fff!important}.dicom-display{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden;position:relative}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:10}.loading-overlay .spinner{border-color:#ffffff4d;border-top-color:#fff}.dicom-canvas{display:block;cursor:default}.dicom-canvas.panning{cursor:grab}.dicom-canvas.panning:active{cursor:grabbing}.image-info{background:#fff;padding:25px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.image-info h3{font-size:18px;color:#2d3748;margin-bottom:15px;font-weight:600}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:15px}.info-item{display:flex;flex-direction:column;gap:5px}.info-label{font-size:12px;color:#718096;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.info-value{font-size:15px;color:#2d3748;font-weight:500}.keyboard-shortcuts{background:#fff;padding:20px 25px;border-radius:12px;box-shadow:0 2px 8px #0000001a}.keyboard-shortcuts h4{font-size:16px;color:#2d3748;margin-bottom:15px;font-weight:600}.shortcuts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px}.shortcut-item{display:flex;align-items:center;gap:10px;font-size:13px;color:#4a5568}.shortcut-item kbd{padding:4px 10px;background:#edf2f7;border:1px solid #cbd5e0;border-radius:4px;font-family:monospace;font-size:12px;font-weight:600;color:#667eea;min-width:40px;text-align:center;box-shadow:0 2px #cbd5e0}.shortcut-item span{color:#718096}.cine-player{background:linear-gradient(135deg,#667eea,#764ba2);padding:25px 30px;border-radius:12px;box-shadow:0 4px 20px #667eea4d;color:#fff}.cine-header{margin-bottom:15px}.cine-header h3{font-size:18px;color:#fff;margin-bottom:5px;font-weight:700}.cine-header p{font-size:14px;color:#ffffffe6}.cine-controls{display:flex;flex-direction:column;gap:15px}.cine-play-button{padding:16px 32px!important;background:#fff!important;color:#667eea!important;border:none!important;border-radius:8px;font-weight:700!important;font-size:16px!important;transition:all .3s ease;cursor:pointer;box-shadow:0 4px 12px #0003}.cine-play-button:hover{background:#f7fafc!important;transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.cine-info{font-size:14px;color:#fffffff2;font-weight:400;text-align:center}@media (max-width: 768px){.viewer-content{flex-direction:column}.sidebar{width:100%;border-right:none;border-bottom:1px solid #e2e8f0}.viewer-header{flex-direction:column;gap:15px}.header-right{width:100%;justify-content:space-between}}.cine-container{width:100%;min-height:100vh;background:#1a202c;display:flex;flex-direction:column;color:#fff}.cine-header-bar{background:#2d3748;padding:15px 30px;display:flex;align-items:center;gap:20px;box-shadow:0 2px 10px #0000004d}.back-button{padding:10px 20px;background:#4a5568;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#667eea;transform:translate(-2px)}.cine-header-bar h1{font-size:20px;font-weight:700;color:#fff}.cine-content{flex:1;display:flex;flex-direction:column;padding:20px;gap:20px}.cine-display{background:#000;border-radius:12px;overflow:hidden;position:relative;box-shadow:0 4px 20px #00000080}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;z-index:10}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:15px}.cine-canvas{display:block}.cine-controls-panel{background:#2d3748;padding:25px;border-radius:12px;display:flex;flex-direction:column;gap:20px;box-shadow:0 4px 20px #0000004d}.progress-section{display:flex;flex-direction:column;gap:12px}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-label{font-size:16px;font-weight:700;color:#fff}.current-file-name{font-size:12px;color:#a0aec0;font-family:monospace;max-width:400px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.progress-slider{width:100%;height:8px;border-radius:4px;background:#4a5568;outline:none;-webkit-appearance:none;cursor:pointer}.progress-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;transition:all .2s ease}.progress-slider::-webkit-slider-thumb:hover{background:#5568d3;transform:scale(1.2)}.progress-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#667eea;cursor:pointer;border:none}.playback-controls{display:flex;flex-direction:column;gap:20px}.nav-buttons{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}.nav-buttons button,.speed-buttons button{padding:12px 24px;background:#4a5568;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.nav-buttons button:hover,.speed-buttons button:hover{background:#667eea;transform:translateY(-2px)}.play-button{background:#48bb78!important;font-size:16px!important;padding:14px 32px!important}.play-button:hover{background:#38a169!important}.play-button.playing{background:#ed8936!important;animation:pulse-orange 1.5s infinite}@keyframes pulse-orange{0%,to{box-shadow:0 0 #ed8936b3}50%{box-shadow:0 0 0 15px #ed893600}}.speed-control{display:flex;flex-direction:column;gap:12px;align-items:center}.speed-control label{font-size:14px;color:#cbd5e0;font-weight:600}.speed-buttons{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.speed-buttons button{padding:8px 16px;font-size:13px}.speed-buttons button.active{background:#667eea;box-shadow:0 0 0 3px #667eea4d}.image-metadata{display:flex;gap:20px;flex-wrap:wrap;padding:15px 0;border-top:1px solid #4a5568;border-bottom:1px solid #4a5568}.meta-item{display:flex;gap:8px;align-items:center}.meta-label{font-size:12px;color:#a0aec0;font-weight:600;text-transform:uppercase}.meta-item span:last-child{font-size:14px;color:#fff;font-weight:500}.keyboard-help{display:flex;gap:15px;justify-content:center;flex-wrap:wrap;padding:15px;background:#1a202c;border-radius:8px}.help-item{display:flex;align-items:center;gap:8px;font-size:13px;color:#cbd5e0}.help-item kbd{padding:4px 10px;background:#4a5568;border:1px solid #718096;border-radius:4px;font-family:monospace;font-size:12px;font-weight:600;color:#667eea;min-width:35px;text-align:center;box-shadow:0 2px #2d3748}@media (max-width: 768px){.cine-header-bar{flex-direction:column;gap:10px}.nav-buttons,.speed-buttons{flex-direction:column;width:100%}.nav-buttons button,.speed-buttons button{width:100%}}.app{min-height:100vh;display:flex;align-items:center;justify-content:center}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;color:#fff}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{to{transform:rotate(360deg)}}*{margin:0;padding:0;box-sizing:border-box}body{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:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{min-height:100vh}button{cursor:pointer;font-family:inherit}input{font-family:inherit}
