.booking-page{min-height:100vh;padding:2rem;background:radial-gradient(circle at top left,rgba(255,140,66,.22),transparent 28%),radial-gradient(circle at bottom right,rgba(255,92,0,.18),transparent 30%),linear-gradient(135deg,#111827,#1f2937 45%,#0f172a);display:flex;align-items:center;justify-content:center}.booking-container{width:min(1220px,100%);max-height:calc(100vh - 4rem);display:grid;grid-template-columns:330px minmax(0,1fr);background:#fffffff5;border:1px solid rgba(255,255,255,.45);border-radius:28px;overflow:hidden;box-shadow:0 30px 90px #0f172a59}.booking-sidebar{padding:2.2rem 1.9rem;background:linear-gradient(180deg,#fff7f2,#fff 42%,#fff4ec);border-right:1px solid rgba(148,163,184,.2);overflow-y:auto}.profile-section{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem}.brand-avatar{width:60px;height:60px;display:grid;place-items:center;border-radius:18px;background:linear-gradient(135deg,#ff5c00,#ff8c42);color:#fff;font-size:1.25rem;font-weight:900;box-shadow:0 12px 28px #ff5c0047}.profile-name{display:block;margin-bottom:.25rem;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#f97316}.profile-info h1{margin:0;font-size:1.45rem;line-height:1.1;color:#111827}.call-details{display:grid;gap:.95rem;margin-bottom:1.4rem;padding-bottom:1.4rem;border-bottom:1px solid rgba(148,163,184,.22)}.detail-row{display:flex;align-items:center;gap:.75rem;color:#475569;font-size:.95rem;font-weight:600}.detail-row svg,.duration-icon svg,.cal-nav svg,.back-btn svg,.selected-time-display svg,.success-icon svg,.times-placeholder svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.detail-row svg{color:#f97316;flex-shrink:0}.sidebar-desc{margin:0 0 1.4rem;font-size:.92rem;line-height:1.7;color:#64748b}.duration-picker{display:grid;gap:.75rem;margin-bottom:1.4rem}.duration-option{width:100%;display:flex;align-items:center;gap:.85rem;padding:.9rem 1rem;border:1.5px solid #e2e8f0;border-radius:16px;background:#fff;cursor:pointer;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease;text-align:left}.duration-option:hover{transform:translateY(-1px);border-color:#fdba74;box-shadow:0 12px 28px #0f172a14}.duration-option.selected{border-color:#fb923c;background:linear-gradient(135deg,#ffedd5f2,#fff7edfa);box-shadow:0 14px 32px #f9731629}.duration-icon{width:40px;height:40px;display:grid;place-items:center;border-radius:12px;background:#fff1e6;color:#f97316;flex-shrink:0}.duration-icon.urgent{background:#fff7d6;color:#d97706}.duration-content{flex:1;min-width:0}.duration-title{display:block;font-size:.95rem;font-weight:700;color:#111827}.duration-desc{display:block;margin-top:.18rem;font-size:.8rem;color:#64748b}.duration-check{width:24px;height:24px;display:grid;place-items:center;border-radius:999px;border:2px solid #e2e8f0;color:#fff;background:transparent;flex-shrink:0;transition:background .18s ease,border-color .18s ease}.duration-check svg{width:14px;height:14px;opacity:0;transform:scale(.7);transition:opacity .18s ease,transform .18s ease}.duration-option.selected .duration-check{background:#f97316;border-color:#f97316}.duration-option.selected .duration-check svg{opacity:1;transform:scale(1)}.sidebar-tags{display:flex;flex-wrap:wrap;gap:.55rem}.tag{padding:.45rem .85rem;border-radius:999px;background:#f973161a;color:#c2410c;font-size:.76rem;font-weight:700}.booking-main{position:relative;display:flex;flex-direction:column;min-height:0;overflow-y:auto;padding:2rem 2.4rem;color:#111827}.calendar-section{display:flex;flex-direction:column;flex:1 1 auto;min-height:0}.calendar-section h2,.success-section h2{margin:0 0 1.6rem;font-size:1.55rem;line-height:1.15;color:#111827}.calendar-wrapper{display:flex;flex:1 1 auto;min-height:0;gap:2.5rem}.calendar-container{flex:1;min-width:0}.calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.45rem}.cal-month{font-size:1.2rem;font-weight:800;color:#111827}.cal-nav{width:44px;height:44px;display:grid;place-items:center;border:1px solid #e2e8f0;border-radius:14px;background:#fff;color:#475569;cursor:pointer;transition:border-color .18s ease,color .18s ease,background .18s ease}.cal-nav:hover:not(:disabled){border-color:#fdba74;color:#ea580c;background:#fff7ed}.cal-nav:disabled{opacity:.45;cursor:not-allowed}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px}.cal-day-name{padding:.8rem 0 .45rem;text-align:center;font-size:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}#calendarGrid{display:contents}.cal-day{aspect-ratio:1;width:100%;max-width:58px;margin:4px auto;border:none;border-radius:999px;background:transparent;color:#475569;font-size:1rem;font-weight:600;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease}.cal-day:hover:not(.disabled):not(.selected){background:#fff7ed;color:#ea580c;transform:translateY(-1px)}.cal-day.has-slots:not(.selected):not(.disabled){background:#fff1e6;color:#c2410c}.cal-day.today:not(.selected){box-shadow:inset 0 0 0 2px #f9731659}.cal-day.selected{background:linear-gradient(135deg,#ff5c00,#ff8c42);color:#fff;box-shadow:0 12px 26px #f9731647}.cal-day.disabled{color:#cbd5e1;cursor:not-allowed;background:transparent}.cal-day.empty{visibility:hidden}.times-container{flex:0 0 250px;display:flex;flex-direction:column;min-height:0;padding-left:2rem;border-left:1px solid #e2e8f0}.times-header{margin-bottom:1rem}.times-header-text{display:block;font-size:1.05rem;font-weight:800;color:#111827}.times-header-sub{display:block;margin-top:.3rem;font-size:.85rem;font-weight:600;color:#64748b}.times-list{display:flex;flex-direction:column;flex:1 1 auto;min-height:0;gap:.75rem;overflow-y:auto;padding-right:.35rem}.times-placeholder{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:2rem 1rem;color:#94a3b8;text-align:center;font-size:.9rem}.time-btn{width:100%;padding:.95rem 1.1rem;border:1.5px solid #fb923c;border-radius:12px;background:#fff;color:#c2410c;font-size:.98rem;font-weight:700;cursor:pointer;transition:background .18s ease,color .18s ease,transform .18s ease,box-shadow .18s ease}.time-btn:hover,.time-btn.selected{background:linear-gradient(135deg,#ff5c00,#ff8c42);color:#fff;transform:translateY(-1px);box-shadow:0 14px 26px #f9731638}.time-btn.booked,.time-btn.booked:hover{border-color:#d1d5db;background:#f3f4f6;color:#9ca3af;cursor:not-allowed;transform:none;box-shadow:none}.loading-overlay{position:absolute;inset:0;border-radius:24px;background:#ffffffd6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;opacity:0;visibility:hidden;transition:opacity .18s ease,visibility .18s ease;z-index:10}.loading-overlay.active{opacity:1;visibility:visible}.loading-overlay span{font-weight:600;color:#475569}.loader,.btn-loader{width:18px;height:18px;border-radius:999px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;animation:spin .7s linear infinite}.loader{width:42px;height:42px;border-width:3px;border-color:#f973162e;border-top-color:#f97316}.form-section{animation:slide-in .24s ease}.back-btn{display:inline-flex;align-items:center;gap:.5rem;margin-bottom:1.1rem;padding:0;border:none;background:transparent;color:#64748b;font-size:.92rem;font-weight:700;cursor:pointer}.back-btn:hover{color:#ea580c}.selected-time-display{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.1rem;border:1px solid rgba(249,115,22,.16);border-radius:16px;background:linear-gradient(135deg,#fff7ed,#fff1e6);color:#c2410c;font-weight:700}.booking-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1rem}.field{display:grid;gap:.45rem}.field-full{grid-column:1 / -1}.field span{font-size:.88rem;font-weight:700;color:#334155}.field input,.field textarea{width:100%;padding:.95rem 1rem;border:1.5px solid #e2e8f0;border-radius:14px;background:#fff;color:#111827;font:inherit;transition:border-color .18s ease,box-shadow .18s ease}.field input:focus,.field textarea:focus{outline:none;border-color:#fb923c;box-shadow:0 0 0 4px #f973161f}.field textarea{resize:vertical;min-height:120px}.form-actions{padding-top:.25rem;display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}.turnstile-inline{margin-left:auto;max-width:100%}.turnstile-inline .cf-turnstile{max-width:100%}.submit-btn,.book-another-btn{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;min-height:54px;padding:.95rem 1.4rem;border:none;border-radius:14px;background:linear-gradient(135deg,#ff5c00,#ff8c42);color:#fff;font-size:.98rem;font-weight:800;cursor:pointer;box-shadow:0 16px 30px #f9731640;transition:transform .18s ease,box-shadow .18s ease,opacity .18s ease}.submit-btn:hover,.book-another-btn:hover{transform:translateY(-1px);box-shadow:0 18px 36px #f973164d}.submit-btn:disabled{opacity:.7;cursor:wait}.alert{margin-top:1rem;padding:.95rem 1rem;border-radius:14px;font-size:.92rem;font-weight:600}.alert.error{background:#fef2f2;border:1px solid #fecaca;color:#b91c1c}.alert.success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.success-section{min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:3rem 1rem;animation:pop-in .28s ease}.success-section[hidden],#calendarSection[hidden],#formSection[hidden],#successPanel[hidden]{display:none!important}.success-icon{width:84px;height:84px;display:grid;place-items:center;margin-bottom:1.5rem;border-radius:999px;background:linear-gradient(135deg,#dcfce7,#bbf7d0);color:#16a34a}.success-message{max-width:520px;margin:0 0 1.5rem;color:#475569;line-height:1.65}@keyframes spin{to{transform:rotate(360deg)}}@keyframes slide-in{0%{opacity:0;transform:translate(18px)}to{opacity:1;transform:translate(0)}}@keyframes pop-in{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@media(min-width:981px){.booking-container{height:calc(100vh - 4rem)}}@media(max-width:980px){.booking-container{grid-template-columns:1fr}.booking-sidebar{border-right:none;border-bottom:1px solid rgba(148,163,184,.2)}.calendar-wrapper{flex-direction:column;gap:1.75rem}.times-container{flex:none;padding-left:0;padding-top:1.5rem;border-left:none;border-top:1px solid #e2e8f0}.times-list{max-height:none}.form-actions{flex-direction:column;align-items:flex-start}.turnstile-inline{margin-left:0}}@media(max-width:640px){.booking-page{padding:0}.booking-container{border-radius:0;min-height:100vh}.booking-sidebar,.booking-main{padding:1.4rem}.booking-form{grid-template-columns:1fr}.cal-day{max-width:46px;font-size:.9rem}}
