.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px}.loading-spinner.small{padding:20px}.loading-spinner.large{padding:60px}.spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #2563eb;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}.loading-spinner.small .spinner{width:20px;height:20px;border-width:2px}.loading-spinner.large .spinner{width:60px;height:60px;border-width:6px}.loading-spinner p{color:#6b7280;font-size:14px}.notification-list{width:400px;max-height:600px;background-color:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);overflow:hidden;display:flex;flex-direction:column}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background-color:var(--bg-secondary)}.notification-header h3{margin:0;font-size:1.25rem;color:var(--text-primary)}.mark-all-btn{background:none;border:none;color:var(--primary-color);font-size:.875rem;cursor:pointer;padding:.25rem .5rem}.mark-all-btn:hover{text-decoration:underline}.notifications-container{flex:1;overflow-y:auto;max-height:500px}.no-notifications{padding:3rem 2rem;text-align:center;color:var(--text-secondary)}.empty-icon{width:64px;height:64px;margin:0 auto 1rem;opacity:.5}.notification-item{display:flex;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);cursor:pointer;transition:var(--transition);position:relative}.notification-item:hover{background-color:var(--bg-secondary)}.notification-item.unread{background-color:#4f46e50d}.notification-item.unread:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-color:var(--primary-color)}.notification-icon{flex-shrink:0;width:40px;height:40px;border-radius:50%;background-color:var(--primary-color);color:#fff;display:flex;align-items:center;justify-content:center}.notification-icon svg{width:20px;height:20px}.notification-content h4{margin:0 0 .25rem;font-size:.9375rem;font-weight:600;color:var(--text-primary)}.notification-content p{margin:0 0 .5rem;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.notification-time{font-size:.75rem;color:var(--text-light)}.delete-notification-btn{flex-shrink:0;background:none;border:none;color:var(--text-light);cursor:pointer;padding:.25rem;opacity:0;transition:var(--transition)}.notification-item:hover .delete-notification-btn{opacity:1}.delete-notification-btn:hover{color:var(--danger-color)}.delete-notification-btn svg{width:18px;height:18px}@media (max-width: 480px){.notification-list{width:100vw;max-height:100vh;border-radius:0}}.notification-bell{position:relative}.bell-button{position:relative;background:none;border:none;cursor:pointer;padding:8px;border-radius:50%;transition:background-color .3s ease}.bell-button:hover{background:#f3f4f6}.bell-icon{font-size:20px}.notification-badge{position:absolute;top:0;right:0;background:#dc2626;color:#fff;border-radius:50%;width:18px;height:18px;font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center}.dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:998}.header{background-color:#fff;box-shadow:0 2px 4px #0000001a;position:sticky;top:0;z-index:1000}.header-container{max-width:1200px;margin:0 auto;padding:0 20px;display:flex;justify-content:space-between;align-items:center;height:70px}.logo{text-decoration:none;color:#2563eb}.logo h2{font-size:24px;font-weight:700}.navigation{display:flex;align-items:center;gap:20px}.nav-link{text-decoration:none;color:#4b5563;font-weight:500;padding:8px 16px;border-radius:5px;transition:all .3s ease}.nav-link:hover{color:#2563eb;background-color:#f3f4f6}.user-menu{display:flex;align-items:center;gap:15px}.user-name{color:#374151;font-weight:500}.auth-links{display:flex;align-items:center;gap:15px}.footer{background-color:#1f2937;color:#fff;margin-top:auto}.footer-container{max-width:1200px;margin:0 auto;padding:40px 20px 20px}.footer-content{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;margin-bottom:30px}.footer-section h3,.footer-section h4{margin-bottom:15px;color:#f9fafb}.footer-section p{color:#d1d5db;line-height:1.6}.footer-section ul{list-style:none}.footer-section ul li{margin-bottom:8px;color:#d1d5db}.footer-section a{color:#d1d5db;text-decoration:none;transition:color .3s ease}.footer-section a:hover{color:#60a5fa}.footer-bottom{border-top:1px solid #374151;padding-top:20px;text-align:center;color:#9ca3af}.features-section{padding:5rem 0;background-color:var(--bg-secondary)}.section-header{text-align:center;margin-bottom:4rem}.section-header h2{font-size:2.5rem;margin-bottom:1rem;color:var(--text-primary)}.section-header p{font-size:1.125rem;color:var(--text-secondary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.feature-card{background-color:#fff;padding:2rem;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-md);text-align:center;transition:var(--transition)}.feature-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-lg)}.feature-card h3{font-size:1.5rem;margin-bottom:1rem;color:var(--text-primary)}.feature-card p{color:var(--text-secondary);line-height:1.6}@media (max-width: 768px){.features-grid{grid-template-columns:1fr}.section-header h2{font-size:2rem}}.how-it-works-section{padding:5rem 0;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.how-it-works-section .section-header{text-align:center;margin-bottom:4rem}.how-it-works-section .section-header h2{font-size:2.5rem;margin-bottom:1rem;color:#fff}.how-it-works-section .section-header p{font-size:1.125rem;color:#ffffffe6}.steps-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-bottom:4rem;position:relative}.step-card{background-color:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);padding:2rem;border-radius:var(--border-radius-lg);text-align:center;position:relative;border:1px solid rgba(255,255,255,.2);transition:var(--transition)}.step-card:hover{background-color:#ffffff26;transform:translateY(-5px)}.step-number{position:absolute;top:-15px;left:50%;transform:translate(-50%);width:40px;height:40px;background-color:#fff;color:var(--primary-color);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;box-shadow:var(--shadow-md)}.step-icon{font-size:3rem;margin:1.5rem 0 1rem}.step-card h3{font-size:1.5rem;margin-bottom:1rem;color:#fff}.step-card p{color:#ffffffe6;line-height:1.6}.cta-section{text-align:center;padding-top:3rem;border-top:1px solid rgba(255,255,255,.2)}.cta-section h3{font-size:2rem;margin-bottom:2rem;color:#fff}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.cta-buttons .btn{min-width:150px}.cta-buttons .btn-outline{background-color:transparent;border-color:#fff;color:#fff}.cta-buttons .btn-outline:hover{background-color:#fff;color:var(--primary-color)}@media (max-width: 768px){.steps-container{grid-template-columns:1fr}.how-it-works-section .section-header h2{font-size:2rem}.cta-section h3{font-size:1.5rem}}.home-page{max-width:1200px;margin:0 auto;padding:0 20px}.hero-section{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;padding:80px 0;min-height:70vh}.hero-content h1{font-size:48px;font-weight:700;color:#1f2937;line-height:1.2;margin-bottom:20px}.hero-content p{font-size:18px;color:#6b7280;line-height:1.6;margin-bottom:30px}.hero-actions{display:flex;gap:15px}.btn-large{padding:15px 30px;font-size:16px;font-weight:600}.hero-image{display:flex;justify-content:center;align-items:center}.placeholder-image{width:400px;height:300px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;font-weight:500}.login-form{display:flex;flex-direction:column}.login-btn{width:100%;padding:12px;font-size:16px;margin-top:10px}.login-btn:disabled{background-color:#9ca3af;cursor:not-allowed}.login-btn:disabled:hover{background-color:#9ca3af}.login-page{min-height:80vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:40px 20px}.login-container{background:white;padding:40px;border-radius:10px;box-shadow:0 10px 25px #0000001a;width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:30px}.login-header h2{color:#1f2937;margin-bottom:8px;font-size:24px}.login-header p{color:#6b7280;font-size:14px}.login-footer{text-align:center;margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.link{color:#2563eb;text-decoration:none;font-weight:500}.link:hover{text-decoration:underline}.register-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.register-card{background-color:#fff;border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);padding:2.5rem;width:100%;max-width:600px}.register-card h2{text-align:center;margin-bottom:.5rem;color:var(--text-primary)}.register-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:2rem}.user-type-selector{display:flex;gap:.5rem;margin-bottom:2rem;background-color:var(--bg-secondary);padding:.5rem;border-radius:var(--border-radius)}.type-btn{flex:1;padding:.75rem;background-color:transparent;border:none;border-radius:var(--border-radius);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:var(--transition)}.type-btn.active{background-color:var(--primary-color);color:#fff}.type-btn:hover:not(.active){background-color:#4f46e51a}.register-form{margin-top:1.5rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.error-text{display:block;color:var(--danger-color);font-size:.875rem;margin-top:.25rem}.btn-block{width:100%;margin-top:1rem}.note{text-align:center;margin-top:1rem;color:var(--text-secondary)}.login-link{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color);color:var(--text-secondary)}.login-link a{color:var(--primary-color);font-weight:500}.login-link a:hover{text-decoration:underline}@media (max-width: 640px){.register-card{padding:1.5rem}.form-row{grid-template-columns:1fr}}.about-page{min-height:calc(100vh - 200px);background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:2rem 0}.about-container{max-width:1200px;margin:0 auto;padding:0 2rem}.about-hero{text-align:center;padding:3rem 0;margin-bottom:3rem}.about-hero h1{font-size:3rem;color:#2c3e50;margin-bottom:1rem;font-weight:700}.about-hero .subtitle{font-size:1.5rem;color:#5a6c7d;font-weight:300}.about-section{background:white;border-radius:12px;padding:2.5rem;margin-bottom:2rem;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.about-section:hover{transform:translateY(-5px);box-shadow:0 8px 15px #00000026}.about-section h2{font-size:2rem;color:#2c3e50;margin-bottom:1.5rem;border-bottom:3px solid #3498db;padding-bottom:.5rem}.about-section p{font-size:1.1rem;line-height:1.8;color:#555}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;margin-top:2rem}.feature-card{text-align:center;padding:2rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:12px;color:#fff;transition:transform .3s ease}.feature-card:hover{transform:scale(1.05)}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{font-size:1.3rem;margin-bottom:.8rem;color:#fff}.feature-card p{font-size:1rem;line-height:1.6;color:#ffffffe6}.benefits-list{list-style:none;padding:0}.benefits-list li{font-size:1.1rem;padding:1rem;margin-bottom:1rem;background:#f8f9fa;border-left:4px solid #3498db;border-radius:4px;color:#555}.benefits-list strong{color:#2c3e50;font-weight:600}@media (max-width: 768px){.about-hero h1{font-size:2rem}.about-hero .subtitle{font-size:1.2rem}.about-section{padding:1.5rem}.features-grid{grid-template-columns:1fr}}.contact-page{min-height:calc(100vh - 200px);background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:2rem 0}.contact-container{max-width:1200px;margin:0 auto;padding:0 2rem}.contact-hero{text-align:center;padding:3rem 0;margin-bottom:3rem}.contact-hero h1{font-size:3rem;color:#2c3e50;margin-bottom:1rem;font-weight:700}.contact-hero .subtitle{font-size:1.5rem;color:#5a6c7d;font-weight:300}.contact-content{display:grid;grid-template-columns:1fr 2fr;gap:2rem}.contact-info h2,.contact-form-section h2{font-size:2rem;color:#2c3e50;margin-bottom:1.5rem}.info-card{display:flex;align-items:flex-start;background:white;padding:1.5rem;border-radius:12px;margin-bottom:1.5rem;box-shadow:0 4px 6px #0000001a;transition:transform .3s ease}.info-card:hover{transform:translate(10px)}.info-icon{font-size:2.5rem;margin-right:1rem}.info-details h3{font-size:1.2rem;color:#2c3e50;margin-bottom:.5rem}.info-details p{font-size:1rem;color:#666;line-height:1.6}.contact-form-section{background:white;padding:2.5rem;border-radius:12px;box-shadow:0 4px 6px #0000001a}.contact-form{display:flex;flex-direction:column;gap:1.5rem}.form-group label{font-size:1rem;color:#2c3e50;margin-bottom:.5rem;font-weight:600}.form-group input,.form-group textarea{padding:.8rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .3s ease,box-shadow .3s ease;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.form-group textarea{resize:vertical;min-height:120px}.submit-btn{padding:1rem 2rem;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .3s ease,box-shadow .3s ease}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 12px #667eea66}.submit-btn:active{transform:translateY(0)}.success-message{text-align:center;padding:3rem;background:linear-gradient(135deg,#11998e 0%,#38ef7d 100%);border-radius:12px;color:#fff}.success-icon{font-size:4rem;margin-bottom:1rem;animation:checkmark .5s ease-in-out}@keyframes checkmark{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.success-message h3{font-size:2rem;margin-bottom:.5rem;color:#fff}.success-message p{font-size:1.1rem;color:#ffffffe6}@media (max-width: 992px){.contact-content{grid-template-columns:1fr}.contact-info{order:2}.contact-form-section{order:1}}@media (max-width: 768px){.contact-hero h1{font-size:2rem}.contact-hero .subtitle{font-size:1.2rem}.contact-form-section{padding:1.5rem}.info-card{flex-direction:column;text-align:center}.info-icon{margin-right:0;margin-bottom:1rem}}.privacy-page{min-height:calc(100vh - 200px);background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:2rem 0}.privacy-container{max-width:900px;margin:0 auto;padding:0 2rem}.privacy-hero{text-align:center;padding:3rem 0;margin-bottom:2rem}.privacy-hero h1{font-size:3rem;color:#2c3e50;margin-bottom:1rem;font-weight:700}.privacy-hero .subtitle{font-size:1.2rem;color:#5a6c7d;font-style:italic}.privacy-content{background:white;border-radius:12px;padding:3rem;box-shadow:0 4px 6px #0000001a}.privacy-section{margin-bottom:2.5rem;padding-bottom:2rem;border-bottom:1px solid #e0e0e0}.privacy-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.privacy-section h2{font-size:1.8rem;color:#2c3e50;margin-bottom:1rem;font-weight:600}.privacy-section h3{font-size:1.3rem;color:#34495e;margin-top:1.5rem;margin-bottom:.8rem;font-weight:600}.privacy-section p{font-size:1.05rem;line-height:1.8;color:#555;margin-bottom:1rem}.privacy-section ul{margin-left:1.5rem;margin-bottom:1rem}.privacy-section ul li{font-size:1.05rem;line-height:1.8;color:#555;margin-bottom:.5rem;position:relative;padding-left:.5rem}.privacy-section ul li::marker{color:#3498db}.privacy-section strong{color:#2c3e50;font-weight:600}.privacy-section:nth-child(4),.privacy-section:nth-child(5){background:#f8f9fa;padding:1.5rem;border-radius:8px;border:2px solid #3498db}.privacy-content:before{content:"";display:block;height:0}@media (max-width: 768px){.privacy-hero h1{font-size:2rem}.privacy-hero .subtitle{font-size:1rem}.privacy-content{padding:1.5rem}.privacy-section h2{font-size:1.5rem}.privacy-section h3{font-size:1.2rem}.privacy-section p,.privacy-section ul li{font-size:1rem}}.upcoming-appointments{background:white;padding:25px;border-radius:10px;box-shadow:0 2px 4px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header h3{color:#1f2937;margin:0}.btn-small{padding:8px 16px;font-size:12px}.empty-state{text-align:center;padding:40px 20px;color:#6b7280}.empty-state p{margin-bottom:15px}.appointments-list{display:flex;flex-direction:column;gap:15px}.appointment-card{display:flex;justify-content:space-between;align-items:center;padding:20px;border:1px solid #e5e7eb;border-radius:8px;transition:all .3s ease}.appointment-card:hover{border-color:#2563eb;box-shadow:0 2px 8px #2563eb1a}.appointment-info h4{margin:0 0 5px;color:#1f2937}.specialty{color:#6b7280;font-size:14px;margin:0 0 8px}.date{color:#374151;font-weight:500;margin:0}.time-slot{color:#6b7280;font-size:13px;margin:4px 0 0}.status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize;display:inline-block;margin-top:10px}.status.scheduled{background:#dbeafe;color:#1e40af}.status.confirmed{background:#d1fae5;color:#065f46}.status.completed{background:#dcfce7;color:#166534}.status.cancelled{background:#fef2f2;color:#dc2626}.appointment-actions{display:flex;flex-direction:column;gap:10px;align-items:flex-end}.btn-outline{background:transparent;border:1px solid #d1d5db;color:#374151}.btn-outline:hover:not(:disabled){background:#f3f4f6}.btn-outline:disabled{opacity:.5;cursor:not-allowed}.cancel-warning{color:#dc2626;font-size:.75rem;margin-top:.25rem}.appointment-times{display:flex;flex-direction:column;gap:.75rem;margin:.75rem 0;padding:.75rem;background-color:#f9fafb;border-radius:.375rem}.time-info{display:flex;flex-direction:column;gap:.25rem}.time-info strong{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.booked-time{font-size:.875rem;color:#374151;margin:0}.quick-actions{background:white;padding:25px;border-radius:10px;box-shadow:0 2px 4px #0000001a}.quick-actions h3{color:#1f2937;margin-bottom:20px}.actions-grid{display:grid;gap:15px}.action-card{border:1px solid #e5e7eb;border-radius:8px;transition:all .3s ease;cursor:pointer}.action-card:hover{border-color:var(--action-color);transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.action-content{padding:20px;text-decoration:none;color:inherit;display:flex;align-items:center;gap:15px}.action-icon{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px}.action-info h4{margin:0 0 5px;color:#1f2937;font-size:16px}.action-info p{margin:0;color:#6b7280;font-size:14px}.chatbot-container{display:flex;flex-direction:column;height:500px;background:white;border-radius:12px;box-shadow:0 4px 20px #0000001a;border:1px solid #edf2f7;margin-top:20px;overflow:hidden;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.chatbot-header{padding:16px 20px;background:linear-gradient(135deg,#1a365d 0%,#2c5282 100%);color:#fff;display:flex;justify-content:space-between;align-items:center}.chatbot-header h3{margin:0;font-size:1.1rem;display:flex;align-items:center;gap:8px}.messages-area{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:16px;background:#f8fafc}.message{max-width:80%;padding:12px 16px;border-radius:12px;font-size:.95rem;line-height:1.5;position:relative}.message.bot{align-self:flex-start;background:white;box-shadow:0 2px 4px #0000000d;border-bottom-left-radius:2px;color:#2d3748}.message.user{align-self:flex-end;background:#3182ce;color:#fff;border-bottom-right-radius:2px}.input-area{padding:16px;background:white;border-top:1px solid #edf2f7;display:flex;gap:12px;align-items:center}.chat-input{flex:1;padding:12px;border:1px solid #e2e8f0;border-radius:24px;outline:none;font-size:.95rem;transition:all .2s}.chat-input:focus{border-color:#3182ce;box-shadow:0 0 0 2px #3182ce1a}.voice-btn,.send-btn{width:40px;height:40px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.voice-btn{background:#edf2f7;color:#4a5568}.voice-btn:hover{background:#e2e8f0}.voice-btn.listening{background:#feb2b2;color:#c53030;animation:pulse 1.5s infinite}.send-btn{background:#3182ce;color:#fff}.send-btn:hover{background:#2c5282}.send-btn:disabled{background:#cbd5e0;cursor:not-allowed}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.typing-indicator{display:flex;gap:4px;padding:4px 8px}.dot{width:8px;height:8px;background:#cbd5e0;border-radius:50%;animation:bounce 1.4s infinite ease-in-out}.dot:nth-child(1){animation-delay:-.32s}.dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.patient-dashboard{max-width:1200px;margin:0 auto}.dashboard-header{margin-bottom:30px}.dashboard-header h1{color:#1f2937;font-size:32px;margin-bottom:8px}.dashboard-header p{color:#6b7280;font-size:16px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:white;padding:25px;border-radius:10px;box-shadow:0 2px 4px #0000001a;display:flex;align-items:center;gap:15px;transition:transform .3s ease}.stat-card:hover{transform:translateY(-2px)}.stat-icon{font-size:32px;width:60px;height:60px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center}.stat-info h3{font-size:28px;font-weight:700;color:#1f2937;margin:0 0 5px}.stat-info p{color:#6b7280;margin:0;font-size:14px}.dashboard-content{display:grid;grid-template-columns:2fr 1fr;gap:30px}.content-left,.content-right{display:flex;flex-direction:column;gap:20px}.voice-assistant-container{margin-top:20px;background:white;border-radius:12px;box-shadow:0 4px 6px #0000000d;padding:20px;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.search-filters{background:white;padding:25px;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px}.filters-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.filters-header h3{color:#1f2937;margin:0}.doctor-count{color:#6b7280;font-size:14px;font-weight:500}.filters-grid{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:15px;align-items:end}.filter-group{display:flex;flex-direction:column}.filter-label{font-weight:500;color:#374151;margin-bottom:8px;font-size:14px}.filter-input{padding:10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:border-color .3s ease}.filter-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.doctor-card{background:white;border-radius:10px;box-shadow:0 2px 8px #0000001a;padding:20px;transition:all .3s ease}.doctor-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.doctor-header{display:flex;gap:15px;margin-bottom:15px}.doctor-image{flex-shrink:0}.doctor-image img{width:80px;height:80px;border-radius:50%;object-fit:cover}.doctor-avatar{width:80px;height:80px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:32px}.doctor-info{flex:1}.doctor-name{margin:0 0 5px;color:#1f2937;font-size:18px}.doctor-specialty{margin:0 0 8px;color:#2563eb;font-weight:500;font-size:14px}.doctor-rating{display:flex;align-items:center;gap:8px}.rating-stars{color:#f59e0b;font-weight:500}.rating-count{color:#6b7280;font-size:12px}.doctor-details{margin-bottom:15px}.detail-item{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px}.detail-label{color:#6b7280}.doctor-availability{margin-bottom:15px}.availability{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.availability.available{background:#dcfce7;color:#166534}.availability.not-available{background:#fef2f2;color:#dc2626}.doctor-actions{display:flex;flex-direction:column;gap:8px}.btn-full{width:100%;text-align:center;justify-content:center}.doctor-list{margin-bottom:40px}.doctors-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.empty-state{text-align:center;padding:60px 20px;background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a}.empty-state h3{color:#1f2937;margin-bottom:10px}.empty-state p{color:#6b7280;margin:0}.voice-button{position:relative;display:flex;align-items:center;gap:10px;padding:15px 25px;background:#2563eb;color:#fff;border:none;border-radius:50px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #2563eb4d}.voice-button:hover{background:#1d4ed8;transform:translateY(-2px);box-shadow:0 6px 16px #2563eb66}.voice-button.listening{background:#dc2626;box-shadow:0 4px 12px #dc26264d}.voice-button.listening:hover{background:#b91c1c;box-shadow:0 6px 16px #dc262666}.voice-icon{font-size:20px}.voice-text{font-weight:500}.pulse-animation{position:absolute;top:-5px;left:-5px;right:-5px;bottom:-5px;border:2px solid #dc2626;border-radius:50px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%{transform:scale(1);opacity:1}to{transform:scale(1.1);opacity:0}}.voice-assistant{background:white;padding:20px;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px}.voice-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.voice-header h3{color:#1f2937;margin:0}.voice-controls{display:flex;flex-direction:column;align-items:center;gap:15px}.doctor-search{max-width:1200px;margin:0 auto}.search-header{margin-bottom:30px}.search-header h1{color:#1f2937;font-size:32px;margin-bottom:8px}.search-header p{color:#6b7280;font-size:16px}.doctor-profile-container{padding:2rem;max-width:1200px;margin:0 auto}.profile-header{background:white;border-radius:12px;padding:2rem;display:flex;gap:2rem;box-shadow:0 4px 6px #0000000d;margin-bottom:2rem}.profile-image-container{flex-shrink:0;width:200px;height:200px;border-radius:12px;overflow:hidden;background:#f0f2f5;display:flex;align-items:center;justify-content:center}.profile-image-container img{width:100%;height:100%;object-fit:cover}.profile-avatar{font-size:80px}.profile-info-header{flex:1}.profile-info-header h1{margin:0 0 .5rem;color:#333;font-size:2rem}.specialty-badge{display:inline-block;background:#e3f2fd;color:#1976d2;padding:.25rem .75rem;border-radius:20px;font-weight:500;margin-bottom:1rem}.rating-summary{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.1rem}.doctor-stats{display:flex;gap:2rem;margin-top:1.5rem;border-top:1px solid #eee;padding-top:1.5rem}.stat-item{display:flex;flex-direction:column}.stat-label{color:#666;font-size:.9rem;margin-bottom:.25rem}.stat-value{color:#333;font-weight:600;font-size:1.1rem}.profile-content{display:grid;grid-template-columns:2fr 1fr;gap:2rem}.info-section{background:white;border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000000d;margin-bottom:2rem}.info-section h2{margin:0 0 1.5rem;color:#333;font-size:1.25rem;border-bottom:2px solid #f0f2f5;padding-bottom:.75rem}.qualification-item{display:flex;margin-bottom:1rem;background:#f8f9fa;padding:1rem;border-radius:8px}.qualification-icon{font-size:1.5rem;margin-right:1rem;display:flex;align-items:center}.qualification-details h4{margin:0 0 .25rem;color:#333}.qualification-details p{margin:0;color:#666}.hospital-details{display:flex;gap:1rem}.hospital-icon{font-size:1.5rem;color:#666;margin-top:.25rem}.hospital-info h3{margin:0 0 .5rem;color:#333}.clinic-address{color:#666;line-height:1.6;margin-bottom:1rem}.contact-info{display:flex;align-items:center;gap:.5rem;color:#666}.booking-card{background:white;border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px #0000000d;position:sticky;top:2rem}.fee-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.fee-label{color:#666;font-size:1.1rem}.fee-amount{color:#2e7d32;font-size:1.5rem;font-weight:700}.availability-card{margin-bottom:1.5rem}.availability-card h3{font-size:1rem;margin-bottom:1rem;color:#333}.days-list{display:flex;flex-wrap:wrap;gap:.5rem}.day-badge{background:#f0f2f5;color:#666;padding:.25rem .75rem;border-radius:15px;font-size:.85rem;text-transform:capitalize}.book-btn{width:100%;padding:1rem;background:#1976d2;color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:block;text-align:center}.book-btn:hover{background:#1565c0;transform:translateY(-2px);box-shadow:0 4px 8px #1976d24d}.reviews-list{display:flex;flex-direction:column;gap:1rem}.review-item{border-bottom:1px solid #eee;padding-bottom:1rem}.review-header{display:flex;justify-content:space-between;margin-bottom:.5rem}.reviewer-name{font-weight:500;color:#333}.review-date{color:#999;font-size:.85rem}.review-comment{color:#666;line-height:1.5;margin:0}@media (max-width: 900px){.profile-content{grid-template-columns:1fr}}@media (max-width: 600px){.profile-header{flex-direction:column;align-items:center;text-align:center}.doctor-stats,.rating-summary{justify-content:center}}.time-slot-picker{max-width:600px;margin:0 auto}.picker-header{margin-bottom:30px;text-align:center}.picker-header h3{color:#1f2937;margin-bottom:8px}.picker-header p{color:#6b7280;margin:0}.date-selection{margin-bottom:30px}.date-selection h4{color:#374151;margin-bottom:15px}.date-options{display:flex;gap:10px;overflow-x:auto;padding-bottom:10px}.date-option{padding:12px 16px;border:1px solid #d1d5db;border-radius:8px;background:white;cursor:pointer;transition:all .3s ease;white-space:nowrap;font-size:14px}.date-option:hover{border-color:#2563eb}.date-option.selected{background:#2563eb;color:#fff;border-color:#2563eb}.time-selection{margin-bottom:30px}.time-selection h4{color:#374151;margin-bottom:20px}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}.time-slot{padding:12px 8px;border:1px solid #d1d5db;border-radius:6px;background:white;cursor:pointer;transition:all .3s ease;font-size:14px;font-weight:500;display:flex;flex-direction:column;align-items:center;gap:4px}.time-slot:hover:not(.unavailable){border-color:#2563eb;background:#f0f9ff}.time-slot.selected{background:#2563eb;color:#fff;border-color:#2563eb}.time-slot.unavailable{background:#f3f4f6;color:#9ca3af;cursor:not-allowed;border-color:#e5e7eb}.slot-status{font-size:10px;color:#dc2626;font-weight:500}.time-slot.selected .slot-status{color:#fff}.picker-actions{text-align:center;margin-bottom:20px}.selected-slot-info{background:#f0f9ff;padding:20px;border-radius:8px;border:1px solid #bfdbfe}.selected-slot-info h4{color:#1e40af;margin-bottom:10px}.selected-slot-info p{margin:0;color:#374151;line-height:1.6}.booking-form{max-width:600px;margin:0 auto}.form-header{margin-bottom:30px;text-align:center}.form-header h3{color:#1f2937;margin-bottom:8px}.form-header p{color:#6b7280;margin:0}.appointment-summary{background:#f0f9ff;padding:20px;border-radius:8px;border:1px solid #bfdbfe;margin-bottom:30px}.appointment-summary h4{color:#1e40af;margin-bottom:10px}.appointment-summary p{margin:0;color:#374151;line-height:1.6}.patient-form{display:flex;flex-direction:column;gap:20px}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column}.form-label{font-weight:500;color:#374151;margin-bottom:8px;font-size:14px}.form-input{padding:12px;border:1px solid #d1d5db;border-radius:6px;font-size:14px;transition:all .3s ease;font-family:inherit}.form-input.error{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-input textarea{resize:vertical;min-height:80px}.error-text{color:#dc2626;font-size:12px;margin-top:5px}.form-actions{display:flex;justify-content:space-between;gap:15px;margin-top:30px}.form-actions .btn{flex:1}.booking-confirmation{max-width:700px;margin:0 auto;text-align:center}.confirmation-header{margin-bottom:40px}.success-icon{font-size:64px;margin-bottom:20px}.confirmation-header h2{color:#059669;margin-bottom:10px;font-size:28px}.confirmation-header p{color:#6b7280;font-size:16px;margin:0}.confirmation-details{display:flex;flex-direction:column;gap:20px;margin-bottom:40px}.detail-card{background:white;padding:25px;border-radius:10px;box-shadow:0 2px 4px #0000001a;text-align:left}.detail-card h3{color:#1f2937;margin-bottom:20px;border-bottom:2px solid #f3f4f6;padding-bottom:10px}.details-grid{display:grid;grid-template-columns:1fr 1fr;gap:15px}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6}.detail-label{color:#6b7280;font-weight:500}.detail-value{color:#374151;font-weight:500}.detail-value.fee{color:#059669;font-weight:600}.status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.status.confirmed{background:#dcfce7;color:#166534}.doctor-info{display:flex;gap:15px;align-items:flex-start}.doctor-avatar{width:60px;height:60px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.doctor-details h4{margin:0 0 5px;color:#1f2937}.specialty{color:#2563eb;font-weight:500;margin:0 0 5px}.hospital,.experience{color:#6b7280;margin:0 0 5px;font-size:14px}.rating{color:#f59e0b;font-weight:500;font-size:14px}.next-steps{display:flex;flex-direction:column;gap:20px}.step{display:flex;gap:15px;align-items:flex-start}.step-number{width:30px;height:30px;background:#2563eb;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0}.step-content{flex:1;text-align:left}.step-content strong{color:#1f2937;display:block;margin-bottom:5px}.step-content p{color:#6b7280;margin:0;font-size:14px}.confirmation-actions{display:flex;gap:15px;justify-content:center;margin-bottom:20px}.confirmation-actions .btn{min-width:200px}.link-button{background:none;border:none;color:#2563eb;text-decoration:underline;cursor:pointer;font-size:inherit}.link-button:hover{color:#1d4ed8}.confirmation-footer{color:#6b7280;font-size:14px}.appointment-booking{padding:20px;max-width:1200px;margin:0 auto}.appointment-booking h1{margin-bottom:20px;color:#333}.booking-container{background:white;border-radius:8px;padding:30px;box-shadow:0 2px 10px #0000001a}.appointment-history h3{color:#1f2937;margin-bottom:20px;border-bottom:2px solid #f3f4f6;padding-bottom:10px}.history-list{display:flex;flex-direction:column;gap:15px}.history-item{border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .3s ease}.history-item:hover{border-color:#2563eb;box-shadow:0 2px 8px #2563eb1a}.history-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px;flex-wrap:wrap}.doctor-info h4{margin:0 0 5px;color:#1f2937;white-space:normal;word-break:break-word}.specialty{color:#2563eb;font-weight:500;margin:0 0 8px;font-size:14px}.date{color:#6b7280;margin:0;font-size:14px}.appointment-details{text-align:right}.status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.diagnosis{margin:8px 0 0;color:#374151;font-size:14px;max-width:300px}.appointment-notes{background:#f8fafc;padding:10px;border-radius:6px;border-left:3px solid #2563eb;font-size:14px;color:#374151}.empty-history{text-align:center;padding:60px 20px}.empty-history h3{color:#1f2937;margin-bottom:10px}.empty-history p{color:#6b7280;margin:0}.video-call-action{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.btn-join-video{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:.5rem}.btn-join-video:hover{transform:translateY(-2px);box-shadow:0 8px 16px #667eea66}.btn-join-video:active{transform:translateY(0)}.appointment-actions{margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb;display:flex;gap:10px;align-items:center}.btn-cancel{background:transparent;border:1px solid #dc2626;color:#dc2626;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .3s ease}.btn-cancel:hover:not(:disabled){background:#dc2626;color:#fff}.btn-cancel:disabled{opacity:.5;cursor:not-allowed}.time-slot{color:#6b7280;font-size:13px;margin:4px 0}.prescription-history h3{color:#1f2937;margin-bottom:20px;border-bottom:2px solid #f3f4f6;padding-bottom:10px}.prescriptions-list{display:flex;flex-direction:column;gap:20px}.prescription-card{border:1px solid #e5e7eb;border-radius:8px;padding:20px;transition:all .3s ease}.prescription-card:hover{border-color:#2563eb;box-shadow:0 2px 8px #2563eb1a}.prescription-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.prescription-info h4{margin:0 0 5px;color:#1f2937}.date{color:#6b7280;margin:0 0 8px;font-size:14px}.diagnosis{color:#374151;margin:0;font-size:14px}.prescription-status .status{padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.status.active{background:#dcfce7;color:#166534}.status.completed{background:#dbeafe;color:#1e40af}.status.expired{background:#fef2f2;color:#dc2626}.medicines-list{margin-bottom:15px}.medicines-list h5{color:#374151;margin:0 0 10px;font-size:14px}.medicine-item{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #f3f4f6;font-size:14px}.medicine-name{font-weight:500;color:#1f2937;flex:2}.medicine-dosage{color:#6b7280;flex:2}.medicine-notes{color:#dc2626;flex:1;text-align:right;font-size:12px}.prescription-notes{background:#f0f9ff;padding:10px;border-radius:6px;border-left:3px solid #2563eb;font-size:14px;color:#374151;margin-bottom:15px}.prescription-actions{display:flex;gap:10px}.empty-prescriptions{text-align:center;padding:60px 20px}.empty-prescriptions .empty-icon{font-size:48px;margin-bottom:20px}.empty-prescriptions p{color:#6b7280;margin:0}.medical-history{max-width:1000px;margin:0 auto}.medical-header{margin-bottom:30px}.medical-header h1{color:#1f2937;font-size:32px;margin-bottom:8px}.medical-header p{color:#6b7280;font-size:16px;margin:0}.medical-tabs{display:flex;background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px;overflow:hidden}.tab-button{flex:1;padding:20px;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;font-size:16px;font-weight:500;color:#6b7280;transition:all .3s ease;position:relative}.tab-button.active{color:#2563eb;background:#f0f9ff}.tab-button.active:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;background:#2563eb}.tab-count{background:#e5e7eb;color:#374151;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:600}.tab-button.active .tab-count{background:#2563eb;color:#fff}.tab-content{background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:30px}.upload-zone{margin-bottom:30px}.dropzone{border:2px dashed #d1d5db;border-radius:12px;padding:60px 40px;text-align:center;background:#fafafa;transition:all .3s ease;cursor:pointer;position:relative}.dropzone:hover{border-color:#2563eb;background:#f0f9ff}.dropzone.active{border-color:#2563eb;background:#e0f2fe;border-style:solid}.dropzone.uploading{cursor:not-allowed;opacity:.7}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:15px}.upload-icon{font-size:48px;margin-bottom:10px}.dropzone h3{color:#1f2937;margin:0 0 8px;font-size:20px}.dropzone p{color:#6b7280;margin:0 0 15px;font-size:14px}.file-types{display:flex;flex-direction:column;gap:5px;margin-bottom:20px}.file-types span{color:#9ca3af;font-size:12px}.uploading-content{display:flex;flex-direction:column;align-items:center;gap:15px}.uploading-spinner{width:40px;height:40px;border:3px solid #e5e7eb;border-top:3px solid #2563eb;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.uploading-content h3{color:#1f2937;margin:0}.uploading-content p{color:#6b7280;margin:0;font-size:14px}.upload-tips{background:#f0f9ff;padding:20px;border-radius:8px;border-left:4px solid #2563eb;margin-top:20px}.upload-tips h4{color:#1e40af;margin:0 0 10px;font-size:14px}.upload-tips ul{margin:0;padding-left:20px;color:#374151}.upload-tips li{margin-bottom:5px;font-size:13px;line-height:1.4}.prescription-card{background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a;padding:20px;transition:all .3s ease}.prescription-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.file-info{display:flex;gap:12px;align-items:flex-start}.file-icon{font-size:24px;width:40px;height:40px;background:#f3f4f6;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.file-details{flex:1;min-width:0}.file-name{margin:0 0 4px;color:#1f2937;font-size:16px;word-break:break-word}.file-meta{margin:0;color:#6b7280;font-size:12px}.status-badge{padding:4px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase;background:rgba(0,0,0,.05)}.prescription-preview{margin-bottom:15px}.preview-image{position:relative;border-radius:8px;overflow:hidden;background:#f8fafc;cursor:pointer;transition:all .3s ease}.preview-image:hover{transform:scale(1.02)}.preview-image img{width:100%;height:200px;object-fit:contain;transition:opacity .3s ease;background:white}.image-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#6b7280;font-size:14px}.preview-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.preview-image:hover .preview-overlay{opacity:1}.preview-overlay span{color:#fff;font-weight:500;font-size:14px}.pdf-preview{padding:40px 20px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.pdf-icon{font-size:48px;margin-bottom:10px}.pdf-preview span{color:#6b7280;font-size:14px}.no-image-placeholder{padding:60px 20px;text-align:center;color:#9ca3af;font-size:14px}.preview-image.no-image{height:200px;display:flex;align-items:center;justify-content:center;cursor:default}.preview-image.no-image:hover{transform:none}.validation-notes,.validated-by,.medicines-detected{margin-bottom:10px;font-size:14px}.validation-notes{background:#f0f9ff;padding:10px;border-radius:6px;border-left:3px solid #2563eb}.validated-by{color:#6b7280}.medicines-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}.medicine-tag{background:#dcfce7;color:#166534;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500}.card-actions{display:flex;gap:8px;margin-top:15px}.card-actions .btn{flex:1}.btn-danger{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.btn-danger:hover{background:#fecaca}.image-modal{position:fixed;top:0;left:0;right:0;bottom:0;z-index:1000;display:flex;align-items:center;justify-content:center}.image-modal .modal-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.8)}.image-modal .modal-content{position:relative;max-width:90%;max-height:90%;background:white;border-radius:8px;overflow:hidden}.image-modal .modal-content img{max-width:100%;max-height:100%;object-fit:contain}.close-button{position:absolute;top:10px;right:10px;background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:50%;width:30px;height:30px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:1001}.close-button:hover{background:rgba(0,0,0,.9)}.prescription-list{margin-top:20px}.prescriptions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.empty-prescriptions{text-align:center;padding:60px 20px;background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a}.empty-icon{font-size:64px;margin-bottom:20px}.empty-prescriptions h3{color:#1f2937;margin-bottom:10px}.empty-prescriptions p{color:#6b7280;margin:0;font-size:14px}.prescription-upload{max-width:1000px;margin:0 auto}.upload-header{margin-bottom:30px}.upload-header h1{color:#1f2937;font-size:32px;margin-bottom:8px}.upload-header p{color:#6b7280;font-size:16px;margin:0}.prescriptions-section{margin-top:40px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:15px}.section-header h2{color:#1f2937;margin:0}.prescription-tabs{display:flex;background:white;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.tab-button{padding:12px 20px;background:none;border:none;cursor:pointer;font-size:14px;font-weight:500;color:#6b7280;transition:all .3s ease;display:flex;align-items:center;gap:6px;position:relative}.tab-button:hover{background:#f9fafb;color:#374151}.tab-button.active{background:#2563eb;color:#fff}.tab-count{background:#e5e7eb;color:#374151;padding:2px 6px;border-radius:8px;font-size:12px;font-weight:600}.tab-button.active .tab-count{background:rgba(255,255,255,.3);color:#fff}.notification-item{display:flex;align-items:flex-start;gap:15px;padding:20px;background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a;cursor:pointer;transition:all .3s ease;position:relative;border-left:4px solid transparent}.notification-item.unread{border-left-color:#2563eb;background:#f8fafc}.notification-item:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.notification-icon{font-size:20px;width:40px;height:40px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notification-item.unread .notification-icon{background:#dbeafe}.notification-content{flex:1;min-width:0}.notification-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.notification-title{margin:0;color:#1f2937;font-size:16px;font-weight:600}.notification-item.read .notification-title{color:#6b7280}.notification-time{color:#9ca3af;font-size:12px;font-weight:500;flex-shrink:0;margin-left:10px}.notification-message{margin:0 0 10px;color:#6b7280;font-size:14px;line-height:1.4}.notification-metadata{display:flex;flex-wrap:wrap;gap:8px}.metadata-item{background:#f3f4f6;padding:4px 8px;border-radius:4px;font-size:12px;color:#6b7280;font-weight:500}.notification-actions{display:flex;gap:5px;opacity:0;transition:opacity .3s ease}.notification-item:hover .notification-actions{opacity:1}.action-btn{width:28px;height:28px;border:none;border-radius:50%;cursor:pointer;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.action-btn.mark-read{background:#dcfce7;color:#166534}.action-btn.mark-read:hover{background:#bbf7d0}.action-btn.delete{background:#fef2f2;color:#dc2626}.action-btn.delete:hover{background:#fecaca}.unread-indicator{position:absolute;top:20px;right:20px;width:8px;height:8px;background:#2563eb;border-radius:50%}.notification-settings{background:white;padding:25px;border-radius:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:30px}.settings-header{margin-bottom:30px;text-align:center}.settings-header h3{color:#1f2937;margin-bottom:8px}.settings-header p{color:#6b7280;margin:0}.settings-sections{display:flex;flex-direction:column;gap:30px}.settings-section h4{color:#374151;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #f3f4f6}.settings-group{display:flex;flex-direction:column;gap:20px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:15px;border:1px solid #e5e7eb;border-radius:8px;transition:all .3s ease}.setting-item:hover{border-color:#2563eb;background:#f8fafc}.setting-info{flex:1}.setting-label{display:block;font-weight:600;color:#1f2937;margin-bottom:4px;cursor:pointer}.setting-description{color:#6b7280;font-size:14px;margin:0}.setting-control{margin-left:15px}.toggle-switch{width:44px;height:24px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#d1d5db;border-radius:12px;position:relative;cursor:pointer;transition:all .3s ease}.toggle-switch:checked{background:#2563eb}.toggle-switch:before{content:"";position:absolute;width:20px;height:20px;background:white;border-radius:50%;top:2px;left:2px;transition:all .3s ease}.toggle-switch:checked:before{left:22px}.settings-actions{display:flex;justify-content:flex-end;gap:15px;margin-top:30px;padding-top:20px;border-top:1px solid #e5e7eb}.notifications-center{max-width:800px;margin:0 auto}.notifications-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px}.header-left h1{color:#1f2937;font-size:32px;margin-bottom:8px}.header-left p{color:#6b7280;font-size:16px;margin:0}.header-actions{display:flex;gap:10px}.notifications-filters{display:flex;gap:10px;margin-bottom:30px;padding:20px;background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a}.filter-btn{padding:10px 16px;border:1px solid #e5e7eb;background:white;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;color:#6b7280;transition:all .3s ease;display:flex;align-items:center;gap:6px}.filter-btn:hover{border-color:#2563eb;color:#2563eb}.filter-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.filter-count{background:#e5e7eb;color:#374151;padding:2px 6px;border-radius:10px;font-size:12px;font-weight:600}.filter-btn.active .filter-count{background:rgba(255,255,255,.3);color:#fff}.notifications-list{display:flex;flex-direction:column;gap:10px}.empty-notifications{text-align:center;padding:60px 20px;background:white;border-radius:10px;box-shadow:0 2px 4px #0000001a}.empty-icon{font-size:48px;margin-bottom:20px}.empty-notifications h3{color:#1f2937;margin-bottom:10px}.empty-notifications p{color:#6b7280;margin:0}.patient-orders{padding:2rem;max-width:1200px;margin:0 auto}.patient-orders h2{color:#2c3e50;margin-bottom:2rem}.orders-list{display:flex;flex-direction:column;gap:1.5rem}.order-card{background:white;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;box-shadow:0 2px 4px #0000000d}.order-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #eee}.order-header h3{margin:0;color:#2c3e50;font-size:1.1rem}.order-date{color:#7f8c8d;font-size:.9rem;margin:.25rem 0 0}.order-status{padding:.5rem 1rem;border-radius:20px;color:#fff;font-size:.85rem;font-weight:600;text-transform:capitalize}.order-body{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1rem}.order-items ul{margin:.5rem 0 0;padding-left:1.5rem}.order-items li{margin:.25rem 0;color:#555}.order-details p{margin:.5rem 0;color:#555}.rejection-reason{color:#c62828!important;background:#ffebee;padding:.5rem;border-radius:4px;margin-top:1rem!important}.btn-view-details{padding:.75rem 1.5rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.btn-view-details:hover{background-color:#2980b9}.order-actions{display:flex;gap:1rem;margin-top:1rem}.btn-cancel-order{padding:.75rem 1.5rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.btn-cancel-order:hover{background-color:#c0392b}.btn-cancel-confirm{padding:.75rem 1.5rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.btn-cancel-confirm:hover{background-color:#c0392b}.cancellation-reason{color:#e67e22!important;background:#fff3e0;padding:.5rem;border-radius:4px;margin-top:1rem!important}.no-orders{text-align:center;padding:3rem;background:#f8f9fa;border-radius:8px;color:#7f8c8d;font-size:1.1rem}.order-detail-section{margin:1rem 0}.order-detail-section h4{margin-top:1.5rem;color:#2c3e50}.order-detail-section ul{padding-left:1.5rem}.rejection-info{background:#ffebee;padding:1rem;border-radius:4px;margin-top:1rem}.rejection-info h4{color:#c62828;margin-top:0}.btn-close{padding:.75rem 1.5rem;background-color:#95a5a6;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;margin-top:1rem}.btn-close:hover{background-color:#7f8c8d}@media (max-width: 768px){.order-body{grid-template-columns:1fr}}.video-call-container{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#1a1a2e;z-index:1000;display:flex;flex-direction:column}.video-call-header{padding:1.5rem 2rem;background:rgba(0,0,0,.3);border-bottom:1px solid rgba(255,255,255,.1)}.call-info{display:flex;justify-content:space-between;align-items:center;max-width:1400px;margin:0 auto}.call-info h3{color:#fff;font-size:1.25rem;margin:0}.status{padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:500}.status.connecting{background:#ff9800;color:#fff}.status.connected{background:#4caf50;color:#fff}.video-streams{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}.remote-video-container{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#0f0f1e}.remote-video{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}.waiting-message{display:flex;flex-direction:column;align-items:center;gap:1.5rem;color:#fff}.waiting-message .avatar{width:120px;height:120px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;font-size:3rem;font-weight:700;color:#fff}.waiting-message p{font-size:1.125rem;opacity:.8}.local-video-container{position:absolute;bottom:100px;right:2rem;width:280px;height:160px;border-radius:12px;overflow:hidden;box-shadow:0 8px 32px #0006;border:2px solid rgba(255,255,255,.1);background:#0f0f1e}.local-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.video-off-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#1a1a2e;display:flex;align-items:center;justify-content:center}.video-off-overlay .avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;color:#fff}.video-call-controls{position:absolute;bottom:2rem;left:50%;transform:translate(-50%);display:flex;gap:1rem;padding:1rem 2rem;background:rgba(0,0,0,.6);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:50px;box-shadow:0 8px 32px #0006}.control-btn{width:56px;height:56px;border-radius:50%;border:none;background:rgba(255,255,255,.1);color:#fff;font-size:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.control-btn:hover{background:rgba(255,255,255,.2);transform:scale(1.1)}.control-btn.active,.end-call-btn{background:#e94560}.end-call-btn:hover{background:#d63447;transform:scale(1.1) rotate(135deg)}.video-call-loading,.video-call-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;color:#fff;gap:1.5rem}.spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.1);border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}.video-call-error h2{color:#e94560}.video-call-error button{padding:.75rem 2rem;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:background .3s ease}.video-call-error button:hover{background:#764ba2}@media (max-width: 768px){.local-video-container{width:120px;height:80px;bottom:120px;right:1rem}.video-call-controls{gap:.5rem;padding:.75rem 1.5rem}.control-btn{width:48px;height:48px;font-size:1.25rem}.call-info h3{font-size:1rem}}.patient-layout{display:flex;min-height:calc(100vh - 140px)}.sidebar{width:280px;background:white;box-shadow:2px 0 5px #0000001a;padding:20px 0}.sidebar-header{padding:0 20px 20px;border-bottom:1px solid #e5e7eb;margin-bottom:20px}.sidebar-header h3{color:#2563eb;margin-bottom:15px}.user-info{display:flex;align-items:center;gap:10px}.user-avatar{width:40px;height:40px;background:#f3f4f6;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px}.user-name{font-weight:600;color:#1f2937;margin:0}.user-role{color:#6b7280;font-size:12px;margin:0}.sidebar-nav{display:flex;flex-direction:column;gap:5px;padding:0 10px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 15px;text-decoration:none;color:#6b7280;border-radius:8px;transition:all .3s ease}.nav-item:hover{background:#f3f4f6;color:#374151}.nav-item.active{background:#2563eb;color:#fff}.nav-icon{font-size:18px}.nav-label{font-weight:500}.patient-main{flex:1;padding:30px;background:#f8fafc}.patient-portal{min-height:100vh}.doctor-appointments-card{background:white;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;overflow:hidden;margin-top:0}.doctor-appointments-card .card-header{background:#f8fafc;padding:20px 30px;border-bottom:1px solid #e5e7eb}.doctor-appointments-card .card-header h3{margin:0;color:#0f172a;font-size:1.25rem;font-weight:600}.appointments-content{padding:30px}.appointments-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.appointment-card{display:flex;justify-content:space-between;align-items:center;padding:16px;border:1px solid #e2e8f0;border-radius:8px;transition:all .2s ease;background:white}.appointment-card:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px);border-color:#cbd5e1}.appointment-info h4{margin:0 0 6px;color:#1e293b;font-size:1.05rem}.appointment-meta{display:flex;flex-direction:column;gap:4px;color:#64748b;font-size:.9rem}.appointment-actions{display:flex;align-items:center;gap:12px}.status-badge{padding:4px 12px;border-radius:9999px;font-size:.85rem;font-weight:500;text-transform:capitalize}.status-badge.pending{background:#fff7ed;color:#c2410c}.status-badge.confirmed{background:#f0fdf4;color:#15803d}.status-badge.cancelled{background:#fef2f2;color:#b91c1c}.status-badge.completed{background:#f0f9ff;color:#0369a1}.btn-accept{background:#16a34a;color:#fff;padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.btn-accept:hover{background:#15803d}.btn-reject{background:#dc2626;color:#fff;padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.no-appointments{text-align:center;color:#94a3b8;padding:40px;background:#f8fafc;border-radius:8px;border:1px dashed #e2e8f0;grid-column:1 / -1}.doctor-prescriptions-card{background:white;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid #e5e7eb;overflow:hidden;margin-bottom:24px}.doctor-prescriptions-card .card-header{background:#f8fafc;padding:20px 30px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.doctor-prescriptions-card .card-header h3{margin:0;color:#0f172a;font-size:1.25rem;font-weight:600}.prescriptions-content{padding:30px}.filter-controls button{padding:6px 14px;margin-left:8px;border:1px solid #e2e8f0;background:white;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.filter-controls button:hover{background:#f1f5f9}.filter-controls button.active{background:#2563eb;color:#fff;border-color:#2563eb}.approval-card-wrapper{background:white;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:16px;overflow:hidden}.approval-actions{padding:12px 20px;border-top:1px solid #f1f5f9;background:#f8fafc;display:flex;justify-content:flex-end;gap:12px}.btn-approve{background:#16a34a;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-approve:hover{background:#15803d}.btn-reject{background:#dc2626;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-reject:hover{background:#b91c1c}.prescriptions-grid{display:flex;flex-direction:column;gap:16px}.empty-state{text-align:center;padding:40px;color:#64748b;background:#f8fafc;border-radius:8px;border:1px dashed #cbd5e1}.doctor-patients{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.doctor-patients h3{margin-top:0;color:#111827;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid #e5e7eb}.patients-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px}.patient-card{border:1px solid #e5e7eb;border-radius:8px;padding:15px;background:#f9fafb;transition:all .2s}.patient-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.patient-info h4{margin:0 0 10px;color:#111827;font-size:1.1rem}.patient-info p{margin:5px 0;color:#4b5563;font-size:.9rem}.loading,.error{text-align:center;padding:20px;color:#6b7280}.error{color:#dc2626}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background:white;padding:20px;border-radius:8px;width:90%;max-width:600px;box-shadow:0 4px 6px #0000001a;max-height:80vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:15px}.modal-header h3{margin:0;border:none}.modal-body{padding:10px 0}.history-list{display:flex;flex-direction:column;gap:10px}.history-item{background-color:#f8f9fa;border-radius:4px;padding:10px}.add-prescription-card{background:white;padding:0;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-bottom:24px;border:1px solid #e5e7eb;overflow:hidden}.card-header{background:#f8fafc;padding:20px 30px;border-bottom:1px solid #e5e7eb}.card-header h3{margin:0;color:#0f172a;font-size:1.25rem;font-weight:600}.prescription-form{padding:30px}.form-row{display:flex;gap:20px;margin-bottom:20px}.half-width{flex:1}.form-group label,.section-label{display:block;margin-bottom:8px;font-size:.875rem;font-weight:500;color:#475569}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid #cbd5e1;border-radius:6px;font-size:.95rem;transition:border-color .2s;background-color:#fff}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.medicines-table-container{background:#f9fafb;border:1px solid #e2e8f0;border-radius:8px;padding:16px;margin-bottom:24px}.medicines-table{width:100%;border-collapse:separate;border-spacing:0 8px}.medicines-table th{text-align:left;font-size:.8rem;text-transform:uppercase;color:#64748b;padding:0 8px 8px;font-weight:600;letter-spacing:.05em}.medicines-table td{padding:0 4px;vertical-align:top}.medicines-table input{width:100%;padding:8px;border:1px solid #cbd5e1;border-radius:4px;font-size:.9rem}.medicines-table input:focus{outline:none;border-color:#3b82f6}.btn-icon-remove{background:transparent;color:#ef4444;border:none;font-size:1.5rem;line-height:1;cursor:pointer;padding:4px;border-radius:4px;transition:background .2s}.btn-icon-remove:hover{background:#fee2e2}.btn-add-row{background:white;border:1px dashed #94a3b8;color:#475569;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;margin-top:8px;transition:all .2s;display:inline-flex;align-items:center;gap:6px}.btn-add-row:hover{border-color:#3b82f6;color:#3b82f6;background:#eff6ff}.notes-area{min-height:100px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;margin-top:10px}.btn-create{background:#2563eb;color:#fff;border:none;padding:12px 32px;border-radius:6px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s;box-shadow:0 1px 2px #0000000d}.btn-create:hover{background:#1d4ed8}.btn-create:disabled{background:#93c5fd;cursor:not-allowed}.error-alert{background:#fef2f2;border-left:4px solid #ef4444;color:#b91c1c;padding:12px 16px;margin:16px 24px 0;border-radius:4px;font-size:.9rem}@media (max-width: 768px){.form-row{flex-direction:column;gap:0}.medicines-table th{display:none}.medicines-table tr{display:flex;flex-direction:column;gap:8px;background:white;padding:12px;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:12px}.medicines-table td{padding:0;width:100%!important}.medicines-table input{border-color:#e2e8f0}.btn-icon-remove{width:100%;background:#fef2f2;padding:8px;font-size:1rem;margin-top:4px}.btn-icon-remove:before{content:"Remove Medicine";margin-right:8px}}.btn-edit{background:#eab308;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.btn-edit:hover{background:#ca8a04}.btn-cancel-edit{background:transparent;border:1px solid #cbd5e1;color:#64748b;padding:6px 14px;border-radius:6px;font-size:.9rem;cursor:pointer;font-weight:500}.btn-cancel-edit:hover{background:#f1f5f9;color:#475569}.btn-delete-medicine{background:#fee2e2;color:#dc2626;border:1px solid #fecaca;padding:6px 10px;border-radius:6px;font-size:.85rem;cursor:pointer;font-weight:500}.btn-delete-medicine:hover{background:#fecaca}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:16px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:2px solid #f0f0f0}.modal-header h2{margin:0;color:#1a1a1a;font-size:24px}.close-btn{background:none;border:none;font-size:32px;color:#999;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.close-btn:hover{background:#f0f0f0;color:#333}.patient-summary{padding:20px 24px;background:#f8f9fa;border-bottom:1px solid #e0e0e0}.patient-summary h3{margin:0 0 12px;color:#1a1a1a;font-size:18px}.patient-summary p{margin:6px 0;color:#666;font-size:14px}.consultation-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:600;font-size:14px}.form-group .required{color:#f44336}.form-group input[type=text],.form-group input[type=date],.form-group textarea{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4caf50}.form-group textarea{resize:vertical;min-height:80px}.checkbox-group{margin:24px 0}.checkbox-group label{display:flex;align-items:center;cursor:pointer;font-weight:400}.checkbox-group input[type=checkbox]{width:20px;height:20px;margin-right:12px;cursor:pointer}.checkbox-group span{font-size:15px;color:#333}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:20px;border-top:2px solid #f0f0f0}.modal-actions .btn{padding:12px 24px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-actions .btn-secondary{background:#f0f0f0;color:#666}.modal-actions .btn-secondary:hover:not(:disabled){background:#e0e0e0}.modal-actions .btn-primary{background:#4CAF50;color:#fff}.modal-actions .btn-primary:hover:not(:disabled){background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.modal-actions .btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.modal-content{max-width:100%;margin:0;border-radius:0;max-height:100vh}.modal-overlay{padding:0}}.doctor-queue{padding:20px;max-width:1200px;margin:0 auto}.queue-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.queue-header h2{margin:0;color:#1a1a1a}.queue-count{background:#4CAF50;color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600}.empty-queue{text-align:center;padding:60px 20px;background:#f8f9fa;border-radius:12px}.empty-icon{font-size:64px;margin-bottom:16px}.empty-queue h3{color:#666;margin-bottom:8px}.empty-queue p{color:#999}.queue-list{display:flex;flex-direction:column;gap:16px}.queue-item{background:white;border:2px solid #e0e0e0;border-radius:12px;padding:20px;display:grid;grid-template-columns:60px 1fr 200px 200px 100px;gap:20px;align-items:center;transition:all .3s ease;position:relative}.queue-item:hover{border-color:#4caf50;box-shadow:0 4px 12px #4caf501a}.queue-item.in-progress{border-color:#ff9800;background:#FFF8E1}.queue-position{font-size:32px;font-weight:700;color:#4caf50;text-align:center}.patient-info h3{margin:0 0 8px;color:#1a1a1a;font-size:18px}.patient-contact,.patient-phone{margin:4px 0;color:#666;font-size:14px}.symptoms{margin-top:8px;padding:8px;background:#f0f7ff;border-left:3px solid #2196F3;border-radius:4px;font-size:14px}.symptoms strong{color:#2196f3}.appointment-details{display:flex;flex-direction:column;gap:8px}.detail-item{display:flex;flex-direction:column;gap:2px}.detail-item .label{font-size:12px;color:#999;text-transform:uppercase;font-weight:600}.detail-item .value{font-size:14px;color:#333;font-weight:500}.queue-actions{display:flex;flex-direction:column;gap:8px}.queue-actions .btn{width:100%;padding:10px 16px;font-size:14px;font-weight:600;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.queue-actions .btn-primary{background:#4CAF50;color:#fff}.queue-actions .btn-primary:hover:not(:disabled){background:#45a049;transform:translateY(-2px);box-shadow:0 4px 8px #4caf504d}.queue-actions .btn-success{background:#2196F3;color:#fff}.queue-actions .btn-success:hover:not(:disabled){background:#1976D2;transform:translateY(-2px);box-shadow:0 4px 8px #2196f34d}.queue-actions .btn-outline{background:white;color:#f44336;border:2px solid #f44336}.queue-actions .btn-outline:hover:not(:disabled){background:#f44336;color:#fff}.queue-actions .btn:disabled{opacity:.6;cursor:not-allowed}.status-badge{position:absolute;top:20px;right:20px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.status-badge.checked-in{background:#E8F5E9;color:#4caf50}.status-badge.in-progress{background:#FFF3E0;color:#ff9800}.loading{text-align:center;padding:40px;color:#666}@media (max-width: 1024px){.queue-item{grid-template-columns:50px 1fr;gap:16px}.queue-position{font-size:24px}.appointment-details,.queue-actions{grid-column:1 / -1}.status-badge{position:static;margin-top:12px;display:inline-block}}.doctor-dashboard{padding:30px;max-width:98%;margin:0 auto}.doctor-dashboard h2{color:#111827;margin-bottom:24px}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:white;padding:20px;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;text-align:center;transition:all .2s ease;cursor:pointer;font-family:inherit;width:100%}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000000d}.stat-card.active{border:2px solid #2563eb;background:#eff6ff}.stat-card h3{margin:0 0 10px;color:#4b5563;font-size:.9rem;font-weight:500}.stat-card p{margin:0;color:#111827;font-size:1.8rem;font-weight:600}.dashboard-container{display:flex;flex-direction:column;gap:40px;width:100%}.centered-layout{max-width:1000px;margin:0 auto}@media (max-width: 1200px){.dashboard-grid{grid-template-columns:1fr}}.dashboard-content{animation:fadeIn .3s ease-in-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.schedule-manager{background:white;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:800px;margin:0 auto}.day-row{display:flex;align-items:center;padding:1rem;border-bottom:1px solid #eee}.day-row:last-child{border-bottom:none}.day-name{width:120px;font-weight:500}.day-controls{display:flex;align-items:center;gap:2rem;flex:1}.time-inputs{display:flex;align-items:center;gap:1rem}.time-inputs input{padding:.5rem;border:1px solid #ddd;border-radius:4px}.switch{position:relative;display:inline-block;width:50px;height:24px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s}.slider:before{position:absolute;content:"";height:16px;width:16px;left:4px;bottom:4px;background-color:#fff;transition:.4s}input:checked+.slider{background-color:#2196f3}input:checked+.slider:before{transform:translate(26px)}.slider.round{border-radius:34px}.slider.round:before{border-radius:50%}.btn-save{margin-top:2rem;padding:1rem 2rem;background:#2196F3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem;width:100%}.btn-save:hover{background:#1976D2}.patient-records{padding:20px;background:#f8f9fa;min-height:calc(100vh - 80px)}.patient-records h2{color:#2c3e50;margin-bottom:24px;font-size:24px;font-weight:600}.records-content{background:white;border-radius:12px;box-shadow:0 2px 4px #0000000d;padding:24px;overflow-x:auto}.patients-table{width:100%;border-collapse:collapse;min-width:800px}.patients-table th{text-align:left;padding:16px;color:#7f8c8d;font-weight:600;font-size:14px;border-bottom:1px solid #edf2f7}.patients-table td{padding:16px;border-bottom:1px solid #edf2f7;color:#2c3e50;vertical-align:middle}.patient-info{font-weight:500}.contact-info{display:flex;flex-direction:column;gap:4px}.contact-info .email{color:#7f8c8d;font-size:13px}.no-data{text-align:center;color:#7f8c8d;padding:40px;font-size:16px}.loading{display:flex;justify-content:center;padding:40px;color:#3498db}.error-message{padding:16px;background:#fee2e2;color:#dc2626;border-radius:8px;margin-bottom:20px}.view-history-btn{padding:6px 12px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s}.view-history-btn:hover{background-color:#0056b3}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content.history-modal{background:white;padding:24px;border-radius:12px;width:90%;max-width:900px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 4px 20px #00000026}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #eee}.modal-header h3{margin:0;color:#333;font-size:1.5rem}.close-btn{background:none;border:none;font-size:28px;cursor:pointer;color:#666;transition:color .2s}.close-btn:hover{color:#333}.patient-summary{display:flex;gap:20px;margin-bottom:20px;background:#f8f9fa;padding:12px;border-radius:8px;font-size:.95rem}.modal-body{overflow-y:auto;flex:1}.loading-history,.no-history{text-align:center;padding:40px;color:#666;font-style:italic}.history-table-container{overflow-x:auto}.history-table{width:100%;border-collapse:collapse}.history-table th,.history-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.history-table th{background-color:#f8f9fa;color:#555;font-weight:600}.doctor-info{display:flex;flex-direction:column}.doctor-info small{color:#777}.status-badge{padding:4px 8px;border-radius:4px;font-size:.85rem;text-transform:capitalize}.status-badge.completed{background-color:#d1e7dd;color:#0f5132}.status-badge.cancelled{background-color:#f8d7da;color:#842029}.status-badge.scheduled{background-color:#cfe2ff;color:#084298}.has-prescription{color:#198754;font-weight:500;font-size:.9rem}.doctor-portal{display:flex;min-height:100vh;background-color:#f5f7fa}.doctor-content{flex:1;padding:2rem;overflow-y:auto}.inventory{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.inventory-table{width:100%;border-collapse:collapse;margin-top:1rem}.inventory-table th,.inventory-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.stock-badge{padding:.25rem .5rem;border-radius:4px;font-weight:500}.stock-badge.good{color:#2e7d32;background:#e8f5e9}.stock-badge.low{color:#c62828;background:#ffebee}.btn-add{padding:.75rem 1.5rem;background:#2196F3;color:#fff;border:none;border-radius:4px;cursor:pointer}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:white;padding:2rem;border-radius:12px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.modal-content h3{margin-top:0;margin-bottom:20px;color:#333}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#555}.form-group input,.form-group select{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-row{display:flex;gap:15px}.form-row .form-group{flex:1}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:25px}.btn-cancel,.btn-submit{padding:10px 20px;border-radius:4px;font-weight:500;cursor:pointer;font-size:14px}.btn-cancel{background:#f5f5f5;color:#333;border:1px solid #ddd}.btn-submit{background:#2196F3;color:#fff;border:none}.btn-cancel:hover{background:#eeeeee}.btn-submit:hover{background:#1976D2}.btn-delete{padding:5px 10px;background:#ffebee;color:#c62828;border:none;border-radius:4px;cursor:pointer}.btn-delete:hover{background:#ffcdd2}.controls{display:flex;gap:10px;align-items:center}.search-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;min-width:200px}.sort-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:white}.btn-edit{padding:5px 10px;background:#e3f2fd;color:#1976d2;border:none;border-radius:4px;cursor:pointer;margin-right:5px}.btn-edit:hover{background:#bbdefb}.order-management{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.orders-table{width:100%;border-collapse:collapse;margin-top:1rem}.orders-table th,.orders-table td{padding:1rem;text-align:left;border-bottom:1px solid #eee}.status-badge{padding:.25rem .5rem;border-radius:4px;font-size:.875rem;font-weight:500;text-transform:capitalize}.status-badge.pending{background:#fff3e0;color:#f57c00}.status-badge.processing{background:#e3f2fd;color:#1976d2}.status-badge.completed,.status-badge.confirmed{background:#e8f5e9;color:#2e7d32}.status-badge.cancelled{background:#ffebee;color:#c62828}.btn-action{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-weight:500;margin-right:.5rem}.btn-view{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:4px;cursor:pointer}.btn-view:hover{background:#eee}.check-btn{background:#e8f5e9;color:#2e7d32}.check-btn:hover{background:#c8e6c9}.cancel-btn{background:#ffebee;color:#c62828}.cancel-btn:hover{background:#ffcdd2}.delivered-btn{background:#e8f5e9;color:#2e7d32}.delivered-btn:hover{background:#c8e6c9}.payment-management{padding:20px}.payment-management h2{color:var(--primary-color);margin-bottom:25px}.payment-table-container{background:white;border-radius:12px;box-shadow:0 2px 12px #00000014;overflow:hidden}.payment-table{width:100%;border-collapse:collapse}.payment-table th,.payment-table td{padding:15px 20px;text-align:left;border-bottom:1px solid #eee}.payment-table th{background-color:#f8f9fa;color:#666;font-weight:600}.payment-table tr:hover{background-color:#f8f9fa}.status-badge{padding:6px 12px;border-radius:20px;font-size:.85em;font-weight:500;text-transform:capitalize}.status-badge.completed,.status-badge.success{background-color:#e3f9e5;color:#1b5e20}.status-badge.pending{background-color:#fff3e0;color:#f57c00}.status-badge.failed{background-color:#ffebee;color:#c62828}.pharmacy-portal{display:flex;min-height:100vh;background-color:#f5f7fa}.pharmacy-content{flex:1;padding:2rem;overflow-y:auto}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;padding:2rem;border-radius:8px;width:90%;max-width:600px;max-height:90vh;overflow-y:auto;position:relative;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;border-bottom:1px solid #eee;padding-bottom:1rem}.modal-header h3{margin:0;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#666}.detail-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #f0f0f0}.detail-section:last-child{border-bottom:none}.detail-section h4{color:#2c3e50;margin-bottom:.8rem;font-size:1.1rem}.detail-section p{margin:.5rem 0;color:#555;line-height:1.4}.qualification-item{background-color:#f8f9fa;padding:.5rem;border-radius:4px;margin-bottom:.5rem}.modal-footer{margin-top:2rem;text-align:right}.btn-close{padding:.5rem 1.5rem;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-close:hover{background-color:#5a6268}.user-management{padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.header-actions{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.filters{display:flex;gap:10px}.filters select{padding:8px;border:1px solid #ddd;border-radius:4px;outline:none}.users-table{width:100%;border-collapse:collapse}.users-table th,.users-table td{padding:12px;text-align:left;border-bottom:1px solid #eee}.users-table th{background-color:#f8f9fa;font-weight:600;color:#333}.role-badge{padding:4px 8px;border-radius:12px;font-size:.85rem;text-transform:capitalize}.role-badge.patient{background-color:#e3f2fd;color:#1976d2}.role-badge.doctor{background-color:#e8f5e9;color:#2e7d32}.role-badge.pharmacist{background-color:#fff3e0;color:#f57c00}.role-badge.admin{background-color:#f3e5f5;color:#7b1fa2}.status-badge{padding:4px 8px;border-radius:12px;font-size:.85rem}.status-badge.active{background-color:#e8f5e9;color:#2e7d32}.status-badge.pending{background-color:#ffebee;color:#c62828}.actions-cell{display:flex;gap:8px;align-items:center}.btn-verify,.btn-delete,.btn-view{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:background-color .2s}.btn-verify{background-color:#4caf50;color:#fff}.btn-verify:hover{background-color:#43a047}.btn-delete{background-color:#f44336;color:#fff}.btn-delete:hover{background-color:#d32f2f}.btn-view{background-color:#2196f3;color:#fff}.btn-view:hover{background-color:#1976d2}.error-message{background-color:#ffebee;color:#c62828;padding:10px;border-radius:4px;margin-bottom:20px}.appointments-monitor{padding:40px;max-width:1400px;margin:0 auto}.monitor-header{margin-bottom:30px;text-align:center}.monitor-header h2{color:#1f2937;margin:0 0 8px;font-size:32px}.subtitle{color:#6b7280;margin:0;font-size:16px}.filters{display:flex;gap:20px;align-items:flex-end;justify-content:center;margin-bottom:30px;padding:25px;background:white;border-radius:12px;box-shadow:0 2px 8px #00000014}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-size:14px;font-weight:600;color:#374151}.filter-group input,.filter-group select{padding:10px 14px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;min-width:200px;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#2563eb}.btn-refresh{padding:10px 20px;background:#2563eb;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;transition:background .2s}.btn-refresh:hover{background:#1d4ed8}.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.stat-card h3{font-size:36px;color:#2563eb;margin:0 0 8px;font-weight:700}.stat-card p{margin:0;color:#6b7280;font-size:14px;font-weight:500}.loading{text-align:center;padding:60px;color:#6b7280;font-size:18px;background:white;border-radius:12px;box-shadow:0 2px 8px #00000014}.appointments-table-container{background:white;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.appointments-table{width:100%;border-collapse:collapse}.appointments-table thead{background:#f9fafb}.appointments-table th{padding:16px 20px;text-align:left;font-size:13px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.appointments-table td{padding:18px 20px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#374151}.appointments-table tbody tr:hover{background:#f9fafb}.time-slot{font-weight:700;color:#2563eb;font-size:15px}.person-info{display:flex;flex-direction:column;gap:4px}.person-info strong{color:#1f2937;font-weight:600}.person-info small{color:#6b7280;font-size:12px}.status-badge{display:inline-block;padding:6px 14px;border-radius:16px;font-size:12px;font-weight:600;text-transform:capitalize}.status-scheduled{background:#dbeafe;color:#1e40af}.status-confirmed{background:#d1fae5;color:#065f46}.status-completed{background:#dcfce7;color:#166534}.status-cancelled{background:#fef2f2;color:#dc2626}.booked-time{color:#6b7280;font-size:13px}.no-data{text-align:center;padding:50px!important;color:#9ca3af;font-size:16px}.analytics{padding:40px;max-width:1400px;margin:0 auto}.analytics h2{color:#1f2937;margin:0 0 30px;font-size:32px;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:40px}.stat-card{background:white;padding:25px;border-radius:12px;box-shadow:0 2px 8px #00000014;text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001f}.stat-card h3{color:#6b7280;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0 0 12px}.stat-value{font-size:36px;font-weight:700;color:#2563eb;margin:0}.stat-change{color:#10b981;font-size:14px;margin-top:8px;font-weight:500}.charts-container{background:white;padding:30px;border-radius:12px;box-shadow:0 2px 8px #00000014}.chart-box h3{color:#1f2937;font-size:20px;margin:0 0 20px;font-weight:600}.recent-appointments-table{width:100%;border-collapse:collapse}.recent-appointments-table thead{background:#f9fafb}.recent-appointments-table th{padding:12px 16px;text-align:left;font-size:12px;font-weight:700;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid #e5e7eb}.recent-appointments-table td{padding:16px;border-bottom:1px solid #e5e7eb;font-size:14px;color:#374151}.recent-appointments-table tbody tr:hover{background:#f9fafb}.error{background:#fef2f2;color:#dc2626;padding:20px;border-radius:8px;text-align:center;margin:20px}.bar-chart{display:flex;align-items:flex-end;justify-content:space-around;height:250px;padding:20px 0;border-bottom:2px solid #e5e7eb;margin-bottom:10px}.bar{width:50px;background:linear-gradient(to top,#2563eb,#60a5fa);border-radius:6px 6px 0 0;transition:all .3s ease;box-shadow:0 2px 4px #2563eb33}.bar:hover{opacity:.8;transform:scaleY(1.05)}.chart-labels{display:flex;justify-content:space-around;margin-top:10px;color:#6b7280;font-size:13px;font-weight:500}.reports{padding:1.5rem}.reports-list{background:white;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.report-item{display:flex;align-items:center;padding:1.5rem;border-bottom:1px solid #eee}.report-item:last-child{border-bottom:none}.report-icon{width:50px;height:50px;background:#f5f5f5;border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#666;margin-right:1.5rem}.report-info{flex:1}.report-info h4{margin:0 0 .25rem}.report-info p{margin:0;color:#888;font-size:.9rem}.btn-download{padding:.5rem 1rem;background:#fff;border:1px solid #2196F3;color:#2196f3;border-radius:4px;cursor:pointer;transition:all .2s}.btn-download:hover{background:#2196F3;color:#fff}.admin-portal{display:flex;min-height:100vh;background-color:#f5f7fa}.admin-content{flex:1;padding:2rem;overflow-y:auto}@media (max-width: 768px){.admin-content{padding:1rem}}.patient-pharmacy{padding:2rem;max-width:1200px;margin:0 auto}.pharmacy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.pharmacy-header h2{color:#2c3e50;margin:0}.my-orders-btn{padding:.75rem 1.5rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.medicine-grid{display:flex;flex-wrap:wrap;gap:20px}.medicine-card{background:white;border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;width:calc(33.333% - 14px);box-shadow:0 2px 4px #0000000d;transition:transform .2s}.medicine-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.medicine-info h3{margin:0 0 .5rem;color:#2c3e50}.medicine-meta{font-size:.9rem;color:#7f8c8d;margin-bottom:1rem}.medicine-details{display:flex;justify-content:space-between;margin-bottom:1rem;font-size:.95rem}.price{font-weight:700;color:#27ae60;font-size:1.1rem}.stock{color:#e67e22}.btn-book{width:100%;padding:.75rem;background-color:#2ecc71;color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:700;text-transform:uppercase;font-size:.9rem}.btn-book:hover{background-color:#27ae60}.btn-book:disabled{background-color:#bdc3c7;cursor:not-allowed}.booking-modal-content{background:white;padding:2rem;border-radius:8px;width:90%;max-width:500px}.booking-summary{background:#f8f9fa;padding:1rem;border-radius:4px;margin-bottom:1.5rem}.summary-item{display:flex;justify-content:space-between;margin-bottom:.5rem}.total-row{border-top:1px solid #ddd;margin-top:.5rem;padding-top:.5rem;font-weight:700}.alert-message{padding:15px;border-radius:4px;margin-bottom:20px}.alert-message.success{background-color:#e8f5e9;color:#2e7d32;border:1px solid #c8e6c9}.alert-message.error{background-color:#ffebee;color:#c62828;border:1px solid #ffcdd2}.no-medicines{text-align:center;padding:3rem;background:#f8f9fa;border-radius:8px;color:#7f8c8d;font-size:1.1rem}@media (max-width: 768px){.medicine-card{width:100%}}:root{--primary-color: #4f46e5;--primary-dark: #4338ca;--primary-light: #818cf8;--secondary-color: #10b981;--secondary-dark: #059669;--danger-color: #ef4444;--warning-color: #f59e0b;--success-color: #10b981;--info-color: #3b82f6;--text-primary: #1f2937;--text-secondary: #6b7280;--text-light: #9ca3af;--bg-primary: #ffffff;--bg-secondary: #f9fafb;--bg-tertiary: #f3f4f6;--border-color: #e5e7eb;--border-radius: 8px;--border-radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition: all .3s ease}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;color:var(--text-primary);background-color:var(--bg-secondary);line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;margin-bottom:.5rem}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}a{color:var(--primary-color);text-decoration:none;transition:var(--transition)}a:hover{color:var(--primary-dark)}button{cursor:pointer;border:none;outline:none;font-family:inherit;transition:var(--transition)}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.btn{padding:.75rem 1.5rem;border-radius:var(--border-radius);font-weight:500;font-size:1rem;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-dark);transform:translateY(-2px);box-shadow:var(--shadow-md)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-secondary:hover{background-color:var(--secondary-dark)}.btn-outline{background-color:transparent;border:2px solid var(--primary-color);color:var(--primary-color)}.btn-outline:hover{background-color:var(--primary-color);color:#fff}.btn-danger{background-color:var(--danger-color);color:#fff}.btn-sm{padding:.5rem 1rem;font-size:.875rem}.btn-lg{padding:1rem 2rem;font-size:1.125rem}.card{background-color:var(--bg-primary);border-radius:var(--border-radius-lg);padding:1.5rem;box-shadow:var(--shadow-md);transition:var(--transition)}.card:hover{box-shadow:var(--shadow-lg)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-control{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--border-radius);font-size:1rem;transition:var(--transition)}.form-control:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #4f46e51a}.alert{padding:1rem;border-radius:var(--border-radius);margin-bottom:1rem}.alert-success{background-color:#d1fae5;color:#065f46;border-left:4px solid var(--success-color)}.alert-error{background-color:#fee2e2;color:#991b1b;border-left:4px solid var(--danger-color)}.alert-warning{background-color:#fef3c7;color:#92400e;border-left:4px solid var(--warning-color)}.alert-info{background-color:#dbeafe;color:#1e40af;border-left:4px solid var(--info-color)}.badge{display:inline-block;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.badge-primary{background-color:#ddd6fe;color:var(--primary-dark)}.badge-success{background-color:#d1fae5;color:#065f46}.badge-danger{background-color:#fee2e2;color:#991b1b}.badge-warning{background-color:#fef3c7;color:#92400e}.loading-spinner{display:inline-block;width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.text-center{text-align:center}.text-right{text-align:right}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.gap-4{gap:2rem}.grid{display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 768px){.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;color:#333;background-color:#f8f9fa}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:20px}.btn{padding:10px 20px;border:none;border-radius:5px;cursor:pointer;font-size:14px;transition:all .3s ease}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8}.btn-secondary{background-color:#6b7280;color:#fff}.btn-secondary:hover{background-color:#4b5563}.form-group{margin-bottom:15px}.form-label{display:block;margin-bottom:5px;font-weight:500}.form-input{width:100%;padding:10px;border:1px solid #d1d5db;border-radius:5px;font-size:14px}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.error-message{color:#dc2626;background-color:#fef2f2;padding:10px;border-radius:5px;margin-bottom:15px;border:1px solid #fecaca}.success-message{color:#059669;background-color:#f0fdf4;padding:10px;border-radius:5px;margin-bottom:15px;border:1px solid #bbf7d0}
