.app-nav{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px 0 #0000001a;padding:1rem 2rem}.nav-content{align-items:center;display:flex;justify-content:space-between;margin:0 auto;max-width:1280px}.nav-content h2{color:#111827;font-size:1.5rem;font-weight:600;margin:0}.nav-actions{align-items:center;display:flex;gap:1.5rem}.app-header-new{background:linear-gradient(135deg,#2563eb,#2563eb);border-bottom:3px solid #c17d24;box-shadow:0 2px 8px #00000026;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-container{gap:2rem;justify-content:space-between;margin:0 auto;max-width:1550px;padding:.75rem 1.5rem}.header-container,.header-logo{align-items:center;display:flex}.header-logo{flex-shrink:0;gap:.75rem}.logo-image{background:#0000;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1));height:60px;object-fit:contain;width:auto}.logo-text{color:#fff;display:none;font-size:1.25rem;font-weight:700;text-shadow:0 2px 4px #0003}@media (min-width:768px){.logo-text{display:block}}.desktop-nav{display:none;flex:1 1}@media (min-width:1024px){.desktop-nav{display:block}}.nav-item,.navigation{align-items:center;display:flex;gap:.5rem}.nav-item{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border:none;border-radius:.5rem;color:#fff;cursor:pointer;font-size:.9rem;font-weight:500;padding:.625rem 1rem;transition:all .2s}.nav-item:hover{background:#ffffff40;box-shadow:0 4px 8px #00000026;transform:translateY(-2px)}.nav-item:active{transform:translateY(0)}.header-actions{gap:1rem}.user-info{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border-radius:2rem;display:none;gap:.75rem;padding:.5rem 1rem}@media (min-width:768px){.user-info{display:flex}}.user-avatar,.user-avatar-placeholder{border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px #0000001a;height:36px;object-fit:cover;width:36px}.user-avatar-placeholder{align-items:center;background:#ffffff4d;color:#fff;display:flex;justify-content:center}.user-profile{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;gap:.75rem;padding:.5rem 1rem}.user-avatar img{height:100%;object-fit:cover;width:100%}.user-name{color:#fff;font-size:.9rem;font-weight:600;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-email{color:#6b7280;font-size:.75rem}.user-role{align-items:center;background-color:#dbeafe;border-radius:.25rem;color:#1e40af;display:inline-flex;font-size:.75rem;font-weight:600;gap:.25rem;margin-top:.25rem;padding:.125rem .5rem;width:-webkit-fit-content;width:fit-content}.btn-logout-header{align-items:center;background:#ef4444e6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:none;font-size:.9rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}@media (min-width:768px){.btn-logout-header{display:flex}}.btn-logout-header:hover{background:#dc2626;box-shadow:0 4px 8px #0003;transform:translateY(-2px)}.logout-text{display:none}@media (min-width:1024px){.logout-text{display:inline}}.mobile-menu-toggle{align-items:center;background:#fff3;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s}@media (min-width:1024px){.mobile-menu-toggle{display:none}}.mobile-menu-toggle:hover{background:#ffffff4d}.mobile-nav{animation:slideDown .3s ease-out;background:#e09d3cfa;border-top:1px solid #fff3;display:block;padding:1rem}@media (min-width:1024px){.mobile-nav{display:none}}.mobile-nav .navigation{flex-direction:column;gap:.75rem}.mobile-nav .nav-item{font-size:1rem;justify-content:flex-start;padding:.875rem 1rem;width:100%}.app-body{display:flex;flex:1 1;position:relative}.sidebar{background:linear-gradient(180deg,#1e293b,#0f172a);border-right:1px solid #ffffff1a;box-shadow:2px 0 10px #0000001a;height:calc(100vh - 60px);overflow-y:auto;position:-webkit-sticky;position:sticky;top:0;transition:width .3s ease;width:250px;z-index:100}.sidebar.collapsed{width:70px}.sidebar-content{display:flex;flex-direction:column;height:100%;padding:1rem 0}.sidebar-toggle{align-items:center;background:#2563eb;border:2px solid #1e293b;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:24px;justify-content:center;position:absolute;right:-12px;top:20px;transition:all .2s;width:24px;z-index:10}.sidebar-toggle:hover{background:#1d4ed8;transform:scale(1.1)}.sidebar-nav{display:flex;flex-direction:column;gap:.25rem;margin-top:2rem;padding:0 .75rem}.sidebar-item{align-items:center;border-radius:.5rem;color:#ffffffb3;display:flex;font-size:.95rem;font-weight:500;gap:1rem;padding:.875rem 1rem;position:relative;text-decoration:none;transition:all .2s;white-space:nowrap}.sidebar-item:hover{background:#2563eb1a;color:#fff;transform:translateX(4px)}.sidebar-item.active{background:linear-gradient(90deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #2563eb4d;color:#fff}.sidebar-item.active:before{background:#fff;border-radius:0 2px 2px 0;content:"";height:70%;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.sidebar-icon{flex-shrink:0}.sidebar-text{transition:opacity .2s}.sidebar.collapsed .sidebar-item{justify-content:center;padding:.875rem}.sidebar.collapsed .sidebar-item.active:before,.sidebar.collapsed .sidebar-text{display:none}.main-content-with-sidebar{background:#f9fafb;flex:1 1;min-height:calc(100vh - 60px);overflow-y:auto}.app-footer{background:linear-gradient(135deg,#2c3e50,#34495e);border-top:3px solid #e09d3c;color:#fff;margin-top:auto}.footer-container{margin:0 auto;max-width:1400px;padding:2rem 1.5rem 1rem}.footer-content{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr;margin-bottom:2rem}@media (min-width:768px){.footer-content{grid-template-columns:2fr 1fr 1fr}}.footer-section h3{color:#e09d3c;font-size:1.25rem;font-weight:700;margin-bottom:.75rem}.footer-section h4{color:#e09d3c;font-size:1rem;font-weight:600;margin-bottom:.75rem}.footer-section p{color:#fffc;line-height:1.6}.footer-links{list-style:none;margin:0;padding:0}.footer-links li{margin-bottom:.5rem}.footer-links a{color:#fffc;text-decoration:none;transition:color .2s}.footer-links a:hover{color:#e09d3c}.footer-bottom{border-top:1px solid #ffffff1a;padding-top:1.5rem;text-align:center}.footer-bottom p{color:#fff9;font-size:.875rem}@media (max-width:768px){.app-nav{padding:1rem}.nav-content{align-items:stretch;flex-direction:column;gap:1rem}.nav-actions{justify-content:space-between}.user-profile{justify-content:center}.sidebar{height:100vh;left:-250px;position:fixed;z-index:1000}.sidebar.collapsed{left:-70px}.sidebar.mobile-open{left:0}}.page-container{margin:0 auto;max-width:1400px;padding:2rem}.app-header{margin-bottom:1.5rem}.page-header{border-bottom:2px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1rem}.page-header,.page-header-left{align-items:center;display:flex;gap:1rem}.page-icon{color:#2563eb}.page-title{color:#111827;font-size:2rem;font-weight:700}.welcome-text{color:#374151;font-size:1.25rem;font-weight:600;margin-bottom:.5rem}.page-description{color:#6b7280;font-size:1rem;margin-bottom:2rem}.preview-panel,.settings-panel{display:flex;flex-direction:column}.week-navigation{align-items:center;display:flex;gap:1rem}.week-label{color:#374151;font-weight:500;white-space:nowrap}.grid-container{overflow-x:auto}.grid-wrapper{min-width:100%}.grid-header{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:120px repeat(7,minmax(100px,1fr));margin-bottom:.5rem}.time-header{color:#6b7280;font-size:.875rem;font-weight:500;padding:.5rem}.day-header{border-radius:.5rem;min-width:100px;padding:.5rem;text-align:center}.day-header-active{background-color:#eff6ff}.day-header-inactive{background-color:#f9fafb}.day-name{color:#374151;font-size:.75rem;font-weight:600}.day-date{font-size:.875rem;font-weight:500;margin-top:.25rem}.day-date-active{color:#111827}.day-date-inactive{color:#9ca3af}.day-status{font-size:.75rem;margin-top:.25rem}.day-status-open{color:#16a34a}.day-status-future{color:#6b7280}.slots-container{display:flex;flex-direction:column;gap:.5rem}.slot-row{grid-gap:.5rem;gap:.5rem;grid-template-columns:120px repeat(7,minmax(100px,1fr))}.time-cell{align-items:center;color:#374151;display:flex;font-size:.875rem;font-weight:500;min-width:120px;padding:.5rem}.time-icon{color:#9ca3af;flex-shrink:0;margin-right:.375rem}.time-range{display:flex;flex-direction:column}.time-start{font-size:.875rem;line-height:1.2}.time-end{color:#6b7280;font-size:.75rem;line-height:1.2}.slot-cell{align-items:center;border:2px solid;border-radius:.5rem;display:flex;justify-content:center;min-height:60px;min-width:100px;padding:.75rem;transition:all .2s}.slot-available{background-color:#f0fdf4;border-color:#86efac;cursor:pointer}.slot-available:hover{background-color:#dcfce7;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.slot-blocked{background-color:#fef2f2;border-color:#fca5a5;cursor:not-allowed}.slot-locked{background-color:#f9fafb;border-color:#d1d5db;cursor:not-allowed}.slot-unavailable{background-color:#f3f4f6;border-color:#e5e7eb;cursor:not-allowed}.slot-status{text-align:center;width:100%}.status-available{color:#15803d;font-size:.75rem;font-weight:500}.status-blocked{color:#dc2626;font-size:.75rem;font-weight:500}.status-locked{color:#6b7280;font-size:.75rem}.status-unavailable{color:#9ca3af;font-size:.75rem}.header-content{align-items:flex-start;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.status-tabs{border-bottom:2px solid #e5e7eb;display:flex;gap:.5rem;margin-bottom:2rem;overflow-x:auto}.status-tab{background:none;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;font-size:.95rem;font-weight:500;padding:.875rem 1.5rem;transition:all .2s;white-space:nowrap}.status-tab:hover{background:#00000005;color:#374151}.status-tab.active{color:var(--tab-color);font-weight:600}.user-list-container{display:flex;flex-direction:column;gap:1.5rem}.search-bar{max-width:500px;position:relative}.search-icon{color:#9ca3af;left:1rem;position:absolute;top:50%;transform:translateY(-50%)}.user-count{color:#6b7280;font-size:.875rem;font-weight:500}.table-container{border:1px solid #e5e7eb;border-radius:.75rem;overflow-x:auto}.user-table{background:#fff;border-collapse:collapse;width:100%}.user-table thead{background:#f9fafb;border-bottom:2px solid #e5e7eb}.user-table th{color:#374151;font-size:.875rem;font-weight:600;letter-spacing:.05em;padding:1rem;text-align:left;text-transform:uppercase}.user-table td{border-bottom:1px solid #f3f4f6;padding:1rem}.user-table tbody tr{transition:background-color .2s}.user-table tbody tr:hover{background:#f9fafb}.user-name-cell{align-items:center;display:flex;gap:.75rem}.user-avatar{background:linear-gradient(135deg,#2563eb,#1d4ed8)}.user-name{color:#111827;font-weight:500}.contact-cell{gap:.25rem}.contact-item{color:#6b7280;gap:.5rem}.progress-cell{display:flex;flex-direction:column;gap:.5rem}.progress-bar{background:#e5e7eb;border-radius:9999px;height:8px;overflow:hidden;width:100%}.progress-fill{background:linear-gradient(90deg,#10b981,#059669);height:100%;transition:width .3s}.progress-text{color:#6b7280;font-size:.75rem}.template-list{flex:1 1;overflow-y:auto;padding:1rem}.template-item{border-radius:.5rem;margin-bottom:.75rem;padding:1rem;transition:all .2s}.template-item:hover{border-color:#3b82f6;box-shadow:0 2px 8px #3b82f61a}.template-info h4{color:#111827;font-size:1rem;font-weight:600;margin:0 0 .25rem}.template-date{color:#6b7280;font-size:.8125rem}.template-actions{gap:.5rem}@media (max-width:1023px){.settings-card{position:relative;top:0}}@media (max-width:768px){.page-container{padding:1rem}.page-title{font-size:1.5rem}.grid-header,.slot-row{grid-template-columns:100px repeat(7,120px)}.time-cell{min-width:100px}.slot-cell{min-width:120px}}@media (max-width:480px){.page-header{align-items:flex-start;flex-direction:column}}.booking-container{background:#f5f7fa;min-height:calc(100vh - 200px);padding:24px}.slot-clickable{cursor:pointer;transition:all .2s ease}.slot-clickable:hover{box-shadow:0 2px 8px #0000001a;transform:scale(1.02)}.slot-selected{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border:2px solid #3b82f6}.slot-selected .status-available{color:#1e40af;font-weight:600}.status-check{color:#3b82f6;font-weight:700}.slot-booked{border:2px solid #f59e0b}.selected-slots-section{align-items:center;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:24px;justify-content:space-between;padding:24px}.selected-slots-list{display:flex;flex:1 1;flex-wrap:wrap;gap:12px}.selected-slot-item{background:#fff;border:2px solid #3b82f6;border-radius:8px;color:#1e40af;font-size:14px;font-weight:500;line-height:1.4;padding:12px 16px}.btn-book-now{background:linear-gradient(135deg,#f97316,#ea580c);border:none;border-radius:8px;box-shadow:0 4px 12px #f973164d;color:#fff;cursor:pointer;font-size:16px;font-weight:700;padding:14px 48px;transition:all .2s ease;white-space:nowrap}.btn-book-now:hover{background:linear-gradient(135deg,#ea580c,#c2410c);box-shadow:0 6px 16px #f9731666;transform:translateY(-2px)}@media (max-width:768px){.selected-slots-section{align-items:stretch;flex-direction:column}.btn-book-now{width:100%}}.booking-success-banner{align-items:center;animation:slideDown .3s ease-out;background:#d1fae5;border:1px solid #6ee7b7;border-left:4px solid #10b981;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px 20px}.booking-success-banner svg{color:#059669;flex-shrink:0}.booking-success-banner span{color:#065f46;font-size:15px;font-weight:500}.booking-error-banner{align-items:center;animation:slideDown .3s ease-out;background:#fee2e2;border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px 20px}.booking-error-banner svg{color:#dc2626;flex-shrink:0}.booking-error-banner span{color:#991b1b;font-size:15px;font-weight:500}.btn-book-now:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);opacity:.6}.btn-book-now:disabled:hover{box-shadow:0 4px 12px #9ca3af4d;transform:none}@media (max-width:768px){.booking-error-banner,.booking-success-banner{padding:14px 16px}.booking-error-banner span,.booking-success-banner span{font-size:14px}.booking-error-banner svg,.booking-success-banner svg{height:20px;width:20px}}.bookings-page{margin:0 auto;max-width:1400px;padding:24px;width:100%}.tabs-container{border-bottom:2px solid #e5e7eb;display:flex;gap:8px;margin-bottom:24px}.tab-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#6b7280;cursor:pointer;font-size:16px;font-weight:500;padding:12px 24px;transition:all .2s}.tab-button:hover{background:#f9fafb;color:#374151}.tab-button-active{border-bottom-color:#3b82f6;color:#3b82f6}.bookings-container,.tab-content{width:100%}.bookings-header,.cancellations-header{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.bookings-header h2,.cancellations-header h2{color:#111827;font-size:24px;font-weight:600;margin:0}.btn-request-cancellation{background:linear-gradient(135deg,#ef4444,#dc2626);border:none;border-radius:8px;box-shadow:0 4px 12px #ef44444d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:10px 20px;transition:all .3s}.btn-request-cancellation:hover{box-shadow:0 6px 16px #ef444466;transform:translateY(-2px)}.btn-request-cancellation:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;opacity:.6;transform:none}.bookings-list{display:flex;flex-direction:column;gap:16px}.booking-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:20px;transition:all .3s}.booking-card:hover{border-color:#3b82f6;box-shadow:0 4px 12px #3b82f61a}.booking-card-selected{background:#eff6ff;border-color:#3b82f6}.booking-card-disabled{background:#f9fafb;cursor:not-allowed;opacity:.6}.booking-card-disabled:hover{border-color:#e5e7eb;box-shadow:none}.booking-checkbox{align-items:flex-start;display:flex;padding-top:4px}.booking-checkbox input[type=checkbox]{accent-color:#3b82f6;cursor:pointer;height:20px;width:20px}.booking-details{display:flex;flex:1 1;flex-direction:column;gap:12px}.booking-header-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.booking-date,.booking-instructor,.booking-time{align-items:center;color:#374151;display:flex;font-size:15px;gap:8px}.booking-date svg,.booking-instructor svg,.booking-time svg{color:#3b82f6;flex-shrink:0}.booking-date{font-size:16px;font-weight:600}.status-badge{border-radius:6px;font-size:13px;padding:6px 12px;white-space:nowrap}.status-pending{background:#fef3c7;color:#92400e}.status-cancelled{background:#fee2e2;color:#991b1b}.status-denied{background:#fecaca;color:#7f1d1d}.status-approved{background:#d1fae5;color:#065f46}.cancellation-info{background:#f9fafb;border-radius:8px;margin-top:8px;padding:12px}.cancellation-note{align-items:center;display:flex;font-size:14px;gap:8px;margin:0}.cancellation-note svg{flex-shrink:0}.cancellation-denied{color:#991b1b}.cancellation-approved{color:#065f46}.header-actions{flex-wrap:wrap;gap:16px}.filter-group,.header-actions{align-items:center;display:flex}.filter-group{gap:8px}.filter-group label{color:#6b7280;font-size:14px;font-weight:500}.filter-select{background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-size:14px;padding:8px 12px}.filter-select:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.btn-approve{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 4px 12px #10b9814d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:10px 20px;transition:all .3s}.btn-approve:hover{box-shadow:0 6px 16px #10b98166;transform:translateY(-2px)}.btn-approve:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);cursor:not-allowed;opacity:.6;transform:none}.cancellation-requests-list{display:flex;flex-direction:column;gap:16px}.cancellation-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;display:flex;gap:16px;padding:20px;transition:all .3s}.cancellation-card:hover{border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b1a}.cancellation-card-selected{background:#ecfdf5;border-color:#10b981}.cancellation-checkbox{align-items:flex-start;display:flex;padding-top:4px}.cancellation-checkbox input[type=checkbox]{accent-color:#10b981;cursor:pointer;height:20px;width:20px}.cancellation-details{display:flex;flex:1 1;flex-direction:column;gap:12px}.cancellation-header-row{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.student-info{align-items:center;display:flex;gap:8px}.student-info svg{color:#3b82f6}.student-name{color:#111827;font-size:16px;font-weight:600}.booking-info-row{display:flex;flex-wrap:wrap;gap:24px}.cancellation-reason{background:#f9fafb;border-left:3px solid #3b82f6;border-radius:6px;color:#374151;font-size:14px;padding:12px}.cancellation-reason strong{color:#111827;margin-right:8px}.denial-reason{background:#fef2f2;border-left-color:#ef4444}.cancellation-metadata{color:#6b7280;display:flex;flex-wrap:wrap;font-size:13px;gap:16px}.metadata-item{align-items:center;display:flex}.cancellation-actions{display:flex;gap:12px;margin-top:8px}.btn-deny-single{background:#fff;border:2px solid #ef4444;border-radius:6px;color:#ef4444;cursor:pointer;font-size:14px;font-weight:600;padding:8px 16px;transition:all .2s}.btn-deny-single:hover{background:#ef4444;color:#fff}.btn-deny-single:disabled{cursor:not-allowed;opacity:.5}.modal-content{box-shadow:0 20px 50px #0000004d;max-width:500px;padding:24px}.modal-content h3{color:#111827;font-size:20px;font-weight:600;margin:0 0 16px}.modal-content p{color:#6b7280;font-size:15px;margin:0 0 20px}.form-group label{color:#374151;display:block;font-size:14px;font-weight:500;margin-bottom:8px}.form-group textarea{border:1px solid #d1d5db;border-radius:8px;font-family:inherit;font-size:14px;min-height:100px;padding:12px;resize:vertical;width:100%}.form-group textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;font-size:15px;font-weight:600;padding:10px 20px;transition:all .2s}.btn-primary:hover{box-shadow:0 4px 12px #3b82f666;transform:translateY(-2px)}.btn-primary:disabled{background:linear-gradient(135deg,#9ca3af,#6b7280);transform:none}.btn-secondary{border:2px solid #d1d5db}.btn-secondary:hover{background:#f9fafb;border-color:#9ca3af}.btn-secondary:disabled{opacity:.5}.empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:60px 20px}.empty-icon{margin-bottom:16px}.empty-state h3{color:#111827;font-size:18px;font-weight:600;margin:0 0 8px}.empty-state p{font-size:15px;margin:0}@media (max-width:768px){.bookings-page{padding:16px}.tabs-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.tab-button{font-size:14px;padding:10px 16px;white-space:nowrap}.bookings-header,.cancellations-header{align-items:flex-start;flex-direction:column}.header-actions{align-items:stretch;flex-direction:column;width:100%}.btn-approve,.btn-request-cancellation{width:100%}.booking-card,.cancellation-card{flex-direction:column;gap:12px}.booking-checkbox,.cancellation-checkbox{align-self:flex-start}.booking-info-row{flex-direction:column;gap:12px}.modal-content{margin:20px}.modal-actions{flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}.access-denied-container{align-items:center;background:linear-gradient(135deg,#fef2f2,#fee2e2);border-radius:12px;display:flex;flex-direction:column;justify-content:center;margin:40px auto;max-width:600px;min-height:60vh;padding:40px 20px;text-align:center}.access-denied-container h2{align-items:center;color:#dc2626;display:flex;font-size:32px;font-weight:700;gap:12px;margin:0 0 16px}.access-denied-container h2:before{content:"🚫";font-size:48px}.access-denied-container p{color:#6b7280;font-size:16px;line-height:1.6;margin:0 0 12px;max-width:500px}.access-denied-container p:first-of-type{color:#374151;font-weight:500}.access-denied-container p:last-child{color:#9ca3af;font-size:14px}.manage-bookings-page{margin:0 auto;max-width:1400px;padding:24px;width:100%}@media (max-width:768px){.access-denied-container{margin:20px;min-height:50vh;padding:30px 20px}.access-denied-container h2{font-size:24px}.access-denied-container h2:before{font-size:36px}.access-denied-container p{font-size:15px}.manage-bookings-page{padding:16px}}.slot-booked{color:#92400e;cursor:default;position:relative}.slot-booked:hover{background:linear-gradient(135deg,#fde68a,#fcd34d);border-color:#f59e0b;transform:none}.booked-icon{color:#f59e0b;position:absolute;right:4px;top:4px}.template-info-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:24px;padding:20px}.template-info-header{border-bottom:2px solid #e5e7eb;margin-bottom:16px;padding-bottom:12px}.template-info-header h3{color:#111827;font-size:18px;font-weight:600;margin:0}.template-info-content{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item{display:flex;flex-direction:column;gap:4px}.info-label{color:#6b7280;font-size:13px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.info-value{color:#111827;font-size:15px;font-weight:600}.info-banner{background:#eff6ff;border:2px solid #3b82f6;border-radius:8px;color:#1e40af;font-size:14px;margin-top:24px;padding:16px 20px}.info-banner svg{color:#3b82f6}.error-hint{color:#6b7280;font-size:14px;font-style:italic;margin-top:8px}.legend-booked{background:linear-gradient(135deg,#fef3c7,#fde68a);border:2px solid #f59e0b}.loading-state{padding:60px 20px}.loading-icon{animation:spin 2s linear infinite;color:#3b82f6;margin-bottom:16px}.loading-state h2{color:#374151}.error-state{padding:60px 20px}.error-icon{margin-bottom:16px}.error-state h2{color:#111827;font-size:20px}.error-state p{color:#6b7280;font-size:15px;margin:0 0 8px;max-width:500px}.header-subtitle{color:#6b7280;font-size:14px;font-weight:400;margin:8px 0 0}@media (max-width:768px){.template-info-content{grid-template-columns:1fr}.info-banner{flex-direction:column;text-align:center}.booked-icon{display:none}}.legend-box-booked{border:2px solid #f59e0b}.legend-box-booked,.slot-booked{background:linear-gradient(135deg,#fef3c7,#fde68a)}.slot-booked{border-color:#f59e0b}.status-booked{font-size:13px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);overflow-y:auto;padding:20px}.modal-content{animation:modalSlideIn .3s ease-out;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;max-height:90vh;width:100%}.modal-large{max-width:900px}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.modal-header{border-bottom:2px solid #e5e7eb;padding:24px}.modal-header-content{align-items:center;display:flex;gap:12px}.modal-header h2{color:#111827;font-size:24px;font-weight:700;margin:0}.close-button{background:none;border:none;border-radius:6px;color:#6b7280;cursor:pointer;padding:8px;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#111827}.modal-body{flex:1 1;padding:24px}.detail-section{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:20px;padding:20px}.detail-section:last-child{margin-bottom:0}.section-header{border-bottom:2px solid #e5e7eb;gap:10px;margin-bottom:16px;padding-bottom:12px}.section-header h3{color:#111827;font-size:18px;font-weight:600;margin:0}.section-content{margin-top:16px}.detail-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{color:#6b7280;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.detail-value{align-items:center;color:#111827;display:flex;font-size:15px;font-weight:500;gap:8px}.detail-value-mono{color:#4b5563;font-family:Courier New,monospace;font-size:13px}.detail-icon{color:#9ca3af;flex-shrink:0}.status-badge-detail{border-radius:12px;color:#fff;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.address-section{grid-gap:16px;border-top:1px solid #e5e7eb;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:20px;padding-top:20px}.address-block h4{align-items:center;color:#374151;display:flex;font-size:14px;font-weight:600;gap:6px;margin:0 0 8px}.address-block p{color:#6b7280;font-size:14px;margin:4px 0}.address-block .postcode{color:#111827;font-weight:600}.relationships-list{display:flex;flex-direction:column;gap:12px}.relationship-card{background:#fff;border:2px solid #e5e7eb;border-radius:8px;padding:16px}.relationship-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.relationship-name{color:#111827;font-size:16px;font-weight:600}.relationship-status{border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 12px}.status-active{background:#10b981}.status-inactive{background:#6b7280}.relationship-details{display:flex;flex-direction:column;gap:8px}.relationship-detail{align-items:center;color:#6b7280;display:flex;font-size:14px;gap:8px}.relationship-id{border-top:1px solid #e5e7eb;color:#9ca3af;font-size:12px;margin-top:12px;padding-top:12px}.bookings-table{background:#fff;border-radius:8px;overflow:hidden}.detail-table{border-collapse:collapse;width:100%}.detail-table thead{background:#f3f4f6}.detail-table th{border-bottom:2px solid #e5e7eb;color:#374151;font-size:13px;font-weight:600;letter-spacing:.5px;padding:12px 16px;text-align:left;text-transform:uppercase}.detail-table td{border-bottom:1px solid #f3f4f6;color:#6b7280;font-size:14px;padding:12px 16px}.detail-table tbody tr:last-child td{border-bottom:none}.detail-table tbody tr:hover{background:#f9fafb}.booking-status{background:#e5e7eb;border-radius:12px;color:#374151;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.status-confirmed{background:#d1fae5;color:#065f46}.bookings-summary{background:#f9fafb;border-top:2px solid #e5e7eb;color:#374151;font-size:14px;padding:16px}.empty-section{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.empty-icon{margin-bottom:12px}.empty-section p{color:#9ca3af;font-size:14px;margin:0}.modal-footer{align-items:center;border-top:2px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.btn-primary{background:#3b82f6;font-size:14px;padding:10px 20px}.btn-primary:hover{background:#2563eb}.btn-secondary{background:#f3f4f6;font-size:14px;padding:10px 20px}.btn-secondary:hover{background:#e5e7eb;border-color:#d1d5db}@media (max-width:768px){.modal-content{border-radius:0;max-height:100vh;max-width:100%}.modal-large{max-width:100%}.address-section,.detail-grid{grid-template-columns:1fr}.detail-table{font-size:12px}.detail-table td,.detail-table th{padding:8px 12px}.bookings-table{overflow-x:auto}}.modal-medium{max-width:650px}.edit-form{display:flex;flex-direction:column;gap:24px}.form-section{gap:12px}.form-group{gap:6px}.form-label{gap:8px}.form-sublabel{font-size:13px}.form-label-readonly{color:#9ca3af;font-size:13px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.form-hint{font-size:13px;margin-top:4px}.form-input{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#111827;font-size:15px;padding:10px 14px;transition:all .2s;width:100%}.form-input:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input-readonly{background:#f9fafb;border:2px solid #f3f4f6;border-radius:8px;color:#6b7280;cursor:not-allowed;font-size:15px;padding:10px 14px;width:100%}.form-input::placeholder{color:#9ca3af}.status-toggle-group{gap:12px}.status-toggle-btn{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#6b7280;flex:1 1;font-size:14px;font-weight:600;gap:8px;justify-content:center;min-width:120px;padding:12px 20px;transition:all .2s}.status-toggle-btn:hover{background:#f9fafb;border-color:#d1d5db}.status-toggle-btn.active{background:linear-gradient(135deg,#d1fae5,#a7f3d0);color:#065f46}.status-toggle-btn.inactive{background:linear-gradient(135deg,#f3f4f6,#e5e7eb);border-color:#6b7280;color:#374151}.status-toggle-btn.passed{background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#2563eb;color:#1e40af}.address-group{grid-gap:12px;display:grid;gap:12px;grid-template-columns:2fr 1fr}@media (max-width:600px){.address-group{grid-template-columns:1fr}}.success-banner{align-items:center;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border:2px solid #10b981;border-radius:8px;color:#065f46;display:flex;gap:12px}.error-banner,.success-banner{animation:slideDown .3s ease-out;font-size:14px;font-weight:600;padding:14px 16px}.error-banner{background:linear-gradient(135deg,#fee2e2,#fecaca);border:2px solid #ef4444;color:#991b1b}.btn-primary{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;padding:12px 24px;transition:all .2s}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6}.btn-secondary{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .2s}.btn-secondary:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}.btn-secondary:disabled{cursor:not-allowed;opacity:.6}.btn-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:16px;width:16px}@media (max-width:768px){.modal-medium{max-width:100%}.status-toggle-group{flex-direction:column}.status-toggle-btn{min-width:100%}.form-input,.form-input-readonly{font-size:16px}}.date-cell,.expiry-cell{align-items:center;color:#6b7280;display:flex;gap:6px}.business-name{color:#1f2937;font-weight:500;margin-bottom:4px}.business-address{color:#6b7280;font-size:.875rem}.user-subtitle{color:#9ca3af;font-family:monospace;font-size:.75rem;margin-top:2px}.error-state{background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;margin:2rem 0;padding:3rem 2rem}.error-state h3{color:#dc2626;font-size:1.25rem;margin-bottom:.5rem}.error-state p{color:#991b1b;margin-bottom:1.5rem}.btn-retry{background:#dc2626;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1.5rem;transition:background-color .2s}.btn-retry:hover{background:#b91c1c}.status-badge{border-radius:12px;padding:4px 12px;text-transform:capitalize}.contact-cell{display:flex;flex-direction:column;gap:8px}.contact-item{align-items:center;color:#4b5563;display:flex;font-size:.875rem;gap:8px}.contact-item svg{color:#9ca3af;flex-shrink:0}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:600;height:40px;justify-content:center;width:40px}@media (max-width:1024px){.table-container{overflow-x:auto}.user-table{min-width:800px}}.spinner{border-top-color:#667eea;height:40px;margin:0 auto 1rem;width:40px}.loading-state{padding:3rem 2rem}.loading-state p{color:#6b7280;margin-top:1rem}.empty-state{background:#f9fafb;border:1px dashed #d1d5db;border-radius:8px;margin:2rem 0;padding:3rem 2rem}.student-selector-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;margin-bottom:24px;padding:24px}.selector-header{align-items:center;display:flex;gap:12px;margin-bottom:16px}.selector-icon{color:#2563eb}.selector-header h3{color:#1f2937;font-size:20px;font-weight:600;margin:0}.student-dropdown{background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#1f2937;cursor:pointer;font-family:inherit;font-size:15px;padding:12px 16px;transition:all .2s ease;width:100%}.student-dropdown:hover{border-color:#3b82f6}.student-dropdown:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.student-dropdown option{padding:8px}.selected-student-info{background:#f0f9ff;border-left:4px solid #3b82f6;border-radius:6px;margin-top:16px;padding:16px}.selected-student-info p{color:#1f2937;font-size:14px;margin:6px 0}.selected-student-info strong{color:#1e3a8a;font-weight:600}.error-state .error-hint{color:#6b7280;font-size:14px;font-style:italic;margin-top:12px}.btn-book-now{font-size:15px;font-weight:600;letter-spacing:.5px;min-width:200px;padding:14px 28px;text-transform:uppercase}.btn-book-now:disabled{cursor:not-allowed;opacity:.5}@media (max-width:768px){.student-selector-card{padding:16px}.selector-header h3{font-size:18px}.student-dropdown{font-size:14px;padding:10px 14px}.selected-student-info{padding:12px}.selected-student-info p{font-size:13px}}.spinner{animation:spin .8s linear infinite;border:3px solid #f3f4f6;border-top-color:#3b82f6;height:48px;width:48px}.legend-box-booked{background:#fbbf24;border:1px solid #f59e0b}.slot-booked{background:#fef3c7;border-color:#fbbf24;cursor:not-allowed}.status-booked{color:#92400e;font-size:11px;font-weight:600;text-align:center}.status-toggle-btn.vehicle-btn{background:#fff;border:1px solid #d1d5db;color:#374151;transition:all .2s ease}.status-toggle-btn.vehicle-btn:hover{background:#f9fafb;border-color:#9ca3af}.status-toggle-btn.vehicle-btn.automatic{background:#3b82f6;border-color:#3b82f6;color:#fff}.status-toggle-btn.vehicle-btn.automatic:hover{background:#2563eb;border-color:#2563eb}.status-toggle-btn.vehicle-btn.manual{background:#6b7280;border-color:#6b7280;color:#fff}.status-toggle-btn.vehicle-btn.manual:hover{background:#4b5563;border-color:#4b5563}.status-toggle-btn.vehicle-btn svg{margin-right:.5rem}.form-hint{color:#6b7280;font-size:.875rem;margin-top:.5rem}.form-hint strong{color:#111827;font-weight:600}.form-section{border-bottom:1px solid #e5e7eb;margin-bottom:1.5rem;padding-bottom:1.5rem}.form-section:last-child{border-bottom:none}.form-label{align-items:center;display:flex;font-size:.95rem;gap:.5rem;margin-bottom:.75rem}.status-toggle-group{display:flex;flex-wrap:wrap;gap:.75rem}.status-toggle-btn{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s ease}.status-toggle-btn:hover{box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.status-toggle-btn:active{transform:translateY(0)}.status-toggle-btn.active{background:#10b981;border-color:#10b981;color:#fff}.status-toggle-btn.inactive{background:#ef4444;border-color:#ef4444;color:#fff}.status-toggle-btn.passed{background:#8b5cf6;border-color:#8b5cf6;color:#fff}.student-detail-item-id{display:none;flex-direction:column;gap:4px}.action-btn.register{align-items:center;background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s ease}.action-btn.register:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f64d;transform:translateY(-1px)}.action-btn.register:active{transform:translateY(0)}.action-btn.register .btn-text{display:inline-block}@media (max-width:768px){.action-btn.register .btn-text{display:none}.action-btn.register{padding:.5rem}}.action-buttons{align-items:center;justify-content:flex-start}.action-btn{background:#fff;border:1px solid #e5e7eb;border-radius:6px;height:36px;padding:0;transition:all .2s ease;width:110px}.action-btn:hover{border-color:#3b82f6;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.action-btn.view{color:#3b82f6}.action-btn.view:hover{background:#eff6ff}.action-btn.edit:hover{background:#fffbeb}.action-btn.delete:hover{background:#fef2f2}.user-list-container[data-status=invited] .action-buttons{justify-content:center}.user-list-container:not([data-status=invited]) .action-buttons{justify-content:flex-start}.info-banner{align-items:center;background-color:#e3f2fd;border-left:4px solid #2196f3;border-radius:4px;display:flex;font-size:.95rem;gap:12px;line-height:1.5;margin-bottom:20px;padding:12px 16px}.info-banner svg{color:#2196f3;flex-shrink:0}.select-all-wrapper{align-items:center;background-color:#f5f5f5;border-radius:4px;display:flex;gap:8px;padding:8px 12px}.select-all-wrapper input[type=checkbox]{cursor:pointer;height:18px;width:18px}.select-all-wrapper label{cursor:pointer;font-size:.95rem;font-weight:500;-webkit-user-select:none;user-select:none}.status-badge.status-active{background-color:#4caf50;border-radius:12px;color:#fff;font-size:.85rem;font-weight:600;letter-spacing:.5px;padding:4px 12px;text-transform:uppercase}.bookings-footer-info{background-color:#f5f5f5;border-radius:0 0 8px 8px;border-top:1px solid #e0e0e0;margin-top:20px;padding:16px;text-align:center}.bookings-footer-info p{color:#666;font-size:.95rem;margin:0}.bookings-footer-info strong{color:#333;font-weight:600}.booking-metadata{border-top:1px solid #f0f0f0;margin-top:8px;padding-top:8px}.booking-metadata .metadata-item{color:#666;font-family:Monaco,Courier New,monospace;font-size:.85rem}.cancellation-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px);transition:all .2s ease}.btn-add,.btn-login,.btn-new{align-items:center;background-color:#2563eb;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}.btn-add:hover,.btn-login:hover,.btn-new:hover{background-color:#1d4ed8;box-shadow:0 4px 6px #2563eb33;transform:translateY(-1px)}.btn-add{border-radius:.375rem;font-size:.8125rem;padding:.375rem .75rem}.btn-logout{align-items:center;background-color:#ef4444;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;transition:all .2s}.btn-logout:hover{background-color:#dc2626;box-shadow:0 4px 6px #ef444433;transform:translateY(-1px)}.btn-save,.btn-save-form{align-items:center;background-color:#16a34a;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:background-color .2s}.btn-save-form:hover,.btn-save:hover{background-color:#15803d}.btn-save:disabled{cursor:not-allowed;opacity:.6}.btn-save-form{padding:.75rem 1.5rem}.btn-delete,.btn-delete-small{align-items:center;background-color:#ef4444;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.5rem;transition:background-color .2s}.btn-delete-small:hover,.btn-delete:hover{background-color:#dc2626}.btn-load{align-items:center;background-color:#10b981;border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:.8125rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:background-color .2s}.btn-load:hover{background-color:#059669}.btn-templates{background-color:#6366f1;border-radius:.5rem;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1rem;transition:background-color .2s}.btn-templates:hover{background-color:#4f46e5}.btn-cancel{background:#f3f4f6;border:none;border-radius:.5rem;color:#374151;cursor:pointer;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.btn-cancel:hover{background:#e5e7eb}.btn-close{background:none;border:none;border-radius:.375rem;color:#6b7280;cursor:pointer;padding:.5rem;transition:all .2s}.btn-close:hover{background:#f3f4f6;color:#111827}.nav-button{background:none;border:none;border-radius:.5rem;color:#374151;cursor:pointer;padding:.5rem;transition:background-color .2s}.nav-button:hover{background-color:#f3f4f6}.action-buttons{display:flex;gap:.5rem}.action-btn{align-items:center;border-radius:.375rem;display:flex;justify-content:center;padding:.5rem;transition:all .2s}.action-btn.view{background:#dbeafe;color:#2563eb}.action-btn.view:hover{background:#2563eb;color:#fff}.action-btn.edit{background:#fef3c7;color:#f59e0b}.action-btn.edit:hover{background:#f59e0b;color:#fff}.action-btn.delete{background:#fee2e2;color:#ef4444}.action-btn.delete:hover{background:#ef4444;color:#fff}.settings-form,.user-form{display:flex;flex-direction:column;gap:1rem}.user-form{gap:2rem;padding:1.5rem}.form-group{display:flex;flex-direction:column}.form-label{font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-label-small{color:#6b7280;display:block;font-size:.75rem;margin-bottom:.25rem}.form-input,.form-select,.form-textarea{border:1px solid #d1d5db;border-radius:.5rem;font-size:.875rem;padding:.5rem .75rem;transition:all .2s;width:100%}.form-input-small{border:1px solid #d1d5db;border-radius:.375rem;font-size:.8125rem;padding:.375rem .5rem;transition:all .2s;width:100%}.form-input-small:focus,.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.form-input.error{border-color:#ef4444}.form-textarea{font-family:inherit;font-size:.95rem;min-height:100px;padding:.75rem;resize:vertical}.search-input{border:1px solid #d1d5db;border-radius:.5rem;font-size:.95rem;padding:.75rem 1rem .75rem 3rem;transition:all .2s;width:100%}.search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a;outline:none}.input-group-2{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:1fr 1fr}.form-row{grid-gap:1rem;gap:1rem}.form-help-text{color:#6b7280}.error-text,.form-help-text{font-size:.75rem;margin-top:.25rem}.error-text{color:#ef4444}.form-section{display:flex;flex-direction:column;gap:1rem}.section-title{border-bottom:2px solid #e5e7eb;color:#374151;font-size:1.125rem;font-weight:600;margin-bottom:.5rem;padding-bottom:.5rem}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.form-actions{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;padding-top:1rem}.form-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:1.5rem}.form-header h2{color:#111827;font-size:1.5rem;font-weight:600;margin:0}.settings-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;max-height:calc(100vh - 2rem);overflow-y:auto;padding:1.5rem;position:-webkit-sticky;position:sticky;top:1rem}.settings-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.settings-title-wrapper{gap:.5rem}.settings-icon{color:#2563eb}.settings-title{color:#1f2937;font-size:1.25rem;font-weight:600}.preview-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:1.5rem}.preview-header{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.preview-title{font-size:1.25rem}.preview-panel-full{grid-column:1/-1}.page-content{background:#fff;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:2rem}.dashboard-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-top:2rem}.dashboard-card{background:linear-gradient(135deg,#f8fafc,#f1f5f9);border:1px solid #e2e8f0;border-radius:.75rem;padding:1.5rem;transition:all .2s}.dashboard-card:hover{border-color:#2563eb;box-shadow:0 8px 16px #0000001a;transform:translateY(-4px)}.dashboard-card h3{color:#1f2937;font-size:1.125rem;font-weight:600;margin-bottom:.75rem}.dashboard-card p{color:#6b7280;font-size:.875rem}.login-card{background-color:#fff;border-radius:1rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:400px;padding:3rem 2rem;text-align:center;width:100%}.login-card h1{color:#111827;font-size:1.875rem;font-weight:700;margin-bottom:.5rem}.login-card p{color:#6b7280;font-size:1rem;margin-bottom:2rem}.appointments-list{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.appointment-card{align-items:flex-start;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;display:flex;gap:.5rem;padding:.75rem}.appointment-fields{display:flex;flex:1 1;flex-direction:column;gap:.5rem}.appointment-field{display:flex;flex-direction:column}.create-user-form{background:#fff;border-radius:.75rem;box-shadow:0 4px 6px #0000001a}.unsaved-changes-alert{background-color:#fef3c7;border:1px solid #fcd34d;border-radius:.5rem;margin-top:1rem;padding:.75rem}.unsaved-changes-text{align-items:center;color:#92400e;display:flex;font-size:.875rem;gap:.5rem}.pulse-dot{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite;background-color:#eab308;border-radius:50%;height:.5rem;width:.5rem}.save-message{animation:slideIn .3s ease-out;border-radius:.5rem;font-size:.875rem;font-weight:500;margin-bottom:1rem;padding:.875rem 1rem;text-align:center}.save-message.success{background-color:#d1fae5;border:1px solid #10b981;color:#065f46}.save-message.error{background-color:#fee2e2;border:1px solid #ef4444;color:#991b1b}.error-container,.loading-container,.login-container{align-items:center;background-color:#f9fafb;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:1rem}.login-container{background:linear-gradient(135deg,#667eea,#764ba2)}.spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#2563eb;height:50px;width:50px}.error-container p,.loading-container p{color:#6b7280;font-size:1rem;margin-top:1rem}.error-container h2{color:#ef4444;margin-bottom:.5rem}.loading-state{gap:1rem;padding:3rem}.loading-state .spinner{height:40px;width:40px}.empty-state{color:#6b7280;padding:3rem 0;text-align:center}.empty-state h3{color:#374151;font-size:1.25rem;margin-bottom:.5rem}.empty-state p{color:#6b7280}.empty-icon{color:#d1d5db;margin:0 auto 1rem;opacity:.5}.empty-text{font-size:1rem}.empty-subtext{font-size:.875rem;margin-top:.5rem}.empty-message{background-color:#f9fafb;border:1px dashed #d1d5db;border-radius:.375rem;padding:1rem}.empty-message,.empty-templates{color:#9ca3af;font-size:.875rem;text-align:center}.empty-templates{padding:3rem 1rem}.badge-editing{background-color:#dbeafe;border-radius:.25rem;color:#1e40af;margin-left:.5rem;padding:.25rem .5rem}.badge-editing,.status-badge{display:inline-block;font-size:.75rem;font-weight:600}.status-badge{border-radius:9999px;color:#fff;letter-spacing:.05em;padding:.375rem .75rem;text-transform:uppercase}.template-modal-overlay{align-items:center;animation:fadeIn .2s ease-out;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.template-modal{animation:slideUp .3s ease-out;background-color:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:100%}.modal-header{padding:1.5rem}.modal-header h3{color:#111827;font-size:1.25rem}.modal-close{border-radius:.375rem;color:#6b7280;font-size:2rem;height:2rem;transition:background-color .2s;width:2rem}.modal-close:hover{background-color:#f3f4f6;color:#111827}.legend{display:flex;flex-wrap:wrap;font-size:.875rem;gap:1rem;margin-top:1.5rem}.legend-item{align-items:center;display:flex;gap:.5rem}.legend-box{border:2px solid;border-radius:.25rem;flex-shrink:0;height:1rem;width:1rem}.legend-box-available{background-color:#f0fdf4;border-color:#86efac}.legend-box-blocked{background-color:#fef2f2;border-color:#fca5a5}.legend-box-locked{background-color:#f9fafb;border-color:#d1d5db}.legend-box-unavailable{background-color:#f3f4f6;border-color:#e5e7eb}.legend-text{color:#374151}.publish-container{background:#f5f7fa;min-height:calc(100vh - 200px);padding:24px}.publish-header{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;margin-bottom:24px;padding:20px 24px}.publish-header-left{align-items:center;display:flex;flex:1 1;gap:16px}.publish-template-name{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;color:#1f2937;font-size:16px;font-weight:500;max-width:600px;overflow:hidden;padding:10px 20px;text-overflow:ellipsis;white-space:nowrap}.btn-publish{align-items:center;background:linear-gradient(135deg,#6b7fe3,#5b6fd5);border:none;border-radius:8px;box-shadow:0 2px 8px #5b7fe34d;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:700;gap:8px;letter-spacing:.5px;padding:12px 32px;text-transform:uppercase;transition:all .2s ease}.btn-publish:hover:not(:disabled){background:linear-gradient(135deg,#5b6fd5,#4c5fc5);box-shadow:0 4px 12px #5b7fe366;transform:translateY(-1px)}.btn-publish:active:not(:disabled){transform:translateY(0)}.btn-publish:disabled{background:#9ca3af;cursor:not-allowed;opacity:.6}.badge-active{border-radius:20px;box-shadow:0 2px 6px #10b9814d;font-size:13px;padding:6px 16px}.publish-container .preview-card{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.publish-container .save-message{border-radius:8px;font-size:14px;font-weight:500;margin-bottom:16px;padding:12px 24px}.publish-container .save-message.success{background:#d1fae5;border-left:4px solid #10b981;color:#065f46}.publish-container .save-message.error{background:#fee2e2;border-left:4px solid #ef4444;color:#991b1b}@media (max-width:768px){.publish-header{align-items:stretch;flex-direction:column;gap:16px}.publish-header-left{align-items:flex-start;flex-direction:column;gap:12px}.publish-template-name{max-width:none;width:100%}.btn-publish{justify-content:center;padding:12px 24px;width:100%}.publish-container{padding:16px}}.publish-container .tab-content-placeholder{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:60px 32px}.publish-container .tab-content-placeholder h2{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 12px}.publish-container .tab-content-placeholder p{color:#6b7280;font-size:16px;margin:0}@media (max-width:1023px){.settings-card{max-height:none;position:relative;top:0}}@media (max-width:768px){.login-card{padding:2rem 1.5rem}.login-card h1{font-size:1.5rem}.preview-header{align-items:flex-start;flex-direction:column}.week-navigation{justify-content:space-between;width:100%}.appointment-fields{gap:.75rem}.header-content{align-items:stretch;flex-direction:column}.header-actions{justify-content:stretch;width:100%}.btn-new,.btn-templates{flex:1 1;justify-content:center}.template-modal{margin:1rem;max-height:calc(100vh - 2rem)}.template-item{align-items:stretch;flex-direction:column;gap:.75rem}.template-actions{justify-content:flex-end}.dashboard-grid{grid-template-columns:1fr}}.instructor-info{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin-bottom:24px;padding:20px 24px}.instructor-info h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.loading-state{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:80px 32px;text-align:center}.loading-icon{animation:pulse 2s ease-in-out infinite;color:#6b7fe3;margin-bottom:24px}.loading-state h2{color:#1f2937;font-size:20px;font-weight:600;margin:0}.error-state{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;justify-content:center;padding:80px 32px;text-align:center}.error-icon{color:#ef4444;margin-bottom:24px}.error-state h2{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 12px}.error-message{color:#6b7280;font-size:16px;margin:0;max-width:500px}.error-banner{align-items:center;background:#fee2e2;border:1px solid #fecaca;border-left:4px solid #ef4444;border-radius:8px;display:flex;gap:12px;margin-bottom:24px;padding:16px 20px}.error-banner-icon{color:#ef4444;flex-shrink:0}.error-banner-content{flex:1 1}.error-banner-content h4{color:#991b1b;font-size:16px;font-weight:600;margin:0 0 4px}.error-banner-content p{color:#991b1b;font-size:14px;margin:0}@media (max-width:768px){.instructor-info{padding:16px}.instructor-info h3{font-size:16px}.error-state,.loading-state{padding:60px 24px}.error-icon,.loading-icon{height:48px;width:48px}.error-state h2{font-size:20px}.error-message{font-size:15px}}.support-page{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:2rem}.support-container{background:#fff;border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:600px;padding:3rem;text-align:center;width:100%}.support-icon-wrapper{margin-bottom:2rem}.support-icon{animation:pulse 2s ease-in-out infinite;color:#ef4444}.support-title{color:#1f2937;font-size:2rem;font-weight:700;margin-bottom:1.5rem}.support-description{color:#6b7280;line-height:1.6;margin-bottom:2rem}.support-description p{margin-bottom:.75rem}.support-error-details{background:#fef2f2;border:1px solid #fee2e2;border-radius:8px;margin-bottom:2rem;padding:1.5rem;text-align:left}.support-error-details h3{color:#dc2626;font-size:1rem;margin-bottom:1rem}.error-message{color:#991b1b;font-size:.875rem;margin-bottom:1rem}.error-message strong{display:block;margin-bottom:.5rem}.error-stack{color:#991b1b;font-size:.75rem}.error-stack strong{display:block;margin-bottom:.5rem}.error-stack pre{word-wrap:break-word;background:#fff;border-radius:4px;overflow-x:auto;padding:1rem;white-space:pre-wrap}.support-contact{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;margin-bottom:2rem;padding:2rem}.support-contact-header{align-items:center;display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.support-contact-header svg{color:#667eea}.support-contact-header h3{color:#1f2937;font-size:1.25rem;margin:0}.support-contact p{color:#6b7280;margin-bottom:1rem}.support-email{background:#fff;border:2px solid #667eea;border-radius:8px;color:#667eea;display:inline-block;font-size:1.25rem;font-weight:600;margin:1rem 0;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.support-email:hover{background:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff;transform:translateY(-2px)}.support-contact-note{color:#9ca3af;font-size:.875rem;margin-top:1rem}.support-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.btn-support{align-items:center;border:none;border-radius:8px;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;padding:.875rem 1.5rem;transition:all .3s ease;width:100%}.btn-support:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3;box-shadow:0 4px 12px #667eea4d;transform:translateY(-2px)}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover:not(:disabled){background:#4b5563;box-shadow:0 4px 12px #6b72804d;transform:translateY(-2px)}.btn-outline{background:#fff;border:2px solid #667eea;color:#667eea}.btn-outline:hover:not(:disabled){background:#f3f4f6;transform:translateY(-2px)}.support-help-text{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:1.5rem;text-align:left}.support-help-text p{color:#92400e;margin-bottom:.75rem}.support-help-text strong{font-weight:600}.support-help-text ul{list-style:none;margin:0;padding:0}.support-help-text li{color:#78350f;padding:.5rem 0 .5rem 1.5rem;position:relative}.support-help-text li:before{color:#f59e0b;content:"•";font-weight:700;left:.5rem;position:absolute}@media (max-width:640px){.support-page{padding:1rem}.support-container{padding:2rem 1.5rem}.support-title{font-size:1.5rem}.support-email{font-size:1rem;padding:.625rem 1rem}.btn-support{font-size:.875rem;padding:.75rem 1rem}}.support-container{animation:fadeIn .5s ease-out}.explore-description{color:#6b8079;font-size:25px;line-height:1.6;margin-bottom:2rem}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#111827;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif}.app-container,body{background-color:#f9fafb}.app-container{flex:1 1;min-height:100vh;padding:1rem}@media (min-width:768px){.app-container{padding:2rem}}.app-wrapper{margin:0 auto;max-width:1280px}.app-with-layout{display:flex;flex-direction:column;min-height:100vh}.main-content{display:flex;flex:1 1;flex-direction:column}.app-title{color:#111827;font-size:1.875rem;font-weight:700}.app-subtitle{color:#6b7280;margin-top:.5rem}.app-layout{grid-gap:1.5rem;display:grid;gap:1.5rem}@media (min-width:1024px){.app-layout{grid-template-columns:1fr 2fr}}.inline-icon{display:inline;margin-right:.25rem;vertical-align:middle}@keyframes spin{to{transform:rotate(1turn)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.settings-card::-webkit-scrollbar,.sidebar::-webkit-scrollbar{width:6px}.settings-card::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.sidebar::-webkit-scrollbar-track{background:#0000}.settings-card::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.sidebar::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.settings-card::-webkit-scrollbar-thumb:hover{background:#555}.sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width:768px){.app-title{font-size:1.5rem}}.break-row{background:linear-gradient(90deg,#fef3c7,#fde68a);border-left:4px solid #f59e0b}.break-row .time-cell{background:#fbbf24;color:#78350f;font-weight:600}.break-icon{color:#92400e!important}.break-cell-full{background:linear-gradient(90deg,#fef3c7,#fde68a);border:2px dashed #f59e0b;border-radius:6px;justify-content:center;margin:0 4px;padding:12px}.break-cell-full,.break-label{align-items:center;display:flex}.break-label{color:#92400e;font-size:14px;font-weight:700;gap:8px;letter-spacing:.5px;text-transform:uppercase}.break-label svg{color:#f59e0b}.slot-row{border-bottom:1px solid #e5e7eb;display:grid;grid-template-columns:120px repeat(7,1fr);min-height:60px;transition:all .2s ease}.slot-row:hover{background-color:#f9fafb}.break-row:hover{background:linear-gradient(90deg,#fde68a,#fcd34d)}.time-icon{color:#6b7280}@keyframes breakPulse{0%,to{opacity:1}50%{opacity:.8}}.break-row{animation:breakPulse 3s ease-in-out infinite}.template-item{border-left:4px solid #e5e7eb;transition:border-color .2s ease}.template-active{background:linear-gradient(90deg,#f0fdf4,#fff);border-left-color:#10b981}.template-inactive{background:linear-gradient(90deg,#f9fafb,#fff);border-left-color:#9ca3af}.template-header{align-items:center;display:flex;gap:8px;margin-bottom:4px}.badge-active{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d}.badge-active,.badge-inactive{align-items:center;border-radius:10px;color:#fff;display:inline-flex;font-size:10px;font-weight:700;letter-spacing:.5px;padding:3px 10px;text-transform:uppercase}.badge-inactive{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 4px #6b72804d}.btn-new:disabled{background:#d1d5db;box-shadow:none;color:#9ca3af;opacity:.6}.btn-new:disabled:hover{background:#d1d5db;box-shadow:none;transform:none}@media (max-width:768px){.template-header{gap:6px}.badge-active,.badge-inactive{font-size:9px;padding:2px 8px}.break-label{font-size:12px}.break-cell-full{padding:8px}.template-header{gap:6px}.badge-active,.badge-inactive{font-size:9px;padding:2px 8px}}.badge-status-active{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 2px 4px #10b9814d}.badge-status-active,.badge-status-inactive{align-items:center;border-radius:12px;color:#fff;display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.5px;margin-left:8px;padding:4px 12px;text-transform:uppercase}.badge-status-inactive{background:linear-gradient(135deg,#6b7280,#4b5563);box-shadow:0 2px 4px #6b72804d}.settings-title-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:12px}@media (max-width:768px){.badge-status-active,.badge-status-inactive{font-size:10px;margin-left:6px;padding:3px 10px}.settings-title-wrapper{gap:8px}}.page-container{background:#f5f7fa;display:flex;flex-direction:column;min-height:100vh}.page-header{background:#fff;border-bottom:1px solid #e5e7eb;padding:24px 32px}.page-title-wrapper{align-items:center;display:flex;gap:16px}.page-icon{color:#5b7fe3}.page-title{color:#1f2937;font-size:24px;font-weight:600;margin:0}.tab-navigation{align-items:center;background:#fff;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;padding:0 32px}.tabs{display:flex;gap:0}.tab{background:#0000;border:none;border-bottom:3px solid #0000;color:#9ca3af;cursor:pointer;font-size:15px;font-weight:500;padding:16px 24px;transition:all .2s ease}.tab:hover{background:#f9fafb;color:#6b7280}.tab-active{border-bottom-color:#10b981;color:#10b981;font-weight:600}.tab-content-wrapper{display:flex;flex:1 1;flex-direction:column}.template-actions-bar{background:#fff;border-bottom:1px solid #e5e7eb;display:flex;gap:12px;justify-content:flex-end;padding:16px 32px}.btn-templates-list{align-items:center;background:#5b7fe3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-templates-list:hover{background:#4c6fd5;transform:translateY(-1px)}.btn-new-template{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-new-template:hover:not(:disabled){border-color:#5b7fe3;color:#5b7fe3}.btn-new-template:disabled{cursor:not-allowed;opacity:.5}.alert{font-size:14px;font-weight:500;margin:0;padding:12px 32px}.alert-success{background:#d1fae5;border-left:4px solid #10b981;color:#065f46}.alert-error{background:#fee2e2;border-left:4px solid #ef4444;color:#991b1b}.alert-info{background:#dbeafe;border-left:4px solid #3b82f6;color:#1e40af}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 20px 25px -5px #0000001a;max-height:80vh;max-width:600px;overflow:hidden;width:90%}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:20px 24px}.modal-header h3{color:#1f2937;font-size:18px;font-weight:600;margin:0}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#9ca3af;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.modal-close:hover{background:#f3f4f6;color:#4b5563}.modal-body{max-height:60vh;overflow-y:auto;padding:20px 24px}.template-item{align-items:center;border:1px solid #e5e7eb;border-radius:8px;display:flex;justify-content:space-between;margin-bottom:12px;padding:16px;transition:all .2s ease}.template-item:hover{background:#f9fafb;border-color:#5b7fe3}.template-info{flex:1 1}.template-name-row{align-items:center;display:flex;gap:12px;margin-bottom:6px}.template-name-row h4{color:#1f2937;font-size:15px;font-weight:600;margin:0}.template-date{color:#9ca3af;font-size:13px;margin:0}.template-actions{align-items:center;display:flex;gap:8px}.btn-load-template{background:#5b7fe3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:8px 20px;transition:all .2s ease}.btn-load-template:hover{background:#4c6fd5;transform:translateY(-1px)}.btn-delete-template{align-items:center;background:#fee2e2;border:none;border-radius:6px;color:#b91c1c;cursor:pointer;display:flex;justify-content:center;padding:8px;transition:all .2s ease}.btn-delete-template:hover{background:#fecaca}.content-split{grid-gap:0;display:grid;flex:1 1;gap:0;grid-template-columns:400px 1fr}.content-left{background:#fff;border-right:1px solid #e5e7eb;overflow-y:auto;padding:24px}.content-right{background:#fafbfc;overflow-y:auto;padding:24px}.template-status-badge{margin-bottom:20px;text-align:center}.form-section{max-width:100%}.form-group{margin-bottom:20px}.form-label{color:#374151;display:block;font-size:14px;font-weight:600;margin-bottom:8px}.form-sublabel{color:#6b7280;display:block;font-size:12px;font-weight:500;margin-bottom:6px}.form-control{border:1px solid #d1d5db;border-radius:6px;color:#1f2937;font-size:14px;padding:10px 14px;transition:all .2s ease;width:100%}.form-control:focus{border-color:#5b7fe3;box-shadow:0 0 0 3px #5b7fe31a;outline:none}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.form-col{display:flex;flex-direction:column}.btn-save-template{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;margin-top:8px;padding:12px 24px;transition:all .2s ease;width:100%}.btn-save-template:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.btn-save-template:disabled{cursor:not-allowed;opacity:.6}.preview-section{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.preview-header{align-items:center;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;padding:5px 9px}.preview-title{color:#1f2937;font-size:18px;font-weight:600;margin:0}.badge{align-items:center;border-radius:12px;display:inline-flex;font-size:11px;font-weight:700;letter-spacing:.3px;padding:4px 10px;text-transform:uppercase}.badge-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.badge-secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff}.tab-content-placeholder{background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000001a;margin:24px;padding:48px 32px;text-align:center}.tab-content-placeholder h2{color:#1f2937;font-size:24px;font-weight:600;margin:0 0 12px}.tab-content-placeholder p{color:#6b7280;font-size:16px;margin:0}.text-muted{color:#9ca3af;padding:20px;text-align:center}@media (max-width:1200px){.content-split{grid-template-columns:1fr}.content-left{border-bottom:1px solid #e5e7eb;border-right:none}}@media (max-width:768px){.page-header{padding:16px 20px}.tab-navigation{padding:0 20px}.tabs{overflow-x:auto;width:100%}.tab{font-size:14px;padding:12px 16px}.template-actions-bar{flex-wrap:wrap;padding:12px 20px}.btn-new-template,.btn-templates-list{flex:1 1;min-width:140px}.content-left,.content-right{padding:16px}.alert{padding:12px 20px}}.preview-actions{background:#fff;border-bottom:1px solid #e5e7eb;border-radius:12px 12px 0 0;display:flex;gap:12px;justify-content:flex-end;padding:16px 20px}.btn-templates{align-items:center;background:#5b7fe3;border:none;border-radius:8px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-templates:hover{background:#4c6fd5;box-shadow:0 4px 8px #5b7fe34d;transform:translateY(-1px)}.btn-new{align-items:center;background:#fff;border:2px solid #e5e7eb;border-radius:8px;color:#6b7280;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease}.btn-new:hover:not(:disabled){background:#f9fafb;border-color:#5b7fe3;color:#5b7fe3}.btn-new:disabled{background:#f3f4f6;cursor:not-allowed;opacity:.5}.preview-panel .preview-card{border-radius:0 0 12px 12px}.preview-panel-full .preview-card{border-radius:12px}@media (max-width:768px){.preview-actions{gap:8px;padding:12px 16px}.btn-new,.btn-templates{flex:1 1;font-size:13px;justify-content:center;padding:8px 16px}}.StudentSignupForm_formContainer__x8tJn{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin:0 auto;max-width:1200px;padding:2rem}.StudentSignupForm_formHeader__zoYIO{align-items:center;border-bottom:2px solid #e5e7eb;display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem}.StudentSignupForm_formHeader__zoYIO h2{color:#111827;font-size:1.75rem;font-weight:600;margin:0}.StudentSignupForm_closeButton__KwxQ1{background:none;border:none;border-radius:4px;color:#6b7280;cursor:pointer;padding:.5rem;transition:all .2s}.StudentSignupForm_closeButton__KwxQ1:hover{background:#f3f4f6;color:#111827}.StudentSignupForm_form__\+F30A{display:flex;flex-direction:column;gap:2rem}.StudentSignupForm_section__C5JRR{border-bottom:1px solid #e5e7eb;padding-bottom:1.5rem}.StudentSignupForm_section__C5JRR:last-of-type{border-bottom:none}.StudentSignupForm_sectionTitle__\+xGUt{color:#111827;font-size:1.25rem;font-weight:600;margin:0 0 1.5rem}.StudentSignupForm_twoColumnRow__WHWBK{grid-gap:3rem;display:grid;gap:3rem;grid-template-columns:1fr 1fr}.StudentSignupForm_column__CucR-{display:flex;flex-direction:column}.StudentSignupForm_columnTitle__-sXQW{border-bottom:1px solid #e5e7eb;color:#374151;font-size:1.1rem;font-weight:600;margin:0 0 1rem;padding-bottom:.75rem}.StudentSignupForm_formRow__LyKRv{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}.StudentSignupForm_formRow__LyKRv:last-child{margin-bottom:0}.StudentSignupForm_formGroup__cH2Gl{display:flex;flex-direction:column;gap:.5rem}.StudentSignupForm_label__U3Wub{color:#374151;font-size:.95rem;font-weight:500;margin-bottom:.25rem}.StudentSignupForm_input__A-GcX{background:#fff;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;padding:.75rem 1rem;transition:all .2s;width:100%}.StudentSignupForm_input__A-GcX:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.StudentSignupForm_input__A-GcX::placeholder{color:#9ca3af}.StudentSignupForm_inputDisabled__gDfqU,.StudentSignupForm_input__A-GcX:disabled{background-color:#f3f4f6;color:#6b7280;cursor:not-allowed}.StudentSignupForm_inputError__hka1z{border-color:#ef4444}.StudentSignupForm_inputError__hka1z:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.StudentSignupForm_errorText__PePu3{color:#ef4444;font-size:.875rem;margin-top:.25rem}.StudentSignupForm_vehicleButtons__bP7Zy{border:1px solid #d1d5db;border-radius:6px;display:flex;gap:0;overflow:hidden;width:-webkit-fit-content;width:fit-content}.StudentSignupForm_vehicleButton__uiFfP{background:#fff;border:none;border-right:1px solid #d1d5db;color:#374151;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 2rem;transition:all .2s}.StudentSignupForm_vehicleButton__uiFfP:last-child{border-right:none}.StudentSignupForm_vehicleButton__uiFfP:hover{background:#f9fafb}.StudentSignupForm_vehicleButtonActive__WNf\+V{background:#3b82f6;color:#fff}.StudentSignupForm_vehicleButtonActive__WNf\+V:hover{background:#2563eb}.StudentSignupForm_checkboxLabel__FyuZD{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.95rem;gap:.5rem;margin-bottom:1rem;padding:.5rem 0}.StudentSignupForm_checkbox__UGCqD{accent-color:#3b82f6;cursor:pointer;height:1.25rem;width:1.25rem}.StudentSignupForm_formActions__bzI\+i{border-top:1px solid #e5e7eb;display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem;padding-top:1.5rem}.StudentSignupForm_cancelButton__nGdcl{background:#fff;border:1px solid #d1d5db;border-radius:6px;color:#374151;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .2s}.StudentSignupForm_cancelButton__nGdcl:hover{background:#f9fafb;border-color:#9ca3af}.StudentSignupForm_submitButton__SkUYs{align-items:center;background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.StudentSignupForm_submitButton__SkUYs:hover{background:#2563eb;box-shadow:0 2px 8px #3b82f64d}.StudentSignupForm_submitButton__SkUYs:active{transform:translateY(1px)}@media (max-width:768px){.StudentSignupForm_formContainer__x8tJn{padding:1.5rem}.StudentSignupForm_twoColumnRow__WHWBK{gap:2rem;grid-template-columns:1fr}.StudentSignupForm_formRow__LyKRv{gap:1rem;grid-template-columns:1fr}.StudentSignupForm_formHeader__zoYIO h2{font-size:1.5rem}.StudentSignupForm_sectionTitle__\+xGUt{font-size:1.125rem}.StudentSignupForm_columnTitle__-sXQW{font-size:1rem}.StudentSignupForm_formActions__bzI\+i{flex-direction:column-reverse}.StudentSignupForm_cancelButton__nGdcl,.StudentSignupForm_submitButton__SkUYs{justify-content:center;width:100%}.StudentSignupForm_vehicleButtons__bP7Zy{width:100%}.StudentSignupForm_vehicleButton__uiFfP{flex:1 1;padding:.75rem 1rem}}@media (max-width:480px){.StudentSignupForm_formContainer__x8tJn{padding:1rem}.StudentSignupForm_input__A-GcX{font-size:.95rem;padding:.65rem .875rem}.StudentSignupForm_label__U3Wub{font-size:.9rem}.StudentSignupForm_vehicleButton__uiFfP{font-size:.95rem}}.homepage-container{background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;max-height:100vh;min-height:100vh;overflow:hidden;position:relative}.homepage-container:before{background:radial-gradient(circle at 20% 50%,#ffffff0d 0,#0000 50%),radial-gradient(circle at 80% 80%,#ffffff0d 0,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.homepage-header{justify-content:flex-end;left:0;padding:1.5rem 3rem;position:absolute;right:0;top:0;z-index:10}.auth-buttons,.homepage-header{align-items:center;display:flex}.auth-buttons{gap:1rem}.btn-login,.btn-signup{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:none;font-size:.95rem;padding:.75rem 1.5rem;transition:all .3s ease}.btn-login{background:#ffffff26;border:1px solid #ffffff4d;color:#fff}.btn-login:hover{background:#ffffff40;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.btn-signup{background:#fff;border:1px solid #fff;color:#667eea}.btn-signup:hover{background:#f8f9ff;box-shadow:0 4px 12px #00000026;transform:translateY(-2px)}.homepage-main{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;padding:2rem;position:relative;z-index:1}.logo-section{animation:fadeInDown .8s ease-out;margin-bottom:2rem;text-align:center}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.main-logo{animation:logoFloat 3s ease-in-out infinite;border-radius:20px;box-shadow:0 10px 30px #0003;height:120px;margin-bottom:1rem;object-fit:contain;opacity:1;padding:1rem;width:120px}@keyframes logoFloat{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.brand-title{color:#fff;font-size:2.5rem;font-weight:700;margin:0 0 .5rem;text-shadow:0 2px 10px #0000001a}.brand-tagline{color:#ffffffe6;font-size:1.1rem;font-weight:300;margin:0}.feature-showcase{animation:fadeInUp .8s ease-out .2s both;margin-bottom:2rem;max-width:1000px;width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.feature-slider{align-items:center;display:flex;height:350px;justify-content:center;perspective:1000px;position:relative}.feature-slide{max-width:700px;opacity:0;pointer-events:none;position:absolute;transform:scale(.8) translateX(-100%);transition:all .6s cubic-bezier(.4,0,.2,1);width:85%}.feature-slide.active{opacity:1;pointer-events:auto;transform:scale(1) translateX(0);z-index:2}.feature-slide.previous{opacity:.3;transform:scale(.85) translateX(100%)}.image-wrapper{background:#fff;border:3px solid #fff3;border-radius:16px;box-shadow:0 20px 50px #0000004d;overflow:hidden;position:relative;width:100%}.feature-image{background:#fff;display:block;height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:contain;object-position:center;padding:.5rem;width:100%}.feature-info{color:#fff;margin-top:1rem;text-align:center}.feature-info h3{font-size:1.3rem;font-weight:600;margin:0 0 .5rem}.feature-info p{font-size:.95rem;font-weight:300;margin:0;opacity:.9}.slider-indicators{display:flex;gap:.5rem;justify-content:center;margin-top:1.5rem}.indicator{background:#ffffff4d;border:none;border-radius:50%;cursor:pointer;height:8px;padding:0;transition:all .3s ease;width:8px}.indicator.active{background:#fff;border-radius:4px;width:24px}.indicator:hover{background:#fff9}.cta-section{animation:fadeInUp .8s ease-out .4s both;text-align:center}.cta-section h2{color:#fff;font-size:1.5rem;font-weight:600;margin:0 0 1.5rem}.cta-buttons{display:flex;gap:1rem;justify-content:center}.cta-btn{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;min-width:160px;padding:1rem 2.5rem;transition:all .3s ease}.cta-btn.primary{background:#fff;box-shadow:0 4px 15px #0003;color:#667eea}.cta-btn.primary:hover{box-shadow:0 6px 20px #0000004d;transform:translateY(-3px)}.cta-btn.secondary{background:#0000;border:2px solid #fff;color:#fff}.cta-btn.secondary:hover{background:#ffffff1a;transform:translateY(-3px)}.homepage-footer{color:#ffffffb3;font-size:.85rem;padding:1rem;position:relative;text-align:center;z-index:1}.homepage-footer p{margin:0}@media (min-width:1920px){.main-logo{height:140px;width:140px}.brand-title{font-size:3rem}.feature-slider{height:400px}.feature-image{height:320px}}@media (max-width:1600px){.homepage-header{padding:1.5rem 2rem}.main-logo{height:100px;width:100px}.brand-title{font-size:2.2rem}.feature-slider{height:320px}.feature-image{height:240px}}@media (max-width:1024px){.homepage-header{padding:1rem 1.5rem}.homepage-main{padding:1.5rem}.main-logo{height:90px;width:90px}.brand-title{font-size:2rem}.brand-tagline{font-size:1rem}.feature-slider{height:280px}.feature-image{height:200px}.cta-section h2{font-size:1.3rem}.cta-buttons{align-items:center;flex-direction:column}.cta-btn{max-width:280px;width:100%}}@media (max-width:767px){.homepage-header{padding:1rem}.auth-buttons{gap:.5rem}.btn-login,.btn-signup{font-size:.85rem;padding:.6rem 1rem}.btn-login span,.btn-signup span{display:none}.homepage-main{padding:1rem}.logo-section{margin-bottom:1.5rem}.main-logo{height:80px;width:80px}.brand-title{font-size:1.8rem}.brand-tagline{font-size:.9rem}.feature-showcase{margin-bottom:1.5rem}.feature-slider{height:240px}.feature-image{height:160px}.feature-info h3{font-size:1.1rem}.feature-info p{font-size:.85rem}.cta-section h2{font-size:1.2rem;margin-bottom:1rem}.cta-btn{font-size:.95rem;min-width:140px;padding:.85rem 2rem}}@media (max-width:480px){.brand-title{font-size:1.5rem}.feature-slider{height:220px}.feature-image{height:140px}.cta-buttons{gap:.75rem}.cta-btn{font-size:.9rem;min-width:120px;padding:.75rem 1.5rem}}.indicator:focus-visible,button:focus-visible{outline:2px solid #fff;outline-offset:4px}@media print{.homepage-container{background:#fff}.auth-buttons,.cta-section,.homepage-footer,.homepage-header{display:none}}.minimal-homepage{background:#fff;display:flex;flex-direction:column;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;max-height:100vh;min-height:100vh;overflow:hidden;position:relative}.auth-links{display:flex;gap:1rem;position:absolute;right:3rem;top:2rem;z-index:10}.link-btn{align-items:center;background:#0000;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.6rem 1.2rem;transition:all .2s ease}.link-btn:hover{background:#f8f9ff;border-color:#667eea;color:#667eea}.link-btn.signup{background:#667eea;border-color:#667eea;color:#fff}.link-btn.signup:hover{background:#5568d3}.content-center{align-items:center;display:flex;flex:1 1;flex-direction:column;justify-content:center;overflow-y:auto;padding:2rem;text-align:center}.logo-wrapper{margin-bottom:2rem}.logo-img{border-radius:20px;box-shadow:0 10px 40px #00000014;height:140px;object-fit:contain;width:140px}.main-title{color:#111827;font-size:3rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem}.subtitle{color:#6b7280;font-size:1.2rem;font-weight:400;margin:0 0 3rem}.feature-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:3rem;max-width:1200px;width:100%}.feature-card{background:#f9fafb;border:2px solid #e5e7eb;border-radius:12px;display:flex;flex-direction:column;overflow:hidden;transition:all .3s ease}.feature-card:hover{border-color:#667eea;box-shadow:0 12px 35px #00000014;transform:translateY(-4px)}.card-image-wrapper{background:#fff;border-bottom:2px solid #e5e7eb;height:200px;overflow:hidden;position:relative;width:100%}.card-image-wrapper img{height:100%;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;object-fit:contain;object-position:center;padding:.5rem;width:100%}.card-content{padding:1rem;text-align:center}.card-content h3{color:#111827;font-size:1rem;font-weight:600;margin:0 0 .5rem}.card-content p{color:#6b7280;font-size:.85rem;line-height:1.4;margin:0}.quick-actions{display:flex;gap:1rem}.action-btn{border:none;border-radius:10px;cursor:pointer;font-size:1rem;font-weight:600;padding:1rem 2.5rem;transition:all .3s ease}.action-btn.primary{background:#667eea;color:#fff}.action-btn.primary:hover{background:#5568d3;box-shadow:0 6px 20px #667eea4d;transform:translateY(-2px)}.action-btn.secondary{background:#fff;border:2px solid #667eea;color:#667eea}.action-btn.secondary:hover{background:#f8f9ff;transform:translateY(-2px)}@media (max-width:1024px){.auth-links{right:2rem;top:1.5rem}.logo-img{height:120px;width:120px}.main-title{font-size:2.5rem}.subtitle{font-size:1.1rem;margin-bottom:2.5rem}.feature-grid{gap:1.25rem;grid-template-columns:repeat(2,1fr)}.card-image-wrapper{height:180px}}@media (max-width:768px){.auth-links{gap:.5rem;right:1rem;top:1rem}.link-btn{font-size:.85rem;padding:.5rem .8rem}.content-center{padding:1rem}.logo-img{height:100px;width:100px}.main-title{font-size:2rem}.subtitle{font-size:1rem;margin-bottom:2rem}.feature-grid{gap:1rem;grid-template-columns:1fr;margin-bottom:2rem}.card-image-wrapper{height:160px}.card-content h3{font-size:.95rem}.card-content p{font-size:.8rem}.quick-actions{flex-direction:column;max-width:300px;width:100%}.action-btn{padding:.85rem 2rem;width:100%}}@media (max-width:480px){.link-btn span{display:none}.link-btn{padding:.5rem}.main-title{font-size:1.75rem}.logo-img{height:80px;width:80px}.card-image-wrapper{height:140px}}button:focus-visible{outline:2px solid #667eea;outline-offset:4px}@media (prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media print{.auth-links,.quick-actions{display:none}}.btn-login,.btn-signup{align-items:center;background:#0000;border:1px solid #e5e7eb;border-radius:8px;color:#374151;cursor:pointer;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.6rem 1.2rem;transition:all .2s ease}
/*# sourceMappingURL=main.d9cde7b9.css.map*/