.home-page{min-height:100vh;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);display:flex;align-items:center;justify-content:center;padding:24px 16px;font-family:inherit}.home-container{width:100%;max-width:680px;text-align:center}.home-header{margin-bottom:48px}.home-logo{font-size:3.5rem;margin-bottom:12px;display:block}.home-title{font-size:2.6rem;font-weight:800;color:#fff;margin:0 0 10px;letter-spacing:-1px}.home-subtitle{font-size:1.1rem;color:#ffffffa6;margin:0}.home-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:36px}.home-card{background:#ffffff12;border:1.5px solid rgba(255,255,255,.12);border-radius:20px;padding:32px 24px;text-decoration:none;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px;transition:transform .2s,background .2s,border-color .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.home-card:hover{transform:translateY(-4px);background:#ffffff21;border-color:#ffffff47}.home-card-icon{font-size:2.4rem}.home-card-title{font-size:1.25rem;font-weight:700;color:#fff;margin:0}.home-card-desc{font-size:.88rem;color:#fff9;margin:0;line-height:1.5}.home-card-btn{margin-top:8px;font-size:.85rem;font-weight:700;padding:8px 18px;border-radius:30px;display:inline-block}.home-card-student .home-card-btn{background:#4f6ef7;color:#fff}.home-card-admin .home-card-btn{background:#ffffff26;color:#ffffffe6;border:1px solid rgba(255,255,255,.2)}.home-footer{margin-top:8px}.home-login-link{color:#fff6;font-size:.82rem;text-decoration:none;transition:color .15s}.home-login-link:hover{color:#fffc}@media (max-width: 520px){.home-cards{grid-template-columns:1fr}.home-title{font-size:2rem}.home-card{padding:24px 18px}}.admin-nav{display:flex;flex-direction:row;justify-content:space-between;align-items:center;background-color:#2c3e50;padding:1rem 2rem;margin-bottom:2rem;direction:rtl}.nav-items{display:flex;flex-direction:row;gap:1rem}.nav-item{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px;transition:background-color .2s}.nav-item:hover{background-color:#ffffff1a}.nav-item.active{background-color:#3498db}.btn-logout{padding:.5rem 1rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-logout:hover{background-color:#c0392b}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:#2c3e50;color:#fff;padding:1rem 2rem}.app-header h1{margin:0;font-size:1.5rem}.app-main{flex:1;padding:2rem}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}.spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-message{margin-top:1rem;color:#666}.error-message{padding:1rem;background-color:#fee;border:1px solid #fcc;border-radius:4px;margin:1rem 0}.error-text{color:#c33;margin:0}.date-input{width:100%;max-width:300px;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;margin-bottom:.5rem}.date-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.selected-date-info{margin-top:.75rem;color:#555;font-size:.9rem}.form-label{display:block;margin-bottom:.75rem;font-weight:500;color:#2c3e50;font-size:1rem}.time-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:.75rem;margin-top:1rem}.time-slot-btn{padding:.75rem 1rem;background-color:#fff;border:2px solid #3498db;border-radius:4px;color:#3498db;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.time-slot-btn:hover{background-color:#ebf5fb;transform:translateY(-2px);box-shadow:0 2px 4px #0000001a}.time-slot-btn.selected{background-color:#3498db;color:#fff;border-color:#2980b9}.time-slot-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.no-slots-message{margin-top:1rem;padding:1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px;color:#856404;text-align:center}.selected-time-info{margin-top:.75rem;color:#555;font-size:.9rem}.booking-form-section{margin:2rem 0;padding:1.5rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px}.booking-confirmation{background-color:#f8f9fa;border:2px solid #3498db}.booking-confirmation h3{margin:0 0 .5rem;color:#2c3e50}.confirm-message{margin:.5rem 0 1rem;color:#666}.booking-details{background-color:#fff;padding:1rem;border-radius:4px;margin:1rem 0;border:1px solid #e0e0e0}.btn-confirm-booking{width:100%;padding:1rem;background-color:#27ae60;color:#fff;border:none;border-radius:4px;font-size:1.1rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:1rem}.btn-confirm-booking:hover:not(:disabled){background-color:#229954;transform:translateY(-2px);box-shadow:0 4px 8px #0003}.btn-confirm-booking:disabled{background-color:#95a5a6;cursor:not-allowed;transform:none}.booking-success-message{background-color:#d4edda;border:2px solid #28a745;border-radius:4px;padding:1.5rem;margin:2rem 0;text-align:center}.booking-success-message h3{margin:0 0 1rem;color:#155724}.booking-success-message .booking-details{margin:1rem auto;max-width:400px;background-color:#fff;padding:1rem;border-radius:4px;border:1px solid #e0e0e0}.detail-item{padding:.5rem 0;border-bottom:1px solid #f0f0f0}.detail-item:last-child{border-bottom:none}.detail-item strong{color:#2c3e50}.redirect-message{margin-top:1rem;color:#666;font-style:italic}.lesson-info{background-color:#f8f9fa;border-left:4px solid #3498db;padding:1.5rem;margin:2rem 0;border-radius:4px}.lesson-info h3{margin:0 0 .5rem;color:#2c3e50;font-size:1.5rem}.instruction{margin:.5rem 0 0;color:#666;font-size:1rem}.student-info{margin:1.5rem 0;padding:1rem;background-color:#fff;border:1px solid #e0e0e0;border-radius:4px}.student-info p{margin:0;color:#555}.student-info strong{color:#2c3e50}.booking-page{max-width:800px;margin:0 auto;padding:2rem}.booking-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.booking-calendar{background:#fff;border-radius:16px;box-shadow:0 2px 16px #00000014;padding:24px;max-width:480px;margin:0 auto;font-family:inherit}.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.cal-title{font-size:1.15rem;font-weight:700;color:#1a1a2e;margin:0}.cal-nav-btn{background:none;border:1px solid #e0e0e0;border-radius:8px;width:36px;height:36px;font-size:1.2rem;cursor:pointer;color:#555;display:flex;align-items:center;justify-content:center;transition:background .15s,border-color .15s}.cal-nav-btn:hover:not(:disabled){background:#f0f4ff;border-color:#4f6ef7;color:#4f6ef7}.cal-nav-btn:disabled{opacity:.35;cursor:not-allowed}.cal-day-names{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:6px}.cal-day-name{text-align:center;font-size:.78rem;font-weight:600;color:#888;padding:4px 0}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.cal-cell{aspect-ratio:1;border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:.85rem;transition:transform .1s,box-shadow .1s;position:relative;min-height:44px}.cal-empty{background:transparent}.cal-past{background:#f5f5f5;color:#ccc;cursor:default}.cal-available{background:#d4f5e0;color:#1a6e3c;cursor:pointer;font-weight:600;border:1.5px solid #a5e0be}.cal-available:hover,.cal-available:focus{background:#b8edce;transform:scale(1.06);box-shadow:0 2px 8px #22a05640;outline:none}.cal-blocked{background:#f0f0f0;color:#bbb;cursor:default}.cal-today{box-shadow:0 0 0 2px #4f6ef7}.cal-day-number{font-size:.9rem;line-height:1}.cal-slots-count{font-size:.62rem;margin-top:2px;opacity:.75}.cal-loading{text-align:center;padding:32px;color:#888;font-size:.95rem}.cal-legend{display:flex;gap:20px;justify-content:center;margin-top:16px;font-size:.82rem;color:#555}.legend-item{display:flex;align-items:center;gap:6px}.legend-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.legend-available{background:#d4f5e0;border:1.5px solid #a5e0be}.legend-blocked{background:#f0f0f0;border:1.5px solid #ddd}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal-box{background:#fff;border-radius:20px;padding:32px 28px;width:100%;max-width:440px;box-shadow:0 8px 40px #0000002e;position:relative;animation:slideUp .2s ease-out;max-height:90vh;overflow-y:auto}@keyframes slideUp{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-close-btn{position:absolute;top:14px;left:14px;background:none;border:none;font-size:1.1rem;cursor:pointer;color:#888;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.modal-close-btn:hover{background:#f0f0f0;color:#333}.modal-title{font-size:1.35rem;font-weight:700;color:#1a1a2e;margin:0 0 4px;text-align:center}.modal-date-label{text-align:center;color:#4f6ef7;font-weight:600;font-size:.95rem;margin:0 0 20px}.modal-section{margin-bottom:18px}.modal-label{display:block;font-size:.88rem;font-weight:600;color:#444;margin-bottom:8px}.slots-grid{display:flex;flex-wrap:wrap;gap:8px}.slot-btn{padding:8px 14px;border:1.5px solid #d0d9ff;border-radius:10px;background:#f4f6ff;color:#3a50d0;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s;font-family:inherit}.slot-btn:hover{background:#dde3ff;border-color:#4f6ef7}.slot-btn.slot-selected{background:#4f6ef7;border-color:#4f6ef7;color:#fff;font-weight:700}.modal-loading,.modal-no-slots{color:#888;font-size:.9rem;padding:8px 0}.modal-input{width:100%;padding:11px 14px;border:1.5px solid #ddd;border-radius:10px;font-size:.95rem;font-family:inherit;color:#222;outline:none;transition:border-color .15s;box-sizing:border-box}.modal-input:focus{border-color:#4f6ef7;box-shadow:0 0 0 3px #4f6ef71f}.modal-input.input-error{border-color:#e53935}.field-error{color:#e53935;font-size:.8rem;margin:4px 0 0}.modal-error{background:#fff3f3;border:1px solid #f5c2c2;border-radius:10px;padding:10px 14px;color:#c62828;font-size:.88rem;margin-bottom:16px;text-align:center}.modal-actions{display:flex;gap:10px;margin-top:6px}.btn-confirm{flex:1;padding:12px;background:#4f6ef7;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:background .15s,transform .1s;font-family:inherit}.btn-confirm:hover:not(:disabled){background:#3a57d4;transform:translateY(-1px)}.btn-confirm:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{flex:0 0 auto;padding:12px 20px;background:#f3f4f6;color:#374151!important;border:1.5px solid #d1d5db;border-radius:12px;font-size:1rem;cursor:pointer;transition:background .15s;font-family:inherit}.btn-cancel:hover:not(:disabled){background:#e5e7eb}.public-booking-page{min-height:100vh;background:linear-gradient(135deg,#f0f4ff,#e8f0fe,#f4f6ff);display:flex;align-items:flex-start;justify-content:center;padding:32px 16px 60px}.booking-page-container{width:100%;max-width:540px}.booking-page-header{text-align:center;margin-bottom:28px}.booking-page-title{font-size:2rem;font-weight:800;color:#1a1a2e;margin:0 0 8px;letter-spacing:-.5px}.booking-page-subtitle{font-size:1rem;color:#666;margin:0}.booking-calendar-wrapper{width:100%}.success-banner{display:flex;align-items:center;gap:14px;background:#e6faf0;border:1.5px solid #a3dfc0;border-radius:14px;padding:14px 18px;margin-bottom:20px;animation:fadeInDown .3s ease-out;position:relative}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.success-banner-icon{width:36px;height:36px;border-radius:50%;background:#22a856;color:#fff;font-size:1.1rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.success-banner-body{flex:1}.success-banner-title{font-weight:700;color:#1a6e3c;margin:0 0 2px;font-size:1rem}.success-banner-details{color:#2d7a50;font-size:.88rem;margin:0}.success-banner-close{background:none;border:none;color:#888;font-size:1rem;cursor:pointer;padding:4px;border-radius:50%;transition:background .15s;line-height:1}.success-banner-close:hover{background:#00000012}@media (max-width: 480px){.booking-page-title{font-size:1.6rem}.public-booking-page{padding:20px 12px 40px}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-container{background:#fff;padding:2.5rem;border-radius:8px;box-shadow:0 10px 25px #0003;width:100%;max-width:400px}.login-container h2{margin:0 0 2rem;text-align:center;color:#2c3e50}.login-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:#555;font-size:.9rem}.form-group input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.btn-login{padding:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:.5rem}.btn-login:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-login:disabled{opacity:.6;cursor:not-allowed;transform:none}.remember-me-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#555;cursor:pointer;margin-bottom:.5rem;direction:rtl}.remember-me-checkbox{width:16px;height:16px;cursor:pointer;accent-color:#667eea}.admin-dashboard{padding:2rem}.admin-dashboard h2{margin-bottom:2rem;color:#2c3e50}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:3rem}.stat-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem;text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-4px);box-shadow:0 4px 12px #0000001a}.stat-card h3{font-size:3rem;margin:0 0 .5rem;color:#3498db}.stat-card p{margin:.5rem 0 1rem;color:#666;font-size:1.1rem}.stat-link{display:inline-block;color:#3498db;text-decoration:none;font-weight:500;transition:color .2s}.stat-link:hover{color:#2980b9;text-decoration:underline}.dashboard-quick-links{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem}.dashboard-quick-links h3{margin:0 0 1.5rem;color:#2c3e50}.quick-links-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.quick-link{display:block;padding:1rem 1.5rem;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:4px;text-decoration:none;color:#2c3e50;text-align:center;transition:all .2s}.quick-link:hover{background:#3498db;color:#fff;border-color:#3498db;transform:translateY(-2px);box-shadow:0 2px 8px #3498db4d}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2000;animation:confirmFadeIn .15s ease}@keyframes confirmFadeIn{0%{opacity:0}to{opacity:1}}.confirm-box{background:#fff;border-radius:14px;padding:2rem 2.2rem 1.6rem;max-width:380px;width:90%;text-align:center;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;align-items:center;gap:1rem;animation:confirmSlideUp .18s ease;border-top:4px solid #f59e0b}@keyframes confirmSlideUp{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-icon{width:46px;height:46px;border-radius:50%;background:#fffbeb;color:#d97706;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;flex-shrink:0}.confirm-message{margin:0;font-size:1rem;color:#1e293b;line-height:1.55;font-weight:500}.confirm-actions{display:flex;gap:.75rem;width:100%;justify-content:center;margin-top:.2rem}.confirm-btn-cancel{flex:1;padding:.6rem 1rem;border:1.5px solid #e2e8f0;border-radius:8px;background:#f8fafc;color:#475569;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.confirm-btn-cancel:hover{background:#e2e8f0}.confirm-btn-ok{flex:1;padding:.6rem 1rem;border:none;border-radius:8px;background:#ef4444;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.confirm-btn-ok:hover{background:#dc2626}.success-message{padding:1rem;background-color:#d4edda;border:1px solid #c3e6cb;border-radius:4px;margin:1rem 0}.success-text{color:#155724;margin:0}.search-input{flex:1;min-width:200px;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.search-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.filter-select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background-color:#fff;cursor:pointer}.filter-select:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.students-table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.btn-edit,.btn-block,.btn-regenerate{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-regenerate{background-color:#9b59b6;color:#fff}.btn-regenerate:hover{background-color:#8e44ad}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin:2rem 0}.btn-pagination{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .2s}.btn-pagination:hover:not(:disabled){background-color:#2980b9;transform:translateY(-2px);box-shadow:0 2px 4px #0003}.btn-pagination:disabled{background-color:#95a5a6;cursor:not-allowed;transform:none}.pagination span{color:#555;font-weight:500}.modal-content{background:#fff;border-radius:8px;padding:2rem;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 20px #0000004d}.modal-form label{display:flex;flex-direction:column;gap:.5rem;color:#555}.modal-form input,.modal-form select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1.5rem}.btn-cancel,.btn-save,.btn-close{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background-color:#95a5a6;color:#fff}.btn-cancel:hover{background-color:#7f8c8d}.btn-save{background-color:#3498db;color:#fff}.btn-save:hover{background-color:#2980b9}.btn-close{background-color:#e74c3c;color:#fff}.btn-close:hover{background-color:#c0392b}.token-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:.9rem;font-family:monospace;background-color:#f8f9fa;word-break:break-all}.btn-copy{padding:.75rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s}.btn-copy:hover{background-color:#2980b9}.token-link{margin:1rem 0;font-size:.9rem;color:#555;word-break:break-all}.students-management{max-width:1200px;margin:0 auto;padding:2rem}.students-management h2{margin-bottom:2rem;color:#2c3e50}.filters-section{display:flex;gap:1rem;margin-bottom:1.5rem}.search-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.filter-select{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;min-width:150px}.students-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.students-table thead{background-color:#2c3e50;color:#fff}.students-table th{padding:1rem;text-align:left;font-weight:500}.students-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.students-table tr:last-child td{border-bottom:none}.students-table tbody tr:hover{background-color:#f8f9fa}.status-badge.active{background-color:#d4edda;color:#155724}.status-badge.blocked{background-color:#f8d7da;color:#721c24}.btn-block{background-color:#e74c3c;color:#fff}.btn-block:hover{background-color:#c0392b}.btn-unblock{background-color:#27ae60}.btn-unblock:hover{background-color:#229954}.btn-regenerate{background-color:#f39c12;color:#fff}.btn-regenerate:hover{background-color:#e67e22}.btn-cancel,.btn-close{padding:.75rem 1.5rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer}.token-display{display:flex;gap:.5rem;margin:1rem 0}.token-input{flex:1;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-family:monospace;font-size:.9rem}.btn-copy{padding:.75rem 1rem;border:none;border-radius:4px;background:#3498db;color:#fff;cursor:pointer}.btn-copy:hover{background:#2980b9}.token-link{margin-top:1rem;font-size:.9rem;word-break:break-all}.token-link a{color:#3498db;text-decoration:none}.token-link a:hover{text-decoration:underline}.filters-section{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-select,.filter-input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;background-color:#fff}.filter-select{cursor:pointer}.filter-select:focus,.filter-input:focus{outline:none;border-color:#3498db;box-shadow:0 0 0 3px #3498db1a}.bookings-table{width:100%;border-collapse:collapse;background:#fff;border-radius:4px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.btn-edit{padding:.5rem 1rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.btn-cancel-booking{padding:.5rem 1rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:.9rem;cursor:pointer;transition:all .2s}.no-data{text-align:center;padding:2rem;color:#666}.bookings-management{max-width:1200px;margin:0 auto;padding:2rem}.bookings-management h2{margin-bottom:2rem;color:#2c3e50}.filters-section{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-select,.filter-input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.filter-select,.filter-input{min-width:150px}.bookings-table{width:100%;border-collapse:collapse;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.bookings-table thead{background-color:#2c3e50;color:#fff}.bookings-table th{padding:1rem;text-align:left;font-weight:500}.bookings-table td{padding:1rem;border-bottom:1px solid #e0e0e0}.bookings-table tbody tr:hover{background-color:#f8f9fa}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-badge.confirmed{background-color:#d4edda;color:#155724}.status-badge.cancelled{background-color:#f8d7da;color:#721c24}.action-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.action-buttons button{padding:.5rem 1rem;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .2s}.btn-edit{background-color:#3498db;color:#fff}.btn-edit:hover{background-color:#2980b9}.btn-cancel-booking{background-color:#e74c3c;color:#fff}.btn-cancel-booking:hover{background-color:#c0392b}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:2rem}.btn-pagination{padding:.5rem 1rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;transition:all .2s}.btn-pagination:hover:not(:disabled){background-color:#f8f9fa;border-color:#3498db}.btn-pagination:disabled{opacity:.5;cursor:not-allowed}.no-data{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;padding:2rem;border-radius:8px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.modal-content h3{margin:0 0 1.5rem;color:#2c3e50}.modal-form{display:flex;flex-direction:column;gap:1rem}.modal-form label{display:flex;flex-direction:column;gap:.5rem;font-weight:500}.modal-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.btn-cancel{padding:.75rem 1.5rem;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer}.btn-save{padding:.75rem 1.5rem;border:none;border-radius:4px;background:#27ae60;color:#fff;cursor:pointer}.btn-save:hover{background:#229954}.connected-state{text-align:center}.btn-disconnect{padding:.75rem 2rem;background-color:#e74c3c;color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:1rem}.btn-disconnect:disabled{opacity:.6;cursor:not-allowed;transform:none}.disconnected-state{text-align:center}.status-indicator{display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:1.2rem;font-weight:500;margin-bottom:1.5rem}.btn-connect{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:1rem}.btn-connect:disabled{opacity:.6;cursor:not-allowed;transform:none}.calendar-connection{max-width:800px;margin:0 auto;padding:2rem}.calendar-connection h2{margin-bottom:2rem;color:#2c3e50}.connection-status{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:2rem}.status-indicator{display:flex;align-items:center;gap:.75rem;font-size:1.2rem;font-weight:500;margin-bottom:1.5rem}.status-dot{width:12px;height:12px;border-radius:50%;display:inline-block}.status-indicator.connected .status-dot{background-color:#27ae60;box-shadow:0 0 0 3px #27ae6033}.status-indicator.disconnected .status-dot{background-color:#e74c3c;box-shadow:0 0 0 3px #e74c3c33}.status-details{background:#f8f9fa;padding:1.5rem;border-radius:4px;margin:1.5rem 0}.status-details p{margin:.5rem 0;color:#555}.status-details strong{color:#2c3e50}.sync-error{color:#e74c3c}.connection-instructions{background:#f8f9fa;padding:1.5rem;border-radius:4px;margin:1.5rem 0}.connection-instructions p{margin:0;color:#666;line-height:1.6}.btn-connect,.btn-disconnect{padding:.75rem 2rem;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;margin-top:1rem}.btn-connect{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-connect:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-disconnect{background-color:#e74c3c;color:#fff}.btn-disconnect:hover:not(:disabled){background-color:#c0392b;transform:translateY(-2px);box-shadow:0 4px 12px #e74c3c4d}.btn-connect:disabled,.btn-disconnect:disabled{opacity:.6;cursor:not-allowed;transform:none}.success-message{background-color:#d4edda;color:#155724;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #c3e6cb}.generic-link-panel{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#f0f9ff;border:1px dashed #7dd3fc;border-radius:10px;padding:.9rem 1.2rem;margin-bottom:1.4rem}.generic-link-info{display:flex;flex-direction:column;gap:.2rem}.generic-link-desc{font-size:.82rem;color:#64748b}.generic-badge{display:inline-block;font-size:.68rem;font-weight:700;background:#3b82f6;color:#fff;border-radius:20px;padding:1px 8px;margin-right:6px;vertical-align:middle}.generic-identify-form{background:#fff;border-radius:14px;box-shadow:0 4px 24px #0000001a;padding:2rem 2.4rem;max-width:460px;margin:0 auto}.generic-identify-form .modal-confirm-btn{width:100%;margin-top:1.2rem;background:#6366f1;color:#fff;border:none;border-radius:10px;padding:.8rem 1.4rem;font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s}.generic-identify-form .modal-confirm-btn:hover:not(:disabled){background:#4f46e5}.generic-identify-form .modal-confirm-btn:disabled{opacity:.6;cursor:not-allowed}.gender-radio-group{display:flex;gap:1.4rem;padding:.4rem 0}.gender-radio-label{display:flex;align-items:center;gap:.4rem;font-size:1rem;cursor:pointer;font-weight:500}.gender-radio-label input[type=radio]{width:18px;height:18px;accent-color:#6366f1;cursor:pointer}.schedule-loading{padding:24px;text-align:center;color:#888}.no-items-text{color:#aaa;font-size:.9rem;padding:8px 0}.form-error{background:#fff3f3;border:1px solid #f5c2c2;border-radius:10px;padding:10px 14px;color:#c62828;font-size:.88rem;margin:12px 0}.form-success{background:#e6faf0;border:1px solid #a3dfc0;border-radius:10px;padding:10px 14px;color:#1a6e3c;font-size:.88rem;margin:12px 0}.settings-section{margin-bottom:28px}.settings-section-title{font-size:1rem;font-weight:700;color:#2c3e50;margin:0 0 14px;padding-bottom:8px;border-bottom:2px solid #eef0f8}.section-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.section-header-row .settings-section-title{margin:0;padding:0;border:none}.days-list{display:flex;flex-direction:column;gap:10px}.day-row{display:flex;align-items:center;gap:16px;padding:10px 14px;border-radius:10px;background:#f8f9ff;border:1.5px solid #eee;transition:border-color .15s}.day-row.day-active{border-color:#c5d0ff;background:#f0f3ff}.day-toggle{display:flex;align-items:center;gap:8px;cursor:pointer;min-width:80px}.day-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#4f6ef7;cursor:pointer}.day-label{font-weight:600;font-size:.9rem;color:#333}.day-times{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.time-field{display:flex;align-items:center;gap:6px}.time-label{font-size:.78rem;color:#777}.time-input{padding:6px 10px;border:1.5px solid #ddd;border-radius:8px;font-size:.9rem;color:#222;background:#fff;outline:none;font-family:inherit;transition:border-color .15s}.time-input:focus{border-color:#4f6ef7;box-shadow:0 0 0 2px #4f6ef71a}.time-sep{color:#888;font-size:1.1rem}.lesson-settings-row{display:flex;gap:20px;flex-wrap:wrap}.lesson-setting{flex:1;min-width:160px;display:flex;flex-direction:column;gap:6px}.setting-label{font-size:.85rem;font-weight:600;color:#444}.setting-input{padding:9px 12px;border:1.5px solid #ddd;border-radius:10px;font-size:.95rem;width:100%;box-sizing:border-box;font-family:inherit;color:#222;outline:none;transition:border-color .15s}.setting-input:focus{border-color:#4f6ef7}.blocked-range-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f0f0f0;flex-wrap:wrap}.select-day{padding:7px 10px;border:1.5px solid #ddd;border-radius:8px;font-size:.9rem;background:#fff;color:#222;outline:none;cursor:pointer;font-family:inherit}.btn-add-block{padding:6px 14px;background:#4f6ef7;color:#fff;border:none;border-radius:8px;font-size:.85rem;cursor:pointer;font-weight:600;transition:background .15s;font-family:inherit}.btn-add-block:hover{background:#3a57d4}.btn-remove{background:none;border:1px solid #ddd;border-radius:6px;color:#888;cursor:pointer;width:28px;height:28px;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.btn-remove:hover{background:#ffe5e5;border-color:#f5a0a0;color:#c62828}.btn-save{padding:12px 28px;background:#4f6ef7;color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;margin-top:8px;transition:background .15s,transform .1s;font-family:inherit}.btn-save:hover:not(:disabled){background:#3a57d4;transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed}.bookings-table-wrapper{width:100%}.bookings-toolbar{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem;flex-wrap:wrap}.bookings-search{flex:1;min-width:180px}.bookings-filters{display:flex;gap:.5rem;flex-wrap:wrap}.filter-select{min-width:150px}.bookings-summary{font-size:.82rem;color:#6b7280;margin-bottom:.5rem;text-align:right}.bookings-pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1rem;padding:.5rem 0}.pagination-btn{background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;width:2rem;height:2rem;font-size:1.1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.pagination-btn:hover:not(:disabled){background:#e5e7eb}.pagination-btn:disabled{opacity:.4;cursor:default}.pagination-info{font-size:.88rem;color:#374151;min-width:3rem;text-align:center}.table-scroll{overflow-x:auto}.bookings-table{width:100%;border-collapse:collapse;font-size:.88rem}.bookings-table th{background:#f4f6ff;color:#3a3a6e;font-weight:700;padding:12px 14px;text-align:right;border-bottom:2px solid #e0e4f5;white-space:nowrap}.bookings-table td{padding:11px 14px;border-bottom:1px solid #f0f0f0;color:#333}.bookings-table tr:last-child td{border-bottom:none}.bookings-table tr:hover td{background:#fafbff}.row-cancelled td{opacity:.5}.cell-email{font-size:.82rem;color:#555}.cell-lesson-num{font-weight:700;color:#4f6ef7}.status-badge{display:inline-flex;padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:700}.status-active{background:#e6faf0;color:#1a6e3c}.status-cancelled{background:#f5f5f5;color:#999}.btn-cancel-booking{padding:5px 12px;background:transparent;border:1.5px solid #f5a0a0;border-radius:8px;color:#c62828;font-size:.8rem;cursor:pointer;transition:background .15s;font-family:inherit}.btn-cancel-booking:hover:not(:disabled){background:#ffe5e5}.add-block-panel{background:#f8f9ff;border:1.5px solid #e0e4f5;border-radius:14px;padding:20px;margin-bottom:24px}.panel-subtitle{font-size:.95rem;font-weight:700;color:#2c3e50;margin:0 0 14px}.block-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:14px}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.85rem;font-weight:600;color:#444}.form-input{padding:9px 12px;border:1.5px solid #ddd;border-radius:10px;font-size:.95rem;font-family:inherit;color:#222;outline:none;transition:border-color .15s;background:#fff}.form-input:focus{border-color:#4f6ef7}.toggle-group{display:flex;border-radius:10px;overflow:hidden;border:1.5px solid #ddd}.toggle-btn{flex:1;padding:8px;border:none;background:#fff;font-size:.82rem;cursor:pointer;font-family:inherit;color:#555;transition:background .15s,color .15s}.toggle-btn.active{background:#4f6ef7;color:#fff;font-weight:700}.block-times-row{display:flex;align-items:flex-end;gap:10px;margin-bottom:14px}.blocks-list{margin-top:4px}.block-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:10px;background:#f8f9ff;border:1px solid #e8eaf5;margin-bottom:8px}.block-info{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.block-date{font-weight:700;color:#2c3e50;font-size:.9rem}.block-type{color:#e53935;font-weight:600;font-size:.85rem;background:#fff3f3;padding:2px 8px;border-radius:6px}.block-reason{color:#777;font-size:.82rem;font-style:italic}.settings-section-hint{font-size:.83rem;color:#888;margin-bottom:12px;line-height:1.4}.setting-select{padding:8px 12px;border:1px solid #ddd;border-radius:8px;font-size:.95rem;background:#fff;cursor:pointer;min-width:160px}.toggle-label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#555;cursor:pointer}.toggle-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3a8f5c}@media (max-width: 600px){.block-form-grid{grid-template-columns:1fr}.lesson-settings-row{flex-direction:column}.day-row{flex-wrap:wrap}}.student-link-item{display:flex;align-items:flex-start;gap:12px;background:#f9f9f9;border:1px solid #e8e8e8;border-radius:10px;padding:14px 16px;margin-bottom:10px}.link-info{flex:1;display:flex;flex-direction:column;gap:3px}.link-student-name{font-weight:600;font-size:1rem;color:#222}.link-email{font-size:.85rem;color:#555;direction:ltr;text-align:right}.link-note{font-size:.82rem;color:#888;font-style:italic}.link-lessons{font-size:.82rem;color:#3a8f5c;font-weight:500}.link-lesson-row{display:flex;align-items:center;gap:6px;font-size:.82rem;flex-wrap:wrap}.link-lesson-label{color:#6b7280}.link-lesson-value{color:#374151;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:4px;padding:1px 4px;border-radius:4px;transition:background .15s}.link-lesson-value:hover{background:#f3f4f6}.edit-pencil{font-size:.75rem;color:#9ca3af;opacity:0;transition:opacity .15s}.link-lesson-value:hover .edit-pencil{opacity:1}.link-lesson-edit{display:flex;align-items:center;gap:6px}.lesson-num-input{width:70px!important;padding:3px 6px!important;font-size:.85rem!important}.btn-sm{padding:4px 10px!important;font-size:.8rem!important}.link-url-row{display:flex;align-items:center;gap:8px;margin-top:6px;flex-wrap:wrap}.link-url{font-size:.78rem;background:#eef6f1;color:#2a6040;padding:4px 10px;border-radius:6px;direction:ltr;word-break:break-all;font-family:monospace}.btn-copy{background:#3a8f5c;color:#fff;border:none;border-radius:6px;padding:4px 12px;font-size:.8rem;cursor:pointer;white-space:nowrap;transition:background .2s}.btn-copy:hover{background:#2e7348}.btn-copy-done{background:#27ae60}.token-error-box{text-align:center;padding:60px 24px}.token-error-icon{font-size:3rem;margin-bottom:12px}.token-error-title{font-size:1.4rem;color:#c0392b;margin-bottom:8px}.token-error-desc{color:#666}.modal-student-badge{display:flex;align-items:center;gap:12px;background:#eef6f1;border:1px solid #b7ddc8;border-radius:10px;padding:12px 16px;margin-bottom:12px}.modal-student-icon{font-size:1.6rem}.modal-student-name{font-weight:600;color:#222;margin:0}.modal-student-email{font-size:.85rem;color:#555;margin:0;direction:ltr}.alert-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:2000;animation:alertFadeIn .15s ease}@keyframes alertFadeIn{0%{opacity:0}to{opacity:1}}.alert-box{background:#fff;border-radius:14px;padding:2rem 2.2rem 1.6rem;max-width:380px;width:90%;text-align:center;box-shadow:0 8px 32px #0000002e;display:flex;flex-direction:column;align-items:center;gap:.9rem;animation:alertSlideUp .18s ease}@keyframes alertSlideUp{0%{transform:translateY(18px);opacity:0}to{transform:translateY(0);opacity:1}}.alert-box--error{border-top:4px solid #ef4444}.alert-box--success{border-top:4px solid #22c55e}.alert-box--info{border-top:4px solid #3b82f6}.alert-icon{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.3rem;font-weight:700;flex-shrink:0}.alert-icon--error{background:#fef2f2;color:#ef4444}.alert-icon--success{background:#f0fdf4;color:#22c55e}.alert-icon--info{background:#eff6ff;color:#3b82f6}.alert-message{margin:0;font-size:1rem;color:#1e293b;line-height:1.55;font-weight:500}.alert-close-btn{margin-top:.4rem;padding:.55rem 2rem;border:none;border-radius:8px;background:#f1f5f9;color:#334155;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s}.alert-close-btn:hover{background:#e2e8f0}.admin-schedule-page{max-width:900px;margin:0 auto;padding:24px 20px 60px;font-family:inherit}.admin-schedule-header{margin-bottom:28px}.admin-schedule-title{font-size:1.8rem;font-weight:800;color:#1a1a2e;margin:0 0 6px}.admin-schedule-subtitle{color:#777;font-size:.95rem;margin:0}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;background:#f0f3ff;border-radius:14px;padding:5px;width:fit-content}.admin-tab-btn{padding:10px 20px;border:none;border-radius:10px;background:transparent;color:#555;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}.admin-tab-btn:hover{background:#e0e6ff;color:#3a57d4}.admin-tab-active{background:#fff!important;color:#4f6ef7!important;box-shadow:0 2px 8px #4f6ef726}.admin-schedule-content{background:#fff;border-radius:16px;box-shadow:0 2px 16px #00000012;padding:28px}.section-title{font-size:1.1rem;font-weight:700;color:#2c3e50;margin:0 0 20px;padding-bottom:12px;border-bottom:2px solid #eef0f8}.gcal-banner{display:flex;align-items:center;gap:12px;border-radius:12px;padding:12px 16px;margin-bottom:20px;font-size:.88rem;flex-wrap:wrap}.gcal-banner-warn{background:#fff8e1;border:1.5px solid #ffe082;color:#7a5800}.gcal-banner-ok{background:#e6faf0;border:1.5px solid #a3dfc0;color:#1a6e3c}.gcal-banner-icon{font-size:1.1rem;flex-shrink:0}.gcal-banner-text{flex:1;line-height:1.4}.gcal-banner-link{font-weight:700;font-size:.85rem;white-space:nowrap;text-decoration:none;padding:5px 12px;border-radius:8px;transition:background .15s}.gcal-banner-warn .gcal-banner-link{background:#ffe082;color:#5a3e00}.gcal-banner-warn .gcal-banner-link:hover{background:#ffd54f}.gcal-banner-ok .gcal-banner-link{background:#a3dfc0;color:#0e4d2a}.gcal-banner-ok .gcal-banner-link:hover{background:#7bcca2}@media (max-width: 600px){.admin-schedule-page{padding:16px 12px 40px}.admin-tabs{width:100%;flex-wrap:wrap}.admin-tab-btn{flex:1;text-align:center;padding:9px 10px;font-size:.82rem}.admin-schedule-content{padding:18px 14px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Heebo,Inter,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.6;color:#1f2937;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}[dir=ltr],code,.link-url,.cell-email{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}#root{min-height:100vh}
