*{box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#333;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;padding:0;min-height:100vh}#root{min-height:100vh}.phone-verification{min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center}.verification-container{max-width:500px;width:100%;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 40px #0003}.verification-container h2{margin-top:0;color:#333;text-align:center}.verification-subtitle{text-align:center;color:#666;margin-bottom:2rem}.verification-form{margin-top:1.5rem}.phone-input,.otp-input{width:100%;padding:1rem;font-size:1.1rem;border:2px solid #ddd;border-radius:6px;text-align:center;letter-spacing:.5rem;font-family:monospace;box-sizing:border-box}.phone-input{letter-spacing:normal;text-align:left}.otp-input{font-size:1.5rem;font-weight:700}.phone-input:focus,.otp-input:focus{outline:none;border-color:#667eea}.help-text{margin-top:.5rem;font-size:.9rem;color:#666;text-align:center}.dev-otp{margin-top:1rem;padding:1rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;text-align:center;color:#856404}.dev-otp code{background:#fff;padding:.25rem .5rem;border-radius:4px;font-size:1.2rem;font-weight:700;color:#333}.info-box{margin-top:1.5rem;padding:1rem;background:#f5f5f5;border-radius:6px;text-align:center;color:#666}.btn-primary,.btn-secondary,.btn-link,.btn-link-inline{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500;width:100%;margin-bottom:.5rem}.btn-link,.btn-link-inline{background:transparent;color:#667eea;text-decoration:underline;padding:0;width:auto;margin:0}.btn-link:hover,.btn-link-inline:hover{color:#5568d3}.btn-link-inline{display:inline;font-size:inherit}@media(max-width:600px){.phone-verification{padding:1rem}.verification-container{padding:1.5rem}}.availability-selector{margin:1.5rem 0}.selector-header{margin-bottom:1rem}.selector-header h3{margin:0 0 .5rem;color:#333}.help-text{color:#666;font-size:.9rem;margin:0}.time-grid{display:flex;gap:4px;overflow-x:auto;padding:1rem 0;margin-bottom:1rem}.hour-labels{display:flex;flex-direction:column;gap:2px;min-width:60px;position:sticky;left:0;background:#fff;z-index:10}.hour-label{height:32px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:#666;font-weight:500;border:1px solid transparent}.day-column{display:flex;flex-direction:column;gap:2px;min-width:80px}.day-header{display:flex;align-items:center;justify-content:space-between;padding:.5rem;background:#f5f5f5;border-radius:4px;margin-bottom:.25rem;position:sticky;top:0;z-index:5}.day-name{font-weight:600;color:#333;font-size:.9rem}.clear-day-btn{background:transparent;border:none;color:#999;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.clear-day-btn:hover{background:#fee;color:#c33}.time-slot{width:100%;height:32px;border:1px solid #ddd;background:#fff;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;border-radius:2px;position:relative}.time-slot:hover{border-color:#667eea;background:#f0f4ff;transform:scale(1.05);z-index:2}.time-slot.selected{background:#667eea;border-color:#5568d3;color:#fff}.time-slot.selected .check{font-size:.9rem;font-weight:700}.selected-summary{margin-top:1.5rem;padding:1rem;background:#f5f5f5;border-radius:6px}.selected-summary h4{margin:0 0 .75rem;color:#333;font-size:.9rem}.ranges-list{display:flex;flex-wrap:wrap;gap:.5rem}.range-badge{padding:.5rem .75rem;background:#667eea;color:#fff;border-radius:4px;font-size:.85rem;font-weight:500}.empty-state{margin-top:1rem;padding:1rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;text-align:center;color:#856404}.empty-state p{margin:0;font-size:.9rem}@media(max-width:768px){.time-grid{gap:2px}.day-column{min-width:60px}.hour-labels{min-width:50px}.hour-label{font-size:.7rem}.day-name{font-size:.8rem}.time-slot{height:28px}}.time-grid::-webkit-scrollbar{height:8px}.time-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.time-grid::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}.time-grid::-webkit-scrollbar-thumb:hover{background:#999}.payment-form{display:flex;flex-direction:column;gap:1.5rem}.payment-summary{background:#f5f5f5;border-radius:8px;padding:1rem;border:1px solid #ddd}.summary-row{display:flex;justify-content:space-between;padding:.5rem 0;color:#666}.summary-row.total{border-top:2px solid #ddd;margin-top:.5rem;padding-top:.75rem;font-weight:700;font-size:1.1rem;color:#333}.card-element-container{padding:1rem;border:1px solid #ddd;border-radius:6px;background:#fff}.payment-actions{display:flex;gap:1rem}.payment-actions .btn-primary,.payment-actions .btn-secondary{flex:1;padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s}.payment-actions .btn-primary{background:#667eea;color:#fff}.payment-actions .btn-primary:hover:not(:disabled){background:#5568d3}.payment-actions .btn-primary:disabled{opacity:.6;cursor:not-allowed}.payment-actions .btn-secondary{background:#f0f0f0;color:#666}.payment-actions .btn-secondary:hover:not(:disabled){background:#e0e0e0}.booking-flow{min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.booking-container{max-width:600px;margin:0 auto;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 10px 40px #0003}.booking-container h1{margin-top:0;color:#333;text-align:center}.step{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.step h2{margin-top:0;color:#333;text-align:center}.validation-error{display:block;color:#c33;font-size:.85rem;margin-top:.25rem}.postcode-input{width:100%;padding:1rem;font-size:1.1rem;border:2px solid #ddd;border-radius:6px;margin-bottom:1rem;box-sizing:border-box}.postcode-input:focus{outline:none;border-color:#667eea}.option-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1rem}.option-card,.product-card{padding:2rem;border:2px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;transition:all .2s;text-align:center}.option-card:hover,.product-card:hover{border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.option-card h3,.product-card h3{margin-top:0;color:#333}.option-card p,.product-card p{color:#666;margin-bottom:0}.product-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1rem}.form-group input[type=text],.form-group input[type=tel],.form-group input[type=email],.form-group textarea{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:6px;font-size:1rem;box-sizing:border-box;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea}.form-group input:invalid:not(:focus):not(:placeholder-shown),.form-group textarea:invalid:not(:focus):not(:placeholder-shown){border-color:#c33}.help-text{display:block;font-size:.85rem;color:#666;margin-top:.25rem}.availability-slot{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem;padding:.5rem;background:#f5f5f5;border-radius:6px}.availability-slot select,.availability-slot input[type=number]{padding:.5rem;border:1px solid #ddd;border-radius:4px;flex:1}.availability-slot span{color:#666}.btn-primary,.btn-secondary,.btn-remove{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;cursor:pointer;transition:all .2s;font-weight:500}.btn-primary{background:#667eea;color:#fff;width:100%;margin-bottom:.5rem}.btn-primary:hover:not(:disabled){background:#5568d3;transform:translateY(-1px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#f5f5f5;color:#333;width:100%}.btn-secondary:hover{background:#e0e0e0}.btn-remove{background:#fee;color:#c33;padding:.5rem 1rem;font-size:.9rem}.confirmation{text-align:center}.confirmation-message{font-size:1.1rem;color:#333;margin:1.5rem 0;padding:1rem;background:#e8f5e9;border-radius:6px}.booking-details{text-align:left;background:#f5f5f5;padding:1rem;border-radius:6px;margin:1.5rem 0}.booking-details p{margin:.5rem 0;color:#666}.verification-cta{margin-top:2rem;padding:1rem;background:#fff3cd;border-radius:6px;border:1px solid #ffc107}.verification-cta p{margin-bottom:1rem;color:#856404}.booking-actions{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}@media(max-width:600px){.booking-flow{padding:1rem}.booking-container{padding:1.5rem}.option-grid,.product-grid{grid-template-columns:1fr}.availability-slot{flex-wrap:wrap}}.student-dashboard{min-height:100vh;padding:2rem;background:#f5f5f5}.phone-number{color:#666;margin:0}.balance-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.balance-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:8px;text-align:center}.balance-card h3{margin:0 0 .5rem;font-size:.9rem;opacity:.9}.balance-amount{margin:0;font-size:2rem;font-weight:700}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:2px solid #f0f0f0}.tab{padding:.75rem 1.5rem;background:transparent;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;color:#666;transition:all .2s;font-weight:500}.tab:hover{color:#667eea;background:#f8f9ff}.tab.active{color:#667eea;border-bottom-color:#667eea}.tab-content{min-height:300px}.empty-state{text-align:center;padding:3rem;color:#666}.bookings-list{display:flex;flex-direction:column;gap:1rem}.booking-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.booking-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#667eea}.booking-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.booking-header h3{margin:0;color:#333}.booking-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:.5rem}.booking-details p{margin:.25rem 0;color:#666;font-size:.9rem}.credits-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.credit-type{padding:1.5rem;background:#f8f9ff;border-radius:8px;border:2px solid #e0e4ff}.credit-type h3{margin:0 0 .5rem;color:#333;font-size:1rem}.credit-amount{margin:0;font-size:2rem;font-weight:700;color:#667eea}.ledger-table{width:100%;border-collapse:collapse;font-size:.9rem}.ledger-table thead{background:#f5f5f5}.ledger-table th{padding:.75rem;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0}.ledger-table td{padding:.75rem;border-bottom:1px solid #f0f0f0}.ledger-row:hover{background:#f8f9ff}.type-badge{padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:500;text-transform:capitalize}.type-add{background:#d1e7dd;color:#0f5132}.type-deduct{background:#f8d7da;color:#842029}.type-adjustment{background:#fff3cd;color:#856404}.type-refund{background:#cfe2ff;color:#084298}.positive{color:#0f5132;font-weight:500}.negative{color:#842029;font-weight:500}.loading{text-align:center;padding:3rem;color:#666}@media(max-width:768px){.student-dashboard,.dashboard-container{padding:1rem}.tabs{flex-wrap:wrap}.tab{flex:1;min-width:100px;font-size:.9rem;padding:.5rem 1rem}.ledger-table{font-size:.8rem}.ledger-table th,.ledger-table td{padding:.5rem}.booking-details{grid-template-columns:1fr}}.manager-dashboard{min-height:100vh;padding:2rem;background:#f5f5f5}.dashboard-container{max-width:1400px;margin:0 auto;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.filters{display:flex;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.filter-btn{padding:.5rem 1rem;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:.9rem;color:#666;transition:all .2s}.filter-btn:hover{background:#e0e0e0}.filter-btn.active{background:#667eea;color:#fff;border-color:#667eea}.requests-list{display:flex;flex-direction:column;gap:1rem}.request-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.request-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#667eea}.request-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.request-header h3{margin:0 0 .25rem;color:#333}.request-meta{margin:0;color:#666;font-size:.9rem}.status-submitted{background:#fff3cd;color:#856404}.status-instructor_contacted,.status-completed{background:#d1e7dd;color:#0f5132}.status-cancelled{background:#f8d7da;color:#842029}.status-offered{background:#e0e7ff;color:#3730a3}.status-pending{background:#fef3c7;color:#92400e}.status-accepted{background:#d1fae5;color:#065f46}.status-declined{background:#fee2e2;color:#991b1b}.status-expired{background:#f3f4f6;color:#6b7280}.request-details{margin-bottom:1rem}.request-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-primary,.btn-secondary{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.btn-primary:disabled,.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-body p{margin:.5rem 0;color:#666}.instructors-list{margin-top:1.5rem}.instructors-list label{display:block;margin-bottom:.75rem;color:#333;font-weight:500}.instructor-options{display:flex;flex-direction:column;gap:.5rem}.instructor-option{padding:1rem;background:#f8f9ff;border:2px solid #e0e4ff;border-radius:6px;cursor:pointer;text-align:left;transition:all .2s}.instructor-option:hover:not(:disabled){background:#f0f4ff;border-color:#667eea}.instructor-option:disabled{opacity:.6;cursor:not-allowed}.instructor-option strong{display:block;color:#333;margin-bottom:.25rem}.instructor-option p{margin:0;color:#666;font-size:.9rem}.no-instructors{padding:1rem;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;color:#856404;text-align:center}@media(max-width:768px){.manager-dashboard,.dashboard-container{padding:1rem}.detail-row{flex-direction:column;gap:.5rem}.modal-content{margin:1rem}}.product-form{padding:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500;font-size:.9rem}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group input[type=checkbox]{margin-right:.5rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid #e0e0e0;margin-top:1rem}.btn-small{padding:.4rem .8rem;font-size:.85rem}.btn-danger{background:#dc3545;color:#fff}.btn-danger:hover:not(:disabled){background:#c82333}.products-section{margin-top:2rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{margin:0;color:#333}.products-list{margin-top:1rem}.products-table{width:100%;border-collapse:collapse;margin-top:1rem}.products-table th,.products-table td{padding:.75rem;text-align:left;border-bottom:1px solid #e0e0e0}.products-table th{background:#f8f9fa;font-weight:600;color:#333}.products-table tr.inactive{opacity:.6}.products-table .status-badge.active{background:#d1e7dd;color:#0f5132}.products-table .status-badge.inactive{background:#f8d7da;color:#842029}.products-table td{vertical-align:middle}.products-table .btn-small{margin-right:.5rem}.negative-balance-section{margin-top:2rem}.instructor-dashboard{min-height:100vh;padding:2rem;background:#f5f5f5}.dashboard-container{max-width:1200px;margin:0 auto;background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a}.dashboard-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.dashboard-header h1{margin:0 0 .5rem;color:#333}.subtitle{color:#666;margin:0}.jobs-summary{margin-bottom:2rem}.summary-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:8px;text-align:center}.summary-card h3{margin:0 0 .5rem;font-size:1rem;opacity:.9}.summary-number{margin:0;font-size:2.5rem;font-weight:700}.jobs-list{display:flex;flex-direction:column;gap:1rem}.job-card{border:1px solid #e0e0e0;border-radius:8px;padding:1.5rem;transition:all .2s}.job-card:hover{box-shadow:0 4px 12px #0000001a;border-color:#667eea}.job-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.job-header h3{margin:0 0 .25rem;color:#333}.job-meta{margin:0;color:#666;font-size:.9rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.status-assigned{background:#cfe2ff;color:#084298}.status-instructor_contacted{background:#d1e7dd;color:#0f5132}.job-details{margin-bottom:1rem}.detail-row{display:flex;gap:2rem;margin-bottom:.5rem;flex-wrap:wrap}.detail-row span{color:#666;font-size:.9rem}.job-actions{display:flex;gap:.5rem;flex-wrap:wrap}.btn-primary,.btn-secondary,.btn-accept,.btn-decline{padding:.5rem 1rem;border:none;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover:not(:disabled){background:#5568d3}.btn-accept{background:#28a745;color:#fff}.btn-accept:hover:not(:disabled){background:#218838}.btn-decline{background:#dc3545;color:#fff}.btn-decline:hover:not(:disabled){background:#c82333}.btn-secondary{background:#f5f5f5;color:#333}.btn-secondary:hover:not(:disabled){background:#e0e0e0}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{background:#fff;border-radius:12px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;color:#333}.modal-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;color:#666;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.modal-close:hover{background:#f5f5f5;color:#333}.modal-body{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;color:#333;font-weight:500}.form-group input[type=number],.form-group input[type=text],.form-group textarea,.form-group select{width:100%;padding:.75rem;border:2px solid #ddd;border-radius:6px;font-size:1rem;box-sizing:border-box;font-family:inherit}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea}.help-text{margin-top:.25rem;font-size:.85rem;color:#666}.skill-progress-item{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem;padding:.5rem;background:#f5f5f5;border-radius:6px}.skill-progress-item select,.skill-progress-item input{flex:1;padding:.5rem;border:1px solid #ddd;border-radius:4px}.btn-remove{background:#fee;color:#c33;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem}.btn-remove:hover{background:#fcc}.modal-actions{display:flex;gap:.5rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e0e0e0}.modal-actions .btn-primary,.modal-actions .btn-secondary{flex:1}.empty-state,.loading{text-align:center;padding:3rem;color:#666}.error-message{background:#fee;color:#c33;padding:1rem;border-radius:6px;margin-bottom:1rem;border:1px solid #fcc}@media(max-width:768px){.instructor-dashboard,.dashboard-container{padding:1rem}.detail-row{flex-direction:column;gap:.5rem}.skill-progress-item{flex-wrap:wrap}.modal-content{margin:1rem}}.manager-login{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.manager-login-container{background:#fff;border-radius:8px;padding:2rem;max-width:400px;width:90%;box-shadow:0 4px 16px #0003}.manager-login-container h3{margin:0 0 1.5rem;color:#333;font-size:1.5rem}.manager-login-form{display:flex;flex-direction:column;gap:1rem}.manager-login-form .form-group{display:flex;flex-direction:column;gap:.5rem}.manager-login-form label{font-weight:500;color:#666;font-size:.9rem}.manager-login-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.manager-login-form input:focus{outline:none;border-color:#667eea}.manager-login .error-message{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem}.manager-login-form .btn-primary,.manager-login-form .btn-secondary{padding:.75rem 1.5rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;font-weight:500;transition:background .2s}.manager-login-form .btn-primary{background:#667eea;color:#fff}.manager-login-form .btn-primary:hover:not(:disabled){background:#5568d3}.manager-login-form .btn-primary:disabled{opacity:.6;cursor:not-allowed}.manager-login-form .btn-secondary{background:#f0f0f0;color:#666;margin-top:.5rem}.manager-login-form .btn-secondary:hover:not(:disabled){background:#e0e0e0}.instructor-login{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.instructor-login-container{background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 6px #0000001a;width:100%;max-width:400px}.instructor-login-container h3{margin:0 0 1.5rem;color:#333;text-align:center}.instructor-login-form{display:flex;flex-direction:column;gap:1rem}.instructor-login-form .form-group{display:flex;flex-direction:column}.instructor-login-form label{margin-bottom:.5rem;color:#555;font-weight:500}.instructor-login-form input{padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem}.instructor-login-form input:focus{outline:none;border-color:#667eea}.instructor-login .error-message{background:#fee;color:#c33;padding:.75rem;border-radius:4px;margin-bottom:1rem;text-align:center}.instructor-login-form .btn-primary,.instructor-login-form .btn-secondary{padding:.75rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer}.instructor-login-form .btn-primary{background:#667eea;color:#fff}.instructor-login-form .btn-primary:hover:not(:disabled){background:#5568d3}.instructor-login-form .btn-primary:disabled{opacity:.6;cursor:not-allowed}.instructor-login-form .btn-secondary{background:#f0f0f0;color:#333}.instructor-login-form .btn-secondary:hover:not(:disabled){background:#e0e0e0}.App{min-height:100vh}.app-nav{background:#fff;border-bottom:2px solid #e0e0e0;padding:1rem 0;position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.nav-container{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-logo{margin:0;font-size:1.25rem;color:#667eea;font-weight:600}.nav-links{display:flex;gap:1rem}.nav-link{padding:.5rem 1rem;background:transparent;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:1rem;color:#666;transition:all .2s;font-weight:500}.nav-link:hover{color:#667eea}.nav-link.active{color:#667eea;border-bottom-color:#667eea}.dashboard-placeholder{min-height:60vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.dashboard-placeholder p{font-size:1.1rem;color:#666;margin-bottom:1.5rem}.dashboard-placeholder .btn-primary,.dashboard-placeholder .btn-secondary{margin:.5rem}.login-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 80px);padding:2rem;background:#f5f5f5}.login-content{background:#fff;border-radius:8px;padding:2rem;max-width:500px;width:100%;box-shadow:0 2px 8px #0000001a}.login-content h2{margin:0 0 .5rem;color:#333;font-size:1.75rem}.login-subtitle{color:#666;margin:0 0 1.5rem;font-size:.95rem}.manager-login-btn{position:fixed;bottom:20px;right:20px;padding:.5rem 1rem;background:#667eea1a;border:1px solid rgba(102,126,234,.3);border-radius:20px;color:#667eea;font-size:.85rem;cursor:pointer;opacity:.6;transition:opacity .2s;z-index:100;font-weight:500}.manager-login-btn:hover{opacity:1;background:#667eea33}.instructor-login-btn{position:fixed;bottom:20px;left:20px;padding:.5rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:20px;color:#22c55e;font-size:.85rem;cursor:pointer;opacity:.6;transition:opacity .2s;z-index:100;font-weight:500}.instructor-login-btn:hover{opacity:1;background:#22c55e33}@media(max-width:768px){.nav-container{padding:0 1rem;flex-direction:column;gap:1rem}.nav-logo{font-size:1.1rem}.nav-links{width:100%;justify-content:center}.manager-login-btn{bottom:15px;right:15px;font-size:.75rem;padding:.4rem .8rem}.instructor-login-btn{bottom:15px;left:15px;font-size:.75rem;padding:.4rem .8rem}}
