.calendar-modal-backdrop{align-items:center;background-color:rgba(0,0,0,.6);bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.calendar-modal{background:#fff;border-radius:8px;box-shadow:0 10px 25px rgba(0,0,0,.3);max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}.calendar-modal-header{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;padding:1.5rem}.calendar-modal-header h2{color:#333;font-size:1.25rem;margin:0;text-transform:capitalize}.calendar-modal-close{background:none;border:none;border-radius:4px;color:#666;cursor:pointer;font-size:1.5rem;line-height:1;padding:.25rem;transition:color .2s,background-color .2s}.calendar-modal-close:hover{background-color:#f5f5f5;color:#333}.calendar-modal-body{padding:1.5rem}.calendar-appointments-list{margin-bottom:2rem}.calendar-appointments-list h3{color:#333;font-size:1rem;margin:0 0 1rem}.calendar-appointments-list ul{list-style:none;margin:0;padding:0}.calendar-appointment-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:4px;margin-bottom:.5rem;padding:.75rem}.calendar-appointment-item strong{color:#495057;display:block;margin-bottom:.25rem}.calendar-appointment-item p{color:#6c757d;font-size:.9rem;margin:0}.calendar-new-appointment h3{color:#333;font-size:1rem;margin:0 0 1rem}.calendar-modal-form{gap:1rem}.calendar-form-group,.calendar-modal-form{display:flex;flex-direction:column}.calendar-form-group label{color:#333;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.calendar-form-input,.calendar-form-textarea{border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .2s,box-shadow .2s}.calendar-form-input:focus,.calendar-form-textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.25);outline:none}.calendar-form-textarea{font-family:inherit;min-height:80px;resize:vertical}.calendar-form-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.calendar-btn{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .2s,transform .1s}.calendar-btn:hover{transform:translateY(-1px)}.calendar-btn:active{transform:translateY(0)}.calendar-btn-cancel{background-color:#6c757d;color:#fff}.calendar-btn-cancel:hover{background-color:#5a6268}.calendar-btn-primary{background-color:#007bff;color:#fff}.calendar-btn-primary:hover{background-color:#0056b3}.calendar-form-select{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.75rem;transition:border-color .3s ease;width:100%}.calendar-form-select:focus{border-color:#007bff;box-shadow:0 0 0 2px rgba(0,123,255,.25);outline:none}.calendar-no-times-available{background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:1rem;text-align:center}.calendar-no-times-available p{color:#6c757d;font-weight:500;margin:0 0 .5rem}.calendar-no-times-available small{color:#868e96;font-size:.875rem}.appointment-time{color:#007bff;font-weight:500}.calendar-btn:disabled{cursor:not-allowed;opacity:.6}.calendar-btn:disabled,.calendar-btn:disabled:hover{background-color:#6c757d}@media (max-width:576px){.calendar-modal-backdrop{padding:.5rem}.calendar-modal{max-height:95vh}.calendar-modal-body,.calendar-modal-header{padding:1rem}.calendar-form-actions{flex-direction:column}.calendar-btn{width:100%}}.calendar-container{background:#fff;border-radius:12px;box-shadow:0 4px 6px rgba(0,0,0,.1);box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;max-width:100%;padding:1.5rem;width:100%}.calendar-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:0 .5rem}.calendar-title{color:#333;font-size:1.5rem;font-weight:600;margin:0;text-transform:capitalize}.calendar-nav-button{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;color:#495057;cursor:pointer;display:flex;font-size:1.2rem;height:40px;justify-content:center;transition:all .2s ease;width:40px}.calendar-nav-button:hover{background:#e9ecef;border-color:#adb5bd;transform:translateY(-1px)}.calendar-nav-button:active{transform:translateY(0)}.calendar-weekdays{background:#e9ecef;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);margin-bottom:1rem;overflow:hidden}.calendar-weekday{background:#f8f9fa;color:#6c757d;font-size:.9rem;font-weight:600;padding:.75rem .5rem;text-align:center}.calendar-grid{background:#e9ecef;border-radius:8px;display:grid;gap:1px;grid-template-columns:repeat(7,1fr);overflow:hidden}.calendar-day{align-items:center;background:#fff;border:none;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;min-height:60px;padding:0;position:relative;transition:all .2s ease}.calendar-day:hover:not(.calendar-day-disabled){background:#f8f9fa;transform:scale(1.02)}.calendar-day:active:not(.calendar-day-disabled){transform:scale(.98)}.calendar-day-number{color:#495057;font-size:.9rem;font-weight:500;margin-top:.5rem}.calendar-day-other-month{background:#f8f9fa}.calendar-day-other-month .calendar-day-number{color:#adb5bd}.calendar-day-today{background:#fff3cd;border:2px solid #ffc107;font-weight:600}.calendar-day-today .calendar-day-number{color:#856404}.calendar-day-today:hover:not(.calendar-day-disabled){background:#ffeaa7}.calendar-day-today-circle{font-weight:600;position:relative}.calendar-day-today-circle .calendar-day-number{color:#007bff;font-weight:700;position:relative;z-index:2}.calendar-day-today-circle .calendar-day-number:before{background:transparent;border:2px solid #007bff;border-radius:50%;content:"";height:32px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:32px;z-index:1}.calendar-day-today-circle:hover:not(.calendar-day-disabled){background:#f8f9fa}.calendar-day-today-circle:hover:not(.calendar-day-disabled) .calendar-day-number:before{background:rgba(0,123,255,.1)}.calendar-day-sunday .calendar-day-number,.calendar-day-sunday.calendar-day-disabled .calendar-day-number{color:#dc3545!important;font-weight:600}.calendar-outside-working-hours{position:relative}.calendar-outside-working-hours:after{content:"🕒";font-size:12px;left:2px;opacity:.7;position:absolute;top:2px}.calendar-outside-working-hours:hover:after{opacity:1}.calendar-working-hours-info{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;font-size:12px;margin-bottom:10px;padding:8px 12px;text-align:center}.calendar-working-hours-info.closed{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.calendar-day-past{background:#e9ecef;cursor:not-allowed}.calendar-day-past .calendar-day-number{color:#6c757d;text-decoration:line-through}.calendar-day-disabled{background:#e9ecef;cursor:not-allowed;opacity:.6}.calendar-day-disabled .calendar-day-number{color:#6c757d}.calendar-day-has-appointments{background:#e3f2fd;border-left:4px solid #2196f3}.calendar-day-has-appointments:hover:not(.calendar-day-disabled){background:#bbdefb}.calendar-day-holiday{background:#ffebee;border-left:4px solid #f44336}.calendar-day-holiday:hover:not(.calendar-day-disabled){background:#ffcdd2}.calendar-day-disabled-date{background:#f3e5f5;border-left:4px solid #9c27b0}.calendar-day-disabled-date:hover:not(.calendar-day-disabled){background:#e1bee7}.calendar-appointments-indicator{align-items:center;background:#2196f3;border-radius:50%;bottom:.25rem;color:#fff;display:flex;font-size:.75rem;font-weight:600;height:18px;justify-content:center;position:absolute;right:.25rem;width:18px}.calendar-appointments-count{line-height:1}@media (max-width:768px){.calendar-container{padding:1rem}.calendar-title{font-size:1.25rem}.calendar-nav-button{font-size:1rem;height:36px;width:36px}.calendar-day{min-height:50px}.calendar-weekday{font-size:.8rem;padding:.5rem .25rem}.calendar-day-number{font-size:.8rem}.calendar-appointments-indicator{font-size:.7rem;height:16px;width:16px}}@media (max-width:480px){.calendar-container{padding:.75rem}.calendar-title{font-size:1.1rem}.calendar-nav-button{font-size:.9rem;height:32px;width:32px}.calendar-day{min-height:40px}.calendar-weekday{font-size:.75rem;padding:.4rem .2rem}.calendar-day-number{font-size:.75rem}.calendar-appointments-indicator{bottom:.15rem;font-size:.65rem;height:14px;right:.15rem;width:14px}}.calendar-themed{--today-circle-color:#3b82f6;--border-color:#d1d5db;--day-hover-bg:#f3f4f6}.calendar-themed .calendar-working-hours-info{border-bottom:none;border-radius:0;font-size:13px;font-weight:500;margin:0;padding:10px 1.5rem}.calendar-themed.calendar-container{border:1px solid var(--border-color);border-radius:0;box-shadow:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;padding:0}.calendar-themed.calendar-container .calendar-header{align-items:center;background:#7c3aed;border-radius:0;box-shadow:none;color:#fff;display:flex;justify-content:space-between;margin:0;padding:1rem 1.5rem}.calendar-themed.calendar-container .calendar-title{color:#fff;font-size:1.1rem;font-weight:600;letter-spacing:.5px;margin:0;text-shadow:none;text-transform:uppercase}.calendar-themed .calendar-nav-button{align-items:center;background:transparent;border:none;border-radius:4px;color:#fff;cursor:pointer;display:flex;font-size:1.5rem;font-weight:300;height:40px;justify-content:center;padding:.5rem;transition:background-color .2s ease;width:40px}.calendar-themed .calendar-nav-button:hover{background:hsla(0,0%,100%,.1);box-shadow:none;transform:none}.calendar-themed .calendar-nav-button:disabled{background:transparent;cursor:not-allowed;opacity:.5}.calendar-themed.calendar-container .calendar-weekdays{background:#5b21b6;border-radius:0;display:grid;gap:0;grid-template-columns:repeat(7,1fr);margin:0}.calendar-themed.calendar-container .calendar-weekday{background:#5b21b6;border:none;border-right:1px solid hsla(0,0%,100%,.1);color:#fff;font-size:.75rem;font-weight:600;letter-spacing:.5px;padding:.75rem .5rem;text-align:center;text-transform:uppercase}.calendar-themed .calendar-weekday:last-child{border-right:none}.calendar-themed .calendar-grid{background:transparent;border:none;border-radius:0;display:grid;gap:0;grid-template-columns:repeat(7,1fr)}.calendar-themed .calendar-day{align-items:center;background:#fff;border:1px solid var(--border-color);border-left:none;border-top:none;cursor:pointer;display:flex;flex-direction:column;justify-content:flex-start;min-height:60px;padding:1rem .5rem;position:relative;text-align:center;transition:background-color .2s ease}.calendar-themed .calendar-day:nth-child(7n){border-right:none}.calendar-themed .calendar-day:hover:not(.calendar-day-disabled){background:#f8f9fa;transform:scale(1.02)}.calendar-themed .calendar-day:active:not(.calendar-day-disabled){transform:scale(.98)}.calendar-themed .calendar-day-number{color:#374151;font-size:.9rem;font-weight:500;line-height:1}.calendar-themed .calendar-day-today{background:#fef3c7;border:1px solid #f59e0b;color:#92400e;font-weight:600}.calendar-themed .calendar-day-today .calendar-day-number{background:transparent;color:#92400e;font-weight:600}.calendar-themed .calendar-day-today-circle{background:transparent}.calendar-themed .calendar-day-today-circle .calendar-day-number{background:transparent;color:var(--today-circle-color);font-weight:600;position:relative}.calendar-themed .calendar-day-today-circle .calendar-day-number:before{border:2px solid var(--today-circle-color);border-radius:50%;content:"";height:32px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:32px;z-index:1}.calendar-themed .calendar-day-other-month{background:#f8f9fa}.calendar-themed .calendar-day-other-month .calendar-day-number{color:#adb5bd}.calendar-themed .calendar-day-disabled{background:#e9ecef;cursor:not-allowed;opacity:.6}.calendar-themed .calendar-day-disabled .calendar-day-number{color:#6c757d}.calendar-themed .calendar-day-has-appointments{background:#e3f2fd;border-left:4px solid #2196f3}.calendar-themed .calendar-day-has-appointments:hover:not(.calendar-day-disabled){background:#bbdefb}.calendar-themed .calendar-day-holiday{background:#ffebee;border-left:4px solid #f44336}.calendar-themed .calendar-day-holiday:hover:not(.calendar-day-disabled){background:#ffcdd2}.calendar-themed .calendar-day-disabled-date{background:#f3e5f5;border-left:4px solid #9c27b0}.calendar-themed .calendar-day-disabled-date:hover:not(.calendar-day-disabled){background:#e1bee7}.calendar-themed .calendar-day-sunday .calendar-day-number,.calendar-themed .calendar-day-sunday.calendar-day-disabled .calendar-day-number{color:#dc3545!important;font-weight:600}.calendar-themed .calendar-appointments-indicator{align-items:center;background:#2196f3;border-radius:50%;bottom:.25rem;color:#fff;display:flex;font-size:.75rem;font-weight:600;height:18px;justify-content:center;position:absolute;right:.25rem;width:18px}.calendar-themed .calendar-appointments-count{line-height:1}@media (max-width:768px){.calendar-themed .calendar-header{padding:.75rem 1rem}.calendar-themed .calendar-title{font-size:1rem}.calendar-themed .calendar-nav-button{font-size:1.3rem;height:35px;width:35px}.calendar-themed .calendar-day{min-height:50px;padding:.75rem .25rem}.calendar-themed .calendar-weekday{font-size:.7rem;padding:.5rem .25rem}.calendar-themed .calendar-appointments-indicator{font-size:.7rem;height:16px;width:16px}}@media (max-width:480px){.calendar-themed .calendar-header{padding:.5rem .75rem}.calendar-themed .calendar-title{font-size:.9rem}.calendar-themed .calendar-nav-button{font-size:.9rem;height:32px;width:32px}.calendar-themed .calendar-day{min-height:40px}.calendar-themed .calendar-weekday{font-size:.75rem;padding:.4rem .2rem}.calendar-themed .calendar-appointments-indicator{bottom:.15rem;font-size:.65rem;height:14px;right:.15rem;width:14px}}.calendar-themed .calendar-day-past{background:#e9ecef;cursor:not-allowed}.calendar-themed .calendar-day-past .calendar-day-number{color:#6c757d;text-decoration:line-through}.calendar-themed .calendar-outside-working-hours{position:relative}.calendar-themed .calendar-outside-working-hours:after{content:"🕒";font-size:12px;left:2px;opacity:.7;position:absolute;top:2px}.calendar-themed .calendar-outside-working-hours:hover:after{opacity:1}.calendar-themed .calendar-working-hours-info{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;font-size:12px;margin-bottom:10px;padding:8px 12px;text-align:center}.calendar-themed .calendar-working-hours-info.closed{background:#f8d7da;border-color:#f5c6cb;color:#721c24}