body{background-color:#fafafa;color:#1a202c}:root{--reforged-red:#dc2626;--reforged-black:#000;--reforged-white:#fff;--reforged-gray-light:#f8f9fa;--reforged-gray-medium:#6b7280;--reforged-gray-dark:#1a202c}.login-container{background:linear-gradient(135deg,#f8f9fa,#e9ecef);flex-direction:column;gap:32px;min-height:100vh;padding:20px}.login-container,.login-logo{align-items:center;display:flex;justify-content:center}.login-logo{margin-bottom:16px}.logo-image{max-width:400px;object-fit:contain;width:100%}.login-card{animation:slideUp .3s ease-out;background:#fff;border:1px solid #e2e8f0;border-radius:16px;box-shadow:0 10px 30px #0000001a;max-width:380px;padding:32px;width:100%}.login-header{margin-bottom:24px;text-align:center}.login-header p{color:#333;font-size:16px;font-weight:500;margin:0}.login-form{gap:18px}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:8px}.form-group label{color:#000}.form-group input{background:#fff;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;padding:12px 16px;transition:border-color .2s ease}.form-group input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.form-group input:disabled{background-color:#f8f9fa;cursor:not-allowed}.error-message{background-color:#fee;gap:8px;justify-content:center}.error-dismiss-button{align-items:center;background:none;border:none;border-radius:4px;color:#c53030;cursor:pointer;display:flex;font-size:18px;font-weight:700;height:24px;justify-content:center;line-height:1;padding:4px;position:absolute;right:8px;top:50%;transform:translateY(-50%);width:24px}.error-dismiss-button:hover{background-color:#c530301a}.login-button{margin-top:8px;padding:16px 24px}.login-button:hover:not(:disabled){box-shadow:0 4px 12px #dc26264d;transform:translateY(-2px)}.login-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.login-footer{margin-top:24px;text-align:center}.login-links{display:flex;gap:16px;justify-content:space-between;margin-bottom:12px}.link-button{background:none;border:none;color:#4299e1;cursor:pointer;font-size:14px;font-weight:500;padding:0;text-decoration:underline;transition:color .2s ease}.link-button:hover:not(:disabled){color:#3182ce}.link-button:disabled{color:#a0aec0;cursor:not-allowed;opacity:.6}.coming-soon{color:#718096;font-size:12px;font-style:italic;margin:0}.success-message{background-color:#f0fff4;color:#38a169}.loading-message{padding:20px;text-align:center}.loading-spinner{border:3px solid #f3f3f3;height:30px;margin:0 auto 16px;width:30px}.confirmation-content{padding:20px 0}.reset-email{color:#666;font-size:14px;font-style:italic;margin:4px 0 0}.login-header h2{color:#000;font-size:24px;font-weight:600;margin:0 0 8px}@media (max-width:768px){.login-container{gap:24px;padding:16px}.login-card{padding:20px}.login-links{align-items:center;flex-direction:column;gap:12px}.logo-image{max-width:300px}}@media (max-width:480px){.login-container{gap:16px}.logo-image{max-width:250px}}.modal-overlay{background-color:#00000080;padding:20px}.modal-content{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;max-height:90vh;max-width:500px;overflow-y:auto;width:100%}.modal-content.large-modal{max-width:800px}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{border-bottom:2px solid #dc2626;padding:24px 24px 16px}.modal-header h2{color:#1a202c;font-size:20px;font-weight:600;margin:0}.modal-close{background:none;border:none;border-radius:4px;color:#718096;cursor:pointer;font-size:24px;padding:4px;transition:background-color .2s ease}.modal-close:hover{background-color:#f7fafc;color:#4a5568}.modal-tabs{border-bottom:1px solid #e2e8f0;display:flex;padding:0 24px}.tab-button{border-bottom:2px solid #0000;color:#718096;padding:12px 16px;transition:all .2s ease}.tab-button:hover{color:#4a5568}.modal-form{padding:24px}.form-group{margin-bottom:20px}.form-group label{margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{border:2px solid #e2e8f0;border-radius:6px;font-family:inherit;padding:10px 12px;transition:border-color .2s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:#f7fafc;cursor:not-allowed;opacity:.6}.selected-date-display{color:#dc2626;margin-top:8px}.date-navigation{margin:0 auto 16px}.checkbox-group{margin-bottom:20px}.checkbox-label{align-items:center;display:flex;font-weight:400}.checkbox-label input[type=checkbox]{margin-right:8px;transform:scale(1.1);width:auto}.checkbox-text{font-size:14px}.modal-actions{border-top:1px solid #e2e8f0;gap:12px;margin-top:24px;padding-top:20px}.btn-primary{background:linear-gradient(135deg,#dc2626,#000);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:transform .2s ease,box-shadow .2s ease}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.btn-primary:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;color:#4a5568;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.btn-secondary:hover:not(:disabled){background:#edf2f7}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.btn-cancel{font-size:12px;padding:6px 12px}.btn-cancel:hover:not(:disabled){background:#c53030}.btn-cancel:disabled{opacity:.6}.btn-danger{transition:transform .2s ease,box-shadow .2s ease}.btn-danger:hover:not(:disabled){background:#c53030;box-shadow:0 4px 12px #e53e3e4d;transform:translateY(-1px)}.btn-danger:disabled{box-shadow:none;opacity:.6;transform:none}.btn-warning{background:#ed8936;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:transform .2s ease,box-shadow .2s ease}.btn-warning:hover:not(:disabled){background:#dd6b20;box-shadow:0 4px 12px #ed89364d;transform:translateY(-1px)}.btn-warning:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.confirmation-dialog{max-width:450px;transition:transform .3s ease,box-shadow .3s ease}.confirmation-dialog.success{box-shadow:0 20px 40px #22c55e33;transform:scale(1.02)}.confirmation-dialog .modal-header h3{align-items:center;color:#1a202c;display:flex;font-size:18px;font-weight:600;gap:8px;margin:0}.confirmation-icon{font-size:20px;transition:transform .3s ease}.confirmation-icon.success{animation:successPulse 1.5s ease-in-out}.confirmation-icon.loading{animation:loadingSpin 1s linear infinite}@keyframes loadingSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.confirmation-body{padding:20px 24px;transition:all .3s ease}.confirmation-body.success{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border-radius:8px;margin:0 8px}.confirmation-body p{color:#4a5568;font-size:16px;line-height:1.5;margin:0;transition:all .3s ease}.confirmation-body.success p{animation:successTextSlide .5s ease-out .3s both;color:#166534;font-weight:600}@keyframes successTextSlide{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.success-checkmark{height:115px;margin:0 auto 20px;width:80px}.success-checkmark .check-icon{border:4px solid #4caf50;border-radius:50%;box-sizing:initial;height:80px;position:relative;width:80px}.success-checkmark .check-icon:before{background:#fff;border-radius:100px 0 0 100px;content:"";height:100px;left:-2px;position:absolute;top:3px;transform:rotate(-45deg);transform-origin:100% 50%;width:30px}.success-checkmark .check-icon:after{animation:rotate-circle 4.25s ease-in;background:#fff;border-radius:0 100px 100px 0;content:"";height:100px;left:30px;position:absolute;top:0;transform:rotate(-45deg);transform-origin:0 50%;width:60px}.success-checkmark .check-icon .icon-line{background-color:#4caf50;border-radius:2px;display:block;height:5px;position:absolute;z-index:10}.success-checkmark .check-icon .icon-line.line-tip{animation:icon-line-tip .75s;left:14px;top:46px;transform:rotate(45deg);width:25px}.success-checkmark .check-icon .icon-line.line-long{animation:icon-line-long .75s;right:8px;top:38px;transform:rotate(-45deg);width:47px}.success-checkmark .check-icon .icon-circle{border:4px solid #4caf5080;border-radius:50%;box-sizing:initial;height:80px;left:-4px;position:absolute;top:-4px;width:80px;z-index:10}.success-checkmark .check-icon .icon-fix{background-color:#fff;height:85px;left:26px;position:absolute;top:8px;transform:rotate(-45deg);width:5px;z-index:1}@keyframes rotate-circle{0%{transform:rotate(-45deg)}5%{transform:rotate(-45deg)}12%{transform:rotate(-405deg)}to{transform:rotate(-405deg)}}@keyframes icon-line-tip{0%{left:1px;top:19px;width:0}54%{left:1px;top:19px;width:0}70%{left:-8px;top:37px;width:50px}84%{left:21px;top:48px;width:17px}to{left:14px;top:45px;width:25px}}@keyframes icon-line-long{0%{right:46px;top:54px;width:0}65%{right:46px;top:54px;width:0}84%{right:0;top:35px;width:55px}to{right:8px;top:38px;width:47px}}.error-message,.success-message{gap:12px;margin-bottom:16px;position:relative}.success-message{align-items:center;display:flex;justify-content:space-between}.message-close-btn{align-items:center;background:none;border:none;border-radius:50%;color:inherit;cursor:pointer;display:flex;flex-shrink:0;font-size:18px;font-weight:700;height:20px;justify-content:center;opacity:.7;padding:0;transition:background-color .2s ease;width:20px}.message-close-btn:hover{background-color:#0000001a;opacity:1}.error-message .message-close-btn:hover{background-color:#c530301a}.success-message .message-close-btn:hover{background-color:#22543d1a}.loading-spinner{color:#718096;font-size:14px;padding:20px;text-align:center}.appointments-tab{padding:24px}.section{margin-bottom:32px}.section h3{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 16px}.appointments-list{display:flex;flex-direction:column;gap:12px}.appointment-time{color:#718096;font-size:12px}.no-appointments{padding:32px}.status-badge.completed{color:#276749}.status-badge.frozen{background:#bfdbfe;color:#1e40af}.current-subscription{background:#f7fafc}.current-subscription h3{font-size:18px}.subscription-details{gap:20px}.subscription-section{background:#fff;border:1px solid #e2e8f0;border-radius:6px}.section-header{margin-bottom:12px}.section-header h4{margin:0}.btn-freeze{background:#f59e0b;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:background-color .2s ease,transform .1s ease}.btn-freeze:hover:not(:disabled){background:#d97706;transform:translateY(-1px)}.btn-freeze:disabled{background:#94a3b8;cursor:not-allowed;transform:none}.btn-unfreeze{background:#10b981;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:background-color .2s ease,transform .1s ease}.btn-unfreeze:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.btn-unfreeze:disabled{background:#94a3b8;cursor:not-allowed;transform:none}.detail-row{border-bottom:1px solid #f3f4f6}.detail-label{color:#6b7280;font-size:13px}.detail-value{color:#1f2937;font-size:13px;font-weight:500}.no-subscription{background:#f9fafb;border:1px solid #e5e7eb;color:#6b7280}.appointments-history{display:flex;flex-direction:column;gap:12px;max-height:400px;overflow-y:auto}.appointment-history-item{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px;transition:background-color .2s ease}.appointment-history-item:hover{background:#f1f5f9}.appointment-main-info{grid-gap:16px;align-items:center;display:grid;gap:16px;grid-template-columns:1fr auto auto;margin-bottom:8px}.appointment-date-time{display:flex;flex-direction:column;gap:4px;min-width:0}.appointment-date{font-size:14px;font-weight:600}.appointment-time{color:#64748b;font-size:13px}.appointment-status-actions{align-items:center;display:flex;gap:12px}.appointment-details{color:#64748b;font-size:12px;padding-left:0}.booked-info{color:#64748b}.appointments-history .btn-cancel-small{background:#ef4444;border:none;border-radius:4px;color:#fff;cursor:pointer;display:inline-block;font-size:12px;font-weight:500;height:auto;padding:6px 12px;transition:background-color .2s ease;white-space:nowrap;width:auto}.appointments-history .btn-cancel-small:hover:not(:disabled){background:#dc2626}.appointments-history .btn-cancel-small:disabled{background:#94a3b8;cursor:not-allowed}@media (max-width:768px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-header{padding:20px 20px 12px}.appointments-tab,.modal-form{padding:20px}.form-row{grid-template-columns:1fr}.modal-actions{flex-direction:column-reverse}.appointment-item{align-items:flex-start;flex-direction:column;gap:12px}.appointment-item .btn-cancel{align-self:flex-end}.date-navigation{max-width:280px}.date-nav-btn{font-size:14px;height:32px;min-width:32px}.date-navigation input{font-size:13px;min-width:120px}.date-selection{padding:16px}.selected-date-display{font-size:14px}.appointment-main-info{gap:12px;grid-template-columns:1fr}.appointment-status-actions{justify-self:start;margin-top:8px}.appointment-history-item{padding:12px}}.timeslot-management{padding:24px}.timeslot-header{flex-wrap:wrap;gap:24px;margin-bottom:32px}.timeslot-header h2{color:#1a202c;font-size:24px;font-weight:700;margin:0}.header-controls{align-items:flex-start;display:flex;flex-wrap:wrap;gap:24px;min-height:44px}.date-selector{align-items:center;display:flex;gap:12px;height:44px}.date-selector label{color:#4a5568;font-size:14px;font-weight:500}.date-navigation:focus-within{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a}.date-selector input{background:#fff;border:none;font-size:14px;min-width:140px;outline:none;padding:8px 12px}.date-selector input::-webkit-calendar-picker-indicator{cursor:pointer}.btn-close-day{background:#e53e3e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:background-color .2s ease}.btn-close-day:hover{background:#c53030}.btn-close-day:disabled{background:#a0aec0;cursor:not-allowed}.btn-close-range{background:#d97706;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 16px;transition:background-color .2s ease}.btn-close-range:hover{background:#b45309}.btn-close-range:disabled{background:#a0aec0;cursor:not-allowed}.overrides-section{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:20px}.overrides-section h3{color:#1a202c;font-size:18px;font-weight:600;margin:0 0 16px}.overrides-list{display:flex;flex-direction:column;gap:12px}.override-item{align-items:flex-start;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;gap:16px;justify-content:space-between;padding:16px}.override-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.override-description{color:#1a202c;font-size:14px;font-weight:600;line-height:1.4}.override-meta{display:flex;flex-direction:column;gap:2px}.override-creator{color:#4a5568;font-size:12px;font-weight:500}.override-date{color:#718096;font-size:11px}.override-type{color:#1a202c;font-size:14px;font-weight:600}.override-time{color:#4a5568;font-size:14px}.override-reason{color:#718096;font-size:13px}.btn-remove-override{background:#e53e3e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:background-color .2s ease;white-space:nowrap}.btn-remove-override:hover{background:#c53030}.no-timeslots{color:#718096}.timeslots-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.timeslot-card{border-left:4px solid #e2e8f0;transition:box-shadow .2s ease,transform .2s ease}.timeslot-header-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.time-range{align-items:center;color:#1a202c;display:flex;font-size:18px;gap:8px}.override-indicator{animation:pulse 2s infinite;color:#d97706;font-size:16px}.capacity-override-indicator{animation:pulse 2s infinite;color:#38b2ac;font-size:16px}.timeslot-card.has-time-override{background:linear-gradient(135deg,#fff,#fef3cd);border:2px solid #d97706}.timeslot-card.has-override{border-left-width:6px}.timeslot-override-info{background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;margin-bottom:12px;padding:8px 12px}.timeslot-override-info .override-description{color:#4a5568;font-size:12px;font-style:italic;line-height:1.3}.original-time-info{color:#718096;font-size:14px;font-style:italic;margin:8px 0 0}.capacity-info{background:#f7fafc;border-radius:20px;color:#4a5568;font-size:14px;font-weight:500;padding:4px 12px}.timeslot-status{margin-bottom:16px}.status-indicator{border-radius:6px;font-size:12px;font-weight:600;padding:6px 12px;text-transform:uppercase}.status-indicator.available{background:#c6f6d5;color:#22543d}.status-indicator.partial{background:#fed7a1;color:#c05621}.status-indicator.full{background:#fed7d7;color:#c53030}.status-indicator.unavailable{background:#e2e8f0;color:#4a5568}.timeslot-actions{gap:6px;margin-bottom:16px}.btn-view-clients{background:#3182ce;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 12px;transition:background-color .2s ease}.btn-view-clients:hover{background:#2c5aa0}.btn-change-time{background:#805ad5;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 12px;transition:background-color .2s ease}.btn-change-time:hover{background:#6b46c1}.btn-change-capacity{background:#38b2ac;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 12px;transition:background-color .2s ease}.btn-change-capacity:hover{background:#319795}.btn-disable{background:#e53e3e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 12px;transition:background-color .2s ease}.btn-disable:hover{background:#c53030}.btn-book{background:#22c55e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:6px 12px;transition:background-color .2s ease}.btn-book:hover{background:#16a34a}.current-appointments{border-top:1px solid #e2e8f0;margin-top:16px;padding-top:16px}.current-appointments h4{color:#4a5568;font-size:14px;font-weight:600;margin:0 0 12px}.appointment-item{background:#f7fafc;border-radius:6px;margin-bottom:6px;padding:8px 12px}.client-name{color:#2d3748}.btn-cancel-small{align-items:center;background:#e53e3e;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:12px;font-weight:700;height:20px;justify-content:center;transition:background-color .2s ease;width:20px}.btn-cancel-small:hover{background:#c53030}.timeslot-management .modal-content{max-width:500px}.timeslot-management .modal-header h3{color:#1a202c;font-size:18px;font-weight:600;margin:0}.timeslot-management .form-group select{background-color:#fff;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.timeslot-management .form-group select:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.timeslot-management .form-group input[type=time]{background-color:#fff;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;padding:10px 12px;transition:border-color .2s ease;width:100%}.timeslot-management .form-group input[type=time]:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.timeslot-management .form-group textarea{background-color:#fff;border:2px solid #e2e8f0;border-radius:6px;font-size:14px;min-height:80px;padding:10px 12px;resize:vertical;transition:border-color .2s ease;width:100%}.timeslot-management .form-group textarea:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.btn-danger{background:#e53e3e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.btn-danger:hover{background:#c53030}.btn-danger:disabled{background:#a0aec0;cursor:not-allowed}.timeslot-card.available{border-left-color:#22c55e}.timeslot-card.partial{border-left-color:#f59e0b}.timeslot-card.full{border-left-color:#ef4444}.timeslot-card.unavailable{border-left-color:#6b7280;opacity:.7}@media (max-width:768px){.timeslot-management{padding:16px}.header-controls,.timeslot-header{align-items:stretch;flex-direction:column}.header-controls{gap:12px}.date-selector{justify-content:space-between}.timeslots-grid{grid-template-columns:1fr}.timeslot-card{padding:16px}.timeslot-header-info{align-items:flex-start;flex-direction:column;gap:8px}.timeslot-actions{flex-wrap:wrap;gap:4px}.timeslot-actions>*{flex:1 1;min-width:calc(50% - 2px)}.appointment-item{align-items:flex-start;flex-direction:column;gap:8px}.appointment-item .btn-cancel-small{align-self:flex-end}.override-item{align-items:stretch;flex-direction:column;gap:12px}.btn-remove-override{align-self:flex-end}}.clients-info{max-height:60vh;overflow-y:auto}.timeslot-details{background:#f7fafc;border:1px solid #e2e8f0;border-radius:6px;margin-bottom:20px;padding:16px}.timeslot-details h4{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 12px}.detail-row{align-items:flex-start;gap:12px;margin-bottom:8px}.detail-row:last-child{margin-bottom:0}.detail-row .label{color:#4a5568;flex-shrink:0;font-weight:500;min-width:100px}.detail-row .value{color:#1a202c;flex:1 1;text-align:right}.override-note{color:#718096;display:block;font-size:12px;font-style:italic;margin-top:4px}.booked-clients h4{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 16px}.clients-list{display:flex;flex-direction:column;gap:12px}.client-item{align-items:flex-start;background:#f7fafc;gap:16px;padding:16px}.client-info{flex:1 1}.client-name{font-size:14px;font-weight:600;margin-bottom:4px}.booking-details{display:flex;flex-direction:column;gap:2px}.booked-at{color:#4a5568;font-size:12px}.booked-by{color:#718096;font-size:11px;font-style:italic}.client-actions{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:8px}.client-status{flex-shrink:0}.status-badge.active{background:#c6f6d5;color:#22543d}.btn-cancel-appointment{background:#e53e3e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:11px;font-weight:500;padding:4px 8px;transition:background-color .2s ease}.btn-cancel-appointment:hover{background:#c53030}.no-bookings{color:#718096;padding:40px 20px;text-align:center}.no-bookings p{font-size:14px;margin:0}@media (max-width:768px){.detail-row{align-items:flex-start;flex-direction:column;gap:4px}.detail-row .value{text-align:left}.client-item{align-items:flex-start;flex-direction:column;gap:12px}.client-actions{align-items:center;align-self:stretch;flex-direction:row;justify-content:space-between}.booking-details{gap:1px}}.global-timeslot-management{margin:0 auto;max-width:1400px;padding:20px}.global-timeslot-header{margin-bottom:30px}.global-timeslot-header h3{color:#333;font-size:1.5rem;margin:0 0 8px}.global-timeslot-header p{color:#666;margin:0 0 20px}.controls{align-items:center;display:flex;flex-wrap:wrap;gap:15px;margin-bottom:20px}.day-filter{background:#fff;border:1px solid #ddd;border-radius:4px;font-size:14px;min-width:150px;padding:8px 12px}.create-button{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s}.create-button:hover{background:#0056b3}.copy-button{background:#17a2b8;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;min-width:70px;padding:6px 12px;transition:all .2s}.copy-button:hover{background:#138496;transform:translateY(-1px)}.paste-button{background:#6f42c1;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:all .2s}.paste-button:hover:not(:disabled){background:#5a32a3;transform:translateY(-1px)}.paste-button:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.timeslots-grid{grid-gap:25px;gap:25px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.day-section{background:#f8f9fa;border-radius:8px;box-shadow:0 2px 4px #0000001a;min-height:200px;padding:20px}.day-header{align-items:center;border-bottom:2px solid #007bff;color:#495057;display:flex;font-size:1.2rem;font-weight:600;justify-content:space-between;margin:0 0 20px;padding-bottom:8px}.day-header h4{flex:1 1;margin:0;text-align:center}.timeslots-list{display:flex;flex-direction:column;gap:15px}.timeslot-card{border:1px solid #dee2e6;box-shadow:0 1px 3px #0000001a;transition:all .2s}.timeslot-card:hover{transform:translateY(-1px)}.timeslot-card.disabled{background:#f8f8f8;border-left:4px solid #dc3545;opacity:.7}.timeslot-card:not(.disabled){border-left:4px solid #28a745}.timeslot-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.time-info{flex:1 1}.time-range{color:#333;font-size:16px;font-weight:600;margin-bottom:6px}.effective-time{color:#007bff;margin-left:8px}.capacity,.effective-time{font-size:14px;font-weight:500}.capacity{color:#666}.timeslot-status{align-items:flex-end;display:flex;flex-direction:column;gap:6px}.status-badge{font-size:11px;letter-spacing:.5px}.status-badge.disabled{background:#f8d7da;color:#721c24}.status-badge.modified{background:#fff3cd;color:#856404}.status-badge.custom{background:#d4edda;color:#155724}.reason{background:#f1f3f4;border-left:3px solid #007bff;border-radius:6px;color:#555;font-size:13px;margin:12px 0;padding:10px}.timeslot-meta{border-top:1px solid #eee;color:#666;font-size:12px;margin:12px 0;padding-top:8px}.timeslot-meta div{margin-bottom:3px}.timeslot-actions{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-start;margin-top:15px}.timeslot-actions button{border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;min-width:70px;padding:6px 12px;text-align:center;transition:all .2s}.edit-button{background:#007bff}.edit-button:hover{background:#0056b3;transform:translateY(-1px)}.toggle-button.enabled{background:#28a745;color:#fff}.toggle-button.disabled{background:#dc3545;color:#fff}.toggle-button:hover{opacity:.8;transform:translateY(-1px)}.reset-button{background:#ffc107;color:#212529}.reset-button:hover{background:#e0a800;transform:translateY(-1px)}.delete-button{background:#dc3545;color:#fff}.delete-button:hover{background:#c82333;transform:translateY(-1px)}.loading{color:#666;padding:60px}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-left:4px solid #dc3545;border-radius:6px;color:#721c24}.success-message{background:#d4edda;border:1px solid #c3e6cb;border-left:4px solid #28a745;border-radius:6px;color:#155724;padding:12px 16px}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal{background:#fff;border-radius:8px;box-shadow:0 4px 20px #0000004d;max-height:90vh;max-width:500px;overflow:auto;width:90%}.modal-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#333;margin:0}.close-button{align-items:center;background:none;border:none;border-radius:50%;color:#999;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;transition:all .2s;width:30px}.close-button:hover{background:#e9ecef;color:#666}.modal-content{padding:20px}.form-group{margin-bottom:15px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:8px 12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-row{grid-gap:15px;gap:15px;grid-template-columns:1fr 1fr}.form-group input[type=checkbox]{margin-right:8px;width:auto}.readonly-input{background:#f8f9fa!important;color:#6c757d!important;cursor:not-allowed!important;font-weight:500}.help-text{color:#6c757d;display:block;font-size:12px;font-style:italic;margin-top:5px}.modal-actions{background:#f8f9fa;border-top:1px solid #dee2e6;display:flex;gap:10px;justify-content:flex-end;padding:20px}.save-button{background:#28a745;border-radius:4px;font-size:14px;padding:10px 20px;transition:background-color .2s}.save-button:hover{background:#218838}.cancel-button{background:#6c757d;padding:10px 20px;transition:background-color .2s}.cancel-button:hover{background:#5a6268}.paste-info{background:#e3f2fd;border:1px solid #bbdefb;border-left:4px solid #2196f3;border-radius:6px;margin-bottom:20px;padding:15px}.paste-info p{color:#0d47a1;font-size:14px;margin:0 0 8px}.paste-info p:last-child{margin-bottom:0}.paste-info .warning{color:#bf360c;font-weight:500}.timeslots-preview{background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;margin-top:20px;max-height:200px;overflow-y:auto;padding:15px}.timeslots-preview h4{color:#333;font-size:14px;font-weight:600;margin:0 0 12px}.preview-list{display:flex;flex-direction:column;gap:8px}.preview-item{align-items:center;background:#fff;border:1px solid #dee2e6;border-radius:4px;display:flex;font-size:12px;justify-content:space-between;padding:8px 12px}.preview-item .time{color:#333;flex:1 1;font-weight:600}.preview-item .capacity{color:#666;margin:0 10px}.preview-item .status{border-radius:10px;font-size:10px;font-weight:600;letter-spacing:.5px;padding:2px 6px;text-transform:uppercase}.preview-item .status.enabled{background:#d4edda;color:#155724}.preview-item .status.disabled{background:#f8d7da;color:#721c24}@media (max-width:1200px){.timeslots-grid{grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}}@media (max-width:768px){.form-row,.timeslots-grid{grid-template-columns:1fr}.controls{align-items:stretch;flex-direction:column}.timeslot-actions{justify-content:center}.day-filter{min-width:auto}.global-timeslot-management{padding:15px}}.timeslots-grid[data-single-day=true]{grid-template-columns:1fr;margin:0 auto;max-width:800px}.timeslots-grid[data-single-day=true] .day-section{min-height:auto}.timeslots-grid[data-single-day=true] .timeslots-list{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.broadcast-email{margin:0 auto;max-width:800px;padding:0}.broadcast-email-header{margin-bottom:32px;text-align:center}.broadcast-email-header h2{color:#1a202c;font-size:24px;font-weight:700;margin:0 0 8px;position:relative}.broadcast-email-header h2:after{background:linear-gradient(135deg,#dc2626,#000);border-radius:2px;bottom:-8px;content:"";height:3px;left:50%;position:absolute;transform:translateX(-50%);width:60px}.broadcast-email-header p{color:#718096;font-size:16px;margin:16px 0 0}.broadcast-email .success-message{background-color:#f0fff4!important;border:1px solid #9ae6b4!important;border-radius:8px;color:#38a169!important;font-size:14px;margin-bottom:24px;padding:12px 16px}.broadcast-email .error-message{background-color:#fed7d7!important;border:1px solid #feb2b2!important;border-radius:8px;color:#c53030!important;margin-bottom:24px;padding:16px 20px}.error-list{margin:8px 0 0;padding-left:20px}.error-list li{color:#c53030;margin-bottom:4px}.broadcast-email-form{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:32px;padding:32px}.form-group{margin-bottom:24px}.form-group label{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;justify-content:space-between;margin-bottom:8px}.required{color:#dc2626;margin-left:4px}.variable-button{background:#4f46e5;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;margin-left:auto;padding:4px 12px;transition:background-color .2s ease}.variable-button:hover:not(:disabled){background:#4338ca}.variable-button:disabled{cursor:not-allowed;opacity:.6}.form-input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;padding:12px 16px;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.form-input:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.form-textarea{background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-family:inherit;font-size:14px;min-height:120px;padding:12px 16px;resize:vertical;transition:border-color .2s ease,box-shadow .2s ease;width:100%}.form-textarea:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.form-textarea:disabled{background:#f9fafb;color:#6b7280;cursor:not-allowed}.character-count{color:#6b7280;font-size:12px;margin-top:4px;text-align:right}.message-note{background:#f8fafc;border-left:3px solid #e5e7eb;border-radius:6px;color:#6b7280;font-size:12px;margin-top:8px;padding:8px 12px}.checkbox-label{align-items:flex-start!important;cursor:pointer;display:flex!important;gap:12px;margin-bottom:0!important}.form-checkbox{cursor:pointer;flex-shrink:0;height:18px;margin:2px 0 0;width:18px}.checkbox-text{color:#374151;font-weight:500;line-height:1.5}.checkbox-description{color:#6b7280;display:block;font-size:13px;font-weight:400;line-height:1.4;margin-top:4px}.variable-info{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;margin-bottom:24px;padding:20px}.variable-info h4{color:#374151;font-size:16px;font-weight:600;margin:0 0 12px}.variable-info ul{margin:0 0 16px;padding-left:20px}.variable-info li{color:#4b5563;margin-bottom:4px}.variable-info code{background:#f3f4f6;border-radius:4px;color:#dc2626;font-size:13px;font-weight:600;padding:2px 6px}.variable-example{color:#4b5563;font-size:14px;line-height:1.5;margin:0}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:16px;justify-content:flex-end;margin-top:32px;padding-top:24px}.clear-button{background:#6b7280;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:background-color .2s ease,transform .2s ease}.clear-button:hover:not(:disabled){background:#4b5563;transform:translateY(-1px)}.clear-button:disabled{cursor:not-allowed;opacity:.6;transform:none}.send-button{align-items:center;background:linear-gradient(135deg,#dc2626,#000);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;padding:12px 32px;transition:transform .2s ease,box-shadow .2s ease}.send-button:hover:not(:disabled){box-shadow:0 4px 12px #dc26264d;transform:translateY(-2px)}.send-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.loading-spinner{border:2px solid #0000;border-top-color:currentcolor;height:14px;width:14px}.email-preview{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:32px}.email-preview h3{border-bottom:2px solid #e5e7eb;color:#1a202c;font-size:18px;font-weight:600;margin:0 0 20px;padding-bottom:12px}.preview-content{display:flex;flex-direction:column;gap:16px}.preview-audience,.preview-message,.preview-subject{display:flex;flex-direction:column;gap:8px}.preview-audience strong,.preview-message strong,.preview-subject strong{color:#374151;font-size:14px}.preview-body{background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#4b5563;font-size:14px;line-height:1.6;min-height:40px;padding:16px}.preview-variable{background:#dbeafe;border-radius:4px;color:#1e40af;font-weight:600;padding:2px 6px}@media (max-width:768px){.broadcast-email{padding:0 16px}.broadcast-email-form,.email-preview{padding:20px}.broadcast-email-header h2{font-size:20px}.form-actions{flex-direction:column;gap:12px}.clear-button,.send-button{justify-content:center;width:100%}.checkbox-label{flex-direction:column;gap:8px}.form-checkbox{margin-top:0}.variable-info{padding:16px}.variable-info h4{font-size:14px}}.settings{margin:0 auto;max-width:1200px;padding:20px}.settings-tabs{border-bottom:2px solid #dee2e6;display:flex;gap:10px;margin-top:20px}.tab-button{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;font-size:16px;font-weight:500;padding:12px 20px;transition:all .3s ease}.tab-button:hover{background:#f7fafc;color:#1a202c}.tab-button.active{background:#dc26260d;border-bottom-color:#dc2626;color:#dc2626}.settings-header{margin-bottom:30px}.settings-header h2{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 8px}.settings-header p{color:#6b7280;font-size:14px;margin:0}.loading{color:#6b7280;font-size:16px;height:200px;justify-content:center}.error-message,.loading{align-items:center;display:flex}.error-message{background-color:#fef2f2;border:1px solid #fecaca;color:#dc2626;justify-content:space-between;padding:12px 16px}.close-error{align-items:center;background:none;border:none;color:#dc2626;cursor:pointer;display:flex;font-size:18px;height:20px;justify-content:center;padding:0;width:20px}.close-error:hover{background-color:#fee2e2;border-radius:50%}.settings-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr))}.setting-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a;padding:24px;transition:box-shadow .2s ease}.setting-card:hover{box-shadow:0 4px 6px -1px #0000001a}.setting-header{margin-bottom:16px}.setting-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 4px}.setting-key{background-color:#f3f4f6;border-radius:4px;color:#6b7280;font-family:monospace;font-size:12px;padding:2px 8px}.setting-description{color:#6b7280;font-size:14px;line-height:1.5;margin:0 0 20px}.setting-value-section{margin-bottom:16px}.setting-value-section label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.view-mode{align-items:center;display:flex;gap:12px}.setting-value{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;color:#1f2937;font-weight:600;min-width:60px;padding:8px 12px;text-align:center}.edit-button{background-color:#3b82f6;border-radius:6px}.edit-button:hover{background-color:#2563eb}.edit-mode{display:flex;flex-direction:column;gap:12px}.setting-input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;max-width:200px;padding:8px 12px;width:100%}.setting-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.edit-actions{display:flex;gap:8px}.save-button{background-color:#10b981;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:background-color .2s ease}.save-button:hover:not(:disabled){background-color:#059669}.save-button:disabled{cursor:not-allowed;opacity:.6}.cancel-button{background-color:#6b7280;font-size:12px;padding:6px 12px}.cancel-button:hover:not(:disabled){background-color:#4b5563}.cancel-button:disabled{cursor:not-allowed;opacity:.6}.setting-meta{border-top:1px solid #e5e7eb;padding-top:12px}.last-updated{color:#9ca3af;font-size:12px}@media (max-width:768px){.settings{padding:16px}.settings-grid{grid-template-columns:1fr}.setting-card{padding:16px}}.book-appointment{margin:0 auto;max-width:1000px;padding:24px}.book-appointment-header{margin-bottom:32px;text-align:center}.book-appointment-header h2{color:#1a202c;font-size:28px;font-weight:700;margin:0 0 8px}.book-appointment-header p{color:#718096;font-size:16px;margin:0}.date-selection{border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:32px;padding:24px}.date-selection label{font-size:16px}.date-selection input{border-radius:8px;font-size:16px;margin-bottom:16px;padding:12px 16px}.date-selection input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-navigation{border:2px solid #e2e8f0;border-radius:6px;justify-content:center;margin-bottom:16px;margin-left:auto;margin-right:auto;max-width:300px;overflow:hidden;transition:border-color .2s ease}.date-navigation:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.date-nav-btn{align-items:center;background:#f7fafc;border:none;color:#4a5568;cursor:pointer;display:flex;font-size:16px;font-weight:600;height:36px;justify-content:center;min-width:36px;padding:8px 12px;transition:background-color .2s ease,color .2s ease}.date-nav-btn:hover:not(:disabled){background:#edf2f7;color:#2d3748}.date-nav-btn:disabled{background:#f7fafc;color:#a0aec0;cursor:not-allowed}.date-navigation input{background:#fff;border:none!important;font-size:14px;margin-bottom:0!important;min-width:140px;outline:none;padding:8px 12px!important}.date-navigation input::-webkit-calendar-picker-indicator{cursor:pointer}.selected-date-display{color:#1a202c;font-size:18px}.subscription-info{background:linear-gradient(135deg,#fef2f2,#f9fafb);border:1px solid #e5e7eb;border-left:4px solid #dc2626;border-radius:8px;margin-bottom:20px;padding:12px 16px}.subscription-period{color:#374151;font-size:14px;font-weight:600;margin:0;text-align:center}.timeslots-section{margin-bottom:32px}.timeslots-section h3{color:#1a202c;font-size:20px;font-weight:600;margin:0 0 20px;text-align:center}.timeslots-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.timeslot-card{border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:20px}.timeslot-card:hover{box-shadow:0 4px 12px #00000026}.timeslot-time{font-size:20px;margin-bottom:16px}.timeslot-availability{margin-bottom:20px}.availability-text{font-size:14px;margin-bottom:8px}.availability-bar{border-radius:3px;height:6px}.book-button{border-radius:8px;font-size:16px;padding:12px 20px}.book-button:hover:not(:disabled){box-shadow:0 4px 12px #dc26264d}.restricted-button{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;color:#fff;cursor:not-allowed;font-size:16px;font-weight:600;opacity:.8;padding:12px 20px;width:100%}.morning-client-restricted{background:#ef44440d;border:2px solid #ef4444}.morning-client-restricted .timeslot-time{color:#dc2626}.availability-text.restricted{color:#dc2626;font-weight:600}.express-interest-button:disabled{background:#9ca3af;opacity:.5}.remove-interest-button:disabled{opacity:.5}.no-timeslots{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:60px 20px}.no-timeslots-icon{font-size:48px;margin-bottom:16px}.no-timeslots h3{color:#1a202c;font-size:20px;font-weight:600;margin:0 0 8px}.no-timeslots p{font-size:16px}.booking-info{background:#fff;border-left:4px solid #667eea;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.booking-info h4{color:#1a202c;font-size:18px;font-weight:600;margin:0 0 16px}.booking-info ul{list-style:none;margin:0;padding:0}.booking-info li{color:#4a5568;font-size:14px;padding:8px 0 8px 20px;position:relative}.booking-info li.morning-client-info{background:#ef44440d;border-left:3px solid #ef4444;border-radius:4px;color:#dc2626;margin:8px 0;padding:12px 16px}.booking-info li:before{color:#22c55e;content:"✓";font-weight:700;left:0;position:absolute}.success-message{background-color:#c6f6d5;border:1px solid #9ae6b4;border-radius:8px;color:#22543d;font-size:14px;margin-bottom:20px;padding:16px 20px;text-align:center}.subscription-warning{background:#fef2f2;border:2px solid #fecaca;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:32px;padding:40px 20px;text-align:center}.subscription-warning .warning-icon{font-size:48px;margin-bottom:16px}.subscription-warning h3{color:#dc2626;font-size:20px;font-weight:600;margin:0 0 16px}.subscription-warning p{color:#7f1d1d;font-size:16px;line-height:1.5;margin:0 0 12px}.subscription-warning p:last-child{margin-bottom:0}@media (max-width:768px){.book-appointment{padding:16px}.book-appointment-header h2{font-size:24px}.date-selection{padding:20px}.timeslots-grid{grid-template-columns:1fr}.timeslot-card{padding:16px}.timeslot-time{font-size:18px}.booking-info{padding:20px}.booking-info li{font-size:13px}.subscription-warning{padding:32px 16px}.subscription-warning .warning-icon{font-size:36px}.subscription-warning h3{font-size:18px}.subscription-warning p{font-size:15px}}@media (max-width:480px){.book-appointment-header h2{font-size:20px}.book-appointment-header p{font-size:14px}.date-selection{padding:16px}.date-navigation{max-width:280px}.date-nav-btn{font-size:14px;height:32px;min-width:32px}.date-navigation input{font-size:13px;min-width:120px}.selected-date-display{font-size:16px}.subscription-info{padding:8px 12px}.subscription-period{font-size:13px}.no-timeslots{padding:40px 16px}.no-timeslots-icon{font-size:36px}.no-timeslots h3{font-size:18px}.no-timeslots p{font-size:14px}.subscription-warning{padding:24px 12px}.subscription-warning .warning-icon{font-size:32px}.subscription-warning h3{font-size:16px}.subscription-warning p{font-size:14px}}.full-slots-info{color:#718096;font-size:14px;font-style:italic;margin-bottom:20px;text-align:center}.timeslot-card.full{background:#fef2f2;border-left:4px solid #ef4444}.timeslot-card.full:hover{border-color:#dc2626}.availability-text.full{color:#ef4444;font-weight:600}.availability-fill.full{background:linear-gradient(135deg,#ef4444,#dc2626)}.express-interest-button{background:linear-gradient(135deg,#f59e0b,#d97706);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 20px;transition:transform .2s ease,box-shadow .2s ease;width:100%}.express-interest-button:hover:not(:disabled){box-shadow:0 4px 12px #f59e0b4d;transform:translateY(-2px)}.express-interest-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.interest-section{display:flex;flex-direction:column;gap:12px}.interest-indicator{align-items:center;background:#fef3c7;border:1px solid #f59e0b;border-radius:6px;color:#92400e;display:flex;font-size:14px;font-weight:600;gap:8px;justify-content:center;padding:8px}.interest-icon{font-size:16px}.remove-interest-button{background:linear-gradient(135deg,#6b7280,#4b5563);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:transform .2s ease,box-shadow .2s ease;width:100%}.remove-interest-button:hover:not(:disabled){box-shadow:0 2px 8px #6b72804d;transform:translateY(-1px)}.remove-interest-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}@media (max-width:768px){.full-slots-info{font-size:13px;margin-bottom:16px}.interest-indicator{font-size:13px;padding:6px}.express-interest-button,.remove-interest-button{font-size:14px;padding:10px 16px}}@media (max-width:480px){.interest-section{gap:8px}.interest-indicator{font-size:12px;padding:4px 6px}.express-interest-button,.remove-interest-button{font-size:13px;padding:8px 12px}}.timeslot-card.has-override{background:linear-gradient(135deg,#fff,#fef9ec);border-left:4px solid #d97706}.time-changed-indicator{animation:pulse 2s infinite;color:#d97706;font-size:16px;margin-left:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.original-time-note{color:#6b7280;font-size:12px;font-style:italic;margin-bottom:8px;margin-top:4px}.override-reason{background:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;color:#4a5568;font-size:12px;font-style:italic;line-height:1.3;margin-bottom:12px;padding:6px 10px}.timeslots-info{color:#6b7280;font-size:14px;font-style:italic;margin-bottom:20px}.client-profile{margin:0 auto;max-width:1200px;padding:24px}.profile-header{margin-bottom:32px;text-align:center}.profile-header h2{color:#1a202c;font-size:28px;font-weight:700;margin:0 0 8px}.profile-header p{color:#718096;font-size:16px;margin:0}.error-message{background-color:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030;font-size:14px;margin-bottom:20px;padding:16px 20px;text-align:center}.profile-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:40px}.profile-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.card-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:12px}.card-header h3{color:#1a202c;font-size:20px;font-weight:600;margin:0}.readonly-badge{background:#f7fafc;border-radius:12px;color:#4a5568;font-size:12px;font-weight:500;padding:4px 12px;text-transform:uppercase}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr}.info-item{display:flex;flex-direction:column;gap:4px}.info-item label{color:#4a5568;font-size:14px;font-weight:500}.info-item span{color:#1a202c;font-size:16px;font-weight:400}.info-item span.expiring-soon{color:#e53e3e;font-weight:600}.card-note{border-top:1px solid #e2e8f0;margin-top:20px;padding-top:16px}.card-note p{color:#718096;font-size:14px;font-style:italic;margin:0}.status-badge{border-radius:12px;color:#fff;padding:6px 12px}.subscription-details{gap:16px;margin-top:16px}.subscription-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px}.subscription-section h4{color:#374151;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 12px;text-transform:uppercase}.status-badge.activated{background:#c6f6d5;color:#22543d}.status-badge.activated,.status-badge.waiting{border-radius:12px;font-size:12px;font-weight:600;padding:4px 8px;text-transform:uppercase}.renewal-notice,.status-badge.waiting{background:#fef5e7;color:#c05621}.renewal-notice{border:1px solid #fed7a1;border-radius:6px;font-size:14px;margin-top:16px;padding:12px 16px}.no-subscription{padding:20px 0}.no-subscription p{color:#718096;font-size:16px;text-align:center}.appointments-section{margin-bottom:40px}.appointments-section h3{color:#1a202c;font-size:22px;font-weight:600;margin:0 0 20px}.appointments-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.appointment-card{background:#fff;border:2px solid #0000;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:all .2s ease}.appointment-card.upcoming{border-left:4px solid #667eea}.appointment-card:hover{box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.appointment-date{margin-bottom:8px}.appointment-time{margin-bottom:12px}.appointment-status{margin-bottom:16px}.status-badge.active{background:#22c55e}.status-badge.completed{background:#3b82f6}.status-badge.cancelled{background:#ef4444}.cancel-button{border-radius:6px;font-weight:500;padding:10px 16px;width:100%}.appointment-info{gap:4px}.no-appointments{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:60px 20px}.no-appointments-icon{font-size:48px;margin-bottom:16px}@media (max-width:768px){.client-profile{padding:16px}.profile-header h2{font-size:24px}.profile-grid{gap:20px;grid-template-columns:1fr}.profile-card{padding:20px}.card-header{align-items:flex-start;flex-direction:column;gap:8px}.appointments-grid{grid-template-columns:1fr}.appointment-card{padding:16px}.appointment-history-item{align-items:flex-start;flex-direction:column;gap:12px;padding:16px}.appointment-history-item .appointment-status{align-self:flex-end}}@media (max-width:480px){.client-profile{padding:12px}.profile-header h2{font-size:20px}.profile-header p{font-size:14px}.profile-card{padding:16px}.card-header h3{font-size:18px}.appointments-section h3{font-size:20px}.no-appointments{padding:40px 16px}.no-appointments-icon{font-size:36px}}.dashboard-container{background-color:#fafafa;min-height:100vh}.dashboard-header{background:#fff;border-bottom:2px solid #dc2626;box-shadow:0 2px 8px #0000001a;padding:20px 0}.header-content{align-items:center;display:flex;gap:20px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.welcome-container{display:inline-block;height:32px;min-width:400px;position:relative}.reforged-text,.welcome-text{color:#1a202c;font-size:24px;font-weight:700;left:0;margin:0;position:absolute;top:0;transition:all .6s ease-in-out;white-space:nowrap;width:100%}.reforged-text.show,.welcome-text.show{opacity:1;transform:translateX(0)}.reforged-text.hide,.welcome-text.hide{opacity:0;transform:translateX(-20px)}.reforged-text{-webkit-text-fill-color:#0000;background:linear-gradient(45deg,#dc2626,#000);background-clip:text;-webkit-background-clip:text;text-shadow:none}.user-info h1{color:#1a202c;font-size:24px;font-weight:700;margin:0 0 4px}.user-role{color:#718096;font-size:14px;font-weight:500;margin:0}.logout-button{background:#e53e3e;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:10px 20px;transition:background-color .2s ease}.logout-button:hover{background:#c53030}.dashboard-main{margin:0 auto;max-width:1200px;padding:0 20px 32px}.dashboard-nav{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;display:flex;gap:4px;margin:20px 0 32px;padding:8px}.nav-tab{background:#0000;border:none;border-radius:8px;color:#4a5568;cursor:pointer;flex:1 1;font-weight:500;padding:12px 24px;text-align:center;transition:all .2s ease}.nav-tab:hover{background:#f7fafc;color:#1a202c}.nav-tab.active{background:linear-gradient(135deg,#dc2626,#000);box-shadow:0 2px 8px #dc26264d;color:#fff}.loading{color:#718096;font-size:18px;padding:60px 20px;text-align:center}.error-banner{background-color:#fed7d7;border:1px solid #feb2b2;border-radius:8px;color:#c53030;margin-bottom:24px;padding:16px 20px}.status-badge{border-radius:20px;font-weight:600;padding:4px 12px}.status-badge.cancelled{color:#c53030}.status-badge.inactive{background:#e2e8f0;color:#4a5568}.primary-button{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:600;padding:12px 24px;transition:transform .2s ease,box-shadow .2s ease}.primary-button:hover{background:#b91c1c;box-shadow:0 4px 12px #dc26264d;transform:translateY(-1px)}.cancel-button{background:#e53e3e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .2s ease}.cancel-button:hover{background:#c53030}.edit-button,.view-button{background:#4299e1;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;margin-right:8px;padding:6px 12px;transition:background-color .2s ease}.edit-button:hover,.view-button:hover{background:#3182ce}.admin-content{position:relative}.tab-content{animation:fadeIn .3s ease-in;display:none}.tab-content.active{display:block}.admin-overview,.clients-management{animation:fadeIn .3s ease-in}.active-subscriptions{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-top:24px;padding:24px}.active-subscriptions .section-header{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:20px}.active-subscriptions .section-header h2{color:#1a202c;flex-shrink:0;font-size:20px;font-weight:600;margin:0}.active-subscriptions .search-form{flex:1 1;max-width:300px}.active-subscriptions .search-input{border:1px solid #d1d5db;border-radius:6px;font-size:14px;padding:8px 12px;transition:border-color .2s ease;width:100%}.active-subscriptions .search-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.subscriptions-table{overflow-x:auto}.subscriptions-table table{border-collapse:collapse;border-spacing:0;width:100%}.subscriptions-table th{background:#f7fafc;border-bottom:2px solid #e2e8f0;color:#2d3748;font-size:14px;font-weight:600;padding:12px 16px;text-align:left;white-space:nowrap}.subscriptions-table th:nth-child(3),.subscriptions-table th:nth-child(4){text-align:center}.subscriptions-table td{border-bottom:1px solid #e2e8f0;padding:16px;vertical-align:middle}.subscriptions-table td:nth-child(3),.subscriptions-table td:nth-child(4){text-align:center}.subscriptions-table tr:hover{background:#f7fafc}.subscription-period{border-radius:6px;font-size:13px;font-weight:500;padding:6px 12px;white-space:nowrap}.subscription-period.active{background:#c6f6d5;color:#22543d}.subscription-period.expiring{background:#fef6cd;color:#975a16}.subscription-period.expired{background:#fed7d7;color:#c53030}.subscription-period.frozen{background:#bfdbfe;color:#1e40af}.monthly-limit{color:#4a5568}.appointments-used,.monthly-limit{font-size:16px;font-weight:600}.appointments-used .limit-reached{background:#fed7d7;border-radius:4px;color:#e53e3e;padding:4px 8px}.appointment-dates{word-wrap:break-word;color:#718096;font-size:13px;line-height:1.4;max-width:250px}.recent-activity h2{color:#1a202c;font-size:20px;font-weight:700;margin:0 0 20px}.activity-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr}.activity-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px}.activity-card h3{color:#4a5568;font-size:16px;font-weight:600;margin:0 0 16px}.client-list{display:flex;flex-direction:column;gap:12px}.client-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:6px;display:flex;justify-content:space-between;padding:12px 16px}.client-name{color:#1a202c;font-weight:500}.client-date{color:#718096;font-size:14px}.no-data{color:#718096;font-style:italic;margin:0;padding:20px;text-align:center}.client-overview{animation:fadeIn .3s ease-in}.quick-stats{margin-bottom:32px}.upcoming-appointments{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.upcoming-appointments h2{color:#1a202c;font-size:20px;font-weight:700;margin:0 0 20px}.appointments-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.appointments-section h2{color:#1a202c;font-size:20px;font-weight:700;margin:0 0 20px}.empty-state{color:#718096;padding:40px 20px;text-align:center}.empty-state p{font-size:16px;margin:0 0 16px}.appointments-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.appointment-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;transition:box-shadow .2s ease}.appointment-card:hover{box-shadow:0 4px 6px #0000000d}.appointment-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.appointment-header h3{color:#1a202c;font-size:16px;font-weight:600;margin:0}.appointment-details p{color:#4a5568;font-size:14px;margin:0 0 8px}.appointment-actions{border-top:1px solid #e2e8f0;margin-top:16px;padding-top:16px}.stats-section{margin-bottom:32px}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.stat-card{background:#fff;border-left:4px solid #dc2626;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px;text-align:center;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:0 4px 16px #00000026;transform:translateY(-2px)}.stat-card h3{color:#6b7280;font-size:14px;font-weight:600;letter-spacing:.5px;margin:0 0 8px;text-transform:uppercase}.stat-number{color:#1a202c;font-size:36px;font-weight:700;margin:0}.clients-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;padding:24px}.section-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.section-header h2{color:#1a202c;font-size:20px;font-weight:700;margin:0;position:relative}.section-header h2:after{background:#dc2626;border-radius:2px;bottom:-4px;content:"";height:3px;left:0;position:absolute;width:40px}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:12px}.search-form{display:flex;gap:8px}.search-input{border:2px solid #e2e8f0;border-radius:6px;font-size:14px;min-width:200px;padding:8px 12px;transition:border-color .2s ease}.search-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.search-button{background:#4a5568;border:none;border-radius:6px;color:#fff;cursor:pointer;font-weight:500;padding:8px 16px;transition:background-color .2s ease}.search-button:hover{background:#2d3748}.clients-table{overflow-x:auto}.clients-table table{border-collapse:collapse;width:100%}.clients-table th{background:#f7fafc;color:#4a5568;font-weight:600;padding:12px 16px;text-align:left}.clients-table td,.clients-table th{border-bottom:1px solid #e2e8f0;font-size:14px}.clients-table td{color:#2d3748;padding:16px}.clients-table tr:hover{background:#f7fafc}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.edit-button{background:#4a5568;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:12px;font-weight:500;padding:6px 12px;transition:background-color .2s ease;white-space:nowrap}.edit-button:hover{background:#2d3748}.edit-button.info{background:#3182ce}.edit-button.info:hover{background:#2c5aa0}.edit-button.subscription{background:#38a169}.edit-button.subscription:hover{background:#2f855a}.edit-button.appointments{background:#d69e2e}.edit-button.appointments:hover{background:#b7791f}.appointments-modal{padding:0}.appointments-modal .section{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:32px;padding:24px}.appointments-modal .section h3{color:#1a202c;font-size:18px;font-weight:600;margin:0 0 20px}.appointments-list{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.appointment-history-item{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:16px 20px}.appointment-history-item:last-child{border-bottom:none}.appointment-history-item .appointment-info{display:flex;flex-direction:column;gap:4px}.appointment-history-item .appointment-date{color:#1a202c;font-size:15px;font-weight:500}.appointment-history-item .appointment-time{color:#718096;font-size:13px}.show-more{background:#f7fafc;color:#718096;font-size:14px;font-style:italic;padding:16px 20px;text-align:center}.no-appointments{padding:40px 20px}.no-appointments p{color:#718096;font-size:16px;margin:0}.appointment-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:8px;display:flex;justify-content:space-between;padding:16px}.appointment-info{display:flex;flex-direction:column;gap:8px}.appointment-date{color:#1a202c;font-size:16px}.appointment-time{color:#4a5568;font-size:14px}.appointment-status{margin-top:4px}.status-badge{border-radius:4px;font-size:12px;font-weight:500;padding:4px 8px;text-transform:uppercase}.status-badge.booked{background:#dbeafe;color:#1e40af}.status-badge.cancelled{background:#fed7d7;color:#742a2a}.status-badge.completed{background:#c6f6d5;color:#22543d}.btn-cancel{background:#e53e3e;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .2s ease}.btn-cancel:hover{background:#c53030}.btn-cancel:disabled{background:#a0aec0;cursor:not-allowed}.no-appointments{color:#718096;font-style:italic;padding:24px;text-align:center}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:16px}.subscription-status{border-radius:4px;font-size:12px;font-weight:500;padding:4px 8px;text-transform:uppercase}.subscription-status.active{background:#c6f6d5;color:#22543d}.subscription-status.expired{background:#fed7d7;color:#742a2a}.subscription-status.none{background:#edf2f7;color:#4a5568}.subscription-status.disabled{background:#fed7d7;color:#742a2a;font-weight:600}.current-subscription{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:20px}.current-subscription h3{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 16px}.subscription-details{display:flex;flex-direction:column;gap:12px}.detail-row{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;padding:8px 0}.detail-row:last-child{border-bottom:none}.detail-label{color:#4a5568;font-size:14px;font-weight:500}.detail-value{color:#1a202c;font-size:14px}.detail-value.active{color:#22543d;font-weight:600}.detail-value.inactive{color:#742a2a;font-weight:600}.no-subscription{background:#fef5e7;border:1px solid #f6ad55;border-radius:8px;margin-bottom:24px;padding:20px;text-align:center}.no-subscription p{color:#744210;font-style:italic;margin:0}@media (max-width:768px){.header-content{align-items:center;flex-direction:column;gap:16px;text-align:center}.welcome-container{min-width:300px}.reforged-text,.welcome-text{font-size:18px}.dashboard-main{padding:20px 16px}.dashboard-nav{flex-direction:column;gap:8px}.nav-tab{padding:16px;text-align:center}.appointments-grid,.stats-grid{grid-template-columns:1fr}.section-header{gap:16px}.header-actions,.section-header{align-items:stretch;flex-direction:column}.header-actions,.search-form{width:100%}.search-input{min-width:auto;width:100%}.clients-table{font-size:12px}.clients-table td,.clients-table th{padding:8px}.action-buttons{flex-direction:column;gap:4px}.edit-button{font-size:11px;padding:4px 8px}.client-item{align-items:flex-start;flex-direction:column;gap:8px}.activity-grid{grid-template-columns:1fr}.appointment-item{align-items:flex-start;flex-direction:column;gap:12px}.appointment-info{width:100%}.appointment-history-item{align-items:flex-start;flex-direction:column;gap:12px;padding:16px}.appointment-history-item .appointment-status{align-self:flex-end}.form-row{grid-template-columns:1fr}.detail-row{align-items:flex-start;flex-direction:column;gap:4px}.subscription-details{gap:8px}.current-subscription{padding:16px}.subscriptions-table{font-size:14px}.subscriptions-table td,.subscriptions-table th{padding:8px 4px}.subscription-period{font-size:11px;padding:4px 6px}.appointment-dates{font-size:12px;max-width:150px}.active-subscriptions .section-header{align-items:stretch;flex-direction:column;gap:12px}.active-subscriptions .search-form{max-width:none}}.date-selection{background:#fff;border:1px solid #e2e8f0;border-radius:8px;margin-bottom:24px;padding:20px;text-align:center}.date-selection label{color:#4a5568;display:block;font-size:14px;font-weight:600;margin-bottom:12px}.date-selection input{border:2px solid #e2e8f0;border-radius:6px;font-size:14px;margin-bottom:12px;padding:10px 14px;transition:border-color .2s ease}.date-selection input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.selected-date-display{color:#667eea;font-size:16px;font-weight:600}.timeslots-section h4{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 16px;text-align:center}.timeslots-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}.timeslot-card{background:#fff;border:2px solid #e2e8f0;border-radius:8px;padding:16px;transition:all .2s ease}.timeslot-card:hover{border-color:#667eea;box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.timeslot-time{color:#1a202c;font-size:16px;font-weight:700;margin-bottom:12px;text-align:center}.timeslot-availability{margin-bottom:16px}.availability-text{color:#4a5568;display:block;font-size:12px;margin-bottom:6px;text-align:center}.availability-bar{background:#e2e8f0;border-radius:2px;height:4px;overflow:hidden;width:100%}.availability-fill{background:linear-gradient(135deg,#22c55e,#16a34a);height:100%;transition:width .3s ease}.book-button{background:linear-gradient(135deg,#dc2626,#000);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 16px;transition:transform .2s ease,box-shadow .2s ease;width:100%}.book-button:hover:not(:disabled){box-shadow:0 4px 8px #dc26264d;transform:translateY(-2px)}.book-button:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.no-timeslots{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:8px;padding:40px 20px;text-align:center}.no-timeslots-icon{font-size:32px;margin-bottom:12px}.no-timeslots h4{color:#1a202c;font-size:16px;font-weight:600;margin:0 0 8px}.no-timeslots p{color:#718096;font-size:14px;margin:0}.appointment-details{margin-top:4px}.booked-info{color:#718096;font-size:12px;font-style:italic}.upcoming-appointments-admin{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:32px;padding:24px}.upcoming-appointments-admin .section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.upcoming-appointments-admin .section-header h2{color:#1a202c;font-size:20px;font-weight:700;margin:0}.date-navigation{gap:12px}.date-navigation,.nav-arrow{align-items:center;display:flex}.nav-arrow{background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;color:#4a5568;cursor:pointer;font-size:16px;font-weight:600;height:40px;justify-content:center;transition:all .2s ease;width:40px}.nav-arrow:hover{background:#edf2f7;border-color:#dc2626;color:#dc2626;transform:translateY(-1px)}.date-input{background:#fff;border:2px solid #e2e8f0;border-radius:8px;font-size:14px;font-weight:500;padding:10px 14px;transition:border-color .2s ease}.date-input:focus{border-color:#dc2626;box-shadow:0 0 0 3px #dc26261a;outline:none}.loading-state{color:#718096;padding:40px 20px;text-align:center}.upcoming-timeslots{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.upcoming-timeslots .timeslot-card{background:#f8f9fa;border:2px solid #e2e8f0;border-radius:10px;padding:20px;transition:all .2s ease}.upcoming-timeslots .timeslot-card:hover{border-color:#dc2626;box-shadow:0 4px 12px #dc26261a;transform:translateY(-2px)}.upcoming-timeslots .timeslot-header{align-items:center;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.upcoming-timeslots .timeslot-header h3{color:#1a202c;font-size:16px;font-weight:700;margin:0}.upcoming-timeslots .capacity-info{background:#dbeafe;border-radius:16px;color:#1e40af;font-size:12px;font-weight:600;padding:4px 12px}.upcoming-timeslots .timeslot-appointments{display:flex;flex-direction:column;gap:8px}.upcoming-timeslots .appointments-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:1fr 1fr}.upcoming-timeslots .appointment-item{align-items:center;background:#fff;border:1px solid #e2e8f0;border-radius:3px;display:flex;justify-content:space-between;min-height:28px;padding:4px 8px;position:relative}.cancel-appointment-btn{align-items:center;background:#dc2626;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:11px;font-weight:700;height:16px;justify-content:center;margin-left:4px;transition:background-color .2s;width:16px}.cancel-appointment-btn:hover{background:#b91c1c}.cancel-appointment-btn:active{transform:scale(.95)}.appointment-item{transition:all .3s ease-out}.appointment-item.removing{margin:0;max-height:0;opacity:0;overflow:hidden;padding:0;transform:translateX(20px)}.upcoming-timeslots .appointment-item .client-name{color:#1a202c;font-weight:600}.upcoming-timeslots .appointment-item .status-badge{font-size:10px;padding:3px 8px}@media (max-width:768px){.upcoming-appointments-admin .section-header{align-items:stretch;flex-direction:column;gap:16px}.date-navigation{justify-content:center}.upcoming-timeslots .appointments-grid{grid-template-columns:1fr}.cancel-appointment-btn{font-size:16px;height:24px;width:24px}.upcoming-timeslots{grid-template-columns:1fr}.nav-arrow{font-size:14px;height:35px;width:35px}.date-input{font-size:13px;padding:8px 12px}}.skeleton{animation:skeleton-loading 1.5s infinite;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:200% 100%;border-radius:4px}.skeleton-text{height:16px;margin:4px 0}.skeleton-row{opacity:.7}.skeleton-row td{padding:12px 8px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.email-confirmation-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.email-confirmation-card{animation:slideUp .6s ease-out;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a;max-width:500px;overflow:hidden;width:100%}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.confirmation-header{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-bottom:1px solid #e2e8f0;padding:40px 40px 20px;text-align:center}.logo-section{margin-bottom:20px}.logo-image{height:auto;max-width:200px}.confirmation-header h1{color:#1a202c;font-size:28px;font-weight:700;margin:0}.confirmation-content{padding:40px;text-align:center}.loading-section{align-items:center;display:flex;flex-direction:column;gap:20px}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#dc2626;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-section h2{color:#374151;font-size:20px;font-weight:600;margin:0}.loading-section p{color:#6b7280;font-size:16px;margin:0}.success-section{flex-direction:column;gap:20px}.success-icon,.success-section{align-items:center;display:flex}.success-icon{animation:successPulse .6s ease-out;background:linear-gradient(135deg,#22c55e,#16a34a);border-radius:50%;color:#fff;font-size:30px;font-weight:700;height:60px;justify-content:center;width:60px}@keyframes successPulse{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-section h2{color:#1a202c;font-size:24px;font-weight:700;margin:0}.success-section p{color:#4b5563;font-size:16px;line-height:1.6;margin:0}.redirect-info{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;margin:10px 0;padding:16px}.redirect-info p{color:#1e40af;font-size:14px;margin:0}.error-section{flex-direction:column;gap:20px}.error-icon,.error-section{align-items:center;display:flex}.error-icon{animation:errorShake .6s ease-out;background:linear-gradient(135deg,#ef4444,#dc2626);border-radius:50%;color:#fff;font-size:30px;font-weight:700;height:60px;justify-content:center;width:60px}@keyframes errorShake{0%,to{transform:translateX(0)}25%{transform:translateX(-5px)}75%{transform:translateX(5px)}}.error-section h2{color:#1a202c;font-size:24px;font-weight:700;margin:0}.error-section p{color:#4b5563;font-size:16px;line-height:1.6;margin:0}.error-actions{display:flex;gap:12px;margin-top:10px}.login-button{background:linear-gradient(135deg,#dc2626,#000);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;min-width:160px;padding:14px 28px;transition:transform .2s ease,box-shadow .2s ease}.login-button:hover{box-shadow:0 4px 12px #dc26264d;transform:translateY(-2px)}.login-button:active{transform:translateY(0)}.resend-button{background:#6b7280;border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;min-width:160px;padding:14px 28px;transition:background-color .2s ease,transform .2s ease}.resend-button:hover{background:#4b5563;transform:translateY(-1px)}.resend-button:active{transform:translateY(0)}.confirmation-footer{background:#f8fafc;border-top:1px solid #e2e8f0;padding:20px 40px;text-align:center}.confirmation-footer p{color:#6b7280;font-size:14px;margin:0}@media (max-width:768px){.email-confirmation-container{padding:16px}.email-confirmation-card{max-width:100%}.confirmation-header{padding:30px 20px 15px}.confirmation-header h1{font-size:24px}.logo-image{max-width:180px}.confirmation-content{padding:30px 20px}.error-section h2,.success-section h2{font-size:20px}.error-section p,.success-section p{font-size:14px}.error-actions{flex-direction:column;width:100%}.login-button,.resend-button{min-width:auto;width:100%}.confirmation-footer{padding:15px 20px}}@media (max-width:480px){.error-icon,.success-icon{font-size:24px;height:50px;width:50px}.confirmation-header h1{font-size:20px}.logo-image{max-width:150px}}.App{text-align:left}*{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.f104d07a.css.map*/