@import url("https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700;800&display=swap");*{margin:0;padding:0;box-sizing:border-box}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:#f5f7fa;color:#333;overflow-x:hidden}.booking-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:30px 20px 20px}.page-header{text-align:center;margin-bottom:24px;max-width:1500px;width:100%}.page-title{font-size:30px;font-weight:800;color:#1a1a1a;margin-bottom:6px;letter-spacing:-.5px}.page-subtitle{font-size:16px;font-weight:500;color:#666;letter-spacing:.2px}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.success-modal{background:#fff;border-radius:24px;padding:50px 60px;text-align:center;max-width:500px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.3);animation:slideUp .4s ease-out}@keyframes slideUp{0%{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}.success-icon-container{margin-bottom:24px}.success-checkmark{display:inline-flex;align-items:center;justify-content:center;width:80px;height:80px;background:linear-gradient(135deg,#7c6dd6,#9b8ce8);border-radius:50%;color:#fff;font-size:48px;font-weight:700;animation:scaleIn .5s ease-out .2s backwards}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-title{font-size:32px;font-weight:800;color:#1a1a1a;margin-bottom:32px;letter-spacing:-.5px}.success-message{font-size:18px;color:#666;margin-bottom:24px;line-height:1.6}.success-message strong{color:#7c6dd6;font-weight:700}.redirect-message{font-size:14px;color:#999;margin-bottom:12px;font-weight:500}.loading-bar{width:100%;height:4px;background:#e8ecef;border-radius:2px;overflow:hidden}.loading-bar-fill{height:100%;background:linear-gradient(90deg,#7c6dd6,#9b8ce8);border-radius:2px;animation:loadingProgress 4s linear forwards}@keyframes loadingProgress{0%{width:0}to{width:100%}}.booking-container{width:100%;max-width:1500px;height:600px;min-height:600px;background:#fff;border-radius:16px;box-shadow:0 4px 32px rgba(0,0,0,.1);overflow:hidden;display:grid;grid-template-columns:280px 1fr 360px}.event-info-panel{padding:30px 24px;border-right:1px solid #e8ecef;background:#f8f7ff;overflow-y:auto}.event-logo{width:144px;height:144px;border-radius:8px;margin-bottom:14px;object-fit:contain;display:block}.event-organizer{font-size:11px;color:#8b7dd8;font-weight:600;margin-bottom:8px;text-transform:uppercase;letter-spacing:1px}.event-title{font-size:19px;font-weight:700;color:#1a1a1a;margin-bottom:14px;line-height:1.3}.event-duration{display:flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:#666;margin-bottom:18px;padding-bottom:18px;border-bottom:1px solid #e8ecef}.clock-icon{width:18px;height:18px;color:#7c6dd6}.event-description{font-size:13px;color:#555;line-height:1.6;margin-bottom:18px}.event-features{display:flex;flex-direction:column;gap:12px;margin-top:24px;padding-top:0;border-top:none}.feature-item{display:flex;align-items:center;gap:10px;font-size:14px;color:#333}.feature-icon{width:18px;height:18px;color:#7c6dd6;flex-shrink:0}.calendar-column{border-right:1px solid #e8ecef}.calendar-column,.form-column{padding:24px;position:relative;display:flex;flex-direction:column;height:100%;overflow:hidden}.form-column{background:#fff}.column-content{display:flex;flex-direction:column;height:100%;overflow:hidden}.column-title{font-size:16px;font-weight:700;color:#1a1a1a;margin-bottom:16px;text-align:center}.step-indicator{justify-content:center;margin-bottom:18px;flex-shrink:0}.step-indicator,.step-item{display:flex;align-items:center;gap:10px}.step-item{font-size:14px;color:#999;font-weight:600}.step-item.active{color:#667eea}.step-item.completed{color:#28a745}.step-number{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:#e8ecef;color:#999;font-weight:700;font-size:14px}.step-item.active .step-number{background:#667eea;color:#fff}.step-item.completed .step-number{background:#28a745;color:#fff}.step-line{width:50px;height:2px;background:#e8ecef}.step-item.completed+.step-line,.step-item.completed~.step-line{background:#28a745}.step-content{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.step-title{font-size:18px;font-weight:700;color:#1a1a1a;margin-bottom:16px;text-align:center}.step-header-with-back{display:flex;align-items:center;gap:16px;margin-bottom:20px;position:relative}.back-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid #e0e4e8;background:#fff;border-radius:6px;color:#666;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;position:absolute;left:0}.back-btn:hover{border-color:#667eea;color:#667eea;background:#f8f9ff}.step-header-with-back .step-title{flex:1 1;margin:0}.calendar-section{display:flex;flex-direction:column;overflow:hidden}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-shrink:0}.calendar-month{font-size:15px;font-weight:700;color:#1a1a1a}.calendar-nav{display:flex;gap:6px}.nav-btn{width:30px;height:30px;border:1px solid #e0e4e8;background:#fff;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;color:#666}.nav-btn:hover{border-color:#667eea;background:#f8f9ff;color:#667eea}.calendar-grid{width:100%;flex:1 1}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:3px;gap:3px;margin-bottom:5px}.weekday{text-align:center;font-size:10px;font-weight:600;color:#999;text-transform:uppercase;padding:5px 0}.calendar-dates{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px}.date-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:#333;border-radius:6px;cursor:pointer;transition:all .15s;position:relative;min-height:36px}.date-cell:hover:not(.disabled):not(.other-month){background:#f3f1ff;color:#7c6dd6}.date-cell.other-month{color:#ddd;cursor:default}.date-cell.disabled{color:#e5e5e5;cursor:not-allowed;text-decoration:line-through}.date-cell.available{color:#333;font-weight:500}.date-cell.selected{background:#7c6dd6;color:#fff;font-weight:700}.date-cell.today{border:2px solid #7c6dd6}.timezone-display{display:flex;align-items:center;gap:6px;font-size:11px;color:#666;margin-top:10px;padding-top:10px;border-top:1px solid #e8ecef;flex-shrink:0}.globe-icon{width:14px;height:14px;color:#999}.calendar-time-vertical{display:grid;grid-template-columns:1fr 240px;grid-gap:20px;gap:20px;flex:1 1;overflow:hidden}.calendar-section-inline{display:flex;flex-direction:column;overflow:hidden}.time-slots-section-vertical{display:flex;flex-direction:column;gap:8px;border-left:2px solid #e8ecef;padding-left:20px;overflow-y:auto}.time-slots-heading{font-size:14px;font-weight:700;color:#1a1a1a;margin:0;padding-bottom:12px;text-align:left}.time-slots-list{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding-right:8px}.time-slots-list::-webkit-scrollbar{width:5px}.time-slots-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.time-slots-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:10px}.time-slots-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.time-slot-vertical{padding:14px 16px;border:2px solid #e0e4e8;background:#fff;border-radius:8px;text-align:center;font-size:15px;font-weight:600;color:#333;cursor:pointer;transition:all .2s;width:100%;display:flex;align-items:center;justify-content:center}.time-slot-vertical:hover:not(:disabled){border-color:#7c6dd6;background:#f8f7ff;color:#7c6dd6}.time-slot-vertical.selected{background:#7c6dd6;border-color:#7c6dd6;color:#fff;font-weight:700;box-shadow:0 2px 8px rgba(124,109,214,.2)}.time-slot-vertical:disabled{opacity:.4;cursor:not-allowed;background:#f9f9f9;border-color:#e8ecef;text-decoration:line-through}.loading-slots{color:#7c6dd6;font-size:14px;font-weight:600}.loading-slots,.no-slots-vertical{text-align:center;padding:40px 20px}.no-slots-vertical{color:#999;font-size:13px;line-height:1.5}.time-slots-section-full{flex:1 1;display:flex;flex-direction:column;overflow:hidden}.time-slots-subtitle{font-size:16px;font-weight:600;color:#555;margin-bottom:16px;text-align:center}.time-slots-grid-full{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px;overflow-y:auto;padding:4px}.time-slot-large{padding:10px 8px;border:1.5px solid #e0e4e8;background:#fff;border-radius:5px;text-align:center;font-size:12px;font-weight:600;color:#333;cursor:pointer;transition:all .2s}.time-slots-grid::-webkit-scrollbar{width:6px}.time-slots-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.time-slots-grid::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:10px}.time-slots-grid::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.time-slot{padding:10px 8px;border:1.5px solid #e0e4e8;background:#fff;border-radius:6px;text-align:center;font-size:13px;font-weight:600;color:#333;cursor:pointer;transition:all .2s}.time-slot-large:hover:not(:disabled){border-color:#667eea;background:#f8f9ff;color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px rgba(102,126,234,.15)}.time-slot-large.selected{background:#667eea;border-color:#667eea;color:#fff;box-shadow:0 4px 12px rgba(102,126,234,.3)}.time-slot-large:disabled{opacity:.25;cursor:not-allowed;background:#f9f9f9;text-decoration:line-through}.no-slots{text-align:center;padding:40px 20px;color:#999;font-size:14px}.selected-time-banner{display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;background:#f8f7ff;border:1.5px solid #7c6dd6;border-radius:6px;color:#7c6dd6;font-size:12px;font-weight:600;margin-bottom:14px;line-height:1.4}.booking-form-inline{flex-direction:column;flex:1 1}.booking-form-full,.booking-form-inline{display:flex;gap:12px;overflow-y:auto;padding:4px}.booking-form-full{flex-direction:column}.booking-form-full::-webkit-scrollbar{width:6px}.booking-form-full::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.booking-form-full::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:10px}.booking-form-full::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:600;color:#555}.form-group input{padding:12px 14px;border:1.5px solid #e0e4e8;border-radius:6px;font-size:14px;transition:all .2s;font-family:inherit;background:#fff;color:#333}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.form-group input.error{border-color:#ef4444}.phone-input-group{display:flex;gap:10px;align-items:center}.country-code-select{border:1.5px solid #e0e4e8;border-radius:6px;font-size:14px;font-family:inherit;font-weight:500;background:#fff;color:#333;cursor:pointer;transition:all .2s;min-width:85px;max-width:85px;flex-shrink:0;appearance:none;-webkit-appearance:none;-moz-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3e%3cpolyline points='6 9 12 15 18 9'%3e%3c/polyline%3e%3c/svg%3e");background-repeat:no-repeat;background-position:right 8px center;background-size:16px;padding:12px 32px 12px 14px}.country-code-select:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.phone-input-group input{flex:1 1}.error-message{font-size:11px;color:#ef4444;margin-top:3px}.selected-time-display{padding:10px 12px;background:#f8f9ff;border:1.5px solid #667eea;border-radius:6px;font-size:12px;color:#667eea;font-weight:600;display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.change-btn{padding:5px 10px;background:#fff;border:1px solid #667eea;border-radius:4px;color:#667eea;font-size:11px;font-weight:600;cursor:pointer;transition:all .2s}.change-btn:hover{background:#667eea;color:#fff}.submit-btn-inline{padding:14px 20px;background:#7c6dd6;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px rgba(124,109,214,.3)}.submit-btn-inline:hover:not(:disabled){background:#6b5cc5;transform:translateY(-1px);box-shadow:0 6px 20px rgba(124,109,214,.4)}.submit-btn-inline:disabled{opacity:.5;cursor:not-allowed;transform:none}.submit-btn-large{padding:12px 20px;background:#667eea;color:#fff;border:none;border-radius:7px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:12px;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 16px rgba(102,126,234,.3)}.submit-btn-large:hover:not(:disabled){background:#5568d3;transform:translateY(-2px);box-shadow:0 6px 20px rgba(102,126,234,.4)}.submit-btn-large:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{width:14px;height:14px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.alert{position:fixed;top:24px;left:50%;transform:translateX(-50%);z-index:1000;max-width:600px;width:90%;padding:16px 20px;border-radius:12px;display:flex;align-items:flex-start;gap:14px;font-size:14px;line-height:1.5;animation:slideIn .3s ease-out;box-shadow:0 6px 24px rgba(0,0,0,.15)}@keyframes slideIn{0%{opacity:0;transform:translate(-50%,-20px)}to{opacity:1;transform:translate(-50%)}}.alert-success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.alert-error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.alert-icon{flex-shrink:0;font-size:16px}.alert-content{flex:1 1}.alert-content strong{display:block;margin-bottom:3px;font-weight:700;font-size:14px}.alert-content p{margin:3px 0;font-size:12px}.calendar-link{display:inline-block;margin-top:6px;padding:5px 10px;background:#28a745;color:#fff;text-decoration:none;border-radius:4px;font-size:11px;font-weight:600;transition:background .2s}.calendar-link:hover{background:#218838}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:hsla(0,0%,100%,.95);display:flex;align-items:center;justify-content:center;z-index:10;border-radius:12px}.loading-text{font-size:14px;color:#667eea;font-weight:600}.booking-footer,.booking-header{display:none}@media (max-width:968px){.booking-page{padding:15px 10px 10px}.page-header{margin-bottom:20px;padding:0 10px}.page-title{font-size:26px}.page-subtitle{font-size:15px}.booking-container{grid-template-columns:1fr;height:auto;min-height:auto;border-radius:12px}.event-info-panel{border-right:none;border-bottom:1px solid #e8ecef;padding:20px}.event-logo{width:126px;height:126px}.event-title{font-size:16px}.event-description{line-height:1.5}.calendar-column{border-right:none;border-bottom:1px solid #e8ecef;padding:20px}.form-column{padding:20px}.column-title{font-size:15px;margin-bottom:14px}.event-logo{width:120px;height:120px;margin-bottom:10px}.event-title{font-size:18px;margin-bottom:10px}.event-description{font-size:13px;margin-bottom:15px}.event-features{gap:8px}.feature-item{font-size:12px}.booking-interface{padding:20px}.calendar-time-vertical{grid-template-columns:1fr;gap:20px}.time-slots-section-vertical{border-left:none;border-top:2px solid #e8ecef;padding-left:0;padding-top:20px}.time-slots-list{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:8px;gap:8px;max-height:300px}.step-label{display:none}.step-title{font-size:18px}.time-slots-grid-full{grid-template-columns:repeat(3,1fr);gap:10px}.back-btn{position:static}.step-header-with-back{flex-direction:column;align-items:flex-start;gap:12px}}@media (max-width:640px){.booking-page{padding:10px 0 0}.page-header{margin-bottom:16px;padding:0 12px}.page-title{font-size:24px}.page-subtitle{font-size:14px}.success-modal{padding:40px 30px;border-radius:20px;width:95%}.success-checkmark{width:70px;height:70px;font-size:42px}.success-title{font-size:26px}.success-message{font-size:16px}.booking-container{border-radius:12px 12px 0 0;height:auto;min-height:auto}.event-info-panel{padding:16px}.event-logo{width:108px;height:108px;margin-bottom:10px}.event-organizer{font-size:10px;margin-bottom:4px}.event-title{font-size:15px;margin-bottom:8px}.event-duration{font-size:13px;margin-bottom:12px;padding-bottom:12px}.event-description{font-size:12px;line-height:1.5}.calendar-column,.form-column{padding:16px}.column-title{font-size:14px;margin-bottom:12px}.calendar-header{margin-bottom:10px}.calendar-month{font-size:13px}.nav-btn{width:28px;height:28px}.calendar-dates{gap:3px}.date-cell{font-size:12px;min-height:34px}.weekday{font-size:9px}.time-slot-vertical{padding:12px 8px;font-size:13px}.time-slots-heading{font-size:13px;padding-bottom:10px}.selected-time-banner{padding:10px 12px;font-size:11px}.form-group label{font-size:12px}.form-group input{padding:10px 12px;font-size:14px}.country-code-select{padding:10px 30px 10px 12px;font-size:13px;min-width:80px;max-width:80px;background-size:14px}.submit-btn-inline{padding:13px 18px;font-size:14px}.timezone-display{font-size:10px}}