.App{padding:20px;font-family:Arial,sans-serif}.loading-calendar,.loading-payment{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:16px;color:#666;background:#f9f9f9;border-radius:8px;margin:20px 0}.loading-calendar:after,.loading-payment:after{content:"";width:20px;height:20px;border:2px solid #ddd;border-top-color:#007bff;border-radius:50%;animation:loading-spin 1s linear infinite;margin-left:10px}@keyframes loading-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.demo-welcome-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:450px;width:90%;max-height:85vh;overflow-y:auto;z-index:1001;animation:modalSlideIn .3s ease-out}.demo-welcome-modal .modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;border-radius:12px 12px 0 0;text-align:center}.demo-welcome-modal .modal-header h3{margin:0;font-size:1.3em;font-weight:600}.demo-welcome-modal .modal-content{padding:24px}.demo-welcome-modal .welcome-message{text-align:center;margin-bottom:24px}.demo-welcome-modal .welcome-message p{color:#555;font-size:1.05em;line-height:1.5;margin-bottom:20px}.demo-welcome-modal .demo-highlights{background:#f8f9ff;border-radius:8px;padding:16px;margin:16px 0;text-align:left}.demo-welcome-modal .demo-highlights h4{margin:0 0 12px;color:#333;font-size:1em}.demo-welcome-modal .demo-highlights ul{margin:0;padding-left:20px;list-style-type:none}.demo-welcome-modal .demo-highlights li{margin:6px 0;color:#555;position:relative}.demo-welcome-modal .demo-highlights li:before{content:"";position:absolute;left:-16px;top:50%;transform:translateY(-50%);width:4px;height:4px;background:#667eea;border-radius:50%}.demo-welcome-modal .demo-limits{background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:12px;margin:16px 0}.demo-welcome-modal .demo-limits .limit-note{margin:0;color:#856404;font-size:.9em;text-align:center}.demo-welcome-modal .modal-actions{display:flex;gap:12px;justify-content:center;margin-top:20px}.demo-welcome-modal .btn-secondary{background:#f8f9fa;color:#6c757d;border:1px solid #dee2e6;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:.95em;transition:all .2s ease}.demo-welcome-modal .btn-secondary:hover{background:#e9ecef;border-color:#adb5bd}.demo-welcome-modal .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:.95em;font-weight:500;transition:all .2s ease}.demo-welcome-modal .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.demo-welcome-modal .privacy-note{text-align:center;margin-top:16px;padding-top:16px;border-top:1px solid #eee}.demo-welcome-modal .privacy-note small{color:#888;font-size:.85em}.recaptcha-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 20px 40px #00000026;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;z-index:1001;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.recaptcha-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 16px;border-bottom:2px solid #f0f0f0}.recaptcha-modal .modal-header h3{margin:0;color:#333;font-size:1.3em}.recaptcha-modal .modal-content{padding:24px}.verification-explanation{margin-bottom:20px}.verification-explanation h4{color:#333;margin:0 0 12px;font-size:1.1em}.verification-explanation p{color:#666;line-height:1.5;margin:0 0 16px}.demo-benefits{background:#f8f9ff;padding:16px;border-radius:8px;margin:16px 0;border-left:4px solid #007bff}.demo-benefits h5{margin:0 0 10px;color:#333;font-size:1em}.demo-benefits ul{margin:0;padding-left:20px}.demo-benefits li{color:#555;margin:6px 0;line-height:1.4}.demo-limits{background:#fff8e1;padding:12px 16px;border-radius:6px;border-left:4px solid #ffa726;margin:16px 0}.limit-note{margin:0;color:#7a5c00;font-size:.95em}.error-message{background:#ffebee;border:1px solid #ffcdd2;border-radius:6px;padding:12px;margin:16px 0;gap:8px;color:#c62828}.error-banner,.error-message{display:flex;align-items:center}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;margin-bottom:16px;gap:10px;color:#dc2626;animation:errorSlideIn .3s ease-out}@keyframes errorSlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.error-banner .error-icon{font-size:18px;flex-shrink:0}.error-banner .error-text{flex:1 1;font-size:14px;line-height:1.4}.error-banner .error-dismiss{background:none;border:none;color:#dc2626;font-size:20px;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease;flex-shrink:0}.error-banner .error-dismiss:hover{background-color:#dc26261a}.verification-input.has-error,input.has-error{border-color:#dc2626!important;background-color:#fef2f2}.error-icon{font-size:1.2em}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin:24px 0 16px}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px;min-width:120px;justify-content:center}.btn-primary{background:var(--primary-color,#007bff);border:1px solid var(--primary-color,#007bff)}.btn-primary:hover:not(:disabled){background:var(--primary-color-hover,#0056b3);border-color:var(--primary-color-hover,#0056b3)}.btn-primary:disabled{background:#ccc;border-color:#ccc;cursor:not-allowed}.btn-secondary{background:#fff;color:#666;border:1px solid #ddd}.btn-secondary:hover:not(:disabled){background:#f8f9fa;border-color:#bbb}.spinner-small{width:16px;height:16px;border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.privacy-note{text-align:center;color:#888;border-top:1px solid #f0f0f0;padding-top:16px;margin-top:16px}.privacy-note small{line-height:1.4}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:20px;border-bottom:2px solid #e0e0e0;position:relative}.header-title-section{display:flex;flex-direction:row;align-items:center;gap:16px;flex:1 1}.header-title-content{display:flex;flex-direction:column;align-items:center;flex:1 1}.demo-status-indicator{margin-top:8px;padding:6px 12px;border-radius:20px;font-size:.85em;font-weight:500;transition:all .3s ease}.demo-status-indicator.readonly{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border:1px solid #d1ecf1;color:#856404}.demo-status-indicator.interactive{background:linear-gradient(135deg,#d1edff,#a7f3d0);border:1px solid #28a745;color:#155724}.demo-status-text{display:flex;align-items:center;gap:4px}.calendar-container.demo-readonly{position:relative}.calendar-container.demo-readonly .rbc-calendar{opacity:1}.calendar-container.demo-readonly .rbc-day-slot,.calendar-container.demo-readonly .rbc-month-view,.calendar-container.demo-readonly .rbc-time-slot,.calendar-container.demo-readonly .rbc-time-view{cursor:help}.calendar-container.demo-readonly .rbc-event{cursor:help;box-shadow:0 2px 4px #0000001a}.calendar-container.demo-readonly .rbc-event:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.calendar-container.demo-interactive .rbc-calendar{opacity:1!important;transition:none!important}.calendar-container.demo-interactive .rbc-month-view,.calendar-container.demo-interactive .rbc-time-view{cursor:default!important}.calendar-container.demo-interactive .rbc-day-slot,.calendar-container.demo-interactive .rbc-event,.calendar-container.demo-interactive .rbc-time-slot{cursor:pointer!important}.calendar-container{transition-property:transform,box-shadow!important;transition-duration:.3s!important}.grecaptcha-badge{visibility:hidden!important;opacity:0!important;pointer-events:none!important}#__next,#root,.App,body>div:first-child{transform:none!important;position:relative!important;z-index:1!important}#__next,#root,.App,.calendar-container,.calendar-container *,.rbc-calendar,body>div:first-child{opacity:1!important;filter:none!important}.demo-action-counter{position:fixed;bottom:20px;right:20px;background:#007bffe6;color:#fff;padding:8px 12px;border-radius:20px;font-size:.8em;font-weight:500;z-index:1000;animation:slideInFromBottom .3s ease-out}@keyframes slideInFromBottom{0%{transform:translateY(100px);opacity:0}to{transform:translateY(0);opacity:1}}.header-controls{display:flex;gap:20px;align-items:center}.header h1{color:var(--primary-color,#333);margin:0}.header-logo{border-radius:4px;flex-shrink:0;max-height:72px;width:auto;object-fit:contain}.view-buttons{display:flex;gap:10px;position:absolute;right:0}.view-buttons button{padding:8px 16px;border:2px solid var(--primary-color,#007bff);background-color:#fff;color:var(--primary-color,#007bff);border-radius:5px;cursor:pointer;transition:all .3s ease}.view-buttons button.active,.view-buttons button:hover{background-color:var(--primary-color,#007bff);color:#fff}.calendar-container{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 10px #0000001a}.calendar-empty-state{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;text-align:center;padding:40px;background:#fffffff2;border-radius:12px;box-shadow:0 4px 20px #0000001a;max-width:320px}.empty-state-content{display:flex;flex-direction:column;align-items:center;gap:12px}.empty-state-icon{font-size:48px;line-height:1}.calendar-empty-state h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.calendar-empty-state p{margin:0;font-size:14px;color:#6b7280}.copy-link-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;color:#fff;background-color:#4f46e5;border:none;border-radius:8px;cursor:pointer;transition:background-color .2s,transform .1s;margin-top:8px}.copy-link-btn:hover{background-color:#4338ca;transform:translateY(-1px)}.copy-link-btn:active{transform:translateY(0)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:auto}.modal-overlay:empty,.modal-overlay:not(:has(*)){display:none!important;pointer-events:none!important}.modal{background:#fff;border-radius:8px;padding:30px;max-width:400px;width:90%;max-height:90vh;overflow-y:auto;overflow-x:hidden;box-shadow:0 4px 20px #0000004d;box-sizing:border-box}.modal-content{max-width:100%;overflow:hidden}.modal.payment-modal{max-height:95vh}.modal h2{margin-top:0;color:#333;text-align:center}.form-group label{margin-bottom:5px;font-weight:700;color:#555}.returning-user-welcome{background:linear-gradient(135deg,#e0f2fe,#dbeafe);border:1px solid #93c5fd;border-radius:8px;padding:12px 16px;margin-bottom:16px;font-size:15px;color:#1e40af;text-align:center;animation:fadeIn .3s ease}.offline-indicator{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fca5a5;border-radius:8px;color:#991b1b}.offline-indicator,.reconnected-indicator{padding:12px 16px;margin-bottom:16px;font-size:14px;text-align:center;animation:fadeIn .3s ease}.reconnected-indicator{background:linear-gradient(135deg,#ecfdf5,#d1fae5);border:1px solid #6ee7b7;border-radius:8px;color:#065f46}.form-group input{padding:10px;border:2px solid #ddd;border-radius:5px}.form-group input:focus{border-color:#007bff}.modal-buttons{display:flex;gap:10px;justify-content:center;margin-top:20px}.book-btn,.pay-btn,.save-btn,.verify-btn{background-color:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:5px;cursor:pointer;font-size:16px;transition:background-color .3s ease}.book-btn:hover,.pay-btn:hover,.save-btn:hover,.verify-btn:hover{background-color:#218838}.delete-btn{background-color:#dc3545;color:#fff;border:none;padding:12px 24px;border-radius:5px;cursor:pointer;font-size:16px;transition:background-color .3s ease}.delete-btn:hover{background-color:#c82333}.cancel-btn{background-color:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:5px;cursor:pointer;font-size:16px;transition:background-color .3s ease}.cancel-btn:hover{background-color:#5a6268}.cancel-btn:disabled,.pay-btn:disabled{opacity:.6;cursor:not-allowed}.payment-modal{max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.payment-modal h2{margin:0 0 16px;font-size:20px;flex-shrink:0}.payment-modal p{margin:0 0 8px;font-size:14px;flex-shrink:0}.payment-form{margin-top:20px;flex:1 1;display:flex;flex-direction:column;justify-content:space-between;min-height:0;overflow-y:auto}.payment-amount{text-align:center;font-size:18px;margin-bottom:20px;padding:15px;background-color:#f8f9fa;border-radius:5px}.card-element-container{padding:15px;border:2px solid #ddd;border-radius:5px;margin-bottom:20px;background-color:#fff}.payment-buttons{display:flex;gap:10px;justify-content:center}.error-message{color:#dc3545;text-align:center;margin-bottom:15px;padding:10px;background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:5px}.conflict-alternatives{background:#f0f9ff;border:1px solid #bae6fd;border-radius:8px;padding:12px;margin-top:12px}.alternatives-header{font-size:13px;color:#0369a1;margin:0 0 8px;font-weight:500}.alternatives-list{display:flex;flex-wrap:wrap;gap:8px}.alternative-slot{background:#fff;border:1px solid #0ea5e9;border-radius:6px;padding:8px 16px;font-size:14px;color:#0369a1;cursor:pointer;transition:all .2s ease;font-weight:500}.alternative-slot:hover{background:#0ea5e9;color:#fff;transform:translateY(-1px)}.alternative-slot:focus{outline:2px solid #0369a1;outline-offset:2px}.payment-success{display:block!important;text-align:center;padding:20px 16px;background-color:#d4edda;border:2px solid #28a745;border-radius:10px;margin:12px 0;flex-shrink:0;max-height:-webkit-fit-content;max-height:-moz-fit-content;max-height:fit-content;overflow:hidden}.success-message,.success-message h3,.success-message p{display:block!important;width:100%!important;clear:both!important}.success-icon,.success-message h3,.success-message p{float:none!important}.success-icon{display:block!important;font-size:48px;margin-bottom:15px;animation:bounce .6s ease-in-out;clear:both!important}.success-message h3{color:#155724;margin:0 0 10px;font-size:20px;font-weight:700}.success-message p{color:#155724;margin:0;font-size:16px}.edit-success{text-align:center;padding:30px 20px;background-color:#d4edda;border:2px solid #28a745;border-radius:10px;margin:16px 0;flex-shrink:0;max-height:-webkit-fit-content;max-height:-moz-fit-content;max-height:fit-content;overflow:hidden}.edit-success .success-icon{font-size:64px;margin-bottom:20px;animation:bounce .6s ease-in-out}.edit-success .success-message h3{color:#155724;margin:0;font-size:24px;font-weight:700}.form-group input.invalid{border:2px solid #dc3545!important;box-shadow:0 0 0 .2rem #dc354540}.field-error{color:#dc3545;font-size:12px;margin-top:5px;font-weight:500}.form-group input.valid{border:2px solid #22c55e!important;box-shadow:0 0 0 .2rem #22c55e26}.field-success{color:#22c55e;font-size:14px;margin-top:5px;font-weight:600;position:absolute;right:12px;top:50%;transform:translateY(-50%)}.form-group{position:relative}.payment-note{text-align:center;margin-top:15px;color:#6c757d;flex-shrink:0;font-size:12px}.rbc-calendar{font-family:Arial,sans-serif}.rbc-event{background-color:#007bff;border-radius:3px}.break-event,.break-event.blocked-event,.rbc-event.break-event,.rbc-event.break-event.blocked-event{background-color:#a19424!important;border:1px solid #8b7b1f!important;color:#fff!important;opacity:.8;cursor:not-allowed!important}.break-event:hover,.rbc-event.break-event:hover{opacity:.9;transform:none!important}.blocked-event,.rbc-event.blocked-event{background-color:#dc2626!important;border-color:#b91c1c!important;color:#fff!important;cursor:pointer!important}.appointment-event,.rbc-event.appointment-event{cursor:pointer}.appointment-event.paid,.rbc-event.appointment-event.paid{background-color:#51cf66!important;border-color:#37b24d!important}.appointment-event:not(.paid),.rbc-event.appointment-event:not(.paid){background-color:#2563eb!important;border-color:#1d4ed8!important}.appointment-event.pending,.rbc-event.appointment-event.pending{background-color:#93c5fd!important;border-color:#60a5fa!important;opacity:.8;animation:pendingPulse 1.5s ease-in-out infinite}@keyframes pendingPulse{0%,to{opacity:.7}50%{opacity:1}}@keyframes justBookedFadeIn{0%{opacity:0;transform:scaleY(.3)}to{opacity:1;transform:scaleY(1)}}@keyframes justBookedBadgeFade{0%{opacity:1}70%{opacity:1}to{opacity:0}}.appointment-event.just-booked,.rbc-event.appointment-event.just-booked{animation:justBookedFadeIn .5s ease-out;position:relative}.appointment-event.just-booked:after{content:"Just booked";position:absolute;top:2px;right:4px;font-size:9px;font-weight:600;color:#fff;background:#00000059;padding:1px 5px;border-radius:3px;letter-spacing:.3px;animation:justBookedBadgeFade 8s ease-out forwards;pointer-events:none}.google-calendar-event,.rbc-event.google-calendar-event{background-color:#2563eb!important;border-color:#1d4ed8!important;color:#fff!important;cursor:not-allowed!important}.google-calendar-event:hover,.rbc-event.google-calendar-event:hover{cursor:not-allowed!important}.rbc-time-slot.unavailable-slot,.unavailable-slot{background:repeating-linear-gradient(-45deg,#f8f9fa,#f8f9fa 8px,#e9ecef 0,#e9ecef 16px)!important;opacity:.6!important;cursor:not-allowed!important;pointer-events:none!important}.rbc-time-slot.unavailable-slot:hover,.unavailable-slot:hover{background:repeating-linear-gradient(-45deg,#f8f9fa,#f8f9fa 8px,#e9ecef 0,#e9ecef 16px)!important;opacity:.7!important}.rbc-selected{background-color:#28a745}.rbc-today{background-color:#fff3cd}.rbc-header{font-size:18px!important;font-weight:600!important;padding:12px 8px!important;text-align:center!important;vertical-align:middle!important;color:#333;background-color:#f8f9fa;border-bottom:2px solid #dee2e6;display:flex!important;align-items:center!important;justify-content:center!important;min-height:50px!important}.rbc-month-view .rbc-header{font-size:16px!important;font-weight:500!important;padding:10px 8px!important;min-height:45px!important}.rbc-time-header .rbc-header{font-size:16px!important;font-weight:500!important;min-height:40px!important}.rbc-today .rbc-header{background-color:#fff3cd!important;font-weight:700!important;color:#856404!important}.rbc-header a,.rbc-header span{font-size:inherit!important;font-weight:inherit!important;color:inherit!important;text-decoration:none!important}.rbc-calendar .rbc-header,.rbc-calendar .rbc-header a,.rbc-calendar .rbc-header span{font-size:18px!important;line-height:1.2!important}.rbc-month-view .rbc-header,.rbc-month-view .rbc-header a,.rbc-month-view .rbc-header span{font-size:16px!important;line-height:1.2!important}.rbc-toolbar{display:flex!important;flex-wrap:nowrap!important;align-items:center!important;justify-content:space-between!important;margin-bottom:10px!important;padding:8px 0!important}.rbc-toolbar .rbc-btn-group{flex-shrink:0!important;white-space:nowrap!important}.rbc-btn-group button,.rbc-toolbar button{font-size:14px!important;font-weight:500!important;padding:6px 12px!important;border-radius:5px!important;margin:0 3px!important;min-width:60px!important;height:34px!important;border:1px solid #007bff!important;background-color:#fff!important;color:#007bff!important;transition:all .2s ease!important}.rbc-active,.rbc-toolbar button.rbc-active{background-color:#007bff!important;color:#fff!important;font-weight:600!important}.rbc-btn-group button:hover,.rbc-toolbar button:hover{background-color:#007bff!important;color:#fff!important;transform:translateY(-1px)!important;box-shadow:0 2px 8px #007bff4d!important}.rbc-toolbar .rbc-btn-group:first-child button{background-color:#28a745!important;border-color:#28a745!important;color:#fff!important;font-weight:600!important}.rbc-toolbar .rbc-btn-group:first-child button:hover{background-color:#218838!important;border-color:#1e7e34!important}.rbc-toolbar-label{font-size:18px!important;font-weight:600!important;color:#333!important;text-align:center!important;flex:1 1 auto!important;min-width:0!important;margin:0 8px!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.rbc-allday-cell{padding:0!important;border-bottom:none!important}.rbc-allday-cell,.rbc-row-content{height:10px!important;min-height:10px!important}.rbc-month-view .rbc-row.rbc-row-content:empty{display:none!important}.rbc-time-header .rbc-row{min-height:auto!important}.rbc-time-header .rbc-row:last-child{min-height:10px!important;height:10px!important}.rbc-time-header{border-bottom:1px solid #ddd!important}.rbc-time-gutter,.rbc-time-header-gutter{min-width:60px!important;max-width:60px!important;width:60px!important}.rbc-time-header .rbc-allday-cell{height:8px!important;min-height:8px!important;padding:0!important;background-color:initial!important}.rbc-time-view .rbc-allday-cell{height:8px!important;min-height:8px!important;max-height:8px!important;padding:0!important;border:none!important}.rbc-month-view .rbc-month-header{border-bottom:1px solid #ddd!important}@media (max-width:768px){.rbc-btn-group button,.rbc-toolbar button{font-size:12px!important;padding:4px 8px!important;min-width:0!important;height:32px!important;margin:0 1px!important}.rbc-allday-cell{height:5px!important;min-height:5px!important}}.edit-modal{max-width:500px}.delete-modal{max-width:400px}.appointment-details{background-color:#f8f9fa;padding:12px 15px;border-radius:5px;margin:12px 0}.appointment-details p{margin:4px 0;font-size:14px}.timezone-difference{background:#fef3c7;border-radius:4px;padding:6px 10px!important;margin-top:8px!important;font-size:13px!important;color:#92400e;display:flex;align-items:center;gap:6px}.timezone-difference .tz-icon{font-size:14px}.timezone-difference .tz-label{font-weight:600}.rbc-event:hover{cursor:pointer;opacity:.8}@media (max-width:768px){.App{padding:10px}.header{flex-direction:column!important;gap:8px!important;margin-bottom:8px;padding-bottom:8px;align-items:stretch!important}.header h1{font-size:1.2em;text-align:center}.header-title-section{gap:8px;justify-content:center}.header-title-content{align-items:center}.header-logo{max-height:40px;max-width:min(50vw,200px)}.demo-status-indicator{margin-top:4px;padding:3px 8px;font-size:.7em}.view-buttons{position:static!important;flex-wrap:wrap!important;justify-content:center!important;width:100%!important;gap:6px}.view-buttons a,.view-buttons button,.view-buttons span{padding:6px 10px!important;font-size:12px!important;height:34px!important;min-width:auto!important}.modal{padding:20px;margin:20px}.calendar-container{padding:10px}.modal-buttons,.payment-buttons{flex-direction:column}.payment-modal{max-height:95vh;padding:16px}.payment-modal h2{font-size:18px;margin:0 0 12px}.payment-modal p{font-size:13px;margin:0 0 6px}.payment-success{padding:16px 12px;margin:8px 0}.success-icon{font-size:36px;margin-bottom:10px}.success-message h3{font-size:16px;margin:0 0 8px}.success-message p{font-size:14px;margin:0}.edit-success{padding:24px 16px;margin:12px 0}.edit-success .success-icon{font-size:48px;margin-bottom:15px}.edit-success .success-message h3{font-size:18px}}.owner-actions,.owner-controls{display:flex;align-items:center}.owner-actions{gap:10px}.account-info-btn,.analytics-btn,.my-appointments-btn,.owner-login-btn,.owner-logout-btn,.registration-btn,.settings-btn{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:16px!important;font-weight:500;transition:all .3s ease;height:44px;min-width:120px;display:flex;align-items:center;justify-content:center}.owner-login-btn{background-color:var(--primary-color,#007bff);color:#fff;border:2px solid var(--primary-color,#007bff)}.owner-login-btn:hover{background-color:var(--primary-color-hover,#0056b3);border-color:var(--primary-color-hover,#0056b3);transform:translateY(-1px);box-shadow:0 2px 8px rgba(var(--primary-color-rgb,0,123,255),.3)}.registration-btn{background:linear-gradient(135deg,#667eea,#764ba2)!important;color:#fff!important;border:none!important;padding:10px 20px!important;border-radius:6px!important;font-weight:600!important;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 10px #667eea4d!important}.registration-btn:hover{color:#fff!important;transform:translateY(-1px);box-shadow:0 4px 15px #667eea66!important}.settings-btn{background-color:#f59e0b;color:#fff}.settings-btn:hover{background-color:#d97706}.account-info-btn{background-color:#8b5cf6;color:#fff}.account-info-btn:hover{background-color:#7c3aed}.show-as-filled-btn{background-color:#f59e0b;color:#fff;border:2px solid #f59e0b;font-size:16px!important;font-weight:500;padding:10px 16px;border-radius:6px;height:44px;min-width:120px;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.show-as-filled-btn:hover{background-color:#d97706;border-color:#d97706;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b4d}.show-as-filled-btn.active{background-color:#dc2626;border-color:#dc2626;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.show-as-filled-btn.disabled{color:#6b7280!important;cursor:not-allowed!important;opacity:.6;animation:none!important}.show-as-filled-btn.disabled,.show-as-filled-btn.disabled:hover{background-color:#9ca3af!important;border-color:#9ca3af!important}.show-as-filled-btn.disabled:hover{transform:none!important;box-shadow:none!important}.analytics-btn{background-color:#28a745;color:#fff;border:2px solid #28a745}.analytics-btn:hover{background-color:#1e7e34;border-color:#1e7e34;transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.integration-btn{background-color:#667eea;color:#fff;border:2px solid #667eea}.integration-btn:hover{background-color:#5a6fd8;border-color:#5a6fd8;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.integration-link-btn{background-color:#667eea;color:#fff;border:2px solid #667eea;width:44px!important;min-width:44px!important;padding:8px!important;font-size:18px!important;border-radius:50%!important}.integration-link-btn:hover{background-color:#5a6fd8;border-color:#5a6fd8;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.my-appointments-btn{background-color:#6366f1;color:#fff;border:2px solid #6366f1;text-decoration:none}.my-appointments-btn:hover{background-color:#4f46e5;border-color:#4f46e5;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #6366f14d;text-decoration:none}.my-appointments-btn.disabled{background-color:#9ca3af;border-color:#9ca3af;color:#e5e7eb;cursor:not-allowed;pointer-events:auto}.my-appointments-btn.disabled:hover{background-color:#9ca3af;border-color:#9ca3af;transform:none;box-shadow:none}.help-btn{background-color:#17a2b8;color:#fff;border:2px solid #17a2b8;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:16px!important;font-weight:500;transition:all .3s ease;height:44px;display:flex;align-items:center;justify-content:center;white-space:nowrap}.help-btn:hover{background-color:#138496;border-color:#138496;transform:translateY(-1px);box-shadow:0 2px 8px #17a2b84d}.help-question-mark{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border:2px solid #fff;border-radius:50%;margin-left:6px;font-weight:700;font-size:14px;background-color:#ffffff26;transition:all .2s ease}.help-btn:hover .help-question-mark{background-color:#ffffff40;transform:scale(1.1)}.owner-logout-btn{background-color:#dc3545;color:#fff}.owner-logout-btn:hover{background-color:#c82333}.owner-login-modal{max-width:400px}.owner-login{padding:20px}.owner-login h2{text-align:center;margin-bottom:20px;color:#333}.owner-login .form-group{margin-bottom:15px}.owner-login label{display:block;margin-bottom:5px;font-weight:500;color:#555}.owner-login input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.owner-login input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.login-buttons{display:flex;gap:10px;margin-top:20px}.login-btn{flex:1 1;padding:10px;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.login-btn:hover:not(:disabled){background-color:#0056b3}.login-btn:disabled{background-color:#6c757d;cursor:not-allowed}.owner-login .cancel-btn{flex:1 1;padding:10px;background-color:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.owner-login .cancel-btn:hover:not(:disabled){background-color:#545b62}.demo-credentials-note{display:flex;align-items:flex-start;gap:10px;padding:12px;background-color:#e8f4fd;border:1px solid #b8daff;border-radius:6px;margin-bottom:20px}.demo-note-icon{font-size:18px;margin-top:2px;flex-shrink:0}.demo-note-content{font-size:14px;line-height:1.4;color:#0c5460}.demo-note-content code{background-color:#d1ecf1;padding:2px 4px;border-radius:3px;font-family:Courier New,monospace;font-size:13px;color:#0c5460}.analytics-modal{max-width:95vw;width:1200px;max-height:95vh;padding:0;border-radius:12px;overflow:hidden}.tenant-registration-modal{max-width:700px;width:95%;max-height:85vh;padding:0;border-radius:8px;overflow-y:auto;display:flex;flex-direction:column;border:none;outline:none}.tenant-registration-modal .registration-container{display:flex;flex-direction:column;min-height:auto}.tenant-registration .btn-primary{z-index:1000;position:relative;pointer-events:auto!important;background-color:#4f46e5!important;color:#fff!important;border-color:#4f46e5!important}.tenant-registration .btn-primary:hover:not(:disabled){background-color:#4338ca!important;border-color:#4338ca!important;color:#fff!important}.tenant-registration .btn-primary:disabled{background-color:#9ca3af!important;border-color:#9ca3af!important;color:#fff!important}.registration-success-modal{max-width:500px;width:90%;padding:0;border-radius:12px;overflow:hidden}.tenant-settings-modal{max-width:800px}.account-info-modal,.tenant-settings-modal{width:95%;max-height:90vh;padding:0;border-radius:12px;overflow:hidden}.account-info-modal{max-width:700px}.registration-success{text-align:center;padding:40px}.registration-success .success-icon{font-size:64px;margin-bottom:20px;animation:bounce .6s ease-in-out}@keyframes bounce{0%,60%,to{transform:translateY(0)}30%{transform:translateY(-10px)}}.registration-success h2{color:#1a202c;font-size:28px;font-weight:600;margin:0 0 24px}.registration-success .success-message{margin-bottom:32px}.registration-success .success-message p{color:#4a5568;font-size:16px;line-height:1.6;margin:0 0 16px}.registration-success .tenant-details{background:#f7fafc;border-radius:8px;padding:20px;margin:20px 0;text-align:left}.registration-success .tenant-details p{margin:8px 0;color:#2d3748}.registration-success .calendar-url{background:#4f46e5;color:#fff;padding:12px 16px;border-radius:6px;font-family:Monaco,Menlo,Ubuntu Mono,monospace;font-size:14px;font-weight:500;margin:8px 0 16px;word-break:break-all}.registration-success .next-steps{color:#10b981!important;font-weight:500;font-size:16px}.registration-success .modal-buttons{display:flex;justify-content:center}.registration-success .btn-primary{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 32px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #10b9814d}.registration-success .btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #10b98166}.analytics-dashboard{height:95vh;overflow-y:auto;padding:20px;background:#f8fafc}.analytics-header{border-bottom:2px solid #e2e8f0;background:#fff;padding:20px;margin:-20px -20px 24px;border-radius:12px 12px 0 0}.admin-top-row{margin-bottom:16px}.admin-controls,.admin-top-row{display:flex;justify-content:flex-end;align-items:center}.admin-controls{gap:12px}.analytics-subheader{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;margin-top:16px}.analytics-subheader h3{margin:0;color:#374151;font-size:18px;font-weight:600;text-align:center;grid-column:2}.date-range-controls{display:flex;align-items:center;gap:12px;grid-column:3;justify-self:end}.date-range-controls label{font-weight:500;color:#475569;font-size:14px}.analytics-header h2{margin:0;color:#1e293b;font-size:24px;font-weight:700}.analytics-controls{display:flex;align-items:center;gap:12px}.date-range-select{padding:8px 12px;border:1px solid #cbd5e1;border-radius:6px;background:#fff;font-size:14px;color:#475569}.close-btn{background:#ef4444;color:#fff;border:none;border-radius:50%;width:32px;height:32px;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.close-btn:hover{background:#dc2626}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;gap:20px;margin-bottom:32px}.metric-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;display:flex;align-items:center;gap:16px;transition:transform .2s,box-shadow .2s}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.metric-icon{font-size:32px;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:#f1f5f9;border-radius:12px}.metric-content h3{margin:0 0 8px;font-size:14px;font-weight:500;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:28px;font-weight:700;color:#1e293b;margin-bottom:4px}.metric-trend{font-size:12px;font-weight:500}.metric-trend.positive{color:#059669}.metric-trend.negative{color:#dc2626}.metric-trend.neutral{color:#6b7280}.analytics-skeleton{animation:fadeIn .3s ease}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:200px 0}}.skeleton-subheader{margin-bottom:24px}.skeleton-text{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:400px 100%;animation:shimmer 1.5s infinite;border-radius:4px}.skeleton-text.skeleton-title{width:180px;height:24px}.skeleton-text.skeleton-label{width:100px;height:14px;margin-bottom:8px}.skeleton-text.skeleton-value{width:80px;height:28px;margin-bottom:4px}.skeleton-text.skeleton-trend{width:60px;height:12px}.skeleton-text.skeleton-chart-title{width:150px;height:18px;margin-bottom:20px}.metric-card.skeleton{pointer-events:none}.metric-card.skeleton:hover{transform:none;box-shadow:0 1px 3px #0000001a}.skeleton-icon{width:60px;height:60px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:400px 100%;animation:shimmer 1.5s infinite;border-radius:12px;flex-shrink:0}.skeleton-content{flex:1 1}.chart-card.skeleton{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;height:400px;display:flex;flex-direction:column}.skeleton-chart{flex:1 1;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0 50%,#f0f0f0 75%);background-size:400px 100%;animation:shimmer 1.5s infinite;border-radius:8px}.charts-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:24px;gap:24px;margin-bottom:32px}.chart-container{box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0;height:400px;display:flex;flex-direction:column}.chart-container.full-width{grid-column:1/-1}.chart-container h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#1e293b;flex-shrink:0}.chart-subtitle{display:block;font-size:13px;font-weight:400;color:#64748b;margin-top:2px}.chart-container>div:last-child{flex:1 1;position:relative}.no-data{display:flex;align-items:center;justify-content:center;height:200px;color:#6b7280;font-style:italic;background:#f8fafc;border-radius:8px;border:2px dashed #d1d5db}.payment-breakdown{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a;border:1px solid #e2e8f0}.payment-breakdown h3{margin:0 0 20px;font-size:18px;font-weight:600;color:#1e293b}.payment-status-grid{display:grid;grid-gap:12px;gap:12px}.payment-status-item{display:grid;grid-template-columns:1fr auto auto;grid-gap:16px;gap:16px;padding:12px 16px;background:#f8fafc;border-radius:8px;align-items:center}.status-name{font-weight:500;color:#374151}.status-count{font-size:14px;color:#6b7280}.status-revenue{font-weight:600;color:#059669}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;height:400px;gap:16px}.spinner{width:40px;height:40px;border:4px solid #e2e8f0;border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite}.retry-btn{background:#3b82f6;font-size:14px;margin-top:12px}.retry-btn:hover{background:#2563eb}@media (max-width:1024px){.analytics-modal{width:95vw;max-width:none}.charts-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (max-width:768px){.analytics-dashboard{padding:12px}.analytics-header{flex-direction:column;gap:12px;align-items:stretch;padding:16px;margin:-12px -12px 20px}.analytics-controls{justify-content:space-between}.metrics-grid{grid-template-columns:1fr;gap:16px}.chart-container,.metric-card{padding:16px}.payment-status-item{grid-template-columns:1fr;gap:8px;text-align:center}}.available-slot{background-color:#e8f5e8!important;border-color:#d4e9d4!important;cursor:pointer!important;transition:background-color .2s ease}.available-slot:hover{background-color:#d4edda!important;border-color:#c3e6c3!important}.unavailable-slot{background-color:#fafafa!important;border-color:#f0f0f0!important;cursor:not-allowed!important;opacity:.6;position:relative}.unavailable-slot:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,#0000,#0000 2px,#c8c8c84d 0,#c8c8c84d 4px);pointer-events:none}.selected-for-blocking{background-color:#fff3cd!important;border-color:#ffc107!important;cursor:pointer!important;position:relative;animation:pulse-selected 1.5s ease-in-out infinite}@keyframes pulse-selected{0%,to{background-color:#fff3cd!important}50%{background-color:#ffe69c!important}}.selected-for-blocking:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:12px;color:#856404;font-weight:700;pointer-events:none}.rbc-time-slot{border-top:1px solid #e8e8e8}.rbc-timeslot-group{border-bottom:1px solid #e8e8e8}.rbc-time-gutter .rbc-timeslot-group,.rbc-timeslot-group{height:60px!important;min-height:60px!important}.rbc-time-gutter .rbc-timeslot-group{position:relative;overflow:visible!important}.rbc-time-gutter .rbc-timeslot-group .rbc-time-slot{border:none;overflow:visible!important}.rbc-time-gutter .rbc-timeslot-group .rbc-time-slot:first-child{display:flex;align-items:center;height:60px!important;margin-top:0}.rbc-label{font-size:13px!important;color:#000!important;font-weight:700!important;white-space:nowrap;padding-right:8px}@media (max-width:768px){.rbc-label{font-size:12px!important}}.rbc-btn-group button,.rbc-toolbar button{touch-action:manipulation;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:rgba(0,0,0,.1)}.rbc-time-slot{height:15px!important;min-height:15px!important;cursor:pointer;transition:background-color .2s ease}.btn-primary,.btn-secondary,.quick-book-slot,.rbc-time-slot,a,button,input[type=button],input[type=submit]{touch-action:manipulation}.rbc-month-view,.rbc-time-content{touch-action:pan-x pan-y pinch-zoom}.modal-overlay{touch-action:none}.modal-content,.unified-booking-modal{touch-action:pan-y;-webkit-overflow-scrolling:touch}.rbc-time-slot:active,.rbc-time-slot:hover{background-color:#007bff1a!important}.rbc-event{min-height:36px!important;touch-action:manipulation;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.rbc-event:active{transform:scale(.98);box-shadow:0 2px 8px #0003}.rbc-calendar{max-width:100%!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch}.calendar-container{max-width:100%!important;overflow-x:hidden!important}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{display:table-cell!important}@media (max-width:768px){.rbc-toolbar{flex-direction:row!important;flex-wrap:nowrap!important;gap:2px!important;padding:6px 4px!important;align-items:center!important;justify-content:space-between!important}.rbc-toolbar-label{font-size:12px!important;margin:0 2px!important;flex:1 1 auto!important;min-width:0!important;overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.rbc-toolbar .rbc-btn-group:first-child,.rbc-toolbar .rbc-btn-group:last-child{display:flex!important;flex-shrink:0!important}.rbc-btn-group button,.rbc-toolbar button{min-height:32px!important;min-width:0!important;font-size:12px!important;padding:4px 8px!important;margin:1px!important}.rbc-agenda-view table.rbc-agenda-table{table-layout:fixed!important;width:100%!important}.rbc-agenda-view table.rbc-agenda-table thead>tr>th{display:table-cell!important;padding:4px!important;font-size:11px!important;white-space:nowrap!important}.rbc-agenda-view table.rbc-agenda-table tbody>tr>td{padding:4px!important;font-size:12px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.rbc-agenda-date-cell,.rbc-agenda-view table.rbc-agenda-table thead>tr>th:first-child{width:25%!important}.rbc-agenda-time-cell,.rbc-agenda-view table.rbc-agenda-table thead>tr>th:nth-child(2){width:35%!important;padding-left:4px!important;padding-right:4px!important}.rbc-agenda-event-cell,.rbc-agenda-view table.rbc-agenda-table thead>tr>th:nth-child(3){width:40%!important}.rbc-agenda-view table.rbc-agenda-table thead>tr{display:table-row!important;white-space:nowrap!important}.rbc-time-slot{height:44px!important;min-height:44px!important}.rbc-time-gutter .rbc-timeslot-group,.rbc-timeslot-group{height:88px!important;min-height:88px!important}.rbc-time-gutter .rbc-timeslot-group .rbc-time-slot:first-child{height:88px!important}.rbc-calendar,.rbc-event{font-size:12px!important}.rbc-event{min-height:32px!important;padding:4px 6px!important}.rbc-time-view .rbc-time-gutter{width:60px!important}.rbc-header{font-size:11px!important;padding:4px 2px!important}.rbc-month-view .rbc-date-cell{min-height:60px!important}.rbc-month-view .rbc-date-cell>a{padding:8px!important;font-size:16px!important}}@media (min-width:769px) and (max-width:1024px){.rbc-toolbar{flex-wrap:nowrap!important;justify-content:space-between!important;align-items:center!important}.rbc-btn-group button,.rbc-toolbar button{min-height:34px!important;min-width:0!important;font-size:13px!important;padding:5px 10px!important}.rbc-time-slot{height:15px!important;min-height:15px!important}.rbc-event{min-height:38px!important;font-size:15px!important}.modal,.react-modal-content{max-width:90vw!important}.analytics-modal{max-width:95vw!important}.tenant-settings{padding:16px 20px}}.rbc-btn-group button:active,.rbc-toolbar button:active{transform:scale(.95);background-color:#0056b3!important}@media (max-width:768px){.modal-overlay,.react-modal-overlay{background-color:#0009!important;align-items:flex-end!important;justify-content:center!important}.modal,.react-modal-content{max-width:100%!important;width:100%!important;max-height:90vh!important;margin:0!important;padding:20px 16px!important;border-radius:16px 16px 0 0!important;animation:slideUpModal .3s ease-out!important}.modal:before{content:"";display:block;width:40px;height:4px;background:#d1d5db;border-radius:2px;margin:0 auto 16px}.modal-buttons button,.primary-btn,.secondary-btn{min-height:48px!important;min-width:120px!important;font-size:16px!important;padding:12px 24px!important;margin:8px 4px!important;touch-action:manipulation}.modal-buttons{position:-webkit-sticky!important;position:sticky!important;bottom:0!important;background:#fff!important;padding:16px 0!important;margin:16px -16px -20px!important;border-top:1px solid #e5e7eb!important;flex-direction:column-reverse!important;gap:8px!important;z-index:10!important}.modal-buttons button{width:100%!important;margin:0!important}.modal-content{padding-bottom:100px!important}}@keyframes slideUpModal{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width:768px){.loading-spinner{width:40px!important;height:40px!important}}@media (prefers-reduced-motion:no-preference){.rbc-btn-group button,.rbc-event,.rbc-time-slot,.rbc-toolbar button{transition:all .2s ease}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.modal-content,.modal-overlay,.quick-book-slot,.rbc-event,.toast{animation:none!important;transition:none!important}}@supports (padding:max(0px)){body{padding-left:max(0px,env(safe-area-inset-left));padding-right:max(0px,env(safe-area-inset-right));padding-bottom:max(0px,env(safe-area-inset-bottom))}.modal-content,.unified-booking-modal{padding-bottom:max(16px,env(safe-area-inset-bottom))}.rbc-toolbar{padding-left:max(8px,env(safe-area-inset-left));padding-right:max(8px,env(safe-area-inset-right))}.fixed-bottom-bar,.toast-container{padding-bottom:max(12px,env(safe-area-inset-bottom))}}@media (max-width:320px){.rbc-toolbar{padding:4px 0!important;margin-bottom:6px!important}.rbc-btn-group button,.rbc-toolbar button{font-size:10px!important;padding:3px 5px!important;min-width:0!important;height:28px!important;margin:0 1px!important}.rbc-toolbar-label{font-size:11px!important;margin:0 2px!important}.rbc-label{font-size:10px!important;padding-right:4px}.rbc-time-gutter,.rbc-time-header-gutter{min-width:50px!important;max-width:50px!important;width:50px!important}.quick-book-suggestions{padding:6px 8px;gap:8px}.quick-book-header{font-size:10px}.quick-book-slot{min-width:60px;padding:4px 6px}.slot-day{font-size:8px}.slot-time{font-size:10px}.unified-booking-modal{max-width:100%}.unified-header{padding:8px 12px}.unified-header h2{font-size:14px}.section-content{padding:8px 12px}.form-group input{padding:8px;font-size:16px}.section-actions .btn-primary,.section-actions .btn-secondary{padding:8px 12px;font-size:12px}}.calendar-error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;margin-bottom:16px;display:flex;align-items:center;gap:8px;color:#dc2626;font-size:14px;box-shadow:0 2px 4px #dc26261a}.calendar-error-message.business-hours-error{font-size:20px!important;font-weight:600!important;padding:16px 20px!important;margin:16px auto!important;max-width:600px!important;border-width:2px!important;border-radius:10px!important;box-shadow:0 4px 12px #dc262633!important;gap:10px!important}.calendar-error-message.business-hours-error .error-icon{font-size:24px!important}.calendar-error-message.business-hours-error .error-dismiss{font-size:20px!important;width:28px!important;height:28px!important}.error-icon{font-size:16px;flex-shrink:0}.error-dismiss{background:none;border:none;color:#dc2626;font-size:18px;cursor:pointer;padding:0;margin-left:auto;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.error-dismiss:hover{background-color:#dc26261a}.booked-slot{background-color:#e8f5e8!important;border-color:#d4e9d4!important;opacity:.7}.selected-for-blocking{background-color:#fed7aa!important;border-color:#fb923c!important;border-width:2px!important;box-shadow:0 0 0 2px #fb923c4d!important;animation:selectedPulse 1.5s infinite}@keyframes selectedPulse{0%,to{background-color:#fed7aa!important}50%{background-color:#fbbf24!important}}.blocked-slot{background-color:#fca5a5!important;border-color:#ef4444!important;cursor:not-allowed!important;opacity:.8;position:relative}.blocked-slot:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,#0000,#0000 2px,#dc26264d 0,#dc26264d 4px);pointer-events:none}.block-slots-modal{padding:20px}.block-slots-content{margin:20px 0}.selected-slots-summary{background:#f3f4f6;padding:15px;border-radius:8px;margin:15px 0;max-height:200px;overflow-y:auto}.selected-slots-summary ul{margin:10px 0 0;padding-left:20px}.selected-slots-summary li{margin:5px 0;color:#374151}.reset-slot-modal{padding:20px}.reset-slot-content{margin:20px 0}.reset-slot-content p{margin-bottom:15px;color:#555;text-align:center;line-height:1.5}.slot-details{background:#f3f4f6;padding:15px;border-radius:8px;margin:15px 0;text-align:center;border-left:4px solid #dc2626}.slot-details strong{color:#374151;display:block;margin-bottom:5px}.reset-btn{background-color:#dc2626;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.reset-btn:hover{background-color:#b91c1c}.claim-modal{padding:20px}.claim-content{margin:20px 0}.claim-content p{color:#555;text-align:center}.claim-content p,.claim-modal .form-group{margin-bottom:20px}.claim-modal .form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.claim-modal .modal-buttons{display:flex;gap:10px;justify-content:center;margin-top:20px}.claim-modal .error-message{margin-top:15px}.show-as-filled-container{position:relative;display:inline-block}.help-icon-btn{background:#007bff;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s;flex-shrink:0;position:absolute;top:-8px;right:-8px;z-index:1}.help-icon-btn:hover{background:#0056b3}.help-icon-btn:active{transform:scale(.95)}.help-modal{max-width:650px;width:92%;max-height:85vh;overflow-y:auto;font-size:1rem;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;box-shadow:0 25px 50px -12px #00000040;border:1px solid #e5e7eb;position:relative}.help-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#06b6d4);border-radius:16px 16px 0 0}.help-modal h2{color:#1f2937;font-size:1.5rem;font-weight:700;margin-bottom:24px;text-align:center;border-bottom:2px solid #e5e7eb;padding-bottom:16px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:#0000;background-clip:text}.help-content{margin-bottom:24px;padding:0 4px;line-height:1.7}.help-content p{margin-bottom:16px;color:#4b5563;font-size:1rem;line-height:1.6}.help-content h3{margin-top:24px;margin-bottom:12px;color:#1f2937;font-size:1.1rem;font-weight:600;display:flex;align-items:center;gap:8px}.help-content h3:first-of-type{margin-top:16px}.help-content h3:before{content:"●";color:#3b82f6;font-size:1.2rem}.help-content ol,.help-content ul{margin-left:24px;margin-bottom:20px;padding-left:8px}.help-content ol{counter-reset:step-counter;list-style:none;margin-left:16px}.help-content ol li{counter-increment:step-counter;position:relative;padding-left:32px;margin-bottom:12px}.help-content ol li:before{content:counter(step-counter);position:absolute;left:0;top:0;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;box-shadow:0 2px 4px #3b82f64d}.help-content ul li{margin-bottom:10px;line-height:1.6;position:relative;padding-left:20px}.help-content ul li:before{content:"→";position:absolute;left:0;color:#3b82f6;font-weight:700;font-size:1.1rem}.help-content li{color:#4b5563;line-height:1.6;font-size:.95rem}.help-content strong{color:#1f2937;font-weight:600;background:#3b82f61a;padding:2px 6px;border-radius:4px;font-size:.9rem}.help-content p:last-child{background:linear-gradient(135deg,#eff6ff,#dbeafe);border:1px solid #bfdbfe;border-radius:8px;padding:16px;margin-top:20px;position:relative}.help-content p:last-child:before{content:"💡";position:absolute;top:16px;left:16px;font-size:1.2rem}.help-content p:last-child{padding-left:48px}.help-content p:last-child strong{background:#3b82f633}.super-user-login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.super-user-login-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;max-width:450px;width:90%;max-height:90vh;overflow-y:auto;animation:modalFadeIn .4s ease-out}.super-user-login-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:24px;border-radius:16px 16px 0 0;display:flex;align-items:center;justify-content:space-between}.super-user-login-header h2{margin:0;font-size:1.4em;font-weight:600}.super-user-login-form{padding:32px}.super-user-login-form .error-message{background:#fee;border:1px solid #fcc;border-radius:8px;padding:12px 16px;margin-bottom:24px;color:#c33;display:flex;align-items:center;gap:8px}.super-user-login-form .form-group{margin-bottom:20px}.super-user-login-form label{display:block;margin-bottom:8px;font-weight:600;color:#333}.super-user-login-form input{width:100%;padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.super-user-login-form input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.super-user-login-form input:disabled{background:#f5f5f5;cursor:not-allowed}.super-user-login-form .form-actions{margin-bottom:24px}.super-user-login-form .login-btn{width:100%;padding:14px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px}.super-user-login-form .login-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 16px #667eea4d}.super-user-login-form .login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.super-user-login-form .login-info{background:#f8f9ff;border-radius:8px;padding:16px;border-left:4px solid #667eea}.super-user-login-form .login-info p{margin:0 0 12px;line-height:1.6}.super-user-login-form .login-info code{background:#e8ecff;padding:2px 6px;border-radius:4px;font-family:Monaco,Consolas,monospace;font-size:.9em;color:#5a67d8}.super-user-dashboard{position:fixed;top:0;left:0;right:0;bottom:0;background:#f8f9fa;z-index:1500;display:flex;flex-direction:column;overflow:hidden}.super-user-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px 24px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 10px #0000001a}.super-user-header h2{margin:0;font-size:1.5em;font-weight:600}.super-user-header .header-actions{display:flex;gap:12px}.super-user-header .logout-btn,.super-user-header .settings-btn{background:#fff3;color:#fff;border:none;border-radius:6px;padding:8px 16px;cursor:pointer;transition:background .3s}.super-user-header .logout-btn:hover,.super-user-header .settings-btn:hover{background:#ffffff4d}.super-user-header .close-btn{background:none;color:#fff;border:none;font-size:20px;cursor:pointer;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .3s}.super-user-header .close-btn:hover{background:#fff3}.super-user-content{flex:1 1;overflow-y:auto;padding:24px}.overview-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));grid-gap:16px;gap:16px;margin-bottom:32px}.overview-card{background:#fff;border-radius:12px;padding:20px;display:flex;align-items:center;gap:16px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef;transition:transform .2s,box-shadow .2s}.overview-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001a}.overview-card .card-icon{font-size:2.5em;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;flex-shrink:0}.overview-card .card-content h3{margin:0 0 4px;font-size:1.8em;font-weight:700;color:#2d3748}.overview-card .card-content p{margin:0 0 4px;color:#718096;font-weight:500}.overview-card .card-content small{color:#a0aec0;font-size:.85em}.charts-section{display:grid;grid-template-columns:2fr 1fr;grid-gap:24px;gap:24px;margin-bottom:32px}.chart-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef}.chart-container.subscription-chart{display:flex;align-items:center;justify-content:center}.business-list-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef;margin-bottom:32px}.business-list-header{padding:24px;border-bottom:1px solid #e9ecef;display:flex;align-items:center;justify-content:space-between;gap:20px}.business-list-header h3{margin:0;color:#2d3748;font-size:1.25em;font-weight:600;display:flex;align-items:center;gap:8px}.business-filters{display:flex;gap:12px}.business-filters .search-input{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;min-width:200px}.business-filters .status-filter{padding:8px 12px;border:1px solid #e2e8f0;border-radius:6px;background:#fff}.business-table{display:grid;grid-template-columns:2fr 2fr 1fr 1fr 1fr 1fr 2fr;grid-gap:16px;gap:16px}.business-table-header{display:contents;font-weight:600;color:#4a5568;background:#f7fafc}.business-table-header>div{padding:16px 24px;background:#f7fafc;border-bottom:2px solid #e2e8f0}.business-table-row{display:contents}.business-table-row>div{padding:16px 24px;border-bottom:1px solid #e9ecef;display:flex;flex-direction:column;justify-content:center}.business-table-row:hover>div{background:#f8f9fa}.business-name strong{color:#2d3748;font-weight:600}.business-name small{color:#718096;font-size:.85em}.business-owner div{color:#2d3748;font-weight:500}.business-owner small{color:#718096;font-size:.85em}.status-badge{display:inline-block;padding:4px 12px;border-radius:20px;font-size:.8em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.status-active{background:#c6f6d5;color:#22543d}.status-badge.status-trial{background:#fed7d7;color:#742a2a}.status-badge.status-suspended{background:#feebcb;color:#7c2d12}.status-badge.status-cancelled{background:#e2e8f0;color:#4a5568}.tier-badge{display:inline-block;padding:4px 8px;border-radius:6px;font-size:.75em;font-weight:600;text-transform:capitalize}.tier-badge.tier-solo{background:#e2e8f0;color:#4a5568}.tier-badge.tier-practice{background:#d6f5d6;color:#22543d}.tier-badge.tier-clinic{background:#e6fffa;color:#234e52}.business-actions{display:flex;flex-direction:column;gap:6px}.business-action-btn{padding:4px 10px;border:none;border-radius:4px;font-size:.75em;font-weight:600;cursor:pointer;transition:opacity .2s;white-space:nowrap}.business-action-btn:disabled{opacity:.5;cursor:not-allowed}.business-action-btn.action-suspend{background:#fed7d7;color:#742a2a}.business-action-btn.action-suspend:hover:not(:disabled){background:#feb2b2}.business-action-btn.action-reactivate{background:#c6f6d5;color:#22543d}.business-action-btn.action-reactivate:hover:not(:disabled){background:#9ae6b4}.business-action-btn.action-note{background:#bee3f8;color:#2a4365;flex-shrink:0}.business-action-btn.action-note:hover:not(:disabled){background:#90cdf4}.business-action-btn.action-impersonate{background:#e9d8fd;color:#553c9a}.business-action-btn.action-impersonate:hover:not(:disabled){background:#d6bcfa}.business-action-btn.action-impersonate.has-access{background:#c6f6d5;color:#276749}.business-action-btn.action-impersonate.has-access:hover:not(:disabled){background:#9ae6b4}.health-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.health-badge{padding:2px 8px;border-radius:10px;font-size:.7em;font-weight:600}.health-overdue{background:#fed7d7;color:#9b2c2c}.health-trial-expiring{background:#fefcbf;color:#975a16}.health-inactive{background:#feebcb;color:#7c2d12}.tier-select{padding:4px 6px;border:1px solid #e2e8f0;border-radius:4px;font-size:.85em;background:#fff;cursor:pointer;width:100%}.tier-select:disabled{opacity:.5}.note-input-group{display:flex;gap:4px}.note-input{padding:3px 6px;border:1px solid #e2e8f0;border-radius:4px;font-size:.75em;min-width:0;flex:1 1}.note-input:focus{outline:none;border-color:#667eea}.health-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef;padding:24px}.health-section h3{margin:0;color:#2d3748;font-size:1.25em;font-weight:600}.health-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.health-refresh-btn{padding:4px 12px;background:#edf2f7;border:1px solid #e2e8f0;border-radius:4px;font-size:.85em;cursor:pointer;color:#4a5568}.health-refresh-btn:hover:not(:disabled){background:#e2e8f0}.health-cards{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:16px;gap:16px}.health-card{background:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:16px}.health-card-title{font-size:.8em;font-weight:600;color:#718096;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.health-card-value{font-size:1.1em;font-weight:700;color:#2d3748;margin-bottom:8px;display:flex;align-items:center;gap:8px}.health-card-detail{font-size:.8em;color:#718096;margin-top:6px}.health-bar{height:6px;background:#e2e8f0;border-radius:3px;overflow:hidden}.health-bar-fill{height:100%;background:#48bb78;border-radius:3px;transition:width .3s ease}.health-bar-fill.health-bar-warning{background:#ecc94b}.health-bar-fill.health-bar-danger{background:#f56565}.health-indicator{display:inline-block;width:10px;height:10px;border-radius:50%}.health-indicator-green{background:#48bb78}.health-indicator-yellow{background:#ecc94b}.health-indicator-red{background:#f56565}.churn-risk-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef;padding:24px}.churn-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.churn-section-header h3{margin:0;color:#2d3748;font-size:1.25em;font-weight:600;display:flex;align-items:center;gap:8px}.churn-count-badge{display:inline-flex;align-items:center;justify-content:center;background:#e53e3e;color:#fff;font-size:.7em;font-weight:700;min-width:22px;height:22px;border-radius:11px;padding:0 6px}.churn-no-risks{padding:12px 16px;background:#f0fff4;color:#276749;border-radius:8px;border:1px solid #c6f6d5;font-size:.9em;font-weight:500}.churn-risk-cards{display:grid;grid-gap:12px;gap:12px}.churn-risk-card{padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef;border-left:4px solid #d69e2e}.churn-risk-card.severity-critical{border-left-color:#e53e3e;background:#fff5f5}.churn-risk-card.severity-high{border-left-color:#dd6b20;background:#fffaf0}.churn-risk-card.severity-medium{border-left-color:#d69e2e;background:ivory}.churn-risk-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.churn-risk-header strong{display:block;color:#2d3748;font-size:.95em}.churn-risk-header small{display:block;color:#718096;font-size:.8em}.churn-risk-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.churn-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.75em;font-weight:600;border:1px solid}.churn-badge-critical{background:#fed7d7;color:#c53030}.churn-badge-high{background:#feebc8;color:#c05621}.churn-badge-medium{background:#fefcbf;color:#975a16}.churn-risk-metrics{display:flex;gap:16px;font-size:.8em;color:#718096}.collapse-arrow{display:inline-block;transition:transform .2s ease;font-size:.8em;margin-right:4px}.collapse-arrow.collapsed{transform:rotate(-90deg)}.collapsible-scrollable{max-height:500px;overflow-y:auto}.notification-monitor-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef;padding:24px}.notification-monitor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.notification-monitor-header h3{margin:0;color:#2d3748;font-size:1.25em;font-weight:600}.notification-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:12px;gap:12px;margin-bottom:20px}.notification-type-table{margin-bottom:20px}.notification-type-table h4{margin:0 0 10px;font-size:.95em;color:#4a5568}.notification-type-table table{width:100%;border-collapse:collapse;font-size:.85em}.notification-type-table th{text-align:left;padding:6px 10px;border-bottom:2px solid #e2e8f0;color:#718096;font-weight:600}.notification-type-table td{padding:6px 10px;border-bottom:1px solid #edf2f7}.recent-failures-list h4{margin:0 0 10px;font-size:.95em;color:#4a5568}.recent-failure-row{display:flex;gap:12px;align-items:center;padding:8px 10px;border-bottom:1px solid #edf2f7;font-size:.82em}.recent-failure-row:last-child{border-bottom:none}.failure-recipient{min-width:140px;color:#4a5568;font-family:monospace}.failure-type{min-width:100px;color:#718096}.failure-error-text{flex:1 1;color:#e53e3e;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.failure-attempts{min-width:80px;color:#718096;text-align:right}.failure-time{min-width:60px;color:#a0aec0;text-align:right}@media (max-width:768px){.notification-stats-grid{grid-template-columns:repeat(2,1fr)}.recent-failure-row{flex-wrap:wrap}.churn-risk-metrics{flex-wrap:wrap;gap:8px}}.top-businesses-section{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid #e9ecef;padding:24px}.top-businesses-section h3{margin:0 0 20px;color:#2d3748;font-size:1.25em;font-weight:600}.top-businesses-list{display:grid;grid-gap:12px;gap:12px}.top-business-card{display:flex;align-items:center;gap:16px;padding:16px;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.top-business-card .business-rank{font-size:1.2em;font-weight:700;color:#667eea;min-width:32px}.top-business-card .business-details{flex:1 1}.top-business-card .business-details h4{margin:0 0 4px;color:#2d3748;font-weight:600}.top-business-card .business-details p{margin:0;color:#718096;font-size:.9em}.top-business-card .business-stats{text-align:right}.top-business-card .business-stats div{font-weight:700;color:#2d3748}.top-business-card .business-stats small{color:#718096;font-size:.85em}.empty-state,.error-state,.loading-state{padding:40px;text-align:center;color:#718096}.error-state{color:#e53e3e}.retry-btn{margin-top:16px;padding:8px 16px;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer}.loading-spinner{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:1024px){.business-table,.charts-section{grid-template-columns:1fr}.business-table{gap:0}.business-table-header{display:none}.business-table-row>div{padding:8px 24px;border-bottom:none}.business-table-row{border-bottom:1px solid #e9ecef;margin-bottom:16px}.business-filters{flex-direction:column;gap:8px}.business-filters .search-input{min-width:auto}}@media (max-width:768px){.super-user-content{padding:16px}.overview-cards{grid-template-columns:1fr}.health-cards{grid-template-columns:1fr 1fr}.business-list-header{flex-direction:column;gap:16px}}.super-user-account-settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease-out}.super-user-account-settings-modal{background:#fff;border-radius:16px;box-shadow:0 25px 50px #00000040;max-width:700px;width:90%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:modalSlideIn .4s ease-out}.settings-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px 24px;display:flex;align-items:center;justify-content:space-between}.settings-header h2{margin:0;font-size:1.4em;font-weight:600}.settings-tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #e9ecef}.settings-tabs .tab{flex:1 1;padding:16px 20px;background:none;color:#6c757d;font-weight:500;cursor:pointer;transition:all .3s;border:none;border-bottom:3px solid #0000}.settings-tabs .tab:hover{background:#e9ecef;color:#495057}.settings-tabs .tab.active{color:#667eea;border-bottom-color:#667eea;background:#fff}.settings-content{flex:1 1;overflow-y:auto;padding:24px}.settings-tab-content h3{margin:0 0 24px;color:#2d3748;font-size:1.2em;font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#374151}.form-group input{width:100%;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;transition:border-color .3s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group small{display:block;margin-top:4px;color:#6b7280;font-size:.875em}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 8px 16px #667eea4d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background:#545b62}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.btn-small{padding:8px 16px;font-size:14px}.message{padding:12px 16px;border-radius:8px;margin-bottom:20px;font-weight:500}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f1b0b7}.two-fa-status{padding:20px;background:#f8f9fa;border-radius:12px;margin-bottom:24px}.status-indicator{display:flex;align-items:center;gap:12px;margin-bottom:16px}.status-dot{width:12px;height:12px;border-radius:50%}.status-dot.enabled{background:#28a745;box-shadow:0 0 0 3px #28a74533}.status-dot.disabled{background:#dc3545;box-shadow:0 0 0 3px #dc354533}.status-text{font-weight:600;color:#2d3748}.two-fa-actions{display:flex;gap:12px;margin:16px 0;flex-wrap:wrap}.backup-codes{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-top:20px}.backup-codes h4{margin:0 0 12px;color:#2d3748}.backup-codes p{margin-bottom:16px;color:#6b7280;line-height:1.5}.codes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));grid-gap:8px;gap:8px;margin-bottom:16px}.backup-code{background:#f3f4f6;padding:8px 12px;border-radius:6px;text-align:center;font-family:Monaco,Consolas,monospace;font-weight:600;color:#374151;border:1px solid #d1d5db}.two-fa-verification{background:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;margin-top:16px}.two-fa-verification h4{margin:0 0 12px;color:#2d3748;font-size:1.1em}.two-fa-verification p{margin-bottom:20px;color:#6b7280;line-height:1.5}.verification-input-group{display:flex;gap:12px;margin-bottom:16px;align-items:center}.verification-input{flex:1 1;padding:12px 16px;border:2px solid #d1d5db;border-radius:8px;font-size:18px;font-family:Monaco,Consolas,monospace;letter-spacing:4px;text-align:center;transition:all .2s ease}.verification-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.verification-footer{margin-top:16px;text-align:center}.verification-footer .resend-info{color:#6b7280;font-size:14px;margin:0}.verification-footer .resend-link{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:14px;padding:0;text-decoration:underline;transition:color .2s}.verification-footer .resend-link:hover:not(:disabled){color:#2563eb}.verification-footer .resend-link:disabled{color:#9ca3af;cursor:not-allowed;text-decoration:none}.verification-footer .resend-success{color:#059669;font-size:14px;font-weight:500;margin:0}.verification-footer .resend-error{color:#dc2626;font-size:14px;font-weight:500;margin:0}.verification-actions{display:flex;gap:12px;justify-content:space-between}.verification-actions button{flex:1 1}@media (max-width:768px){.super-user-account-settings-modal{max-width:95%;max-height:95vh}.settings-content{padding:16px}.form-row{grid-template-columns:1fr}.two-fa-actions{flex-direction:column}.codes-grid{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.verification-actions,.verification-input-group{flex-direction:column}}.edit-time-selector{width:100%;max-width:300px}.edit-time-selector .time-grid-popup{max-width:320px}.form-group .appointment-time-selector{margin-top:4px}.hover-time-picker{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 8px 24px #00000026,0 4px 8px #0000001a;padding:12px 16px;color:#fff;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;cursor:pointer;transition:all .2s ease;pointer-events:auto;min-width:200px;text-align:center;animation:pickerFadeIn .2s ease-out}.hover-time-picker:hover{transform:translateX(-50%) translateY(-2px);box-shadow:0 12px 32px #0003,0 6px 12px #00000026}.picker-content{display:flex;flex-direction:column;gap:4px}.picker-time{font-size:18px;font-weight:600;letter-spacing:.5px}.picker-date{font-size:12px;opacity:.9;font-weight:400}.picker-action{font-size:11px;opacity:.8;font-weight:500;margin-top:2px;background:#fff3;padding:4px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}@keyframes pickerFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(-10px) scale(.9)}to{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}}.rbc-time-slot:hover{background-color:#667eea26!important;border-color:#667eea!important;transition:all .15s ease}.calendar-container{position:relative}.empty-state-box{text-align:center;padding:2rem 1rem;color:#6b7280}.empty-state-box .empty-state-icon{font-size:2rem;display:block;margin-bottom:.5rem}.empty-state-box .empty-state-heading{font-weight:600;color:#374151;margin:0 0 .25rem}.empty-state-box .empty-state-sub{font-size:.875rem;margin:0}@media (max-width:768px){.calendar-container[data-view=week] .rbc-time-header-gutter,.calendar-container[data-view=week] .rbc-time-view .rbc-time-gutter{min-width:42px!important;max-width:42px!important;width:42px!important}.calendar-container[data-view=week] .rbc-label{font-size:10px!important;padding-right:4px}.calendar-container[data-view=week] .rbc-time-slot{height:22px!important;min-height:22px!important}.calendar-container[data-view=week] .rbc-time-gutter .rbc-timeslot-group,.calendar-container[data-view=week] .rbc-timeslot-group{height:44px!important;min-height:44px!important}.calendar-container[data-view=week] .rbc-time-gutter .rbc-timeslot-group .rbc-time-slot:first-child{height:44px!important}.calendar-container[data-view=week] .rbc-header{font-size:8px!important;padding:2px 1px!important;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-container[data-view=week] .rbc-event{min-height:18px!important;font-size:9px!important;padding:1px 2px 1px 5px!important;border-left:3px solid!important;border-radius:2px!important;line-height:1.2!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.calendar-container[data-view=week] .rbc-event .rbc-event-label,.calendar-container[data-view=week] .rbc-event-label{display:none!important}.calendar-container[data-view=week] .rbc-allday-cell{height:4px!important;min-height:4px!important}.calendar-container[data-view=week] .rbc-today{background-color:#4285f40f!important}.calendar-container[data-view=week] .rbc-current-time-indicator{background-color:#7c3aed!important;height:2px!important}.calendar-container[data-view=week] .rbc-current-time-indicator:before{content:"";position:absolute;left:-5px;top:-4px;width:10px;height:10px;background-color:#7c3aed;border-radius:50%}}@media (max-width:320px){.calendar-container[data-view=week] .rbc-time-header-gutter,.calendar-container[data-view=week] .rbc-time-view .rbc-time-gutter{min-width:36px!important;max-width:36px!important;width:36px!important}.calendar-container[data-view=week] .rbc-label{font-size:9px!important}.calendar-container[data-view=week] .rbc-header{font-size:7px!important}.calendar-container[data-view=week] .rbc-event{font-size:8px!important}}@media (max-width:480px){input,select,textarea{font-size:16px!important}}