*{box-sizing:border-box}:root{font-family:system-ui,-apple-system,Segoe UI,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-width:320px;min-height:100vh;color:#333;background-color:#f5f5f5}#root{min-height:100vh}.app-container{display:flex;flex-direction:column;min-height:100vh}.header{background-color:#fff;padding:1rem 2rem;box-shadow:0 2px 4px #0000001a}.header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:2rem}.logo{height:50px;width:auto}.cta-button{background-color:#ff6b6b;color:#fff;text-decoration:none;padding:.75rem 1.5rem;border-radius:25px;font-weight:600;cursor:pointer;transition:background-color .2s;white-space:nowrap;display:inline-block}.cta-button:hover{background-color:#ff5252}.main-content{flex:1;background-color:#f5f5f5}.footer{background-color:#2e4c8f;color:#fff;padding:2rem;text-align:center}.footer-content{max-width:1400px;margin:0 auto}.footer p{margin:0;font-size:.9rem}.no-client-id{max-width:600px;margin:4rem auto;padding:3rem 2rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center}.no-client-id h2{color:#2a7de2;margin-bottom:1rem}.no-client-id p{color:#666;margin-bottom:.5rem}.no-client-id .example{font-family:monospace;background:#f5f5f5;padding:.75rem;border-radius:6px;color:#2a7de2;font-weight:600;margin-top:1rem}@media(max-width:768px){.header-content{flex-direction:column;gap:1rem}.logo{height:40px}.cta-button{font-size:.9rem;padding:.65rem 1.25rem}.no-client-id{margin:2rem auto;padding:2rem 1rem}}:root{--color-primary: #2a7de2;--color-primary-hover: #1e6bc9;--color-primary-light: #e3f2fd;--color-primary-lighter: #f5f9ff;--color-success: #4caf50;--color-error: #c62828;--color-error-bg: #ffebee;--color-error-dark: #d32f2f;--color-warning: #e65100;--color-warning-bg: #fff3e0;--color-warning-border: #ffb74d;--color-info: #1976d2;--color-text-primary: #333;--color-text-secondary: #666;--color-text-light: #555;--color-text-muted: #ccc;--color-bg-white: white;--color-bg-light: #f5f5f5;--color-bg-lighter: #f3f3f3;--color-border: #e0e0e0;--color-border-light: #f5f5f5;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px rgba(0, 0, 0, .15);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .2);--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 50%;--radius-pill: 25px}.classes-container{max-width:1400px;margin:0 auto;padding:2rem 1rem}.classes-title{color:var(--color-primary);font-size:2rem;margin-bottom:2rem;text-align:center}.content-grid{display:grid;grid-template-columns:350px 1fr;gap:2rem;align-items:start}.client-details{position:sticky;top:2rem}.client-card{background:var(--color-bg-white);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-sm)}.client-card h2{color:var(--color-primary);font-size:1.5rem;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-border-light)}.client-field{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--color-border-light)}.client-field:last-child{border-bottom:none}.field-label{color:var(--color-text-secondary);font-weight:500;font-size:.95rem}.field-value{color:var(--color-text-primary);font-weight:600;font-size:1rem}.pending-reschedules-card{background:var(--color-bg-white);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-sm);margin-top:1rem}.pending-reschedules-card h2{color:var(--color-warning);font-size:1.5rem;margin-bottom:.75rem;padding-bottom:.75rem;border-bottom:2px solid var(--color-border-light)}.pending-reschedules-instruction{font-size:.85rem;color:var(--color-text-secondary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.highlight{color:var(--color-error);font-weight:600}.bounce-arrow{display:inline-block;font-size:1.1rem;color:var(--color-error);animation:bounce 1.5s ease infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(4px)}}.pending-reschedules-list{display:flex;flex-direction:column;gap:1rem}.pending-program-group{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;background:var(--color-bg-lighter)}.pending-program-header{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--color-border)}.program-color-indicator{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}.program-name{font-weight:600;color:var(--color-text-primary);font-size:.95rem}.pending-classes{display:flex;flex-direction:column;gap:.5rem}.pending-class-item{background:var(--color-bg-white);border:1px solid var(--color-border);border-left:3px solid var(--color-warning);border-radius:var(--radius-md);padding:.75rem;cursor:pointer;transition:all .2s ease}.pending-class-item:hover{border-left-color:var(--color-primary);background-color:var(--color-primary-lighter);box-shadow:var(--shadow-sm);transform:translate(2px)}.pending-class-date{font-size:.9rem;color:var(--color-text-primary);font-weight:600;margin-bottom:.25rem}.pending-class-teacher{font-size:.85rem;color:var(--color-text-secondary)}.calendar-section{min-width:0}.calendar-wrapper{background:var(--color-bg-white);border-radius:var(--radius-xl);padding:1.5rem;box-shadow:var(--shadow-sm)}.calendar-wrapper .fc{font-family:inherit}.calendar-wrapper .fc-button{background-color:var(--color-primary);border-color:var(--color-primary);text-transform:capitalize;font-weight:500}.calendar-wrapper .fc-button:hover,.calendar-wrapper .fc-button-active{background-color:var(--color-primary-hover);border-color:var(--color-primary-hover)}.calendar-wrapper .fc-button:disabled{opacity:.5}.calendar-wrapper .fc-toolbar-title{color:var(--color-text-primary);font-size:1.5rem;font-weight:600}.calendar-wrapper .fc-col-header-cell{background-color:var(--color-bg-light);padding:.75rem 0;font-weight:600;color:var(--color-text-primary)}.calendar-wrapper .fc-timegrid-slot-label{color:var(--color-text-secondary)}.calendar-wrapper .fc-event{border-radius:var(--radius-sm);padding:2px 4px;font-size:.95rem;line-height:1.3;cursor:pointer}.calendar-wrapper .fc-event-title{font-weight:600}.calendar-wrapper .fc-event.event-inactive{opacity:.5;color:var(--color-warning)}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:50px;height:50px;border:4px solid var(--color-bg-lighter);border-top:4px solid var(--color-primary);border-radius:var(--radius-full);animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading p{color:var(--color-text-secondary);font-size:1.1rem}.error{background:var(--color-bg-white);border-radius:var(--radius-xl);padding:3rem 2rem;text-align:center;box-shadow:var(--shadow-sm)}.error h2{color:var(--color-error-dark);margin-bottom:1rem}.error p{color:var(--color-text-secondary);margin-bottom:2rem}.retry-button{background-color:var(--color-primary);color:var(--color-bg-white);border:none;padding:.75rem 2rem;border-radius:var(--radius-pill);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.retry-button:hover{background-color:var(--color-primary-hover)}.empty-state{background:var(--color-bg-white);border-radius:var(--radius-xl);padding:2rem;margin-top:1rem;text-align:center;box-shadow:var(--shadow-sm)}.empty-state p{color:var(--color-text-secondary);margin:0}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:var(--color-bg-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:500px;width:100%;position:relative;overflow:hidden}.modal-close{position:absolute;top:.75rem;right:.75rem;background:#ffffffe6;border:none;border-radius:var(--radius-full);width:32px;height:32px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);transition:background-color .2s;z-index:1}.modal-close:hover{background:#fff}.modal-header{padding:1.5rem;color:var(--color-bg-white)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600}.modal-body{padding:1.5rem}.modal-field{margin-bottom:1rem}.modal-field:last-child{margin-bottom:0}.modal-label{display:block;color:var(--color-text-secondary);font-weight:500;font-size:.9rem;margin-bottom:.25rem}.modal-value{display:block;color:var(--color-text-primary);font-size:1rem;font-weight:600}.modal-actions{margin-top:1.5rem;display:flex;gap:1rem;justify-content:flex-end}.reschedule-button{background-color:var(--color-primary);color:var(--color-bg-white);border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.reschedule-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.reschedule-button:disabled{opacity:.5;cursor:not-allowed}.cancel-class-button{background-color:var(--color-bg-light);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s,border-color .2s}.cancel-class-button:hover:not(:disabled){background-color:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.cancel-class-button:disabled{opacity:.5;cursor:not-allowed}.pending-reschedule-button{background-color:var(--color-bg-light);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s,border-color .2s}.pending-reschedule-button:hover:not(:disabled){background-color:var(--color-warning-bg);border-color:var(--color-warning);color:var(--color-warning)}.pending-reschedule-button:disabled{opacity:.5;cursor:not-allowed}.pending-reschedule-confirm{background:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-radius:var(--radius-md);padding:.75rem 1rem}.pending-reschedule-confirm p{font-size:.9rem;color:var(--color-text-primary);margin-bottom:.75rem}.pending-reschedule-confirm-actions{display:flex;gap:.5rem}.pending-reschedule-confirm-button{background-color:var(--color-warning);color:#fff;border:none;padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:opacity .2s}.pending-reschedule-confirm-button:hover:not(:disabled){opacity:.85}.pending-reschedule-cancel-button{background-color:var(--color-bg-light);color:var(--color-text-primary);border:1px solid var(--color-border);padding:.5rem 1rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;cursor:pointer;transition:background-color .2s}.pending-reschedule-cancel-button:hover:not(:disabled){background-color:var(--color-border)}.confirm-cancel-button{background-color:var(--color-error-dark);color:var(--color-bg-white);border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.confirm-cancel-button:hover:not(:disabled){background-color:var(--color-error)}.confirm-cancel-button:disabled{opacity:.5;cursor:not-allowed}.cancel-confirmation-modal .modal-content{max-width:450px}.cancel-warning{font-size:1.1rem;color:var(--color-text-primary);text-align:center;margin-bottom:.75rem}.cancel-info{font-size:.9rem;color:var(--color-text-secondary);text-align:center;margin-bottom:1.5rem}.booking-window-message{width:100%;padding:1rem 1.5rem;background-color:var(--color-warning-bg);color:var(--color-warning);border-radius:var(--radius-md);font-size:.95rem;font-weight:500;text-align:center;border:1px solid var(--color-warning-border)}.loading-message{margin-top:1rem;padding:.75rem;background-color:var(--color-primary-light);color:var(--color-info);border-radius:var(--radius-md);font-size:.9rem;text-align:center;font-weight:500;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.reschedule-error{margin-top:1rem;padding:.75rem;background-color:var(--color-error-bg);color:var(--color-error);border-radius:var(--radius-md);font-size:.9rem}.week-picker-modal .modal-content{max-width:450px}.week-picker-instructions{color:var(--color-text-secondary);margin-bottom:1.5rem;text-align:center;font-size:.95rem}.week-date-input{width:100%;padding:.875rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:1rem;font-family:inherit;cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;position:relative;background-color:var(--color-bg-white)}.week-date-input::-webkit-calendar-picker-indicator{position:absolute;inset:0;width:auto;height:auto;color:transparent;background:transparent;cursor:pointer}.week-date-input:hover{border-color:var(--color-primary)}.week-date-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #2a7de21a}.week-preview{margin-top:1rem;padding:.875rem;background-color:var(--color-primary-light);border-radius:var(--radius-lg);text-align:center;color:var(--color-info);font-size:.95rem}.week-preview strong{display:block;margin-bottom:.25rem;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.booking-limit-info{margin-top:1rem;padding:.75rem 1rem;background-color:var(--color-bg-light);border-left:3px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-text-light);font-size:.9rem;font-style:italic}.reschedule-modal .modal-content{max-width:600px}.reschedule-options{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;max-height:400px;overflow-y:auto}.reschedule-option{display:flex;align-items:center;padding:1rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color .2s,background-color .2s}.reschedule-option:hover{border-color:var(--color-primary);background-color:var(--color-primary-lighter)}.reschedule-option input[type=radio]{margin-right:1rem;width:20px;height:20px;cursor:pointer;flex-shrink:0}.reschedule-option-details{flex:1;display:flex;flex-direction:column;gap:.5rem}.reschedule-option-datetime{font-size:1rem;color:var(--color-text-primary);font-weight:600}.reschedule-option-meta{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--color-text-secondary)}.time-range{font-weight:500;color:var(--color-info)}.staff-separator{color:var(--color-text-muted);font-weight:700}.staff-name{color:var(--color-text-secondary);font-style:italic}.cancel-button{background-color:var(--color-bg-light);color:var(--color-text-primary);border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.cancel-button:hover{background-color:var(--color-border)}.submit-button{background-color:var(--color-primary);color:var(--color-bg-white);border:none;padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.submit-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.submit-button:disabled{opacity:.5;cursor:not-allowed}.success-toast{position:fixed;top:2rem;right:2rem;z-index:2000;animation:slideInRight .3s ease-out}@keyframes slideInRight{0%{transform:translate(400px);opacity:0}to{transform:translate(0);opacity:1}}.success-toast-content{background:var(--color-success);color:var(--color-bg-white);padding:1rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;align-items:center;gap:.75rem;min-width:300px}.success-icon{font-size:1.5rem;font-weight:700;background:#fff3;width:32px;height:32px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.success-text{flex:1;font-size:1rem;font-weight:500}.success-close{background:transparent;border:none;color:var(--color-bg-white);font-size:1.5rem;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color .2s;flex-shrink:0}.success-close:hover{background-color:#fff3}@media(max-width:968px){.content-grid{grid-template-columns:1fr;gap:1.5rem}.client-details{position:static}.pending-reschedules-card{margin-top:0}.success-toast{top:1rem;right:1rem;left:1rem}.success-toast-content{min-width:0}}@media(max-width:768px){.classes-container{padding:1rem}.classes-title{font-size:1.5rem}.calendar-wrapper{padding:.5rem}.calendar-wrapper .fc-toolbar{flex-direction:column;gap:.5rem}.calendar-wrapper .fc-toolbar-title{font-size:1.25rem}.calendar-wrapper .fc-button{font-size:.85rem;padding:.4rem .8rem}}.token-request-screen{display:flex;justify-content:center;align-items:center;min-height:400px;padding:2rem}.token-request-card{background:var(--color-bg-white);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);padding:2.5rem;max-width:450px;width:100%;text-align:center}.token-request-logo{max-width:200px;height:auto;margin-bottom:1.5rem}.token-request-card h2{color:var(--color-text-primary);font-size:1.5rem;margin-bottom:1rem}.token-request-error{background-color:var(--color-error-bg);color:var(--color-error);padding:1rem;border-radius:var(--radius-md);margin-bottom:1.5rem;font-size:.95rem}.token-request-instructions{color:var(--color-text-secondary);font-size:.95rem;margin-bottom:1.5rem;line-height:1.5}.token-request-form{display:flex;flex-direction:column;gap:1rem}.token-request-input{width:100%;padding:.875rem 1rem;border:2px solid var(--color-border);border-radius:var(--radius-lg);font-size:1rem;font-family:inherit;transition:border-color .2s;box-sizing:border-box}.token-request-input:focus{outline:none;border-color:var(--color-primary)}.token-request-input:disabled{background-color:var(--color-bg-light);cursor:not-allowed}.token-request-button{background-color:var(--color-primary);color:var(--color-bg-white);border:none;padding:.875rem 1.5rem;border-radius:var(--radius-lg);font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.token-request-button:hover:not(:disabled){background-color:var(--color-primary-hover)}.token-request-button:disabled{opacity:.5;cursor:not-allowed}.token-request-success{text-align:center}.token-request-success h2{color:var(--color-success);margin-bottom:1rem}.token-request-success p{color:var(--color-text-primary);margin-bottom:.5rem}.token-request-hint{color:var(--color-text-secondary);font-size:.9rem;margin-top:1rem}
