:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh;width:100%}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#f5f7fa}}.patient-form-container{width:100%;max-width:100%;margin:0;padding:40px;font-family:Outfit,Segoe UI,sans-serif;min-height:100vh}.progress-steps{display:flex;justify-content:center;align-items:center;gap:40px;margin-bottom:50px;position:relative;padding:20px}.step{display:flex;flex-direction:column;align-items:center;gap:12px;position:relative;z-index:1}.step-number{width:50px;height:50px;border-radius:50%;background:#fff;color:#cbd5e1;border:2px solid #e2e8f0;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;transition:all .4s cubic-bezier(.175,.885,.32,1.275);box-shadow:0 4px 10px #0000000d}.step.active .step-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:transparent;transform:scale(1.1);box-shadow:0 10px 25px #667eea66}.step-label{color:#94a3b8;font-size:14px;font-weight:600;transition:all .3s ease;letter-spacing:.5px}.step.active .step-label{color:#475569;font-weight:700}.step-line{position:absolute;top:45px;left:50%;transform:translate(-50%);width:250px;height:3px;background:#e2e8f0;z-index:0;border-radius:10px}.progress-steps.steps-3 .step-line{width:150px}.step-content{background:#fff;border-radius:24px;padding:50px;box-shadow:0 20px 60px -10px #0000001a;animation:slideUp .5s ease-out;border:1px solid rgba(255,255,255,.5)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.step-content h2{color:#1e293b;margin-bottom:30px;text-align:center;font-size:28px;font-weight:800;letter-spacing:-.5px}.step-content h3{color:#667eea;margin-bottom:24px;padding-bottom:15px;border-bottom:2px solid #f1f5f9;font-size:20px;font-weight:700}.gender-options{display:flex;gap:30px;justify-content:center;margin-top:40px}.gender-btn{display:flex;flex-direction:column;align-items:center;gap:20px;padding:40px 60px;border:2px solid #f1f5f9;border-radius:24px;background:#fff;cursor:pointer!important;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:20px;font-weight:600;color:#64748b;min-width:200px}.gender-btn:hover{border-color:#667eea;transform:translateY(-8px);box-shadow:0 20px 40px #667eea26}.gender-btn.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 20px 40px #667eea4d}.gender-icon{font-size:60px;filter:grayscale(100%);transition:all .3s}.gender-btn:hover .gender-icon,.gender-btn.selected .gender-icon{filter:grayscale(0%);transform:scale(1.1)}.form-intro{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:30px;border-radius:20px;margin-bottom:40px;text-align:center;border:1px solid #e2e8f0}.form-intro p{margin:8px 0;color:#475569;font-size:16px;line-height:1.6}.form-section{margin-bottom:40px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:25px}@media(max-width:768px){.form-row{grid-template-columns:1fr}}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;color:#334155;font-weight:600;font-size:14px}.required{color:#ef4444}.form-group input,.form-group select,.form-group textarea{width:100%;padding:16px;border:2px solid #e2e8f0;border-radius:14px;font-size:16px;transition:all .3s ease;font-family:inherit;background:#fcfcfc;color:#1e293b;direction:rtl;text-align:right}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.form-group textarea{resize:vertical;min-height:100px}.error-message{background:#fef2f2;color:#ef4444;padding:16px;border-radius:12px;margin-bottom:30px;text-align:center;font-weight:600;border:1px solid #fee2e2;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}.form-actions{display:flex;gap:20px;justify-content:center;margin-top:50px;padding-top:30px;border-top:1px solid #f1f5f9}.btn{padding:16px 36px;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 10px 25px #667eea4d}.btn-primary:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 15px 35px #667eea80}.btn-secondary{background:#f8fafc;color:#64748b;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f1f5f9;color:#334155;transform:translateY(-2px)}.success-content{text-align:center;padding:80px 40px}.success-icon{font-size:100px;margin-bottom:30px;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.success-content h2{color:#10b981;margin-bottom:20px;font-size:32px}.success-content p{color:#64748b;margin-bottom:40px;font-size:20px}.success-actions{display:flex;flex-direction:column;gap:16px;align-items:center;max-width:320px;margin:0 auto}.btn-whatsapp{background:#25d366!important;color:#fff!important;border:none!important;padding:20px 32px!important;border-radius:20px!important;font-weight:700!important;font-size:22px!important;cursor:pointer!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;box-shadow:0 10px 25px #25d3664d!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:12px!important;width:100%!important;font-family:inherit!important}.btn-whatsapp:hover{background:#128c7e!important;transform:translateY(-4px) scale(1.02)!important;box-shadow:0 15px 35px #25d36666!important}.btn-reset{background:transparent!important;color:#94a3b8!important;border:none!important;font-weight:700!important;font-size:16px!important;cursor:pointer!important;transition:all .2s ease!important;padding:12px!important;font-family:inherit!important}.btn-reset:hover{color:#475569!important;text-decoration:underline!important}.calendar-step{text-align:center}.calendar-selection{margin-top:30px}.calendar-selection h3{margin-top:20px;margin-bottom:15px;color:#334155;font-size:18px;border:none;padding:0}.dates-grid,.slots-grid{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-bottom:30px}.date-btn,.slot-btn{padding:14px 24px;background:#fff;border:2px solid #e2e8f0;border-radius:12px;color:#475569;font-size:16px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s ease-in-out}.date-btn:hover,.slot-btn:hover{border-color:#94a3b8;background:#f8fafc;transform:translateY(-2px);box-shadow:0 4px 10px #0000000d}.date-btn.selected,.slot-btn.selected{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 8px 16px #667eea40;transform:translateY(-2px)}.slots-section{background:#f8fafc;padding:20px;border-radius:16px;margin-top:30px;border:1px solid #f1f5f9;animation:fadeIn .4s ease-out}.loading-spinner{color:#667eea;font-weight:600;margin:20px 0}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media(max-width:768px){.patient-form-container{padding:15px 10px}.step-content{padding:30px 15px}.step-content h2{font-size:22px;margin-bottom:20px}.gender-options{flex-direction:column;gap:15px}.gender-btn{padding:20px 30px;width:100%;gap:10px}.gender-icon{font-size:40px}.progress-steps{gap:10px;flex-wrap:wrap;padding:10px;margin-bottom:30px}.step-line{display:none}.management-layout{padding:10px!important;gap:20px!important}.patient-btn-primary,.patient-btn-secondary{width:100%;padding:14px 20px!important;font-size:16px!important}.form-actions{flex-direction:column-reverse;gap:12px}.btn-whatsapp{font-size:18px!important;padding:16px 20px!important;border-radius:16px!important}}.management-layout{display:flex!important;flex-direction:column!important;gap:0px!important;background:transparent!important;border-radius:0!important;padding:0!important;box-shadow:none!important;border:none!important}@media(min-width:1024px){.management-layout{flex-direction:row!important;gap:40px!important;background:#fff!important;border-radius:24px!important;padding:40px!important;box-shadow:0 10px 40px #0000000d!important;border:1px solid #f1f5f9!important}}.management-calendar-side{width:100%!important}@media(min-width:1024px){.management-calendar-side{width:50%!important}}.management-title{font-size:22px!important;font-weight:700!important;color:#1e293b!important;margin-bottom:30px!important;text-align:center!important;background:#f8fafc!important;padding:16px!important;border-radius:16px!important;border:1px solid #f1f5f9!important}.management-slots-side{width:100%!important;display:flex!important;flex-direction:column!important;margin-top:30px!important}@media(min-width:1024px){.management-slots-side{width:50%!important;margin-top:0!important}}.slots-side-title{font-size:22px!important;font-weight:700!important;color:#1e293b!important;margin-bottom:30px!important;border-bottom:2px solid #f1f5f9!important;padding-bottom:16px!important}.empty-slots-msg{background:#f8fafc!important;border:2px dashed #e2e8f0!important;border-radius:16px!important;padding:30px!important;text-align:center!important;display:flex!important;flex-direction:column!important;align-items:center!important;gap:24px!important;margin-top:16px!important}.empty-slots-msg p{color:#94a3b8!important;font-weight:700!important;font-size:20px!important;font-style:italic!important;margin:0!important}.manage-slots-grid{display:grid!important;grid-template-columns:1fr!important;gap:16px!important}@media(min-width:640px){.manage-slots-grid{grid-template-columns:repeat(2,1fr)!important}}.manage-slot-card{display:flex!important;align-items:center!important;justify-content:space-between!important;padding:16px 20px!important;border-radius:16px!important;border:2px solid #f1f5f9!important;background:#fff!important;transition:all .3s cubic-bezier(.4,0,.2,1)!important;cursor:pointer!important}.manage-slot-card:hover{box-shadow:0 10px 20px #0000000f!important;transform:translateY(-3px)!important;border-color:#e2e8f0!important}.manage-slot-card.available{background:#f0fdf4!important;border-color:#dcfce7!important}.manage-slot-card.available:hover{border-color:#86efac!important;background:#f0fdf4!important}.manage-slot-card.booked{background:#fff1f2!important;border-color:#ffe4e6!important;cursor:not-allowed!important}.manage-slot-card.selected{background:#eff6ff!important;border-color:#0077c0!important;box-shadow:0 10px 25px #0077c026!important}.slot-time{font-weight:700!important;font-family:inherit!important;font-size:20px!important;letter-spacing:.5px!important;color:#1e293b!important}.slot-actions{display:flex!important;align-items:center!important;gap:12px!important}.slot-status{font-size:13px!important;font-weight:700!important;padding:6px 14px!important;border-radius:50px!important}.slot-status.available{background:#dcfce7!important;color:#15803d!important}.slot-status.booked{background:#ffe4e6!important;color:#be123c!important}.slot-status.selected{background:#0077c0!important;color:#fff!important}.patient-btn-primary{background:#0077c0!important;color:#fff!important;padding:14px 40px!important;border-radius:16px!important;font-weight:700!important;font-size:18px!important;border:2px solid #0077c0!important;cursor:pointer!important;transition:all .3s ease!important;box-shadow:0 10px 20px #0077c026!important;font-family:inherit!important}.patient-btn-primary:hover{background:#005a96!important;border-color:#005a96!important;transform:translateY(-2px)!important;box-shadow:0 12px 25px #0077c040!important}.patient-btn-primary:disabled{opacity:.5!important;cursor:not-allowed!important;transform:none!important}.patient-btn-secondary{background:#fff!important;color:#64748b!important;padding:14px 30px!important;border-radius:16px!important;font-weight:700!important;font-size:18px!important;border:2px solid #e2e8f0!important;cursor:pointer!important;transition:all .3s ease!important;font-family:inherit!important}.patient-btn-secondary:hover{background:#f8fafc!important;border-color:#cbd5e1!important;color:#1e293b!important;transform:translateY(-2px)!important}.continuous-calendar-wrapper{background:#fff;border-radius:24px;padding:30px;box-shadow:0 10px 40px #0000000d;border:1px solid #f1f5f9;font-family:inherit;width:100%;max-width:560px;margin:0 auto}.calendar-header{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;margin-bottom:12px}.month-year-display{font-size:1rem;font-weight:700;color:#1e293b}.nav-btn{background:#0077c0;color:#fff;border:none;border-radius:6px;width:28px;height:28px;display:flex;justify-content:center;align-items:center;cursor:pointer!important;transition:all .2s;font-size:.8rem}.nav-btn:hover:not(:disabled){background:#005a96}.nav-btn:disabled{background:#e2e8f0;color:#94a3b8;cursor:not-allowed}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-weekday-header{text-align:center;font-size:.75rem;font-weight:600;color:#64748b;padding-bottom:4px}.calendar-day{aspect-ratio:1;display:flex;justify-content:center;align-items:center;border-radius:6px;border:2px solid transparent;background:transparent;cursor:pointer!important;font-size:.85rem;font-weight:500;color:#334155;transition:all .2s;position:relative}.calendar-day:hover:not(.disabled):not(.selected):not(.empty){background:#f1f5f9}.calendar-day.empty{cursor:default}.calendar-day.disabled{color:#cbd5e1;cursor:not-allowed}.calendar-day.selected{background:#fff;color:#0077c0;border-color:#0077c0;font-weight:700}.calendar-day.today:not(.selected){background:#f8fafc;border-color:#cbd5e1}.calendar-day.available{font-weight:600;color:#1e293b}.availability-dot{position:absolute;bottom:4px;width:4px;height:4px;border-radius:50%;background:#10b981}.calendar-footer{display:flex;justify-content:center;border-top:1px solid #f1f5f9;padding-top:15px;margin-top:15px}.today-btn{background:transparent;border:none;color:#667eea;font-weight:700;font-size:15px;cursor:pointer!important;padding:8px 20px;border-radius:8px;transition:all .2s}.today-btn:hover{background:#f8fafc;color:#4f46e5}.calendar-day.admin-has-available{background-color:#22c55e4d!important}.calendar-day.admin-all-booked{background-color:#ef44444d!important}.calendar-day.selected.admin-has-available,.calendar-day.selected.admin-all-booked{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important}.continuous-calendar-wrapper.size-large{padding:24px}.continuous-calendar-wrapper.size-large .calendar-day{font-size:1.125rem}.continuous-calendar-wrapper.size-large .calendar-weekday-header{font-size:1rem;margin-bottom:8px}.continuous-calendar-wrapper.size-large .nav-btn{width:44px;height:44px}.continuous-calendar-wrapper.size-large .month-year-display{font-size:1.5rem}@media(max-width:600px){.continuous-calendar-wrapper{padding:12px 10px;border-radius:16px}.calendar-grid{gap:2px}.calendar-day{font-size:.8rem;border-radius:4px}.calendar-weekday-header{font-size:.65rem}.month-year-display{font-size:1rem}.nav-btn{width:30px;height:30px;font-size:.9rem}}.dashboard-container{min-height:100vh;width:100%;background:#f0f2f5;background-image:radial-gradient(at 0% 0%,hsla(253,16%,7%,1) 0,transparent 50%),radial-gradient(at 50% 0%,hsla(225,39%,30%,1) 0,transparent 50%),radial-gradient(at 100% 0%,hsla(339,49%,30%,1) 0,transparent 50%),radial-gradient(at 0% 100%,hsla(339,49%,30%,1) 0,transparent 50%),radial-gradient(at 100% 100%,hsla(253,16%,7%,1) 0,transparent 50%);background-size:cover;background-attachment:fixed;font-family:Outfit,Segoe UI,sans-serif;color:#333;padding-bottom:40px}.dashboard-container.login-page{display:flex;align-items:center;justify-content:center;padding:0;overflow:hidden}.login-card{max-width:450px;width:90%;margin:0;background:#ffffffd9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:60px 40px;border-radius:24px;box-shadow:0 20px 60px #00000026,0 0 0 1px #fff6;text-align:center;border:1px solid rgba(255,255,255,.5);animation:fadeInUp .6s ease-out;position:relative;z-index:10}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-card h1{color:#1a1a1a;margin-bottom:12px;font-size:32px;font-weight:700;letter-spacing:-.5px}.login-card p{color:#666;margin-bottom:40px;font-size:16px}.login-card .form-group{margin-bottom:24px;text-align:right}.login-card label{display:block;margin-bottom:8px;color:#444;font-weight:600;font-size:14px}.login-card input{width:100%;padding:16px;border:2px solid #eee;background:#f9f9f9;border-radius:12px;font-size:16px;transition:all .3s ease}.login-card input:focus{outline:none;border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.dashboard-header{background:#fffffff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000000d;padding:20px 40px;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:100;margin-bottom:30px}.dashboard-header h1{margin:0;font-size:24px;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.header-actions{display:flex;gap:12px;align-items:center}.user-name{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:600;margin-left:8px}.dashboard-tabs{display:flex;justify-content:center;gap:15px;margin:0 40px 30px;background:#fff;padding:10px;border-radius:20px;box-shadow:0 10px 30px #0000000a;animation:fadeIn .8s ease-out}.tab-btn{padding:12px 24px;border:none;background:transparent;border-radius:12px;font-size:16px;font-weight:600;color:#64748b;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.tab-btn:hover{color:#1e293b;background:#f8fafc}.tab-btn.active{background:linear-gradient(135deg,#eef2ff,#f5f3ff);color:#4f46e5;box-shadow:inset 0 0 0 2px #c7d2fe}.search-bar{background:#fff;margin:0 40px 30px;padding:25px;border-radius:20px;box-shadow:0 10px 30px #0000000a;border:1px solid rgba(0,0,0,.03);animation:fadeIn .8s ease-out}.search-bar form{display:flex;gap:15px;flex-wrap:wrap}.search-bar input,.search-bar select{padding:14px 20px;border:1px solid #e0e0e0;border-radius:12px;font-size:15px;transition:all .3s ease;background:#fcfcfc}.search-bar input{flex:1;min-width:250px}.search-bar input:focus,.search-bar select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:#fff}.table-container{padding:0 40px;overflow-x:auto;animation:fadeIn 1s ease-out}.bookings-table{width:100%;background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 15px 40px #0000000d;border-collapse:separate;border-spacing:0}.bookings-table th{background:#f8fafc;color:#64748b;font-weight:700;padding:20px 24px;text-align:right;font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid #edf2f7}.bookings-table td{padding:20px 24px;border-bottom:1px solid #f1f5f9;color:#334155;font-size:15px;transition:background .2s}.bookings-table tr:last-child td{border-bottom:none}.bookings-table tr:hover td{background:#f8fafc}.status-badge{padding:6px 14px;border-radius:50px;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:6px}.status-badge:before{content:"";display:block;width:6px;height:6px;border-radius:50%}.status-pending{background:#fff7ed;color:#c2410c;border:1px solid #ffedd5}.status-pending:before{background:#ea580c}.status-confirmed{background:#f0fdf4;color:#15803d;border:1px solid #dcfce7}.status-confirmed:before{background:#16a34a}.status-completed{background:#eff6ff;color:#1d4ed8;border:1px solid #dbeafe}.status-completed:before{background:#2563eb}.status-cancelled{background:#fef2f2;color:#b91c1c;border:1px solid #fee2e2}.status-cancelled:before{background:#dc2626}.action-btn{padding:8px 16px;border:none;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;margin-left:8px;transition:all .2s ease}.action-btn.view{background:#667eea1a;color:#667eea}.action-btn.view:hover{background:#667eea;color:#fff;transform:translateY(-2px)}.action-btn.note{background:#f59e0b1a;color:#f59e0b}.action-btn.note:hover{background:#f59e0b;color:#fff;transform:translateY(-2px)}.action-btn.delete{background:#ef44441a;color:#ef4444}.action-btn.delete:hover{background:#ef4444;color:#fff;transform:translateY(-2px)}.bookings-table tr.has-notes-row td{background-color:#fde0474d!important}.notification-bell{position:relative;background:transparent;border:none;font-size:24px;cursor:pointer;padding:8px;border-radius:50%;transition:all .3s ease}.notification-bell:hover{background:#0000000d;transform:scale(1.05)}.notification-bell .badge{position:absolute;top:0;right:0;background:#ef4444;color:#fff;font-size:11px;font-weight:700;padding:2px 6px;border-radius:10px;transform:translate(25%,-25%);box-shadow:0 2px 4px #ef44444d;animation:popIn .3s cubic-bezier(.175,.885,.32,1.275)}@keyframes popIn{0%{transform:translate(25%,-25%) scale(0)}to{transform:translate(25%,-25%) scale(1)}}.notifications-dropdown{position:absolute;top:calc(100% + 15px);right:0;width:350px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0000001a;border:1px solid rgba(0,0,0,.05);z-index:1000;opacity:0;visibility:hidden;transform:translateY(-10px);transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.notifications-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}.dropdown-header{padding:16px 20px;border-bottom:1px solid #f1f5f9;display:flex;justify-content:space-between;align-items:center}.dropdown-header h3{margin:0;font-size:16px;color:#1e293b}.dropdown-count{font-size:13px;color:#64748b;background:#f1f5f9;padding:4px 10px;border-radius:20px}.dropdown-body{max-height:400px;overflow-y:auto}.no-notifications{padding:30px;text-align:center;color:#94a3b8;font-size:14px}.notification-item{padding:16px 20px;display:flex;gap:15px;border-bottom:1px solid #f8fafc;transition:background .2s;cursor:default}.notification-item:hover{background:#f8fafc}.notification-item.unread{background:#f0f9ff}.notification-item.unread:hover{background:#e0f2fe}.notif-icon{font-size:20px;background:#eef2ff;width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.notif-content{flex:1}.notif-content h4{margin:0 0 4px;font-size:14px;color:#1e293b}.notif-content p{margin:0 0 8px;font-size:13px;color:#64748b;line-height:1.4}.notif-time{font-size:11px;color:#94a3b8}.notes-modal{max-width:500px;width:90%}.note-card{transition:transform .2s ease,box-shadow .2s ease}.note-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px #0000000d!important}.pagination{display:flex;justify-content:center;align-items:center;gap:15px;padding:30px}.pagination button{padding:10px 24px;background:#fff;border:1px solid #e2e8f0;border-radius:12px;color:#64748b;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 2px 5px #00000005}.pagination button:hover:not(:disabled){border-color:#667eea;color:#667eea;transform:translateY(-2px)}.pagination button:disabled{opacity:.5;cursor:not-allowed;background:#f8fafc}.calendar-management-container{padding:0 40px;animation:fadeIn .8s ease-out}.calendar-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:25px;border-radius:20px;box-shadow:0 10px 30px #0000000a;margin-bottom:25px}.calendar-header h2{color:#1e293b;font-size:22px;font-weight:700;margin:0}.date-picker-group{display:flex;align-items:center;gap:15px}.date-picker-group label{font-weight:600;color:#475569}.date-picker-group input{padding:12px 16px;border:1px solid #e2e8f0;border-radius:12px;font-size:15px;outline:none;font-family:inherit}.date-picker-group input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.add-slot-form{display:flex;align-items:flex-end;gap:20px;background:#fff;padding:25px;border-radius:20px;box-shadow:0 10px 30px #0000000a;margin-bottom:30px;flex-wrap:wrap}.add-slot-form .form-group{margin-bottom:0;flex:1;min-width:200px}.slots-list{background:#fff;padding:25px;border-radius:20px;box-shadow:0 10px 30px #0000000a}.slots-list h3{color:#334155;font-size:18px;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid #f1f5f9}.status-booked td{background:#fdf2f8!important;opacity:.8}.dashboard-table{width:100%;border-collapse:separate;border-spacing:0}.dashboard-table th{background:#f8fafc;color:#64748b;padding:16px 20px;text-align:right;font-size:14px;border-bottom:1px solid #e2e8f0}.dashboard-table td{padding:16px 20px;border-bottom:1px solid #f1f5f9;color:#334155}.status-available{color:#16a34a;background:#f0fdf4}.management-layout{display:flex;flex-direction:column;gap:40px;background:#fff;border-radius:24px;padding:30px;box-shadow:0 10px 40px #0000000d;border:1px solid #f1f5f9}.table-responsive{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}@media(min-width:1024px){.management-layout{flex-direction:row;padding:40px}}.management-calendar-side{width:100%}@media(min-width:1024px){.management-calendar-side{width:50%}}.management-title{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:30px;text-align:center;background:#f8fafc;padding:16px;border-radius:16px;border:1px solid #f1f5f9}.management-slots-side{width:100%;display:flex;flex-direction:column}@media(min-width:1024px){.management-slots-side{width:50%}}.slots-side-title{font-size:22px;font-weight:700;color:#1e293b;margin-bottom:30px;border-bottom:2px solid #f1f5f9;padding-bottom:16px}.empty-slots-msg{background:#f8fafc;border:2px dashed #e2e8f0;border-radius:16px;padding:40px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:24px;margin-top:16px}.empty-slots-msg p{color:#94a3b8;font-weight:700;font-size:20px;font-style:italic;margin:0}.divider-line{width:100%;display:flex;align-items:center;gap:16px}.divider-line:before,.divider-line:after{content:"";height:1px;background:#e2e8f0;flex:1}.divider-text{color:#94a3b8;font-weight:600;font-size:14px}.btn-mark-day-off{width:100%;background:#fff1f2;color:#e11d48;border:2px solid #ffe4e6;padding:16px 24px;border-radius:12px;font-size:18px;font-weight:700;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:12px;font-family:inherit}.btn-mark-day-off:hover{background:#ffe4e6;border-color:#fecdd3;transform:translateY(-2px);box-shadow:0 4px 12px #e11d481a}.day-off-icon{font-size:24px}.day-off-banner{background:#fff1f2;border:2px solid #fecdd3;border-radius:16px;padding:32px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;margin-top:16px}.banner-icon{font-size:40px}.day-off-banner h3{color:#be123c;font-weight:700;font-size:22px;margin:0}.day-off-banner p{color:#e11d48;font-size:15px;margin:0}.btn-cancel-day-off{margin-top:16px;background:#fff;color:#e11d48;border:2px solid #fecdd3;padding:12px 24px;border-radius:12px;font-weight:700;font-size:16px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:10px;font-family:inherit}.btn-cancel-day-off svg{width:20px;height:20px}.btn-cancel-day-off:hover{background:#e11d48;color:#fff;border-color:#e11d48;transform:translateY(-2px);box-shadow:0 4px 12px #e11d4833}.manage-slots-grid{display:grid;grid-template-columns:1fr;gap:16px}@media(min-width:640px){.manage-slots-grid{grid-template-columns:repeat(2,1fr)}}.manage-slot-card{display:flex;align-items:center;justify-content:space-between;padding:20px;border-radius:12px;border:2px solid transparent;transition:all .3s ease}.manage-slot-card:hover{box-shadow:0 4px 12px #0000000d;transform:translateY(-2px)}.manage-slot-card.available{background:#f0fdf4;border-color:#dcfce7}.manage-slot-card.booked{background:#fff1f2;border-color:#ffe4e6}.slot-time{font-weight:700;font-family:inherit;font-size:20px;letter-spacing:1px;color:#1e293b}.slot-actions{display:flex;align-items:center;gap:12px}.slot-status{font-size:13px;font-weight:700;padding:6px 12px;border-radius:50px}.slot-status.available{background:#dcfce7;color:#15803d}.slot-status.booked{background:#ffe4e6;color:#be123c}.btn-delete-icon{background:#fff;color:#ef4444;border:1px solid #fecaca;border-radius:8px;width:36px;height:36px;display:flex;justify-content:center;align-items:center;cursor:pointer;transition:all .2s ease;padding:0}.btn-delete-icon svg{width:20px;height:20px}.btn-delete-icon:hover{background:#ef4444;color:#fff;border-color:transparent;transform:scale(1.05)}.modal-overlay{position:fixed;inset:0;background:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .3s ease-out}.modal-content{background:#fff;border-radius:24px;max-width:700px;width:100%;max-height:85vh;display:flex;flex-direction:column;position:relative;box-shadow:0 25px 50px -12px #00000040;animation:scaleUp .4s cubic-bezier(.16,1,.3,1);overflow:hidden}.modal-content>*{padding:0 40px}.modal-content h2{padding-top:40px;flex-shrink:0}.modal-body{overflow-y:auto;overflow-x:hidden;padding:0 40px 40px;flex:1}.modal-body::-webkit-scrollbar{width:5px}.modal-body::-webkit-scrollbar-track{background:#f1f5f9;border-radius:10px}.modal-body::-webkit-scrollbar-thumb{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px}.modal-body::-webkit-scrollbar-thumb:hover{background:linear-gradient(135deg,#5568d3,#653a8b)}.modal-body{scrollbar-width:thin;scrollbar-color:#667eea #f1f5f9}@keyframes scaleUp{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal-close{position:absolute;top:20px;left:20px;width:36px;height:36px;min-width:36px;min-height:36px;border:none;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;font-size:18px;font-weight:300;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s;box-shadow:0 4px 12px #667eea4d;padding:0}.modal-close:hover{background:linear-gradient(135deg,#ef4444,#dc2626);transform:rotate(90deg) scale(1.1);box-shadow:0 4px 12px #ef444466}.modal-content h2{color:#1e293b;margin-bottom:30px;padding-bottom:20px;border-bottom:2px solid #f1f5f9;font-size:24px;font-weight:700}.detail-section{background:#f8fafc;border-radius:16px;padding:24px;margin-bottom:24px;border:1px solid #f1f5f9}.detail-section h3{color:#667eea;font-size:15px;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;font-weight:700}.detail-section p{margin:10px 0;color:#475569;display:flex;justify-content:space-between;border-bottom:1px dashed #e2e8f0;padding-bottom:8px}.detail-section p:last-child{border-bottom:none}.detail-section strong{color:#1e293b;font-weight:600}.btn{padding:14px 28px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 15px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 25px #667eea80}.btn-secondary{background:#fff;color:#64748b;border:1px solid #e2e8f0}.btn-secondary:hover{background:#f8fafc;color:#334155;border-color:#cbd5e1}@media(max-width:768px){.dashboard-header{flex-direction:column;gap:20px;padding:20px}.dashboard-tabs{margin:0 20px 20px;flex-wrap:wrap}.tab-btn{width:calc(50% - 10px);justify-content:center;padding:10px 15px;font-size:14px}.search-bar,.calendar-management-container{margin:0 20px 20px;padding:20px}.calendar-management-container{padding:0}.calendar-header{flex-direction:column;align-items:flex-start;gap:15px}.table-container{padding:0 20px}.login-card{margin:40px 20px;padding:40px 25px}.modal-content{max-height:90vh;margin:0}.modal-close{top:15px;left:15px}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#f5f7fa;min-height:100vh}.app{position:relative;width:100%}[dir=rtl]{text-align:right}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}
