.simple-calendar{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--border);max-width:100%;box-sizing:border-box;padding:max(var(--spacing-lg),env(safe-area-inset-top)) max(var(--spacing-lg),env(safe-area-inset-right)) max(var(--spacing-lg),env(safe-area-inset-bottom)) max(var(--spacing-lg),env(safe-area-inset-left))}.simple-calendar .calendar-mode-header{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-md);margin:0 0 var(--spacing-md) 0;padding:0 0 var(--spacing-md) 0;border-bottom:1px solid var(--border);width:100%;box-sizing:border-box}.simple-calendar .calendar-header-actions{display:flex;align-items:center;gap:var(--spacing-sm);margin-left:auto}.simple-calendar .calendar-help-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--textSecondary);cursor:pointer;transition:all var(--transition-normal);-webkit-tap-highlight-color:transparent;flex-shrink:0}.simple-calendar .calendar-help-button:hover{border-color:var(--primary);background:var(--primary-transparent);color:var(--primary)}.simple-calendar .calendar-help-button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.simple-calendar .view-mode-toggle{display:inline-flex;gap:var(--spacing-xs);background:transparent;border:none;padding:0;margin:0;width:auto}.simple-calendar .view-mode-btn{display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border)!important;border-radius:var(--radius-md);background:var(--surface)!important;color:var(--text)!important;font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;min-height:44px;min-width:44px;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:none!important;transform:none}.simple-calendar .view-mode-btn:hover{border-color:var(--primary)!important;background:var(--primary-transparent)!important;transform:none}.simple-calendar .view-mode-btn.active{border-color:var(--primary)!important;background:var(--primary)!important;color:white!important;box-shadow:none!important}.simple-calendar .view-mode-btn.active:hover{background:var(--primary)!important;transform:none}.simple-calendar .view-mode-btn:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.simple-calendar .view-mode-btn:active{transform:scale(.98)}.simple-calendar .view-mode-icon{flex-shrink:0}.simple-calendar .view-mode-label{font-weight:500}@media (max-width:768px){.simple-calendar .calendar-mode-header{margin:0 0 var(--spacing-md) 0;padding:0 0 var(--spacing-md) 0;gap:var(--spacing-sm)}.simple-calendar .view-mode-toggle{flex:1 1;gap:var(--spacing-xs)}.simple-calendar .view-mode-btn{flex:1 1;justify-content:center;min-height:48px}.simple-calendar .calendar-header-actions{gap:var(--spacing-xs)}.simple-calendar .calendar-header-actions .date-picker-button{min-height:44px;padding:var(--spacing-xs)}.simple-calendar .calendar-help-button{width:44px;height:44px}}@media (max-width:480px){.simple-calendar .calendar-mode-header{margin:0 0 var(--spacing-sm) 0;padding:0 0 var(--spacing-sm) 0;gap:var(--spacing-sm)}.simple-calendar .view-mode-btn{padding:var(--spacing-sm)}.simple-calendar .view-mode-label{font-size:var(--font-size-xs)}.simple-calendar .view-mode-icon{width:18px;height:18px}.simple-calendar .calendar-header-actions{gap:var(--spacing-xs)}.simple-calendar .calendar-header-actions .date-picker-button{font-size:var(--font-size-xs);padding:var(--spacing-xs)}.simple-calendar .calendar-help-button{width:40px;height:40px}}@media (max-width:360px){.simple-calendar .view-mode-btn{padding:var(--spacing-xs) var(--spacing-sm)}.simple-calendar .calendar-help-button{width:36px;height:36px}}.doctor-selector{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.doctor-selector-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border);gap:var(--spacing-sm)}.doctor-selector-title-wrapper{display:flex;align-items:center;gap:var(--spacing-md);flex:1 1}.doctor-selector h3{font-size:var(--font-size-md);font-weight:600;color:var(--text);margin:0}.doctor-clear-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--textSecondary);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal)}.doctor-clear-button:hover{background:var(--primary-transparent);border-color:var(--primary);color:var(--primary)}.help-button{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--border);border-radius:50%;background:var(--surface);color:var(--textSecondary);cursor:pointer;transition:all var(--transition-normal);flex-shrink:0}.help-button:hover{background:var(--primary-transparent);border-color:var(--primary);color:var(--primary);transform:scale(1.1)}.help-button:active{transform:scale(.95)}.doctor-buttons{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));grid-gap:var(--spacing-sm);gap:var(--spacing-sm)}.doctor-btn{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all var(--transition-normal);max-width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-xs);min-height:60px}.doctor-btn-name{font-weight:600;color:var(--text)}.doctor-btn-name,.doctor-btn-service{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;text-align:center}.doctor-btn-service{font-size:var(--font-size-xs);font-weight:500;color:var(--textSecondary)}.doctor-btn:hover{border-color:var(--primary);background:var(--primary-transparent)}.doctor-btn.active{border-color:var(--primary);background:var(--primary);color:white}.doctor-btn.active .doctor-btn-name{color:white}.doctor-btn.active .doctor-btn-service{color:rgba(255,255,255,.9)}.doctor-specialty{font-size:.875rem;opacity:.8;margin-left:.25rem}.doctor-empty,.doctor-loading{padding:var(--spacing-md);text-align:center;color:var(--textSecondary);font-size:var(--font-size-sm)}.doctor-search-wrapper{margin-bottom:var(--spacing-md)}.doctor-search-container{position:relative;display:flex;align-items:center;max-width:100%}.doctor-search-icon{position:absolute;left:var(--spacing-sm);color:var(--textSecondary);pointer-events:none;z-index:1}.doctor-search-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:calc(var(--spacing-md) * 2.5);padding-right:calc(var(--spacing-md) * 2.5);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);transition:all var(--transition-normal);box-sizing:border-box}.doctor-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-transparent)}.doctor-search-input::placeholder{color:var(--textSecondary)}.doctor-search-clear{position:absolute;right:var(--spacing-sm);background:none;border:none;color:var(--textSecondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast);z-index:1;border-radius:var(--radius-sm)}.doctor-search-clear:hover{color:var(--text);background:var(--background)}.doctor-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--border)}.doctor-pagination-info{flex-shrink:0}.doctor-pagination-text{font-size:var(--font-size-xs);color:var(--textSecondary)}.doctor-pagination-controls{display:flex;align-items:center;gap:var(--spacing-md);flex-wrap:wrap}.doctor-pagination-per-page{display:flex;align-items:center;gap:var(--spacing-xs)}.doctor-pagination-label{font-size:var(--font-size-xs);color:var(--textSecondary);white-space:nowrap}.doctor-pagination-select{padding:var(--spacing-xs) var(--spacing-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-normal)}.doctor-pagination-select:focus{outline:none;border-color:var(--primary)}.doctor-pagination-nav{display:flex;align-items:center;gap:var(--spacing-xs)}.doctor-pagination-btn{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition-normal)}.doctor-pagination-btn:hover:not(:disabled){border-color:var(--primary);background:var(--primary-transparent);color:var(--primary)}.doctor-pagination-btn:disabled{opacity:.5;cursor:not-allowed}.doctor-pagination-page{font-size:var(--font-size-xs);color:var(--text);padding:0 var(--spacing-xs);min-width:3rem;text-align:center}@media (min-width:768px){.doctor-selector{padding:var(--spacing-lg)}.doctor-buttons{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--spacing-md)}.doctor-btn{min-height:70px;padding:var(--spacing-md)}.day-navigation{padding:var(--spacing-lg)}.day-navigation-header{flex-wrap:nowrap}.time-slots{padding:var(--spacing-lg)}}@media (min-width:1024px){.doctor-buttons{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.day-buttons{display:flex;flex-direction:row;gap:var(--spacing-md);overflow-x:auto;padding-bottom:var(--spacing-sm);-webkit-overflow-scrolling:touch}.day-btn{min-width:90px;flex:0 0 auto}}.specialty-filter{margin-bottom:var(--spacing-xl)}.specialty-filter h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0 0 var(--spacing-md) 0}.specialty-filter-wrapper{position:relative;max-width:500px}.specialty-input-container{position:relative;display:flex;align-items:center;gap:var(--spacing-xs)}.specialty-search-icon{position:absolute;left:var(--spacing-sm);width:1.25rem;height:1.25rem;color:var(--textSecondary);pointer-events:none;z-index:1}.specialty-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);padding-left:calc(var(--spacing-md) * 2.5);padding-right:calc(var(--spacing-md) * 2.5);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);transition:all var(--transition-normal);box-sizing:border-box}.specialty-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-transparent)}.specialty-clear-btn{position:absolute;right:var(--spacing-sm);background:none;border:none;color:var(--textSecondary);cursor:pointer;padding:var(--spacing-xs);display:flex;align-items:center;justify-content:center;transition:color var(--transition-fast);z-index:1}.specialty-clear-btn:hover{color:var(--text)}.specialty-clear-icon{width:1rem;height:1rem}.specialty-dropdown{position:absolute;top:calc(100% + var(--spacing-xs));left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:300px;overflow-y:auto;z-index:var(--z-modal);margin-top:var(--spacing-xs)}.specialty-dropdown-positioned{position:fixed!important;z-index:var(--z-modal)!important;box-shadow:var(--shadow-xl)!important;margin-top:0!important;margin-left:0!important;margin-right:0!important;overflow-y:auto!important;overflow-x:hidden!important;border-radius:var(--radius-md)!important;background:var(--surface)!important;border:1px solid var(--border)!important}.specialty-option{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:none;background:transparent;color:var(--text);font-size:var(--font-size-sm);text-align:left;cursor:pointer;transition:background-color var(--transition-fast)}.specialty-option:hover{background:var(--primary-transparent);color:var(--primary)}.specialty-option:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.specialty-option:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.specialty-dropdown-overlay{display:none}.day-navigation{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.day-navigation-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border);flex-wrap:wrap;gap:var(--spacing-sm)}.day-navigation-center{display:flex;align-items:center;gap:var(--spacing-md);flex:1 1}.day-navigation-right{flex-shrink:0}.day-navigation h3{font-size:var(--font-size-md);font-weight:600;color:var(--text);margin:0}.date-picker-wrapper{position:relative}.simple-calendar .calendar-header-actions .date-picker-button{min-height:40px;padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm);font-weight:600;gap:var(--spacing-xs)}.date-picker-overlay{display:none}.date-picker-button{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal)}.date-picker-button:hover{border-color:var(--primary);background:var(--primary-transparent)}.date-picker-icon{width:1rem;height:1rem}.date-picker-popup{position:absolute;top:calc(100% + var(--spacing-sm));background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:var(--spacing-md);z-index:var(--z-modal);min-width:280px;max-width:320px;box-sizing:border-box;overflow:hidden}.month-nav{justify-content:space-between;margin-bottom:var(--spacing-md);gap:var(--spacing-sm)}.month-nav,.nav-button{display:flex;align-items:center}.nav-button{justify-content:center;padding:var(--spacing-xs);border:none;background:transparent;color:var(--text);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-normal);flex-shrink:0}.nav-button:hover{background:var(--primary-transparent);color:var(--primary)}.nav-icon{width:1rem;height:1rem}.month-year-button{flex:1 1;padding:var(--spacing-xs) var(--spacing-sm);border:none;background:transparent;color:var(--text);font-size:var(--font-size-md);font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-normal)}.month-year-button:hover{background:var(--primary-transparent);color:var(--primary)}.calendar-grid{display:flex;flex-direction:column}.calendar-grid,.weekdays{gap:var(--spacing-xs);width:100%;box-sizing:border-box}.weekdays{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:var(--spacing-xs);margin-bottom:var(--spacing-xs)}.weekday{text-align:center;font-size:var(--font-size-xs);font-weight:600;color:var(--textSecondary);padding:var(--spacing-xs);box-sizing:border-box;min-width:0}.days-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:var(--spacing-xs);gap:var(--spacing-xs)}.calendar-day,.days-grid{width:100%;box-sizing:border-box}.calendar-day{aspect-ratio:1;min-width:0;padding:var(--spacing-xs);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal);display:flex;align-items:center;justify-content:center}.calendar-day:hover:not(:disabled){border-color:var(--primary);background:var(--primary-transparent);color:var(--primary)}.calendar-day.selected{background:var(--primary);color:white;border-color:var(--primary)}.calendar-day.today{border-color:var(--success);background:var(--success-transparent);font-weight:700}.calendar-day.today.selected{background:var(--primary);border-color:var(--primary)}.calendar-day.other-month{color:var(--textSecondary);opacity:.4}.calendar-day:disabled{cursor:not-allowed;opacity:.3}.year-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:var(--spacing-xs);gap:var(--spacing-xs);max-height:300px;overflow-y:auto;padding:var(--spacing-xs)}.year-button{padding:var(--spacing-sm);border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-normal);text-align:center}.year-button:hover{border-color:var(--primary);background:var(--primary-transparent);color:var(--primary)}.year-button.selected{background:var(--primary);color:white;border-color:var(--primary)}.day-buttons{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;overflow-x:auto;padding-bottom:var(--spacing-sm)}.day-btn{padding:var(--spacing-md);border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition-normal);min-width:80px;flex-shrink:0}.day-btn:hover{border-color:var(--primary);background:var(--primary-transparent)}.day-btn.active{border-color:var(--primary);background:var(--primary);color:white}.day-btn.today{border-color:var(--success)}.day-btn.today:not(.active){background:var(--success-transparent)}.day-info{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.day-weekday{font-size:var(--font-size-xs);font-weight:500;text-transform:uppercase}.day-number{font-size:var(--font-size-lg);font-weight:700}.day-month{font-size:var(--font-size-xs);font-weight:500}.time-slots{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md)}.time-slots h3{font-size:var(--font-size-md);font-weight:600;color:var(--text);margin:0 0 var(--spacing-md) 0;padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border)}.time-slots-empty{padding:var(--spacing-lg);text-align:center;color:var(--textSecondary);font-size:var(--font-size-sm);background:var(--background);border-radius:var(--radius-md)}.time-slots-hint{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--textSecondary)}.time-slots-loading{color:var(--textSecondary);background:var(--background)}.time-slots-error,.time-slots-loading{padding:var(--spacing-lg);text-align:center;font-size:var(--font-size-sm);border-radius:var(--radius-md)}.time-slots-error{color:var(--error);background:var(--error-transparent)}.time-slots-info{margin-bottom:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--primary-transparent);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--primary);font-weight:500}.simple-calendar .slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));grid-gap:var(--spacing-sm);gap:var(--spacing-sm)}.time-slot{padding:var(--spacing-md);border:2px solid var(--border);border-radius:var(--radius-md);background:var(--surface);color:var(--text);cursor:pointer;transition:all var(--transition-normal);display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);min-height:80px;justify-content:center}.time-slot:hover:not(:disabled){border-color:var(--primary);background:var(--primary-transparent);transform:translateY(-2px)}.time-slot.available{border-color:var(--success);background:var(--success-transparent)}.time-slot.available:hover{border-color:var(--success);background:var(--success);color:white}.time-slot.booked{border-color:var(--secondary);background:var(--secondary-transparent);cursor:not-allowed;opacity:.7}.time-slot:disabled{cursor:not-allowed;opacity:.5}.slot-icon{width:1rem;height:1rem}.slot-time{font-size:var(--font-size-sm);font-weight:600}.slot-available-icon{color:var(--success);opacity:.8}.slot-patient,.slot-status{font-size:var(--font-size-xs);text-align:center;opacity:.8}.slots-by-date,.slots-by-doctor{display:flex;flex-direction:column;gap:var(--spacing-lg)}.date-slots-section{border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-md);background:var(--surface)}.date-slots-header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border)}.date-slots-info{flex:1 1;min-width:0}.date-slots-day{margin:0;font-size:var(--font-size-md);font-weight:600;color:var(--text);text-transform:capitalize}.date-slots-meta{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.date-slots-count{font-size:var(--font-size-sm);color:var(--textSecondary);background:var(--primary-transparent);padding:2px var(--spacing-sm);border-radius:var(--radius-full);white-space:nowrap}.doctor-slots-section{border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--spacing-md);background:var(--surface)}.doctor-slots-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border)}.doctor-slots-info{flex:1 1;flex-direction:column}.doctor-slots-info,.doctor-slots-name{min-width:0;display:flex;gap:var(--spacing-xs)}.doctor-slots-name{align-items:center}.doctor-icon{flex-shrink:0;color:var(--primary)}.doctor-slots-name h4{margin:0;font-size:var(--font-size-md);font-weight:600;color:var(--text);flex:1 1;min-width:0}.doctor-slots-name h4,.doctor-slots-service{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.doctor-slots-service{font-size:var(--font-size-sm);color:var(--textSecondary);font-weight:500;padding-left:calc(18px + var(--spacing-xs))}.doctor-slots-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs);flex-shrink:0}.doctor-slots-count{color:var(--textSecondary);background:var(--primary-transparent);padding:2px var(--spacing-sm);border-radius:var(--radius-full)}.doctor-slots-count,.doctor-slots-day{font-size:var(--font-size-sm);white-space:nowrap}.doctor-slots-day{display:flex;align-items:center;gap:.25rem;color:var(--text);font-weight:500;background:var(--surface);padding:.25rem .5rem;border-radius:var(--radius-sm);border:1px solid var(--border)}.doctor-slots-day svg{color:var(--primary);flex-shrink:0}.help-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;height:100%;min-height:100vh;min-height:100dvh;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;z-index:10000;padding:var(--spacing-md);padding-top:max(var(--spacing-md),env(safe-area-inset-top));padding-bottom:max(var(--spacing-md),env(safe-area-inset-bottom));overflow:hidden;overscroll-behavior:none;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.help-modal,.help-modal-overlay{width:100%;isolation:isolate;will-change:transform;transform:translateZ(0);-webkit-transform:translateZ(0);-webkit-overflow-scrolling:touch}.help-modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:500px;max-height:90vh;max-height:calc(100dvh - 2rem);overflow-y:auto;position:relative;z-index:10001;overscroll-behavior:contain}.help-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-lg);border-bottom:1px solid var(--border)}.help-modal-header h3{font-size:var(--font-size-lg);font-weight:600;color:var(--text);margin:0}.help-modal-close{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:none;background:transparent;color:var(--textSecondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-normal)}.help-modal-close:hover{background:var(--background);color:var(--text)}.help-modal-content{padding:var(--spacing-lg)}.help-instructions-list{margin:0;padding-left:var(--spacing-lg);color:var(--text);font-size:var(--font-size-sm);line-height:1.8}.help-instructions-list li{margin-bottom:var(--spacing-sm)}.help-instructions-list li:last-child{margin-bottom:0}@media (max-width:768px){.help-modal-overlay{padding:var(--spacing-sm);align-items:flex-start}.help-modal{width:100%;max-width:100%;margin-top:1rem;max-height:calc(100dvh - 2rem)}.help-modal-content,.help-modal-header{padding:var(--spacing-md)}}.error-message{background:var(--error-transparent);border:1px solid var(--error);border-radius:var(--radius-md);padding:var(--spacing-sm);color:var(--error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-lg)}@media (max-width:768px){.simple-calendar{padding:var(--spacing-md);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);padding-top:max(var(--spacing-md),env(safe-area-inset-top));padding-bottom:max(var(--spacing-md),env(safe-area-inset-bottom))}.day-btn,.doctor-btn,.doctor-clear-button,.doctor-pagination-btn,.help-button,.nav-button,.period-btn,.time-slot{min-height:44px;min-width:44px}.specialty-filter-wrapper{max-width:100%;position:relative}.specialty-input{font-size:16px;min-height:44px}.specialty-dropdown-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);z-index:calc(var(--z-modal) - 1);display:block;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.specialty-dropdown-positioned{border-radius:var(--radius-md);-webkit-overflow-scrolling:touch;transform:translateZ(0);will-change:transform;overscroll-behavior:contain}.doctor-search-container{max-width:100%}.doctor-search-input{font-size:16px;min-height:44px}.doctor-pagination{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.doctor-pagination-info{text-align:center}.doctor-pagination-controls{justify-content:space-between}.doctor-buttons{display:flex;flex-direction:column;gap:var(--spacing-sm)}.doctor-btn{width:100%;text-align:center;justify-content:center}.doctor-selector{padding:var(--spacing-sm)}.doctor-specialty{display:block;margin-left:0;margin-top:.25rem;font-size:.75rem}.day-navigation-header{flex-direction:column;align-items:stretch}.date-picker-wrapper{width:100%}.date-picker-button{width:100%;justify-content:center;min-height:44px}.date-picker-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);right:auto;width:90vw;max-width:320px;z-index:var(--z-modal);-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.date-picker-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:calc(var(--z-modal) - 1);display:block;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px)}.day-buttons{flex-direction:column;gap:var(--spacing-sm);-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain}.day-btn{width:100%;min-height:60px}.simple-calendar .slots-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-sm)}.time-slot{min-height:70px}.doctor-slots-section,.time-slot{padding:var(--spacing-sm)}.doctor-slots-header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.doctor-slots-info{width:100%}.doctor-slots-name h4{font-size:var(--font-size-sm)}.doctor-slots-service{font-size:var(--font-size-xs)}.doctor-slots-meta{flex-direction:row;align-items:center;justify-content:space-between;width:100%}.doctor-slots-count,.doctor-slots-day{font-size:var(--font-size-xs)}.date-slots-section{padding:var(--spacing-sm)}.date-slots-header{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.date-slots-day{font-size:var(--font-size-sm)}.date-slots-meta{justify-content:flex-end}.date-slots-count{font-size:var(--font-size-xs)}}@media (max-width:480px){.simple-calendar{padding:var(--spacing-sm);border-radius:var(--radius-sm);padding-top:max(var(--spacing-sm),env(safe-area-inset-top));padding-bottom:max(var(--spacing-sm),env(safe-area-inset-bottom))}.simple-calendar .slots-grid{grid-template-columns:repeat(2,1fr);gap:var(--spacing-xs)}.time-slot{min-height:64px;padding:var(--spacing-xs)}.slot-time,.time-slot{font-size:var(--font-size-xs)}.day-navigation,.doctor-selector,.time-slots{margin-bottom:var(--spacing-sm);padding:var(--spacing-sm)}.day-navigation h3,.doctor-selector h3,.time-slots h3{font-size:var(--font-size-sm)}.day-navigation-center,.day-navigation-header{flex-direction:column;align-items:flex-start}.day-navigation-center{gap:var(--spacing-sm);width:100%}.day-navigation-right{width:100%}.date-picker-popup{width:95vw;max-width:300px;padding:var(--spacing-sm)}.calendar-day{font-size:var(--font-size-xs);padding:var(--spacing-xs)}.weekday{font-size:10px}.doctor-pagination-btn{width:36px;height:36px}.time-slots-info{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.doctor-slots-section{padding:var(--spacing-xs)}.doctor-slots-header{padding-bottom:var(--spacing-xs);margin-bottom:var(--spacing-xs);gap:var(--spacing-xs)}.doctor-slots-name h4{font-size:var(--font-size-xs)}.doctor-slots-service{font-size:11px;padding-left:calc(16px + var(--spacing-xs))}.doctor-icon{width:16px;height:16px}.doctor-slots-count{font-size:var(--font-size-xs);padding:2px var(--spacing-xs)}.doctor-slots-day{padding:.125rem .25rem}.doctor-slots-day svg{width:14px;height:14px}.date-slots-section{padding:var(--spacing-xs)}.date-slots-header{padding-bottom:var(--spacing-xs);margin-bottom:var(--spacing-xs);gap:var(--spacing-xs)}.date-slots-count,.date-slots-day{font-size:var(--font-size-xs)}.date-slots-count{padding:2px var(--spacing-xs)}}@media (max-width:360px){.simple-calendar{padding:var(--spacing-xs)}.simple-calendar .view-mode-label{display:none!important}.simple-calendar .view-mode-icon{margin:0}.day-btn{min-width:70px}.day-number{font-size:var(--font-size-md)}.day-month,.day-weekday{font-size:10px}}@media (prefers-reduced-motion:reduce){.day-btn,.doctor-btn,.period-btn,.simple-calendar .view-mode-btn,.time-slot{transition:opacity var(--transition-fast)}.simple-calendar .view-mode-btn:active,.time-slot:hover{transform:none}}@media (prefers-contrast:high){.day-btn,.doctor-btn,.period-btn,.simple-calendar .view-mode-btn,.time-slot{border-width:2px}.day-btn.active,.doctor-btn.active,.period-btn.active,.simple-calendar .view-mode-btn.active{border-width:3px}}.heart-loading-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;z-index:9999!important;display:flex!important;align-items:center!important;justify-content:center!important;background:transparent!important;-webkit-backdrop-filter:none!important;backdrop-filter:none!important;background-color:rgba(255,255,255,.637)!important}.heart-loader{position:relative;animation:heart-beat 1.5s ease-in-out infinite}@keyframes heart-beat{0%{transform:scale(1)}14%{transform:scale(1.1)}28%{transform:scale(1)}42%{transform:scale(1.1)}70%{transform:scale(1)}to{transform:scale(1)}}.heart-main{animation:heart-pulse 2s ease-in-out infinite}.heart-inner{animation:heart-glow 1.8s ease-in-out infinite alternate}@keyframes heart-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes heart-glow{0%{opacity:.7;transform:scale(1)}to{opacity:1;transform:scale(1.1)}}.heart-loader:before{content:"";position:absolute;top:50%;left:50%;width:120%;height:120%;background:radial-gradient(circle,rgba(239,68,68,.2) 0,transparent 70%);border-radius:50%;transform:translate(-50%,-50%);animation:heart-aura 2.5s ease-in-out infinite;pointer-events:none}@keyframes heart-aura{0%,to{opacity:.3;transform:translate(-50%,-50%) scale(1)}50%{opacity:.6;transform:translate(-50%,-50%) scale(1.2)}}@media (prefers-color-scheme:dark){.heart-loader:before{background:radial-gradient(circle,rgba(239,68,68,.25) 0,transparent 70%)}}@media (prefers-reduced-motion:reduce){.heart-inner,.heart-loader,.heart-main{animation:none}.heart-loader:before{animation:none;opacity:.2}}.heart-loader:hover,.heart-loader:hover .heart-main{animation-duration:1s}.heart-loader.h-8{--heart-scale:0.8}.heart-loader.h-12{--heart-scale:1}.heart-loader.h-16{--heart-scale:1.2}.heart-loader svg{transform:scale(var(--heart-scale,1))}.menu-search-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-md);animation:menuSearchOverlayFadeIn .2s ease-out}@keyframes menuSearchOverlayFadeIn{0%{opacity:0}to{opacity:1}}.menu-search-container{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden;animation:menuSearchSlideIn .2s ease-out}@keyframes menuSearchSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.menu-search-header{padding:var(--spacing-lg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:var(--spacing-md);flex-shrink:0}.menu-search-input-wrapper{flex:1 1;position:relative;display:flex;align-items:center;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-md);padding:0 var(--spacing-md);transition:all var(--transition-normal)}.menu-search-input-wrapper:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-transparent)}.menu-search-icon{width:1.25rem;height:1.25rem;color:var(--textSecondary);flex-shrink:0;margin-right:var(--spacing-sm)}.menu-search-input{flex:1 1;border:none;background:transparent;font-size:var(--font-size-lg);color:var(--text);padding:var(--spacing-md) 0;outline:none}.menu-search-input::placeholder{color:var(--textSecondary)}.menu-search-clear{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border:none;background:transparent;color:var(--textSecondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);margin-left:var(--spacing-sm)}.menu-search-clear:hover{background:var(--border);color:var(--text)}.menu-search-clear-icon{width:1rem;height:1rem}.menu-search-close{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;border:none;background:transparent;color:var(--textSecondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0}.menu-search-close:hover{background:var(--border);color:var(--text)}.menu-search-close-icon{width:1.25rem;height:1.25rem}.menu-search-results{flex:1 1;overflow-y:auto;min-height:0;padding:var(--spacing-md)}.menu-search-list{display:flex;flex-direction:column;gap:var(--spacing-xs)}.menu-search-item{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);border:1px solid transparent;border-radius:var(--radius-md);background:var(--background);cursor:pointer;transition:all var(--transition-normal);text-align:left;width:100%}.menu-search-item:hover{background:var(--primary-transparent);border-color:var(--primary);transform:translateX(4px)}.menu-search-item:focus{outline:none;box-shadow:0 0 0 3px var(--primary-transparent);border-color:var(--primary)}.menu-search-item-icon{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;border-radius:var(--radius-md);background:var(--primary-transparent);flex-shrink:0}.menu-search-item-icon-svg{width:1.25rem;height:1.25rem;color:var(--primary)}.menu-search-item-content{flex:1 1;display:flex;flex-direction:column;gap:var(--spacing-xs);min-width:0}.menu-search-item-title{font-size:var(--font-size-md);font-weight:600;color:var(--text);line-height:1.2}.menu-search-item-description{font-size:var(--font-size-sm);color:var(--textSecondary);line-height:1.4}.menu-search-empty{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center}.menu-search-empty p{color:var(--textSecondary);font-size:var(--font-size-md);margin:0}.menu-search-footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--border);flex-shrink:0}.menu-search-hint{font-size:var(--font-size-xs);color:var(--textSecondary);text-align:center;display:block}.menu-search-hint kbd{display:inline-block;padding:.125rem .375rem;background:var(--background);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-family:monospace;box-shadow:0 1px 2px rgba(0,0,0,.1)}.dark .menu-search-container{background:var(--surface)}.dark .menu-search-input-wrapper{background:var(--background);border-color:var(--border)}.dark .menu-search-item{background:var(--background)}@media (max-width:768px){.menu-search-overlay{padding:var(--spacing-sm)}.menu-search-container{max-width:100%;max-height:90vh;border-radius:var(--radius-lg)}.menu-search-header{padding:var(--spacing-md)}.menu-search-input{font-size:var(--font-size-md)}.menu-search-item,.menu-search-results{padding:var(--spacing-sm)}.menu-search-item-icon{width:2rem;height:2rem}.menu-search-item-icon-svg{width:1rem;height:1rem}}