body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-box{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;max-width:400px;padding:40px;width:100%}.login-box h1{color:#333;font-size:2em;margin-bottom:10px;text-align:center}.login-box h2{color:#666;font-size:1.5em;font-weight:400;margin-bottom:20px;text-align:center}.role-toggle{display:flex;gap:10px;margin-bottom:30px}.role-toggle button{background:#f0f0f0;border:2px solid #ddd;border-radius:6px;cursor:pointer;flex:1 1;font-weight:600;padding:10px;transition:all .3s}.role-toggle button.active{background:#667eea;border-color:#667eea;color:#fff}.role-toggle button:hover{border-color:#667eea}.form-group{margin-bottom:20px}.form-group label{font-weight:500;margin-bottom:5px}.form-group input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:12px;transition:border-color .3s;width:100%}.form-group input:focus{border-color:#667eea;outline:none}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{padding-right:45px}.password-toggle{align-items:center;background:none;border:none;color:#999;cursor:pointer;display:flex;justify-content:center;padding:5px;position:absolute;right:10px;transition:color .3s}.password-toggle:hover{color:#667eea}.form-group input.valid{border-color:#22c55e}.form-group input.invalid{border-color:#ef4444}.validation-hint{display:block;font-size:12px;margin-top:5px;padding-left:2px}.validation-hint.error{color:#ef4444}.error-message{background:#fee;border-radius:6px;color:#c33;font-size:14px;margin-bottom:20px;padding:10px}.btn-primary{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px;transition:background .3s;width:100%}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.toggle-form{margin-top:20px;text-align:center}.toggle-form p{color:#666;font-size:14px}.toggle-form button{background:none;border:none;color:#667eea;cursor:pointer;font-size:14px;text-decoration:underline}.toggle-form button:hover{color:#5568d3}.doctor-info{background:#e0e7ff;border-left:4px solid #667eea;border-radius:8px;margin-top:20px;padding:15px;text-align:center}.doctor-info .info-text{color:#4338ca;font-size:14px;line-height:1.6;margin:0}.doctor-info strong{display:block;font-size:15px;margin-bottom:5px}.toast{align-items:center;animation:slideIn .3s ease-out;border-radius:8px;bottom:30px;box-shadow:0 4px 12px #00000026;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;gap:12px;max-width:500px;min-width:300px;padding:16px 20px;position:fixed;right:30px;z-index:10000}.toast-success{background:#10b981;color:#fff}.toast-error{background:#ef4444;color:#fff}.toast-info{background:#3b82f6;color:#fff}.toast-icon{align-items:center;background:#fff3;border-radius:50%;display:flex;flex-shrink:0;font-size:20px;font-weight:700;height:24px;justify-content:center;width:24px}.toast-message{flex:1 1;font-size:14px;line-height:1.5}.toast-close{align-items:center;background:none;border:none;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:24px;height:24px;justify-content:center;opacity:.7;padding:0;transition:opacity .2s;width:24px}.toast-close:hover{opacity:1}.file-upload-enhanced{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:20px;width:100%}.file-upload-enhanced .upload-area{display:flex;flex-direction:column;gap:20px}.file-upload-enhanced .drag-drop-zone{align-items:center;background:#f9fafb;border:2px dashed #d1d5db;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:40px;position:relative;text-align:center;transition:all .3s ease}.file-upload-enhanced .drag-drop-zone:hover{background:#ede9fe;border-color:#667eea}.file-upload-enhanced .drag-drop-zone.active{background:#ede9fe;border-color:#667eea;transform:scale(1.02)}.file-upload-enhanced .drag-drop-zone.active .upload-icon{color:#667eea;transform:scale(1.2)}.file-upload-enhanced .upload-icon{font-size:48px;margin:0 0 15px;transition:all .3s ease}.file-upload-enhanced .upload-text{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 8px}.file-upload-enhanced .upload-subtext{color:#6b7280;font-size:14px;margin:0 0 12px}.file-upload-enhanced .upload-allowed{color:#9ca3af;font-size:12px;margin:0}.file-upload-enhanced .file-preview-thumbnail{align-items:center;background:#f3f4f6;border:2px solid #e5e7eb;border-radius:8px;display:flex;height:120px;justify-content:center;margin:15px 0;overflow:hidden;width:120px}.file-upload-enhanced .file-preview-thumbnail img{height:100%;object-fit:cover;width:100%}.file-upload-enhanced .file-info{align-items:center;display:flex;flex-direction:column;gap:8px;text-align:center}.file-upload-enhanced .file-name{color:#1f2937;font-size:16px;font-weight:600;margin:0;max-width:300px;word-break:break-word}.file-upload-enhanced .file-size{color:#6b7280;font-size:14px;margin:0}.file-upload-enhanced .progress-bar{background:#e5e7eb;border-radius:4px;height:8px;margin-top:10px;overflow:hidden;width:100%}.file-upload-enhanced .progress-fill{align-items:center;background:linear-gradient(90deg,#667eea,#764ba2);display:flex;height:100%;justify-content:center;position:relative;transition:width .3s ease}.file-upload-enhanced .progress-text{color:#fff;font-size:10px;font-weight:700;position:absolute}.file-upload-enhanced .btn-clear-file{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:18px;height:32px;justify-content:center;position:absolute;right:10px;top:10px;transition:all .2s ease;width:32px;z-index:10}.file-upload-enhanced .btn-clear-file:hover{background:#dc2626;transform:scale(1.1)}.file-upload-enhanced .btn-clear-file:disabled{cursor:not-allowed;opacity:.5}.file-upload-enhanced .upload-form{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;display:flex;flex-direction:column;gap:15px;padding:20px}.file-upload-enhanced .form-group{display:flex;flex-direction:column;gap:8px}.file-upload-enhanced .form-group label{color:#374151;font-size:14px;font-weight:600}.file-upload-enhanced .form-select,.file-upload-enhanced .form-textarea{border:1px solid #d1d5db;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;transition:all .2s ease}.file-upload-enhanced .form-select:focus,.file-upload-enhanced .form-textarea:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.file-upload-enhanced .form-select:disabled,.file-upload-enhanced .form-textarea:disabled{background:#f3f4f6;color:#9ca3af;cursor:not-allowed}.file-upload-enhanced .form-textarea{min-height:80px;resize:vertical}.file-upload-enhanced .upload-actions{display:flex;gap:10px;justify-content:flex-end}.file-upload-enhanced .btn-cancel,.file-upload-enhanced .btn-upload-submit{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s ease}.file-upload-enhanced .btn-upload-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.file-upload-enhanced .btn-upload-submit:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.file-upload-enhanced .btn-upload-submit:disabled{cursor:not-allowed;opacity:.5}.file-upload-enhanced .btn-cancel{background:#e5e7eb;color:#374151}.file-upload-enhanced .btn-cancel:hover:not(:disabled){background:#d1d5db}.file-upload-enhanced .btn-cancel:disabled{cursor:not-allowed;opacity:.5}.file-upload-compact{align-items:center;display:flex;gap:8px;padding:8px}.file-upload-compact .btn-upload-compact{background:none;border:none;border-radius:4px;cursor:pointer;font-size:20px;padding:4px 8px;transition:all .2s ease}.file-upload-compact .btn-upload-compact:hover:not(:disabled){background:#f3f4f6}.file-upload-compact .btn-upload-compact:disabled{cursor:not-allowed;opacity:.5}.file-upload-compact .file-name-compact{color:#374151;flex:1 1;font-size:14px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.file-upload-enhanced{padding:15px}.file-upload-enhanced .drag-drop-zone{padding:30px 15px}.file-upload-enhanced .file-name{font-size:14px;max-width:200px}.file-upload-enhanced .upload-actions{flex-direction:column;gap:8px}.file-upload-enhanced .btn-cancel,.file-upload-enhanced .btn-upload-submit{width:100%}}@media (max-width:480px){.file-upload-enhanced .drag-drop-zone{padding:20px 10px}.file-upload-enhanced .upload-icon{font-size:36px}.file-upload-enhanced .upload-text{font-size:16px}.file-upload-enhanced .file-preview-thumbnail{height:100px;width:100px}}.file-preview-modal-overlay{align-items:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.file-preview-modal{animation:slideUp .3s ease;background:#fff;border-radius:16px;box-shadow:0 25px 80px #00000059;display:flex;flex-direction:column;height:90vh;margin:0 auto;max-height:900px;max-width:1400px;overflow:hidden;width:95vw}.file-preview-modal .modal-header{align-items:flex-start;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.file-preview-modal .header-info{flex:1 1;min-width:0}.file-preview-modal .modal-header h2{color:#1f2937;font-size:18px;font-weight:700;line-height:1.3;margin:0 0 8px;word-break:break-word}.file-preview-modal .file-meta{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.file-preview-modal .badge{background:linear-gradient(135deg,#dbeafe,#e0e7ff);border-radius:6px;color:#1e40af;font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 10px;text-transform:uppercase}.file-preview-modal .file-size{color:#6b7280;font-size:13px}.file-preview-modal .btn-close{align-items:center;background:none;border:none;border-radius:8px;color:#6b7280;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;padding:8px;transition:all .2s ease;width:36px}.file-preview-modal .btn-close svg{height:20px;width:20px}.file-preview-modal .btn-close:hover{background:#e5e7eb;color:#1f2937}.file-preview-modal .modal-content{display:flex;flex:1 1;min-height:0;overflow:hidden;width:100%}.file-preview-modal .preview-section{align-items:center;background:#f9fafb;border-right:1px solid #e5e7eb;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:0;min-width:0;overflow:hidden;padding:24px;position:relative}.file-preview-modal .image-preview{align-items:center;display:flex;flex:1 1;justify-content:center;overflow:auto;padding:10px;width:100%}.file-preview-modal .image-preview img{background:#fff;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 8px 30px #0000001f;display:block;height:auto;max-height:100%;max-width:100%;object-fit:contain;transform-origin:center center;transition:transform .2s ease;width:auto}.file-preview-modal .zoom-controls{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border-radius:10px;box-shadow:0 4px 12px #0000001a;display:flex;gap:6px;padding:6px;position:absolute;right:20px;top:20px;z-index:10}.file-preview-modal .zoom-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#4b5563;cursor:pointer;display:flex;height:34px;justify-content:center;transition:all .2s ease;width:34px}.file-preview-modal .zoom-btn svg{height:18px;width:18px}.file-preview-modal .zoom-btn:hover:not(:disabled){background:#f3f4f6;border-color:#d1d5db;color:#1f2937}.file-preview-modal .zoom-btn:disabled{cursor:not-allowed;opacity:.4}.file-preview-modal .zoom-level{align-items:center;color:#4b5563;display:flex;font-size:13px;font-weight:600;justify-content:center;min-width:50px;padding:0 10px}.file-preview-modal .error-state,.file-preview-modal .loading-state,.file-preview-modal .no-preview{align-items:center;color:#6b7280;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:40px;text-align:center}.file-preview-modal .loading-spinner-large{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;height:40px;margin:0 auto 16px;width:40px}.file-preview-modal .error-state{color:#dc2626}.file-preview-modal .error-icon{color:#dc2626;height:48px;margin-bottom:16px;width:48px}.file-preview-modal .error-help{color:#6b7280;font-size:13px;margin-top:8px}.file-preview-modal .no-preview-icon{color:#9ca3af;height:64px;margin-bottom:16px;width:64px}.file-preview-modal .no-preview p{color:#6b7280;font-size:15px;margin:0 0 12px}.file-preview-modal .file-type-badge{background:#f3f4f6;border-radius:4px;color:#6b7280;display:inline-block;font-family:monospace;font-size:12px;padding:4px 12px}.file-preview-modal .notes-section{background:#fff;display:flex;flex-direction:column;flex-shrink:0;min-height:0;overflow:hidden;width:380px}.file-preview-modal .notes-header{align-items:flex-start;background:linear-gradient(135deg,#f0fdf4,#ecfdf5);border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:18px 20px}.file-preview-modal .notes-header-content{align-items:flex-start;display:flex;gap:12px}.file-preview-modal .notes-icon{color:#059669;flex-shrink:0;height:24px;margin-top:2px;width:24px}.file-preview-modal .notes-header h3{color:#065f46;font-size:16px;font-weight:700;margin:0 0 4px}.file-preview-modal .notes-subtitle{color:#6b7280;font-size:13px;margin:0}.file-preview-modal .notes-count{background:#059669;border-radius:12px;color:#fff;font-size:12px;font-weight:600;min-width:24px;padding:4px 10px;text-align:center}.file-preview-modal .note-type-selector{background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;gap:6px;overflow-x:auto;padding:12px 16px}.file-preview-modal .note-type-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;color:#4b5563;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease;white-space:nowrap}.file-preview-modal .note-type-btn:hover{background:#f3f4f6;border-color:#d1d5db}.file-preview-modal .note-type-btn.active{border-width:2px}.file-preview-modal .note-type-btn.active.type-note{background:#eff6ff;border-color:#3b82f6;color:#1d4ed8}.file-preview-modal .note-type-btn.active.type-flag{background:#fef2f2;border-color:#ef4444;color:#dc2626}.file-preview-modal .note-type-btn.active.type-highlight{background:#fefce8;border-color:#eab308;color:#a16207}.file-preview-modal .note-type-btn.active.type-correction{background:#fff7ed;border-color:#f97316;color:#c2410c}.file-preview-modal .add-note-form{background:#fff;border-bottom:1px solid #e5e7eb;padding:16px}.file-preview-modal .note-input{border:1px solid #d1d5db;border-radius:10px;font-family:inherit;font-size:14px;margin-bottom:10px;min-height:80px;padding:12px;resize:vertical;transition:all .2s ease;width:100%}.file-preview-modal .note-input:focus{border-color:#059669;box-shadow:0 0 0 3px #0596691a;outline:none}.file-preview-modal .note-input::placeholder{color:#9ca3af}.file-preview-modal .add-note-btn{align-items:center;background:linear-gradient(135deg,#059669,#047857);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:12px 16px;transition:all .2s ease;width:100%}.file-preview-modal .add-note-btn svg{height:18px;width:18px}.file-preview-modal .add-note-btn:hover:not(:disabled){background:linear-gradient(135deg,#047857,#065f46);box-shadow:0 4px 12px #0596694d;transform:translateY(-1px)}.file-preview-modal .add-note-btn:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.file-preview-modal .btn-spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}.file-preview-modal .notes-list{background:#f9fafb;flex:1 1;overflow-y:auto;padding:16px}.file-preview-modal .notes-loading{align-items:center;color:#6b7280;display:flex;flex-direction:column;font-size:14px;gap:12px;justify-content:center;padding:40px 20px}.file-preview-modal .loading-spinner-small{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#059669;height:24px;width:24px}.file-preview-modal .notes-empty{align-items:center;color:#9ca3af;display:flex;flex-direction:column;justify-content:center;padding:48px 20px;text-align:center}.file-preview-modal .empty-icon{color:#d1d5db;height:48px;margin-bottom:16px;width:48px}.file-preview-modal .notes-empty p{color:#6b7280;font-size:15px;font-weight:600;margin:0 0 4px}.file-preview-modal .notes-empty span{color:#9ca3af;font-size:13px}.file-preview-modal .note-item{background:#fff;border:1px solid #e5e7eb;border-radius:10px;margin-bottom:10px;padding:14px;transition:all .2s ease}.file-preview-modal .note-item:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000d}.file-preview-modal .note-item:last-child{margin-bottom:0}.file-preview-modal .note-item.type-flag{border-left:3px solid #ef4444}.file-preview-modal .note-item.type-highlight{border-left:3px solid #eab308}.file-preview-modal .note-item.type-correction{border-left:3px solid #f97316}.file-preview-modal .note-item.type-note{border-left:3px solid #3b82f6}.file-preview-modal .note-item-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.file-preview-modal .note-type-badge{align-items:center;border-radius:4px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:3px 8px}.file-preview-modal .note-type-badge.type-note{background:#eff6ff;color:#1d4ed8}.file-preview-modal .note-type-badge.type-flag{background:#fef2f2;color:#dc2626}.file-preview-modal .note-type-badge.type-highlight{background:#fefce8;color:#a16207}.file-preview-modal .note-type-badge.type-correction{background:#fff7ed;color:#c2410c}.file-preview-modal .note-time{color:#9ca3af;font-size:12px}.file-preview-modal .note-content{color:#374151;font-size:14px;line-height:1.5;margin:0 0 10px;word-break:break-word}.file-preview-modal .note-author{align-items:center;color:#6b7280;display:flex;font-size:12px;gap:6px}.file-preview-modal .note-author svg{height:14px;width:14px}.file-preview-modal .modal-footer{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;flex-shrink:0;gap:12px;justify-content:flex-end;padding:16px 24px}.file-preview-modal .modal-footer button{flex:none;width:auto}.file-preview-modal .btn-mark-read{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;flex:none;font-size:13px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease;white-space:nowrap;width:auto}.file-preview-modal .btn-mark-read svg{height:16px;width:16px}.file-preview-modal .btn-mark-read:hover:not(:disabled){box-shadow:0 4px 12px #3b82f666;transform:translateY(-1px)}.file-preview-modal .btn-mark-read:disabled{background:#9ca3af;cursor:not-allowed;transform:none}.file-preview-modal .btn-mark-read.marked{background:linear-gradient(135deg,#10b981,#059669)}.file-preview-modal .btn-download{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;flex:none;font-size:13px;font-weight:600;gap:6px;padding:10px 20px;transition:all .2s ease;white-space:nowrap;width:auto}.file-preview-modal .btn-download svg{height:16px;width:16px}.file-preview-modal .btn-download:hover{box-shadow:0 4px 12px #6366f166;transform:translateY(-1px)}.file-preview-modal .btn-close-footer{background:#e5e7eb;border:none;border-radius:8px;color:#374151;cursor:pointer;flex:none;font-size:13px;font-weight:600;padding:10px 20px;transition:all .2s ease;white-space:nowrap;width:auto}.file-preview-modal .btn-close-footer:hover{background:#d1d5db}@media (max-width:1200px){.file-preview-modal .notes-section{width:340px}}@media (max-width:900px){.file-preview-modal{height:calc(100vh - 20px);max-height:none;width:calc(100vw - 20px)}.file-preview-modal .modal-content{flex-direction:column;overflow-y:auto}.file-preview-modal .preview-section{border-bottom:1px solid #e5e7eb;border-right:none;flex:none;max-height:50vh;min-height:300px}.file-preview-modal .notes-section{flex:1 1;min-height:300px;width:100%}.file-preview-modal .modal-footer{flex-wrap:wrap;gap:8px;justify-content:center}}@media (max-width:480px){.file-preview-modal .modal-header{padding:14px 16px}.file-preview-modal .modal-header h2{font-size:15px}.file-preview-modal .notes-header{padding:14px 16px}.file-preview-modal .notes-header h3{font-size:14px}.file-preview-modal .note-type-selector{gap:4px;padding:10px 12px}.file-preview-modal .note-type-btn{font-size:12px;padding:6px 10px}.file-preview-modal .add-note-form,.file-preview-modal .notes-list{padding:12px}}.chat-container{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;flex-direction:column;height:calc(100vh - 100px);overflow-x:hidden;overflow-y:auto;position:relative}.chat-header{background:#667eea;color:#fff;justify-content:space-between;padding:20px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.chat-header,.chat-header-left,.chat-header-right{align-items:center;display:flex}.chat-header-right{gap:15px}.chat-header h2{font-size:1.3em;margin:0}.connection-status{align-items:center;display:flex;font-size:14px;gap:8px}.btn-clear-chat{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:20px;color:#fff;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:5px;padding:8px 16px;transition:all .3s}.btn-clear-chat:hover{background:#ffffff4d;border-color:#ffffff80;transform:translateY(-1px)}.btn-clear-chat:active{transform:translateY(0)}.status-dot{background:#ccc;border-radius:50%;height:10px;width:10px}.status-dot.connected{animation:pulse 2s infinite;background:#4caf50}.chat-messages{background:#f9fafb;flex:1 1;min-height:200px;overflow-x:hidden;overflow-y:visible;padding:20px}.message{display:flex;margin-bottom:15px}.message-sent{justify-content:flex-end}.message-received{justify-content:flex-start}.message-content{border-radius:12px;box-shadow:0 1px 3px #0000001a;max-width:70%;padding:12px 16px}.message-sent .message-content{background:#667eea;color:#fff}.message-received .message-content{background:#fff;color:#333}.message-content p{line-height:1.5;margin:0}.message-time{display:block;font-size:11px;margin-top:5px;opacity:.7}.typing-indicator{align-items:center;display:flex;gap:5px;padding:15px!important}.typing-indicator span{animation:typing 1.4s infinite;background:#999;border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.chat-input-form{background:#fff;border-top:1px solid #e5e7eb;bottom:0;display:flex;gap:10px;padding:20px;position:-webkit-sticky;position:sticky;z-index:10}.chat-input{border:1px solid #e5e7eb;border-radius:24px;flex:1 1;font-size:14px;outline:none;padding:12px 16px}.chat-input:focus{border-color:#667eea}.btn-send{background:#667eea;border:none;border-radius:24px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:all .3s}.btn-send:hover:not(:disabled){background:#5568d3}.btn-send:disabled{cursor:not-allowed;opacity:.5}.btn-upload{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:24px;color:#667eea;display:flex;font-size:18px;justify-content:center;padding:12px 16px;transition:all .3s}.btn-upload:hover:not(:disabled){background:#f3f4f6;border-color:#667eea}.btn-upload:disabled{cursor:not-allowed;opacity:.5}.btn-clear-file{background:#ef4444;border:none;border-radius:24px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 16px;transition:all .3s}.btn-clear-file:hover{background:#dc2626}.chat-disclaimer{background:#fff3cd;border-top:1px solid gold;padding:12px 20px;text-align:center}.chat-disclaimer small{color:#856404;font-size:12px}.files-section{background:#fff;border-bottom:1px solid #e5e7eb;border-top:1px solid #e5e7eb}.files-toggle{align-items:center;background:#fff;border:none;color:#1f2937;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;padding:16px 20px;text-align:left;transition:all .2s ease;width:100%}.files-toggle:hover{background:#f9fafb}.files-icon{font-size:20px;line-height:1}.files-label{flex:1 1}.files-badge{background:#667eea;border-radius:12px;color:#fff;font-size:12px;font-weight:600;min-width:24px;padding:4px 8px;text-align:center}.files-chevron{color:#9ca3af;font-size:12px;transition:transform .2s ease}.files-chevron.open{transform:rotate(180deg)}.files-list{background:#f9fafb;border-top:1px solid #e5e7eb;max-height:400px;overflow-y:auto;padding:16px 20px}.files-loading{color:#6b7280;font-size:14px;padding:24px;text-align:center}.files-empty{padding:32px 24px;text-align:center}.empty-icon{display:block;font-size:40px;margin-bottom:12px}.empty-text{color:#1f2937;font-size:14px;font-weight:600;margin:0 0 4px}.empty-subtext{color:#9ca3af;font-size:13px;margin:0}.files-grid{grid-gap:12px;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.file-card{background:#fff;cursor:pointer;overflow:hidden;padding:16px}.file-card:hover{transform:translateY(-2px)}.file-card-header{align-items:center;margin-bottom:12px}.file-icon-container{font-size:24px;line-height:1}.file-status{border-radius:6px;font-size:11px;font-weight:600;padding:4px 8px;white-space:nowrap}.file-status.pending{background:#fef3c7;color:#92400e}.file-status.reviewed{background:#d1fae5;color:#065f46}.file-status.approved{background:#dcfce7;color:#166534}.file-delete-btn{align-items:center;background:none;border:none;border-radius:4px;color:#ef4444;cursor:pointer;display:flex;font-size:18px;justify-content:center;margin-left:8px;padding:4px 8px;transition:all .2s ease}.file-delete-btn:hover{background:#fee2e2;color:#dc2626;transform:scale(1.1)}.file-delete-btn:active{transform:scale(.95)}.file-card-content{margin-bottom:12px}.file-name{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#1f2937;display:-webkit-box;font-size:14px;font-weight:600;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;word-break:break-word}.file-category{color:#667eea;font-size:12px;font-weight:500;margin:0 0 6px}.file-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#6b7280;display:-webkit-box;font-size:13px;margin:6px 0;overflow:hidden;text-overflow:ellipsis}.file-date{color:#9ca3af;font-size:11px;margin:0}.file-summary{background:#f0f4ff;border-left:3px solid #667eea;border-radius:8px;padding:10px}.summary-label{color:#667eea;font-size:10px;font-weight:700;letter-spacing:.5px;margin:0 0 4px;text-transform:uppercase}.summary-text{color:#4b5563;font-size:12px;line-height:1.4;margin:0}.file-card-actions{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.file-download-btn,.file-preview-btn{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;display:flex;flex:1 1;font-size:13px;font-weight:600;gap:6px;justify-content:center;padding:8px 12px;transition:all .2s ease}.file-preview-btn{border-color:#667eea;color:#667eea}.file-preview-btn:hover{background:#667eea;box-shadow:0 4px 8px #667eea33;color:#fff;transform:translateY(-2px)}.file-download-btn{border-color:#10b981;color:#10b981}.file-download-btn:hover{background:#10b981;box-shadow:0 4px 8px #10b98133;color:#fff;transform:translateY(-2px)}.file-download-btn:active,.file-preview-btn:active{transform:translateY(0)}@media (max-width:768px){.files-grid{grid-template-columns:1fr}.files-list{max-height:300px}.message-content{max-width:85%}.file-card-actions{flex-direction:column}.file-download-btn,.file-preview-btn{width:100%}}.files-section-modern{background:#fff;border-bottom:1px solid #e5e7eb;border-top:1px solid #e5e7eb}.files-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:16px 20px;transition:background-color .2s ease;-webkit-user-select:none;user-select:none}.files-header:hover{background-color:#f9fafb}.files-header-left{align-items:center;display:flex;gap:12px}.files-icon-svg{color:#667eea;flex-shrink:0;height:20px;width:20px}.files-title{color:#1f2937;font-size:15px;font-weight:600}.files-count{background:#667eea;border-radius:10px;color:#fff;font-size:11px;font-weight:600;min-width:20px;padding:2px 8px;text-align:center}.files-chevron-svg{color:#9ca3af;flex-shrink:0;height:16px;transition:transform .2s ease;width:16px}.files-chevron-svg.open{transform:rotate(180deg)}.files-content{background:#f9fafb;border-top:1px solid #e5e7eb;max-height:400px;overflow-x:hidden;overflow-y:auto;padding:0}.files-loading-modern{align-items:center;color:#6b7280;display:flex;flex-direction:column;font-size:14px;gap:12px;justify-content:center;padding:32px 20px}.loading-spinner{animation:spin .8s linear infinite;border:3px solid #e5e7eb;height:24px;width:24px}.files-empty-modern{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.empty-icon-svg{color:#d1d5db;height:48px;margin-bottom:16px;width:48px}.files-empty-modern h4{color:#374151;font-size:15px;font-weight:600;margin:0 0 8px}.files-empty-modern p{color:#9ca3af;font-size:13px;margin:0;max-width:240px}.files-list-modern{padding:8px 0}.file-item{border-bottom:1px solid #f3f4f6;gap:12px;padding:12px 20px;transition:background-color .15s ease}.file-item:last-child{border-bottom:none}.file-item:hover{background-color:#fff}.file-item-icon{background:#f0f4ff;border-radius:8px;height:36px;width:36px}.file-item-icon svg{color:#667eea;height:18px;width:18px}.file-item-name{color:#1f2937;font-size:13px;font-weight:600;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-meta{color:#9ca3af;font-size:11px;gap:6px}.file-item-category{color:#667eea;font-weight:500;text-transform:capitalize}.file-item-dot{color:#d1d5db}.file-item-date{color:#9ca3af}.file-item-status{margin-right:8px}.status-badge{border-radius:4px;display:inline-block;font-size:10px;letter-spacing:.3px;padding:3px 8px}.status-badge.reviewed{background:#dbeafe;color:#1e40af}.status-badge.approved{background:#dcfce7;color:#166534}.file-item-actions{align-items:center;gap:4px}.action-btn{align-items:center;background:#0000;display:flex;height:32px;justify-content:center;transition:all .15s ease;width:32px}.action-btn svg{height:16px;width:16px}.action-btn.preview{color:#667eea}.action-btn.preview:hover{background:#f0f4ff;color:#5563d7}.action-btn.download{color:#10b981}.action-btn.download:hover{background:#ecfdf5;color:#059669}.action-btn.delete{color:#ef4444}.action-btn.delete:hover{background:#fef2f2;color:#dc2626}.action-btn-labeled{align-items:center;background:#fff;border:1px solid;border-radius:6px;cursor:pointer;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:6px 10px;transition:all .15s ease}.action-btn-labeled svg{flex-shrink:0;height:14px;width:14px}.action-btn-labeled.preview{border-color:#667eea;color:#667eea}.action-btn-labeled.preview:hover{background:#667eea;color:#fff}.action-btn-labeled.download{border-color:#10b981;color:#10b981}.action-btn-labeled.download:hover{background:#10b981;color:#fff}.action-btn-labeled.delete{border-color:#ef4444;color:#ef4444}.action-btn-labeled.delete:hover{background:#ef4444;color:#fff}@media (max-width:768px){.file-item{padding:10px 16px}.file-item-status{display:none}.file-item-actions{gap:2px}.action-btn{height:28px;width:28px}.action-btn svg{height:14px;width:14px}}.dashboard{background:#f5f7fa;min-height:100vh}.navbar{align-items:center;background:#667eea;box-shadow:0 2px 8px #0000001a;color:#fff;display:flex;justify-content:space-between;padding:15px 30px}.nav-brand h1{font-size:1.5em;margin:0}.nav-user{align-items:center;display:flex;gap:15px}.btn-logout{background:#fff3;border:1px solid #fff;border-radius:6px;color:#fff;cursor:pointer;padding:8px 16px;transition:all .3s}.btn-logout:hover{background:#fff;color:#667eea}.dashboard-container{display:flex;min-height:calc(100vh - 70px)}.sidebar{background:#fff;box-shadow:2px 0 8px #0000000d;width:250px}.sidebar ul{list-style:none;margin:0;padding:20px 0}.sidebar li{margin:0}.sidebar button{background:none;border:none;color:#666;cursor:pointer;font-size:16px;padding:15px 30px;text-align:left;transition:all .3s;width:100%}.sidebar li.active button{background:#f0f2f7;border-left:4px solid #667eea;color:#667eea}.sidebar button:hover{background:#f0f2f7}.main-content{flex:1 1;padding:30px}.dashboard-content h2{color:#333;margin-bottom:30px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:30px}.stat-card{box-shadow:0 2px 8px #0000000d;padding:25px}.stat-card h3{color:#666;font-size:16px;font-weight:500;margin:0 0 15px}.stat-number{color:#333;font-size:36px;font-weight:700;margin:10px 0}.stat-card small{color:#999;font-size:14px}.quick-actions{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:25px}.quick-actions h3{color:#333;margin:0 0 20px}.action-buttons{display:flex;flex-wrap:wrap;gap:15px}.action-btn{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:all .3s}.action-btn:hover{background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.quick-actions-modern{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;padding:28px}.quick-actions-title{align-items:center;color:#1e293b;display:flex;font-size:1.25rem;font-weight:600;gap:10px;margin:0 0 24px}.quick-actions-title:before{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:2px;content:"";display:block;height:24px;width:4px}.quick-actions-grid{display:flex;flex-direction:column;gap:12px}.quick-action-card{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;cursor:pointer;display:flex;gap:16px;overflow:hidden;padding:16px 20px;position:relative;text-align:left;transition:all .3s cubic-bezier(.4,0,.2,1);width:100%}.quick-action-card:before{background:linear-gradient(135deg,#667eea0d,#764ba20d);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.quick-action-card:hover{background:#fff;border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateX(8px)}.quick-action-card:hover:before{opacity:1}.quick-action-card:active{transform:translateX(4px)}.quick-action-icon-wrapper{align-items:center;border-radius:12px;box-shadow:0 4px 12px #00000026;color:#fff;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.quick-action-content{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.quick-action-label{color:#1e293b;font-size:1rem;font-weight:600;line-height:1.3}.quick-action-description{color:#64748b;font-size:.85rem;line-height:1.4}.quick-action-badge{align-items:center;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:14px;box-shadow:0 2px 8px #f093fb66;color:#fff;display:flex;font-size:.85rem;font-weight:700;height:28px;justify-content:center;min-width:28px;padding:0 8px}.quick-action-arrow{color:#cbd5e1;flex-shrink:0;transition:all .3s ease}.quick-action-card:hover .quick-action-arrow{color:#667eea;transform:translateX(4px)}@media (max-width:768px){.quick-actions-modern{padding:20px}.quick-action-card{padding:14px 16px}.quick-action-icon-wrapper{height:42px;width:42px}.quick-action-label{font-size:.95rem}.quick-action-description{font-size:.8rem}}.appointments-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:30px}.appointments-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.appointments-header h2{color:#333;margin:0}.btn-book-new{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .3s}.btn-book-new:hover{background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.loading-state{color:#666;padding:60px 20px;text-align:center}.empty-state p{margin:0 0 10px}.empty-hint{color:#999;font-size:14px!important;margin-bottom:30px!important}.btn-primary-large{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:18px;font-weight:500;margin-top:10px;padding:16px 32px;transition:all .3s}.btn-primary-large:hover{background:#5568d3;box-shadow:0 6px 16px #667eea66;transform:translateY(-2px)}.appointments-grid{display:flex;flex-direction:column;gap:20px}.appointment-item{align-items:stretch;background:#fff;border:1px solid #e5e7eb;border-radius:12px;display:flex;padding:20px;transition:all .3s}.appointment-item:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.appointment-left{align-items:center;display:flex;margin-right:24px}.appointment-date-box{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #667eea4d;color:#fff;min-width:90px;padding:16px;text-align:center}.date-month{font-size:12px;font-weight:600;letter-spacing:1px;margin-bottom:4px;opacity:.9}.date-day{font-size:32px;font-weight:700;line-height:1;margin:8px 0}.date-year{font-size:14px;margin-top:4px;opacity:.9}.appointment-middle{display:flex;flex:1 1;flex-direction:column;justify-content:center}.appointment-time{align-items:center;color:#667eea;display:flex;font-size:14px;font-weight:600;gap:8px;margin-bottom:8px}.time-icon{font-size:16px}.appointment-title{color:#333;font-size:18px;font-weight:600;margin:0 0 12px}.appointment-meta{display:flex;flex-wrap:wrap;gap:20px}.meta-item{align-items:center;color:#666;display:flex;font-size:14px;gap:6px;text-transform:capitalize}.meta-icon{font-size:16px}.appointment-right{align-items:flex-end;display:flex;flex-direction:column;gap:12px;justify-content:space-between;min-width:140px}.status-pill{font-size:13px;letter-spacing:.5px;padding:6px 16px;text-transform:uppercase}.status-pill.status-scheduled{background:#e0f2fe;color:#0369a1}.status-pill.status-completed{background:#d1fae5;color:#065f46}.status-pill.status-cancelled{background:#fee2e2;color:#991b1b}.status-pill.status-checked_in{background:#fef3c7;color:#92400e}.status-pill.status-in_progress{background:#e0e7ff;color:#3730a3}.appointment-actions{display:flex;gap:8px}.btn-action-danger,.btn-action-secondary{border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;padding:8px 16px;transition:all .2s}.btn-action-secondary{background:#f3f4f6;color:#374151}.btn-action-secondary:hover{background:#e5e7eb}.btn-action-danger{background:#fee2e2;color:#991b1b}.btn-action-danger:hover{background:#fecaca}@media (max-width:768px){.appointment-item{flex-direction:column;gap:16px}.appointment-left{margin-right:0}.appointment-date-box{min-width:100%}.appointment-right{align-items:center;flex-direction:row;justify-content:space-between;min-width:100%}.appointments-header{align-items:flex-start;flex-direction:column;gap:16px}.btn-book-new{width:100%}}.modal-overlay{animation:fadeIn .2s ease-out;background:#0009;z-index:10000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-container{animation:slideUp .3s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px 24px 16px}.modal-header h3{color:#333;font-size:20px;font-weight:600;margin:0}.modal-close{background:none;border-radius:4px;color:#999;font-size:32px;height:32px;line-height:1;padding:0;transition:all .2s;width:32px}.modal-close:hover{background:#f3f4f6;color:#333}.modal-body{padding:24px}.modal-warning{align-items:flex-start;background:#fef3c7;border:1px solid #fbbf24;border-radius:8px;display:flex;gap:12px;margin-bottom:20px;padding:16px}.warning-icon{flex-shrink:0;font-size:24px}.modal-warning p{color:#92400e;font-weight:500;margin:0}.appointment-details-modal{background:#f9fafb;border-radius:8px;margin-bottom:16px;padding:16px}.appointment-details-modal p{color:#333;font-size:15px;margin:8px 0}.appointment-details-modal strong{color:#666;display:inline-block;font-weight:600;min-width:80px}.modal-note{color:#666;font-size:14px;line-height:1.5;margin:0}.form-group{margin-bottom:16px}.form-group label{color:#333;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.datetime-input{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:15px;padding:12px;transition:all .2s;width:100%}.datetime-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.modal-footer{border-top:1px solid #e5e7eb;display:flex;gap:12px;padding:16px 24px 24px}.btn-modal-danger,.btn-modal-primary,.btn-modal-secondary{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:15px;font-weight:600;padding:12px 20px;transition:all .2s}.btn-modal-secondary{background:#f3f4f6;color:#374151}.btn-modal-secondary:hover:not(:disabled){background:#e5e7eb}.btn-modal-primary{background:#667eea;color:#fff}.btn-modal-primary:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea66;transform:translateY(-1px)}.btn-modal-danger{background:#ef4444;color:#fff}.btn-modal-danger:hover:not(:disabled){background:#dc2626;box-shadow:0 4px 12px #ef444466;transform:translateY(-1px)}.btn-modal-danger:disabled,.btn-modal-primary:disabled,.btn-modal-secondary:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.modal-container{margin:20px;max-width:95%}.modal-header{padding:20px 20px 12px}.modal-body{padding:20px}.modal-footer{flex-direction:column;padding:12px 20px 20px}.btn-modal-danger,.btn-modal-primary,.btn-modal-secondary{width:100%}}.recorder-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.recorder-modal{background:#fff;border-radius:12px;box-shadow:0 10px 40px #0000004d;max-width:500px;padding:2rem;width:90%}.recorder-header{border-bottom:2px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1rem;text-align:center}.recorder-header h2{color:#1f2937;font-size:1.5rem;margin:0 0 .5rem}.patient-name{font-size:1rem}.recorder-content{margin-bottom:1.5rem}.error-message{align-items:center;background:#fee2e2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;display:flex;gap:.5rem;margin-bottom:1rem;padding:1rem}.error-icon{font-size:1.25rem}.recording-display{padding:2rem 0;text-align:center}.recording-indicator{align-items:center;display:flex;gap:.75rem;justify-content:center;margin-bottom:1rem}.pulse-dot{animation:pulse 1.5s ease-in-out infinite;background:#dc2626;border-radius:50%;height:12px;width:12px}.recording-text{color:#dc2626;font-size:1.1rem;font-weight:600}.recording-time{font-feature-settings:"tnum";color:#1f2937;font-size:3rem;font-variant-numeric:tabular-nums;font-weight:700}.recorder-instructions{color:#6b7280;line-height:1.6;margin:1.5rem 0;text-align:center}.recorder-actions{display:flex;gap:1rem;justify-content:center}.btn-start-recording{background:#10b981;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.btn-start-recording:hover{background:#059669;box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.btn-stop-recording{background:#dc2626;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.btn-stop-recording:hover{background:#b91c1c;box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.btn-cancel{background:#6b7280;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.btn-cancel:hover{background:#4b5563}.processing-display{padding:2rem 0;text-align:center}.spinner{border:4px solid #e5e7eb;border-top-color:#3b82f6;height:60px;margin:0 auto 1.5rem;width:60px}.processing-stage{color:#1f2937;font-size:1.1rem;font-weight:600;margin-bottom:.5rem}.processing-note{color:#6b7280;font-size:.9rem;line-height:1.5}.mode-selector{background:#f3f4f6;border-radius:8px;display:flex;gap:.5rem;margin-bottom:1.5rem;padding:.5rem}.mode-btn{background:#0000;border:none;border-radius:6px;color:#6b7280;cursor:pointer;flex:1 1;font-size:.95rem;font-weight:500;padding:.75rem 1rem;transition:all .2s}.mode-btn:hover{background:#ffffff80}.mode-btn.active{background:#fff;box-shadow:0 2px 4px #0000001a;color:#1f2937}.upload-section{padding:2rem 0;text-align:center}.upload-icon{font-size:4rem;margin-bottom:1rem;opacity:.7}.upload-instructions{color:#6b7280;line-height:1.6;margin:1rem 0 2rem}.btn-upload{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s}.btn-upload:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.patients-list-container{margin:0 auto;max-width:1400px;padding:2rem}.patients-header-modern{margin-bottom:2rem}.header-top{align-items:flex-start;display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between}.header-title-section h1{color:#1e293b;font-size:2rem;font-weight:700;margin:0 0 .5rem}.header-subtitle{color:#64748b;font-size:1rem;margin:0}.header-actions{flex-shrink:0}.search-bar-modern{position:relative;width:320px}.search-bar-modern .search-icon{color:#94a3b8;left:14px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-bar-modern input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;font-size:.95rem;padding:12px 40px 12px 44px;transition:all .3s ease;width:100%}.search-bar-modern input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.search-bar-modern input::placeholder{color:#94a3b8}.clear-search{align-items:center;background:#f1f5f9;border:none;border-radius:50%;color:#64748b;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:all .2s;width:24px}.clear-search:hover{background:#e2e8f0;color:#475569}.patients-stats-modern{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card-modern{align-items:center;background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;display:flex;gap:1rem;padding:1.25rem;transition:all .3s ease}.stat-card-modern:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-2px)}.stat-icon{align-items:center;border-radius:12px;color:#fff;display:flex;flex-shrink:0;height:48px;justify-content:center;width:48px}.stat-content{flex:1 1}.stat-value-modern{color:#1e293b;font-size:1.75rem;font-weight:700;line-height:1.2}.stat-label-modern{color:#64748b;font-size:.85rem;margin-top:2px}.search-results-info{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;color:#0369a1;font-size:.9rem;margin-bottom:1.5rem;padding:12px 16px}.search-results-info strong{color:#0c4a6e}.patients-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.patient-card-modern{background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 4px 20px #00000014;cursor:pointer;overflow:hidden;padding:0;transition:all .3s cubic-bezier(.4,0,.2,1)}.patient-card-modern:hover{border-color:#667eea;box-shadow:0 12px 40px #667eea26;transform:translateY(-4px)}.patient-card-header-modern{align-items:center;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;display:flex;gap:1rem;padding:1.25rem 1.25rem 1rem}.patient-avatar-modern{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:14px;box-shadow:0 4px 12px #667eea4d;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;font-weight:700;height:56px;justify-content:center;width:56px}.patient-info-modern{flex:1 1;min-width:0}.patient-info-modern h3{color:#1e293b;font-size:1.1rem;font-weight:600;margin:0 0 4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.patient-meta{align-items:center;display:flex;gap:12px}.patient-meta .meta-item{align-items:center;color:#64748b;display:flex;font-size:.8rem;gap:4px}.patient-meta .meta-item svg{color:#94a3b8}.blood-type-badge{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:.85rem;font-weight:700;padding:6px 12px}.patient-card-body-modern{padding:1.25rem}.info-grid{display:flex;flex-direction:column;gap:10px;margin-bottom:1rem}.info-item{background:#f8fafc;border-radius:8px;padding:10px 12px}.info-item.allergy-item{background:#fef2f2;border:1px solid #fecaca}.info-label{color:#64748b;font-size:.7rem;font-weight:600;letter-spacing:.05em;margin-bottom:4px;text-transform:uppercase}.info-value{color:#334155;font-size:.85rem;line-height:1.4}.info-value.allergy-value{color:#dc2626}.more-badge{background:#e2e8f0;border-radius:4px;color:#475569;display:inline-block;font-size:.75rem;font-weight:600;margin-left:6px;padding:2px 6px}.visit-stats{border-top:1px solid #e2e8f0;display:flex;flex-wrap:wrap;gap:16px;padding-top:12px}.visit-stat{align-items:center;color:#64748b;display:flex;font-size:.85rem;gap:6px}.visit-stat svg{color:#94a3b8}.visit-stat.last-visit{color:#059669}.visit-stat.last-visit svg{color:#10b981}.patient-card-footer-modern{padding:0 1.25rem 1.25rem}.btn-view-profile-modern{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;justify-content:center;padding:12px;transition:all .3s ease;width:100%}.btn-view-profile-modern:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-view-profile-modern svg{transition:transform .3s ease}.btn-view-profile-modern:hover svg{transform:translateX(4px)}.no-patients-modern{background:#fff;border-radius:16px;box-shadow:0 4px 20px #00000014;grid-column:1/-1;padding:4rem 2rem;text-align:center}.no-patients-modern .empty-icon{color:#cbd5e1;margin-bottom:1.5rem}.no-patients-modern h3{color:#475569;font-size:1.25rem;margin:0 0 .5rem}.no-patients-modern p{color:#94a3b8;margin:0 0 1.5rem}.btn-clear-search{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:10px 20px;transition:all .2s}.btn-clear-search:hover{background:#5568d3}.loading-state-modern{padding:4rem 2rem;text-align:center}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #e2e8f0;border-radius:50%;border-top-color:#667eea;height:48px;margin:0 auto 1rem;width:48px}.loading-state-modern p{color:#64748b;font-size:1rem}.patients-header{margin-bottom:2rem}.patients-header h1{color:#1f2937;font-size:2rem;margin-bottom:1rem}.search-bar{max-width:500px}.search-bar input{border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;padding:.75rem 1rem;transition:border-color .2s;width:100%}.search-bar input:focus{border-color:#3b82f6;outline:none}.patients-stats{display:flex;gap:1rem;margin-bottom:2rem}.stat-card{background:#fff;border-radius:12px;box-shadow:0 2px 4px #0000001a;min-width:150px;padding:1.5rem}.stat-value{color:#3b82f6;font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#6b7280;font-size:.875rem;letter-spacing:.05em;text-transform:uppercase}.patient-card{box-shadow:0 2px 8px #0000001a;cursor:pointer;padding:1.5rem;transition:all .2s}.patient-card:hover{box-shadow:0 4px 12px #00000026}.patient-card-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;gap:1rem;margin-bottom:1rem;padding-bottom:1rem}.patient-avatar{font-size:1.5rem;height:60px;width:60px}.patient-info h3{color:#1f2937;font-size:1.25rem;margin:0}.patient-dob{color:#6b7280;font-size:.875rem;margin:.25rem 0 0}.patient-card-body{margin-bottom:1rem}.profile-item{color:#4b5563;font-size:.9rem;margin-bottom:.75rem}.profile-item strong{color:#1f2937}.patient-card-footer{border-top:1px solid #e5e7eb;display:flex;justify-content:center;margin-top:1rem;padding-top:1rem}.btn-view-profile{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;box-shadow:0 4px 6px #667eea4d;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;transition:all .3s ease;width:100%}.btn-view-profile:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);box-shadow:0 6px 12px #667eea66;transform:translateY(-2px)}.no-patients{grid-column:1/-1}.loading,.no-patients{color:#6b7280;font-size:1.1rem;padding:3rem;text-align:center}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:16px;box-shadow:0 20px 25px -5px #0000001a;max-height:90vh;max-width:900px;overflow-y:auto;position:relative;width:100%}.patient-details-modal{padding:2rem}.modal-close{align-items:center;background:#f3f4f6;border:none;border-radius:50%;cursor:pointer;display:flex;font-size:1.5rem;height:40px;justify-content:center;position:absolute;right:1rem;top:1rem;transition:background .2s;width:40px}.modal-close:hover{background:#e5e7eb}.patient-details-header{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;gap:1.5rem;margin-bottom:2rem;padding-bottom:1.5rem}.patient-avatar-large{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:2rem;font-weight:700;height:80px;justify-content:center;width:80px}.patient-details-header h2{color:#1f2937;font-size:1.75rem;margin:0 0 .5rem}.patient-details-header p{color:#6b7280;font-size:.95rem;margin:.25rem 0}.patient-details-body{display:flex;flex-direction:column;gap:2rem}.detail-section{background:#f9fafb;border-radius:12px;padding:1.5rem}.detail-section h3{color:#1f2937;font-size:1.25rem;margin:0 0 1rem}.detail-section h4{color:#4b5563;font-size:1rem;margin:1.5rem 0 .75rem}.summary-card{background:#fff;border-radius:8px;margin-bottom:1rem;padding:1rem}.summary-card p{color:#4b5563;margin:.5rem 0}.ai-question-section{margin-top:1.5rem}.question-input-group{display:flex;gap:.5rem;margin-bottom:1rem}.question-input-group input{border:2px solid #e5e7eb;border-radius:8px;flex:1 1;font-size:.95rem;padding:.75rem}.question-input-group input:focus{border-color:#3b82f6;outline:none}.btn-ask{background:#3b82f6;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;padding:.75rem 1.5rem;transition:background .2s;white-space:nowrap}.btn-ask:hover:not(:disabled){background:#2563eb}.btn-ask:disabled{background:#9ca3af;cursor:not-allowed}.ai-response{background:#fff;border-left:4px solid #3b82f6;border-radius:8px;padding:1rem}.ai-response strong{color:#3b82f6;display:block;margin-bottom:.5rem}.ai-response p{color:#4b5563;line-height:1.6;margin:0}.profile-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.profile-field{background:#fff;border-radius:8px;font-size:.9rem;padding:1rem}.profile-field strong{color:#1f2937;display:block;margin-bottom:.25rem}.visits-timeline{display:flex;flex-direction:column;gap:1rem}.visit-item{background:#fff;border-left:4px solid #10b981;border-radius:8px;display:flex;gap:1rem;padding:1rem}.visit-number{background:#10b981;border-radius:6px;color:#fff;font-size:.875rem;font-weight:700;height:-webkit-fit-content;height:fit-content;padding:.5rem 1rem;white-space:nowrap}.visit-details{flex:1 1}.visit-date{color:#6b7280;font-size:.875rem;margin:0 0 .5rem}.visit-details p{color:#4b5563;font-size:.9rem;line-height:1.5;margin:.5rem 0}.visit-details p strong{color:#1f2937}@media (max-width:768px){.patients-grid{grid-template-columns:1fr}.patient-details-header{flex-direction:column;text-align:center}.profile-grid{grid-template-columns:1fr}}.settings-container{background:#f9fafb;margin:0 auto;max-width:1000px;min-height:100vh;padding:20px}.settings-header{align-items:center;display:flex;gap:20px;margin-bottom:30px}.settings-header h1{color:#1f2937;font-size:2rem;margin:0}.btn-back{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-back:hover{background:#f3f4f6;border-color:#d1d5db}.settings-error,.settings-loading{color:#6b7280;font-size:16px;padding:40px;text-align:center}.settings-message{animation:slideIn .3s ease;border-radius:8px;font-weight:500;margin-bottom:24px;padding:16px 20px}.settings-message.success{background:#d1fae5;border:1px solid #10b981;color:#065f46}.settings-message.error{background:#fee2e2;border:1px solid #ef4444;color:#991b1b}.settings-sections{display:flex;flex-direction:column;gap:24px}.settings-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.settings-section h2{align-items:center;border-bottom:2px solid #e5e7eb;color:#1f2937;display:flex;font-size:1.25rem;gap:8px;margin:0 0 20px;padding-bottom:12px}.settings-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr)}.form-field{display:flex;flex-direction:column;gap:8px}.form-field.full-width{grid-column:1/-1}.form-field label{color:#374151;font-size:14px;font-weight:600}.form-field input,.form-field textarea{border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;padding:10px 12px;transition:border-color .2s}.form-field input:focus,.form-field textarea:focus{border-color:#3b82f6;outline:none}.form-field textarea{min-height:100px;resize:vertical}.form-field small{color:#6b7280;font-size:12px;font-style:italic}.calendar-connected{display:flex;flex-direction:column;gap:20px}.calendar-status{align-items:flex-start;background:#f0f9ff;border:2px solid #bae6fd;border-radius:8px;display:flex;gap:16px;padding:16px}.status-badge{font-size:13px;padding:6px 12px}.status-badge.success{background:#d1fae5;border:1px solid #10b981;color:#065f46}.calendar-info{flex:1 1}.calendar-info p{color:#1f2937;font-size:14px;margin:4px 0}.btn-disconnect{align-self:flex-start;background:#fff;border:2px solid #ef4444;border-radius:8px;color:#dc2626;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px;transition:all .2s}.btn-disconnect:hover{background:#fef2f2}.calendar-disconnected{align-items:flex-start;display:flex;flex-direction:column;gap:16px}.calendar-description{color:#6b7280;font-size:14px;line-height:1.6;margin:0}.btn-connect-calendar{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;box-shadow:0 2px 4px #0000000d;color:#1f2937;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:12px;padding:12px 24px;transition:all .2s}.btn-connect-calendar:hover{border-color:#4285f4;box-shadow:0 4px 8px #4285f426}.google-icon{-webkit-text-fill-color:#0000;align-items:center;background:linear-gradient(135deg,#4285f4,#34a853 50%,#fbbc05 75%,#ea4335);-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700;height:20px;width:20px}.google-icon,.settings-footer{display:flex;justify-content:center}.settings-footer{background:#fff;border-radius:0 0 12px 12px;border-top:2px solid #e5e7eb;bottom:0;box-shadow:0 -4px 6px #0000000d;margin:24px -20px -20px;padding:20px;position:-webkit-sticky;position:sticky}.btn-save{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;box-shadow:0 4px 6px #3b82f64d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:14px 32px;transition:all .2s}.btn-save:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 6px 12px #3b82f666;transform:translateY(-2px)}.btn-save:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.settings-grid{grid-template-columns:1fr}.settings-header{align-items:flex-start;flex-direction:column}.settings-container{padding:12px}}.file-notification-bell{display:inline-block;position:relative}.file-notification-bell .bell-button{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:24px;justify-content:center;padding:8px 12px;position:relative;transition:all .2s ease}.file-notification-bell .bell-button:hover{background:#f3f4f6}.file-notification-bell .bell-button.has-notifications{animation:gentle-pulse 2s infinite}.file-notification-bell .notification-badge{align-items:center;animation:pulse 2s infinite;background:#ef4444;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #ef44444d;color:#fff;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;position:absolute;right:0;top:0;width:20px}.file-notification-bell .notification-dropdown{animation:slideDown .2s ease;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;max-height:600px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:420px;z-index:10000}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes gentle-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.file-notification-bell .dropdown-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:16px}.file-notification-bell .dropdown-header h3{color:#1f2937;font-size:16px;font-weight:700;margin:0}.file-notification-bell .unread-count{background:#ef4444;border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:2px 8px}.file-notification-bell .notifications-list{flex:1 1;max-height:450px;overflow-y:auto}.file-notification-bell .notification-item{align-items:flex-start;border-bottom:1px solid #e5e7eb;cursor:pointer;display:flex;gap:12px;padding:12px 16px;transition:all .2s ease}.file-notification-bell .notification-item:hover{background:#f3f4f6}.file-notification-bell .notification-item.unread{background:#ede9fe;border-left:4px solid #667eea}.file-notification-bell .notification-content{flex:1 1;min-width:0}.file-notification-bell .patient-info{display:flex;flex-direction:column;gap:4px}.file-notification-bell .patient-name{color:#1f2937;font-size:14px;font-weight:600;margin:0}.file-notification-bell .file-info{color:#374151;font-size:13px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-notification-bell .notification-meta{color:#6b7280;display:flex;flex-wrap:wrap;font-size:12px;gap:8px;margin-top:4px}.file-notification-bell .file-category{background:#f0f9ff;border-radius:4px;color:#0369a1;font-weight:500;padding:2px 6px}.file-notification-bell .file-size{background:#f5f3ff;border-radius:4px;color:#6b21a8;padding:2px 6px}.file-notification-bell .time-ago{color:#9ca3af}.file-notification-bell .notification-actions{align-items:center;display:flex;gap:4px}.file-notification-bell .action-btn{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;font-size:16px;padding:4px 8px;transition:all .2s ease}.file-notification-bell .action-btn:hover{background:#e5e7eb;color:#374151}.file-notification-bell .action-btn.mark-read{color:#10b981}.file-notification-bell .action-btn.mark-read:hover{background:#d1fae5}.file-notification-bell .action-btn.archive{color:#ef4444}.file-notification-bell .action-btn.archive:hover{background:#fee2e2}.file-notification-bell .empty-state,.file-notification-bell .loading-state{color:#6b7280;padding:40px 16px;text-align:center}.file-notification-bell .empty-state p,.file-notification-bell .loading-state p{font-size:14px;margin:0}.file-notification-bell .dropdown-footer{background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;justify-content:center;padding:12px 16px}.file-notification-bell .btn-refresh{background:none;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .2s ease}.file-notification-bell .btn-refresh:hover{background:#fff;border-color:#667eea;color:#667eea}@media (max-width:768px){.file-notification-bell .notification-dropdown{bottom:10px;left:10px;max-height:70vh;position:fixed;right:10px;top:auto;width:auto}.file-notification-bell .notifications-list{max-height:calc(70vh - 140px)}.file-notification-bell .notification-item{padding:12px}.file-notification-bell .file-info{font-size:12px}.file-notification-bell .notification-meta{font-size:11px}}@media (max-width:480px){.file-notification-bell .dropdown-header h3{font-size:14px}.file-notification-bell .patient-name{font-size:13px}.file-notification-bell .notification-actions{gap:2px}.file-notification-bell .action-btn{font-size:14px;padding:2px 4px}}.doctor-dashboard{background:#f5f7fa;min-height:100vh}.stat-card.urgent{border-left:4px solid #ff6b6b}.badge{background:#ff6b6b;border-radius:12px;color:#fff;font-size:12px;margin-left:8px;padding:2px 8px}.empty-state{color:#999;font-size:18px;padding:60px 20px;text-align:center}.approvals-content,.patients-content,.qboard-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:30px}.approval-list,.qboard-list{display:flex;flex-direction:column;gap:20px;margin-top:20px}.approval-card,.qboard-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.approval-header,.qboard-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:15px}.approval-type,.qboard-category{background:#667eea;border-radius:6px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.approval-date,.qboard-date{color:#666;font-size:14px}.urgency-badge{background:#fbbf24;border-radius:6px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.approval-content{background:#fff;border-radius:8px;margin-bottom:15px;max-height:300px;overflow-y:auto;padding:15px}.approval-content pre{color:#333;font-size:14px;margin:0;white-space:pre-wrap}.approval-actions{display:flex;gap:10px}.btn-approve{background:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:10px;transition:all .3s}.btn-approve:hover{background:#059669}.btn-edit{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:10px;transition:all .3s}.btn-edit:hover{background:#2563eb}.btn-reject{background:#ef4444;border:none;border-radius:6px;color:#fff;cursor:pointer;flex:1 1;font-weight:600;padding:10px;transition:all .3s}.btn-reject:hover{background:#dc2626}.qboard-question h4{color:#667eea;font-size:14px;margin-bottom:8px;margin-top:15px}.qboard-question p{color:#333;line-height:1.6;margin-bottom:10px}.qboard-response{border-top:1px solid #e5e7eb;margin-top:20px;padding-top:20px}.qboard-response textarea{border:1px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;margin-bottom:10px;padding:12px;resize:vertical;width:100%}.qboard-response textarea:focus{border-color:#667eea;outline:none}.btn-respond{background:#667eea;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:10px 24px;transition:all .3s}.btn-respond:hover{background:#5568d3}.patients-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:30px}.patients-count{background:#667eea;border-radius:20px;color:#fff;font-size:14px;font-weight:600;padding:8px 20px}.patients-grid{display:flex;flex-direction:column;gap:20px}.patient-card{align-items:stretch;background:#fff;border:2px solid #e5e7eb;border-radius:12px;display:flex;gap:20px;padding:20px;transition:all .3s}.patient-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea33;transform:translateY(-2px)}.patient-time-block{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;box-shadow:0 4px 12px #667eea4d;color:#fff;display:flex;flex-direction:column;justify-content:center;min-width:100px;padding:20px;text-align:center}.patient-time{font-size:24px;font-weight:700;margin-bottom:8px}.patient-duration{font-size:13px;font-weight:500;opacity:.9}.patient-info{display:flex;flex-direction:column;gap:12px}.patient-name-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.patient-name{color:#333;font-size:20px;font-weight:600}.priority-badge{border-radius:20px;font-size:12px;font-weight:600;letter-spacing:.5px;padding:6px 14px;text-transform:uppercase}.priority-badge.priority-high{background:#fee2e2;color:#991b1b}.priority-badge.priority-medium{background:#fef3c7;color:#92400e}.priority-badge.priority-low{background:#d1fae5;color:#065f46}.patient-contact{display:flex;flex-wrap:wrap;gap:24px}.contact-item{align-items:center;color:#666;display:flex;font-size:14px;gap:6px}.contact-icon{font-size:16px}.visit-details{display:flex;flex-direction:column;gap:10px}.visit-reason{color:#333;font-size:15px}.visit-type-status{display:flex;flex-wrap:wrap;gap:10px}.visit-type-tag{background:#f3f4f6;border-radius:6px;color:#374151;font-size:13px;font-weight:500;padding:6px 12px;text-transform:capitalize}.patient-actions{display:flex;flex-direction:column;gap:10px;justify-content:center;min-width:140px}.btn-start-visit,.btn-view-chart{border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s}.btn-view-chart{background:#f3f4f6;color:#374151}.btn-view-chart:hover{background:#e5e7eb}.btn-start-visit{background:#667eea;color:#fff}.btn-start-visit:hover{background:#5568d3;box-shadow:0 4px 8px #667eea4d;transform:translateY(-1px)}.empty-state,.loading-state{padding:60px 20px;text-align:center}.spinner{border:4px solid #f3f3f3;margin:0 auto 20px}.empty-icon{font-size:80px;margin-bottom:20px;opacity:.5}.empty-state h3{color:#333;font-size:24px;margin:0 0 10px}.empty-state p{color:#666;font-size:16px;margin:0}@media (max-width:768px){.patient-card{flex-direction:column}.patient-time-block{min-width:100%}.patient-actions{flex-direction:row;min-width:100%}.btn-start-visit,.btn-view-chart{flex:1 1}.patients-header{align-items:flex-start;flex-direction:column;gap:12px}}@keyframes slideIn{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.files-content{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;padding:30px}.files-content h2{color:#1f2937;font-size:24px;margin-bottom:24px;margin-top:0}.files-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.file-card{background:#f9fafb;border:1px solid #e5e7eb;border-radius:12px;padding:20px;transition:all .2s ease}.file-card:hover{border-color:#667eea;box-shadow:0 4px 12px #667eea1a}.file-card-header{align-items:flex-start;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px}.file-info h4{color:#1f2937;font-size:16px;margin:0 0 8px;word-break:break-word}.patient-name{color:#6b7280;font-size:14px;margin:0}.status-badge{border-radius:6px;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase;white-space:nowrap}.status-badge.pending{background:#fef3c7;color:#92400e}.status-badge.read{background:#d1fae5;color:#065f46}.status-badge.archived{background:#e5e7eb;color:#374151}.file-card-meta{border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding-bottom:16px}.category-badge{background:#dbeafe;border-radius:4px;color:#0369a1;font-size:12px;font-weight:600;padding:4px 8px}.file-size,.upload-date{color:#6b7280;font-size:12px;padding:4px 0}.upload-date{margin-left:auto}.file-card-actions{display:flex;gap:8px}.btn-download,.btn-mark-read,.btn-preview{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;flex:1 1;font-size:13px;font-weight:600;padding:8px 12px;transition:all .2s ease}.btn-preview:hover{background:#667eea;border-color:#667eea;color:#fff}.btn-download:hover{background:#3b82f6;border-color:#3b82f6;color:#fff}.btn-mark-read:hover:not(:disabled){background:#10b981;border-color:#10b981;color:#fff}.btn-mark-read:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.files-grid{grid-template-columns:1fr}.file-card{padding:16px}.file-card-actions{flex-direction:column}.upload-date{margin-left:0;width:100%}}.patient-files-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.patient-file-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;box-shadow:0 1px 3px #0000000d;cursor:pointer;padding:24px;transition:all .3s ease}.patient-file-card:hover{border-color:#667eea;box-shadow:0 8px 25px #667eea26;transform:translateY(-2px)}.patient-file-card-header{align-items:center;display:flex;gap:16px;margin-bottom:20px}.patient-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:52px;justify-content:center;text-transform:uppercase;width:52px}.patient-info{flex:1 1;min-width:0}.patient-info h4{color:#1f2937;font-size:17px;font-weight:600;margin:0 0 4px}.patient-info h4,.patient-info p{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.patient-info p{color:#6b7280;font-size:13px;margin:0}.unread-badge{animation:pulse 2s infinite;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:20px;color:#fff;font-size:12px;font-weight:600;padding:5px 12px;white-space:nowrap}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.patient-file-card-stats{border-bottom:1px solid #f3f4f6;border-top:1px solid #f3f4f6;display:flex;justify-content:space-around;padding:16px 0}.patient-file-card-stats .stat{text-align:center}.patient-file-card-stats .stat-value{color:#1f2937;display:block;font-size:24px;font-weight:700}.patient-file-card-stats .stat-label{color:#6b7280;display:block;font-size:12px;margin-top:2px}.patient-file-card-footer{padding-top:16px;text-align:center}.view-files-link{color:#667eea;font-size:14px;font-weight:600;transition:color .2s}.patient-file-card:hover .view-files-link{color:#5b21b6}.patient-files-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:10000}.patient-files-modal{animation:modalSlideIn .3s ease;background:#fff;border-radius:20px;box-shadow:0 25px 50px #00000040;display:flex;flex-direction:column;max-height:80vh;max-width:700px;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.patient-files-modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:24px 28px}.patient-files-modal-header h3{color:#1f2937;font-size:20px;margin:0}.patient-files-modal-header p{color:#6b7280;font-size:14px;margin:4px 0 0}.patient-files-modal-header .close-btn{align-items:center;background:#f3f4f6;border:none;border-radius:50%;color:#6b7280;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;transition:all .2s;width:36px}.patient-files-modal-header .close-btn:hover{background:#e5e7eb;color:#1f2937}.patient-files-modal-content{flex:1 1;overflow-y:auto;padding:16px 28px 28px}.file-item{align-items:center;background:#f9fafb;border-radius:12px;display:flex;gap:16px;margin-bottom:12px;padding:16px;transition:all .2s}.file-item:last-child{margin-bottom:0}.file-item:hover{background:#f3f4f6}.file-item-icon{align-items:center;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;display:flex;flex-shrink:0;font-size:24px;height:48px;justify-content:center;width:48px}.file-item-info{flex:1 1;min-width:0}.file-item-info h4{color:#1f2937;font-size:15px;font-weight:600;margin:0 0 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-item-meta{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.file-item-meta span{color:#6b7280;font-size:12px}.file-item-meta .category-tag{background:#dbeafe;border-radius:4px;color:#1d4ed8;font-weight:500;padding:2px 8px}.file-item-status{flex-shrink:0}.status-pill{border-radius:20px;font-size:12px;font-weight:600;padding:6px 12px}.status-pill.pending{background:#fef3c7;color:#92400e}.status-pill.read{background:#d1fae5;color:#065f46}.file-item-actions{display:flex;flex-shrink:0;gap:8px}.file-item-actions .btn-icon{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;font-size:16px;height:38px;justify-content:center;transition:all .2s;width:38px}.file-item-actions .btn-icon:hover{background:#667eea;border-color:#667eea;transform:scale(1.05)}.file-item-actions .btn-icon.btn-mark{background:#d1fae5;border-color:#10b981;color:#065f46}.file-item-actions .btn-icon.btn-mark:hover:not(:disabled){background:#10b981;color:#fff}.file-item-actions .btn-icon:disabled{cursor:not-allowed;opacity:.4}.file-item-actions .btn-icon:disabled:hover{background:#d1fae5;transform:none}@media (max-width:768px){.patient-files-grid{grid-template-columns:1fr}.patient-files-modal{border-radius:16px;max-height:90vh;width:95%}.file-item{flex-wrap:wrap}.file-item-status{margin-top:8px;order:3;width:100%}.file-item-actions{justify-content:flex-end;margin-top:12px;order:4;width:100%}}.visit-summary-modal{background:#fff;border-radius:16px;max-height:90vh;max-width:800px;overflow-y:auto;padding:0}.summary-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px 16px 0 0;color:#fff;gap:16px;padding:24px 28px}.summary-header,.summary-icon{align-items:center;display:flex}.summary-icon{background:#fff3;border-radius:12px;height:56px;justify-content:center;width:56px}.summary-header h2{font-size:1.5rem;font-weight:600;margin:0}.summary-subtitle{font-size:.95rem;margin:4px 0 0;opacity:.9}.summary-error,.summary-loading{color:#6b7280;padding:60px 24px;text-align:center}.summary-error p{color:#ef4444;margin-bottom:16px}.summary-error button{background:#667eea;border:none;border-radius:8px;color:#fff;cursor:pointer;font-weight:500;padding:10px 24px}.summary-content{padding:24px 28px}.summary-section{background:#f9fafb;border-left:4px solid #667eea;border-radius:12px;margin-bottom:24px;padding:20px}.summary-section h3{align-items:center;color:#374151;display:flex;font-size:1.1rem;font-weight:600;gap:8px;margin:0 0 16px}.visit-info-section{background:#f0f9ff;border-left-color:#0ea5e9}.visit-info-section .info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.visit-info-section .info-item{display:flex;flex-direction:column;gap:4px}.visit-info-section .info-label{color:#6b7280;font-size:.8rem;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.visit-info-section .info-value{color:#1f2937;font-size:1rem;font-weight:500}.diagnosis-section{background:#fef3c7;border-left-color:#f59e0b}.diagnosis-card{background:#fff;border:1px solid #fcd34d;border-radius:8px;padding:16px}.diagnosis-simple{color:#1f2937;font-size:1.1rem;line-height:1.6;margin:0}.diagnosis-details{border-top:1px solid #e5e7eb;margin-top:12px;padding-top:12px}.diagnosis-details summary{color:#6b7280;cursor:pointer;font-size:.9rem;font-weight:500}.diagnosis-details p{color:#4b5563;font-size:.95rem;margin:8px 0 0}.medications-section{background:#ecfdf5;border-left-color:#10b981}.medications-list{display:flex;flex-direction:column;gap:12px}.medication-item{align-items:flex-start;background:#fff;border:1px solid #d1fae5;border-radius:10px;display:flex;gap:12px;padding:14px}.med-icon{align-items:center;background:#d1fae5;border-radius:8px;color:#059669;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.med-content{display:flex;flex-direction:column;gap:4px}.med-name{color:#1f2937;font-size:1rem;font-weight:600}.med-instructions{color:#6b7280;font-size:.9rem}.tests-section{background:#ede9fe;border-left-color:#8b5cf6}.tests-list{display:flex;flex-direction:column;gap:12px}.test-item{align-items:flex-start;background:#fff;border:1px solid #ddd6fe;border-radius:10px;display:flex;gap:12px;padding:14px}.test-icon{align-items:center;background:#ddd6fe;border-radius:8px;color:#7c3aed;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.test-content{display:flex;flex-direction:column;gap:4px}.test-name{color:#1f2937;font-size:1rem;font-weight:600}.test-prep{color:#6b7280;font-size:.9rem;font-style:italic}.faqs-section{background:#f3f4f6;border-left-color:#6b7280}.faqs-list{display:flex;flex-direction:column;gap:8px}.faq-item{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:14px}.faq-item summary{color:#374151;cursor:pointer;font-size:.95rem;font-weight:500}.faq-item p{color:#6b7280;font-size:.9rem;line-height:1.6;margin:10px 0 0}.warning-section{background:#fef2f2;border-left-color:#ef4444}.warning-section h3{color:#dc2626}.warning-list{list-style:none;margin:0;padding:0}.warning-list li{color:#991b1b;font-size:.95rem;padding:8px 0 8px 28px;position:relative}.warning-list li:before{align-items:center;background:#fecaca;border-radius:50%;color:#dc2626;content:"!";display:flex;font-size:.8rem;font-weight:700;height:20px;justify-content:center;left:0;position:absolute;top:8px;width:20px}.follow-up-note{background:#fff;border:1px solid #fecaca;border-radius:8px;color:#1f2937;font-size:.95rem;margin:16px 0 0;padding:12px}.instructions-section{background:#f0fdf4;border-left-color:#22c55e}.instructions-section p{color:#1f2937;font-size:.95rem;line-height:1.7;margin:0}@media (max-width:640px){.visit-summary-modal{margin:10px;max-height:95vh}.summary-header{padding:20px}.summary-content{padding:16px}.visit-info-section .info-grid{grid-template-columns:1fr}.summary-section{padding:16px}}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App{min-height:100vh}.loading{align-items:center;background:#f5f7fa;display:flex;flex-direction:column;justify-content:center}.spinner{animation:spin 1s linear infinite;border:4px solid #f3f4f6;border-radius:50%;border-top-color:#667eea;height:50px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading p{color:#666;font-size:16px;margin-top:20px}
/*# sourceMappingURL=main.48b0c705.css.map*/