.ot-booking-app,.ot-booking-app *,.ot-booking-app *::before,.ot-booking-app *::after{box-sizing:border-box;margin:0;padding:0}.ot-booking-app{font-family:'Roboto',sans-serif;color:#152a55;background:linear-gradient(180deg,#f8fafc 0%,#ffffff 100%);min-height:100vh;position:relative;overflow-x:hidden}:where(.ot-booking-app) button{font-family:'Roboto',sans-serif;background:none;background-color:transparent;border:none;color:inherit;cursor:pointer;text-align:inherit;display:inline-block;box-shadow:none;border-radius:0;padding:0;margin:0;outline:none;appearance:none;-webkit-appearance:none}.ot-booking-app input{font-family:'Roboto',sans-serif}.ot-booking-app h1,.ot-booking-app h2,.ot-booking-app h3,.ot-booking-app h4{font-family:'Roboto',sans-serif;line-height:1.25;margin:0;padding:0;border:none;background:none;box-shadow:none}.ot-booking-app p{margin:0;padding:0;font-family:'Roboto',sans-serif}.ot-booking-app ul,.ot-booking-app ol{list-style:none;margin:0;padding:0}.ot-booking-app a{color:#3165ae;text-decoration:none}.ot-booking-app a:hover{color:#152a55;text-decoration:underline}.ot-grid-error{grid-column:1 / -1;padding:2rem;text-align:center;color:#c62828;font-size:15px;background:#fce8e6;border-radius:10px}.ot-header{background:linear-gradient(135deg,#3165ae 0%,#152a55 100%);padding:20px 40px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 20px rgba(21,42,85,.15)}.ot-logo{display:flex;align-items:center;gap:12px}.ot-logo-badge{background:#b6af64;color:#152a55;font-weight:700;font-size:14px;padding:8px 12px;border-radius:6px;letter-spacing:1px}.ot-logo-text{color:#fff;font-size:22px;font-weight:500;letter-spacing:-.5px}.ot-tagline{color:#d6ce86;font-size:14px;font-weight:500;letter-spacing:.5px}.ot-progress-container{padding:32px 40px 16px;max-width:600px;margin:0 auto}.ot-progress-track{display:flex;align-items:center;justify-content:center}.ot-progress-step{width:36px;height:36px;border-radius:50%;background:rgba(135,142,149,.25);color:#878e95;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;flex-shrink:0;transition:background 0.3s ease,color 0.3s ease,box-shadow 0.3s ease}.ot-progress-step.ot-step-active{background:#3165ae;color:#fff;box-shadow:0 0 0 4px rgba(49,101,174,.2)}.ot-progress-step.ot-step-done{background:#3165ae;color:#fff;box-shadow:none;cursor:pointer}.ot-progress-step.ot-step-done:hover{background:#254f8c;box-shadow:0 0 0 4px rgba(49,101,174,.15)}.ot-progress-line{flex:1;height:3px;background:rgba(135,142,149,.25);max-width:80px;transition:background 0.3s ease}.ot-progress-line.ot-line-done{background:#3165ae}.ot-progress-labels{display:flex;justify-content:space-between;margin-top:12px}.ot-progress-labels span{font-size:12px;color:#878e95;text-align:center;flex:1;transition:color 0.3s ease,font-weight 0.3s ease}.ot-progress-labels span.ot-label-active{color:#3165ae;font-weight:500}.ot-booking-app .ot-back-btn{background:none;border:none;color:#3165ae;font-size:14px;font-weight:500;cursor:pointer;padding:8px 40px;display:inline-flex;align-items:center;gap:4px;transition:opacity 0.2s ease}.ot-step-panel{display:none;padding:24px 40px 60px;max-width:1200px;margin:0 auto;animation:ot-fade-in 0.4s ease}.ot-step-panel.ot-panel-active{display:block}@keyframes ot-fade-in{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.ot-welcome-section{text-align:center;max-width:800px;margin:0 auto 40px;padding:32px 40px;background:linear-gradient(135deg,rgba(49,101,174,.05) 0%,rgba(182,175,100,.05) 100%);border-radius:20px;border:1px solid rgba(135,142,149,.2)}.ot-booking-app .ot-welcome-title{font-size:36px;font-weight:600;color:#152a55;margin-bottom:16px;letter-spacing:-.5px}.ot-welcome-text{font-size:16px;color:#152a55;line-height:1.7;margin-bottom:24px}.ot-benefits-list{display:flex;flex-direction:column;gap:12px;text-align:left;max-width:600px;margin:0 auto}.ot-benefit-item{display:flex;align-items:flex-start;gap:12px;font-size:15px;color:#152a55;line-height:1.5}.ot-benefit-icon{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:#3165ae;color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-top:2px}.ot-step-heading{text-align:center;margin-bottom:40px}.ot-booking-app .ot-step-heading h2{font-size:32px;font-weight:500;color:#152a55;margin-bottom:8px;letter-spacing:-.5px}.ot-step-heading p{font-size:16px;color:#878e95}.ot-subjects-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:20px;max-width:800px;margin:0 auto}.ot-booking-app .ot-subject-card{background:#fff;border:2px solid rgba(135,142,149,.25);border-radius:16px;padding:32px 24px;cursor:pointer;text-align:center;transition:transform 0.25s ease,box-shadow 0.25s ease;box-shadow:0 4px 20px rgba(21,42,85,.08)}.ot-booking-app .ot-subject-card:hover{background:#fff;transform:translateY(-4px);box-shadow:0 12px 40px rgba(49,101,174,.2)}.ot-subject-icon{font-size:40px;color:#3165ae;margin-bottom:16px;display:block;line-height:1}.ot-subject-name{font-size:18px;font-weight:600;color:#152a55;margin-bottom:6px;display:block}.ot-subject-meta{font-size:13px;color:#878e95}.ot-booking-instructions{text-align:center;max-width:700px;margin:0 auto 40px;padding:28px 40px;background:linear-gradient(135deg,#152a55 0%,#2e65ae 100%);border-radius:16px;color:#fff}.ot-booking-app .ot-booking-instructions h3{font-size:24px;font-weight:600;margin-bottom:20px;color:#d6ce86}.ot-instruction-steps{display:flex;flex-direction:column;align-items:flex-start;gap:16px}.ot-instruction-step{display:flex;align-items:center;gap:12px;font-size:15px;color:#fff;text-align:left}.ot-instruction-number{width:28px;height:28px;border-radius:50%;background:#b6af64;color:#152a55;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.ot-tutors-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.ot-booking-app .ot-tutor-card{background:#fff;border:2px solid rgba(135,142,149,.25);border-radius:16px;padding:24px;cursor:pointer;text-align:left;display:flex;gap:20px;transition:transform 0.25s ease,box-shadow 0.25s ease;box-shadow:0 4px 20px rgba(21,42,85,.06);width:100%}.ot-booking-app .ot-tutor-card:hover{background:#fff;transform:translateY(-4px);box-shadow:0 12px 40px rgba(49,101,174,.15)}.ot-tutor-photo-wrap{position:relative;flex-shrink:0}.ot-tutor-photo{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#3165ae 0%,#629cd1 100%);display:flex;align-items:center;justify-content:center;color:#fff;font-size:24px;font-weight:600}.ot-tutor-photo-img{width:80px;height:80px;border-radius:50%;object-fit:cover;object-position:top center;display:block;flex-shrink:0}.ot-tutor-rating-badge{position:absolute;bottom:-4px;right:-4px;background:#b6af64;color:#152a55;font-size:11px;font-weight:600;padding:3px 8px;border-radius:10px;white-space:nowrap}.ot-tutor-body{flex:1;min-width:0}.ot-tutor-name{font-size:18px;font-weight:600;color:#152a55;margin-bottom:2px}.ot-tutor-degree{font-size:13px;color:#878e95;margin-bottom:12px}.ot-tutor-credentials{font-size:13px;color:#878e95;margin-bottom:12px}.ot-tutor-subject-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.ot-subject-tag{background:rgba(49,101,174,.1);color:#3165ae;font-size:11px;font-weight:500;padding:4px 10px;border-radius:12px}.ot-tutor-bio{font-size:13px;color:#878e95;line-height:1.5;margin-bottom:12px}.ot-tutor-sessions{font-size:12px;color:#878e95;font-weight:500}.ot-tutor-summary-banner{display:flex;align-items:center;gap:16px;padding:20px 24px;background:linear-gradient(135deg,#3165ae 0%,#152a55 100%);border-radius:16px;color:#fff;margin-bottom:32px}.ot-summary-photo{width:60px;height:60px;border-radius:50%;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600;flex-shrink:0;color:#fff}.ot-summary-name{font-size:20px;font-weight:600;margin-bottom:2px}.ot-summary-credentials{font-size:14px;opacity:.85}.ot-section-card{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 20px rgba(21,42,85,.06);margin-bottom:32px}.ot-section-title{font-size:18px;font-weight:600;color:#152a55;margin-bottom:4px}.ot-section-subtitle{font-size:14px;color:#878e95;margin-bottom:20px}.ot-week-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}.ot-week-label{flex:1;text-align:center;font-size:14px;font-weight:600;color:#1a2332}.ot-week-btn{background:#152a55;color:#fff;border:1px solid rgba(21,42,85,.5);border-radius:6px;padding:6px 14px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap}.ot-week-btn:hover:not(:disabled){background:#e2eaff;color:#152a55}.ot-week-btn:disabled{opacity:.4;cursor:not-allowed}.ot-calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px;margin-bottom:16px}.ot-day-col{background:rgba(135,142,149,.08);border-radius:12px;overflow:hidden}.ot-day-header{background:#3165ae;color:#fff;padding:10px 8px;font-size:12px;font-weight:600;text-align:center}.ot-day-slots{padding:8px;display:flex;flex-direction:column;gap:6px}.ot-time-slot{background:rgba(49,101,174,.08);color:#3165ae;padding:8px 8px 6px;border-radius:6px;font-size:12px;font-weight:500;text-align:center}.ot-slot-all-busy{opacity:.45}.ot-slot-label{display:block;margin-bottom:5px}.ot-sub-slots{display:flex;gap:2px;justify-content:center}.ot-sub-slot{flex:1;height:5px;border-radius:2px;background:rgba(34,197,94,.45)}.ot-sub-slot.ot-sub-busy{background:#166534}.ot-slot-partial .ot-sub-slot{background:rgba(182,175,100,.5)}.ot-slot-partial .ot-sub-slot.ot-sub-busy{background:#b6af64}.ot-slot-all-busy .ot-sub-slot,.ot-slot-all-busy .ot-sub-slot.ot-sub-busy{background:rgba(220,38,38,.5)}.ot-calendar-note{font-size:12px;color:#878e95;text-align:center}.ot-packages-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.ot-booking-app .ot-package-card{position:relative;background:#fff;border:2px solid rgba(135,142,149,.25);border-radius:12px;padding:24px 16px;cursor:pointer;text-align:center;transition:border-color 0.2s ease,background 0.2s ease;width:100%}.ot-booking-app .ot-package-card:hover{background:#fff;border-color:#3165ae}.ot-booking-app .ot-package-card.ot-package-selected{border-color:#3165ae;background:rgba(49,101,174,.05)}.ot-booking-app .ot-package-card.ot-package-popular{border-color:#b6af64}.ot-booking-app .ot-package-card.ot-package-popular.ot-package-selected{border-color:#3165ae}.ot-popular-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:#b6af64;color:#152a55;font-size:11px;font-weight:600;padding:4px 12px;border-radius:10px;white-space:nowrap}.ot-package-name{font-size:16px;font-weight:600;color:#152a55;margin-bottom:4px}.ot-package-credits{font-size:13px;color:#878e95;margin-bottom:12px}.ot-package-price{font-size:32px;font-weight:700;color:#3165ae;margin-bottom:4px;line-height:1}.ot-package-per-session{font-size:13px;color:#878e95;margin-bottom:8px}.ot-package-savings{display:inline-block;background:rgba(182,175,100,.2);color:#152a55;font-size:12px;font-weight:600;padding:4px 10px;border-radius:10px}.ot-proceed-section{text-align:center}.ot-booking-app .ot-proceed-btn{background:linear-gradient(135deg,#3165ae 0%,#152a55 100%);color:#fff;border:none;border-radius:12px;padding:18px 48px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity 0.25s ease;box-shadow:0 4px 20px rgba(49,101,174,.3);font-family:'Roboto',sans-serif}.ot-booking-app .ot-proceed-btn:hover:not(:disabled){opacity:.88}.ot-booking-app .ot-proceed-btn:disabled{background:#878e95;cursor:not-allowed;box-shadow:none}.ot-otp-panel{max-width:500px;margin:0 auto;background:#fff;border-radius:16px;padding:36px;box-shadow:0 4px 20px rgba(21,42,85,.08)}.ot-otp-panel h3{font-size:22px;font-weight:600;color:#152a55;margin-bottom:10px}.ot-otp-panel p{font-size:15px;color:#878e95;line-height:1.6;margin-bottom:24px}.ot-checkout-layout{display:grid;grid-template-columns:1fr 1.2fr;gap:32px;max-width:900px;margin:0 auto;overflow:visible}.ot-order-summary{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 20px rgba(21,42,85,.08);height:fit-content}.ot-order-summary h3{font-size:18px;font-weight:600;color:#152a55;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #d6ce86}.ot-order-row{display:flex;justify-content:space-between;padding:12px 0;font-size:14px;color:#152a55}.ot-order-tax-note{font-size:12px;color:#8a95a6;font-style:italic;padding-top:4px;padding-bottom:4px}.ot-order-divider{height:1px;background:#878e95;opacity:.3;margin:8px 0}.ot-order-total{display:flex;justify-content:space-between;padding:16px 0 0;font-size:18px;font-weight:600;color:#152a55}.ot-payment-form{background:#fff;border-radius:16px;padding:28px;box-shadow:0 4px 20px rgba(21,42,85,.08);overflow:visible}#stripe-checkout{overflow:visible;display:block;min-height:650px}#stripe-checkout iframe{display:block;border:0;width:100%!important}.ot-stripe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(135,142,149,.3)}.ot-stripe-logo{font-size:24px;font-weight:700;color:#635bff;font-style:italic;letter-spacing:-1px}.ot-secure-label{font-size:13px;color:#878e95}.ot-form-group{margin-bottom:20px}.ot-form-label{display:block;font-size:14px;font-weight:500;color:#152a55;margin-bottom:8px}.ot-form-input{width:100%;padding:12px 14px;font-size:15px;border:1px solid rgba(135,142,149,.4);border-radius:8px;outline:none;color:#152a55;background:#fff;transition:border-color 0.2s ease,box-shadow 0.2s ease;font-family:'Roboto',sans-serif}.ot-form-input:focus{border-color:#3165ae;box-shadow:0 0 0 3px rgba(49,101,174,.12)}.ot-field-error{display:block;font-size:12px;color:#d63638;margin-top:5px;min-height:16px}.ot-otp-input{font-size:26px;letter-spacing:12px;text-align:center;font-weight:700}.ot-card-group{border:1px solid rgba(135,142,149,.4);border-radius:8px;overflow:hidden}.ot-card-number{width:100%;padding:12px 14px;font-size:15px;border:none;border-bottom:1px solid rgba(135,142,149,.4);outline:none;font-family:'Roboto',sans-serif}.ot-card-row{display:flex}.ot-card-expiry,.ot-card-cvc{flex:1;padding:12px 14px;font-size:15px;border:none;outline:none;font-family:'Roboto',sans-serif}.ot-card-expiry{border-right:1px solid rgba(135,142,149,.4)}.ot-btn-primary{width:100%;background:linear-gradient(135deg,#3165ae 0%,#152a55 100%);color:#fff;border:none;border-radius:8px;padding:16px;font-size:16px;font-weight:600;cursor:pointer;font-family:'Roboto',sans-serif;transition:opacity 0.2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.ot-btn-primary:hover:not(:disabled){opacity:.88}.ot-btn-primary:disabled{background:#878e95;cursor:not-allowed}.ot-btn-ghost{width:100%;background:transparent;color:#878e95;border:1px solid rgba(135,142,149,.4);border-radius:8px;padding:12px 16px;font-size:14px;font-weight:500;cursor:pointer;font-family:'Roboto',sans-serif;transition:border-color 0.2s ease,color 0.2s ease;margin-top:10px;display:flex;align-items:center;justify-content:center}.ot-btn-ghost:hover{border-color:#3165ae;color:#3165ae}.ot-stripe-disclaimer{font-size:12px;color:#878e95;text-align:center;margin-top:16px;line-height:1.5}.ot-processing-inner{display:flex;align-items:center;justify-content:center;gap:10px}.ot-confirmation-container{padding:60px 40px;display:flex;justify-content:center;animation:ot-fade-in 0.5s ease}.ot-confirmation-card{background:#fff;border-radius:20px;padding:48px;max-width:500px;width:100%;text-align:center;box-shadow:0 8px 40px rgba(21,42,85,.1)}.ot-success-icon{width:72px;height:72px;border-radius:50%;background:linear-gradient(135deg,#b6af64 0%,#d6ce86 100%);color:#152a55;font-size:36px;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;animation:ot-checkmark 0.5s ease}@keyframes ot-checkmark{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}100%{transform:scale(1);opacity:1}}.ot-confirmation-card h1{font-size:28px;font-weight:600;color:#152a55;margin-bottom:12px}.ot-confirmation-card>p{font-size:16px;color:#878e95;margin-bottom:28px}.ot-confirmation-details{background:linear-gradient(135deg,rgba(49,101,174,.05) 0%,rgba(182,175,100,.05) 100%);border-radius:12px;padding:20px;margin-bottom:28px;border:1px solid rgba(135,142,149,.2);text-align:left}.ot-detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid rgba(135,142,149,.15);font-size:14px;color:#152a55}.ot-detail-row:last-child{border-bottom:none}.ot-next-steps{background:linear-gradient(135deg,#152a55 0%,#2e65ae 100%);border-radius:12px;padding:20px 24px;margin-bottom:28px;text-align:left}.ot-next-steps h3{font-size:16px;font-weight:600;color:#d6ce86;margin-bottom:12px}.ot-next-steps p{font-size:14px;color:#fff;line-height:1.7}.ot-dashboard-btn{background:linear-gradient(135deg,#3165ae 0%,#152a55 100%);color:#fff;border:none;border-radius:10px;padding:16px 40px;font-size:15px;font-weight:600;cursor:pointer;font-family:'Roboto',sans-serif;box-shadow:0 4px 15px rgba(49,101,174,.3);transition:opacity 0.2s ease}.ot-dashboard-btn:hover{opacity:.88}.ot-loading{position:fixed;inset:0;background:rgba(248,250,252,.8);display:flex;align-items:center;justify-content:center;z-index:9999}.ot-spinner{width:36px;height:36px;border:3px solid rgba(49,101,174,.2);border-top-color:#3165ae;border-radius:50%;animation:ot-spin 0.7s linear infinite}@keyframes ot-spin{to{transform:rotate(360deg)}}@media (max-width:900px){.ot-checkout-layout{grid-template-columns:1fr}.ot-calendar-grid{grid-template-columns:repeat(4,1fr)}.ot-packages-grid{grid-template-columns:1fr}}@media (max-width:680px){.ot-calendar-grid{grid-template-columns:repeat(3,1fr)}.ot-week-btn{padding:5px 10px;font-size:12px}}@media (max-width:700px){.ot-header{padding:16px 20px;flex-wrap:wrap;gap:8px}.ot-progress-container{padding:24px 20px 12px}.ot-step-panel{padding:20px 20px 48px}.ot-welcome-section{padding:24px 20px}.ot-booking-app .ot-welcome-title{font-size:26px}.ot-subjects-grid{grid-template-columns:repeat(2,1fr);gap:12px}.ot-tutors-grid{grid-template-columns:1fr}.ot-booking-app .ot-tutor-card{flex-direction:column}.ot-calendar-grid{grid-template-columns:repeat(2,1fr)}.ot-week-label{font-size:12px}.ot-booking-instructions{padding:20px}.ot-otp-panel{padding:24px 20px}.ot-confirmation-container{padding:32px 20px}.ot-confirmation-card{padding:32px 20px}.ot-booking-app .ot-back-btn{padding:8px 20px}}@media (max-width:420px){.ot-header{padding:12px 16px}.ot-logo-text{font-size:18px}.ot-tagline{font-size:12px}.ot-progress-container{padding:16px 12px 8px}.ot-progress-step{width:28px;height:28px;font-size:12px}.ot-progress-labels span{font-size:10px}.ot-step-panel{padding:16px 16px 40px}.ot-booking-app .ot-welcome-title{font-size:22px}.ot-booking-app .ot-step-heading h2{font-size:22px}.ot-subjects-grid{grid-template-columns:1fr 1fr;gap:10px}.ot-booking-app .ot-subject-card{padding:20px 12px}.ot-calendar-grid{grid-template-columns:1fr}.ot-booking-app .ot-proceed-btn{width:100%;padding:16px 24px;font-size:15px}.ot-booking-app .ot-btn-primary{width:100%}.ot-otp-panel{padding:20px 16px}.ot-form-input{font-size:16px}.ot-otp-input{font-size:20px;letter-spacing:6px}.ot-confirmation-card{padding:24px 16px}.ot-confirmation-card h1{font-size:22px}.ot-section-card{padding:20px 16px}.ot-booking-app .ot-booking-instructions h3{font-size:20px}}.ot-read-more{background:none;border:none;color:#152a55;font-size:13px;font-weight:600;cursor:pointer;padding:0;text-decoration:underline}.ot-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:9999;padding:16px}.ot-modal-box{background:#fff;border-radius:12px;width:100%;max-width:460px;max-height:88vh;overflow-y:auto;padding:28px 24px 24px;position:relative;display:flex;flex-direction:column;gap:12px}.ot-modal-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:#666;padding:2px 6px}.ot-modal-close:hover{color:#111}.ot-modal-photo-row{display:flex;justify-content:center;margin-bottom:4px}.ot-modal-photo-row .ot-tutor-photo-wrap{width:90px;height:90px}.ot-modal-bio{font-size:14px;color:#444;line-height:1.65;white-space:pre-line}.ot-modal-select-btn{margin-top:8px;background:#152a55;color:#fff;border:none;border-radius:8px;padding:13px 24px;font-size:15px;font-weight:600;cursor:pointer;width:100%}.ot-modal-select-btn:hover{background:#1e3d7a}