:root{--bg:#f4f8ff;--surface:#fff;--surface-subtle:#eef5ff;--text:#102336;--muted:#4e6074;--border:#d8e4f5;--brand:#1d62f2;--brand-strong:#0e4ad0;--danger:#b42318;--danger-bg:#fef3f2;--warn-bg:#fff7ed;--warn-border:#fdba74;--ok-bg:#ecfdf3;--ok-text:#027a48;--radius:18px;--radius-sm:12px;--shadow:0 8px 24px #0e2c6214}*{box-sizing:border-box}html,body{min-height:100%;color:var(--text);background:linear-gradient(#eef5ff 0%,#f8fbff 100%);margin:0;font-family:Avenir Next,Segoe UI,Trebuchet MS,sans-serif}a{color:inherit;text-decoration:none}.appRoot{flex-direction:column;min-height:100vh;display:flex}.appContent{flex:1;padding:20px 14px 96px}.topNavWrap{z-index:40;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff0;position:sticky;top:0}.topNav{align-items:center;gap:16px;max-width:1040px;min-height:68px;margin:0 auto;padding:10px 14px;display:flex}.brand{letter-spacing:-.02em;color:#093068;font-size:1.18rem;font-weight:900}.topNavLinks{align-items:center;gap:6px;margin-left:auto;display:none}.navLink{color:var(--muted);border-radius:999px;padding:10px 14px;font-weight:700;line-height:1}.navLink:hover{color:var(--text);background:#eef4ff}.navLinkActive{color:#0f3e95;background:#e4eeff}.accountLink{border:1px solid var(--border);background:var(--surface);border-radius:999px;margin-left:auto;padding:11px 15px;font-weight:800;line-height:1}.accountLink:hover{border-color:#b8d0f7}.siteFooter{border-top:1px solid var(--border);background:#ffffffd9}.siteFooterInner{max-width:1040px;color:var(--muted);margin:0 auto;padding:18px 14px 90px;font-size:.95rem}.siteFooterFine{margin-top:6px;font-size:.85rem}.bottomNav{z-index:50;padding:10px 10px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--border);background:#fffffffa;grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;display:grid;position:fixed;bottom:0;left:0;right:0}.bottomNavLink{color:#4f6278;border-radius:12px;place-items:center;min-height:48px;font-size:.78rem;font-weight:800;display:grid}.bottomNavLinkActive{color:#0f3e95;background:#e7f0ff}.pageShell{gap:14px;max-width:860px;margin:0 auto;display:grid}.pageHeader h1{letter-spacing:-.02em;margin:0;font-size:clamp(1.6rem,3.4vw,2.2rem);line-height:1.14}.pageHeader p{color:var(--muted);max-width:68ch;margin:6px 0 0;line-height:1.4}.card{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:16px}.card+.card{margin-top:12px}.sectionTitle{letter-spacing:-.01em;margin:2px 0 6px;font-size:1.2rem}.sectionText{color:var(--muted);margin:0;line-height:1.45}.eyebrow{color:#0f3e95;text-transform:uppercase;background:#e8f1ff;border:1px solid #cadfff;border-radius:999px;align-items:center;padding:5px 10px;font-size:.75rem;font-weight:800;display:inline-flex}.errorStateBadge{color:#b42318;text-transform:uppercase;background:#fef3f2;border:1px solid #fecdca;border-radius:999px;align-items:center;padding:5px 10px;font-size:.75rem;font-weight:800;display:inline-flex}.actionRow{flex-wrap:wrap;gap:10px;margin-top:14px;display:flex}.button{border:1px solid var(--brand);background:var(--brand);color:#fff;cursor:pointer;border-radius:999px;justify-content:center;align-items:center;min-height:48px;padding:11px 18px;font-weight:800;transition:background .15s,border-color .15s;display:inline-flex}.button:hover{background:var(--brand-strong);border-color:var(--brand-strong)}.button:disabled{opacity:.55;cursor:not-allowed}.buttonFull{width:100%}.buttonSecondary{border-color:var(--border);background:var(--surface);color:var(--text)}.buttonSecondary:hover{background:#eff5ff;border-color:#bfd6fa}.buttonSubtle{color:#1e3046;background:#eef3fb;border-color:#0000}.favoriteControl{justify-items:end;gap:4px;display:grid}.favoriteButton{color:#1e3046;cursor:pointer;background:#fff;border:1px solid #c8d7ee;border-radius:999px;align-items:center;gap:6px;min-height:40px;padding:8px 12px;font-size:.85rem;font-weight:800;display:inline-flex}.favoriteButton:hover{background:#eff5ff;border-color:#bfd6fa}.favoriteButton:disabled{opacity:.65;cursor:not-allowed}.favoriteButtonActive{color:#b42318;background:#fff1f3;border-color:#f3bcc3}.favoriteIcon{fill:none;stroke:currentColor;stroke-width:1.8px;width:16px;height:16px}.favoriteButtonActive .favoriteIcon{fill:currentColor}.favoriteNotice{color:#0f3e95;margin:0;font-size:.76rem;font-weight:700}.favoritePromptLink{color:#0f3e95;cursor:pointer;background:0 0;border:none;padding:0;font-size:.78rem;font-weight:800;text-decoration:underline}.formField{gap:6px;display:grid}.formLabel{font-size:.88rem;font-weight:700}.input,.select{border-radius:var(--radius-sm);width:100%;color:var(--text);min-height:48px;font:inherit;background:#fbfdff;border:1px solid #c8d7ee;padding:10px 12px}.input:focus,.select:focus{border-color:#78a2f3;outline:2px solid #0000;box-shadow:0 0 0 4px #1d62f21f}.fieldHint{color:var(--muted);margin:0;font-size:.82rem}.inlineError{color:var(--danger);margin:0;font-size:.82rem;font-weight:700}.alertError,.alertWarn,.alertInfo,.alertSuccess{border-radius:12px;padding:12px;font-size:.92rem;line-height:1.35}.alertError{background:var(--danger-bg);color:#912018;border:1px solid #fecdca}.alertWarn{background:var(--warn-bg);border:1px solid var(--warn-border);color:#9a3412}.alertInfo{color:#0f3e95;background:#e9f2ff;border:1px solid #bed4fb}.alertSuccess{background:var(--ok-bg);color:var(--ok-text);border:1px solid #abefc6}.skeleton{background:linear-gradient(90deg,#e6eefb 0%,#f3f7ff 45%,#e6eefb 100%) 0 0/220% 100%;border-radius:10px;min-height:16px;animation:1.1s linear infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.listingPreview{gap:12px;display:grid}.previewImage{object-fit:cover;background:#dde8f8;border:1px solid #cfdcf1;border-radius:14px;width:100%;height:180px}.previewImageFallback{color:#617691;background:#eef5ff;border:1px dashed #b6c9e4;border-radius:14px;place-items:center;width:100%;height:180px;font-weight:700;display:grid}.priceLine{color:#0f3e95;margin:0;font-weight:800}.metaLine{color:var(--muted);margin:2px 0 0}.durationGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.durationChip{background:#fff;border:1px solid #c8d7ee;border-radius:12px;min-height:44px;font-weight:700}.durationChipActive{border-color:var(--brand);color:#0f3e95;background:#e7f0ff}.modeToggleRow{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.durationPicker{margin-top:10px}.durationPickerGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.priceBreakdownCard{background:#f8fbff;border:1px solid #dbe6f7;border-radius:12px;gap:8px;padding:12px;display:grid}.priceBreakdownRow,.priceBreakdownTotalRow{justify-content:space-between;align-items:center;gap:10px;display:flex}.priceBreakdownRow{color:#334155}.priceBreakdownTotalRow{color:#0f3e95;font-size:1.02rem}.priceBreakdownDivider{background:#dbe6f7;height:1px}.bookingList{gap:10px;display:grid}.bookingCard{gap:8px;display:grid}.statusChip{color:#0f3e95;text-transform:capitalize;background:#eef5ff;border:1px solid #c8d7ee;border-radius:999px;justify-self:start;padding:4px 10px;font-size:.78rem;font-weight:800}.statusPending{color:#9a3412;background:#fff7ed;border-color:#fdba74}.statusConfirmed,.statusAccepted{color:#027a48;background:#ecfdf3;border-color:#abefc6}.statusCancelled,.statusDeclined,.statusNoShow{color:#b42318;background:#fef3f2;border-color:#fecdca}.splitRow{justify-content:space-between;align-items:center;gap:10px;display:flex}.helpInline{color:var(--muted);margin:6px 2px 0;font-size:.88rem}.helpInline a{color:#0f3e95;font-weight:700;text-decoration:underline}.bookPageShell{padding-bottom:168px}.bookingStickyBar{left:0;right:0;bottom:calc(72px + env(safe-area-inset-bottom));z-index:45;border-top:1px solid var(--border);background:#fffffffa;grid-template-columns:1fr 1fr;gap:8px;padding:10px 12px;display:grid;position:fixed}.inlineSpinner{vertical-align:-2px;border:2px solid #9cb8ea;border-top-color:#1d62f2;border-radius:999px;width:12px;height:12px;margin-right:6px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (min-width:900px){.topNavLinks{display:flex}.accountLink{margin-left:0}.appContent{padding-bottom:28px}.siteFooterInner{padding-bottom:18px}.bottomNav{display:none}.durationGrid{grid-template-columns:repeat(5,minmax(0,1fr))}.durationPickerGrid{grid-template-columns:repeat(2,minmax(0,220px))}.bookPageShell{padding-bottom:24px}.bookingStickyBar{display:none}}@media (max-width:639px){.durationPickerGrid{grid-template-columns:1fr}}
