/* ============================================================
   Cork & Cruise — component & section styles
   ============================================================ */

/* ---------- NAV ---------- */
.nav { position: fixed; inset: 0 0 auto 0; z-index: 60; transition: background .35s ease, box-shadow .35s ease, backdrop-filter .35s ease; }
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 76px; gap: 18px; }
.nav.solid { background: color-mix(in oklab, var(--paper) 86%, transparent); backdrop-filter: blur(14px) saturate(1.4); box-shadow: 0 1px 0 var(--hairline); }
.nav-links { display: flex; gap: 6px; }
.nav-links button { background: none; border: none; padding: 9px 14px; border-radius: 999px; font-size: 0.96rem; font-weight: 500; color: var(--ink-soft); transition: background .2s, color .2s; }
.nav-links button:hover { background: color-mix(in oklab, var(--lake) 12%, transparent); color: var(--lake-deep); }
.nav-links button.on-dark { color: color-mix(in oklab, var(--on-lake) 92%, transparent); }
.nav-links button.on-dark:hover { background: color-mix(in oklab, var(--on-lake) 18%, transparent); color: var(--on-lake); }
.nav-actions { display: flex; align-items: center; gap: 14px; }
.nav-phone { display: inline-flex; align-items: center; gap: 7px; font-weight: 600; font-size: 0.92rem; color: var(--lake-deep); }
.nav-phone.on-dark { color: var(--on-lake); }
.nav-burger { display: none; flex-direction: column; gap: 5px; width: 44px; height: 44px; align-items: center; justify-content: center; background: none; border: none; }
.nav-burger span { width: 22px; height: 2px; background: var(--ink); border-radius: 2px; transition: background .3s; }
.nav-burger.on-dark span { background: var(--on-lake); }
.nav-mobile { display: none; }

@media (max-width: 880px) {
  .nav-links, .nav-phone, .nav-actions .btn { display: none; }
  .nav-burger { display: flex; }
  .nav-mobile { display: flex; flex-direction: column; gap: 4px; padding: 12px var(--gutter) 22px; background: color-mix(in oklab, var(--paper) 96%, transparent); backdrop-filter: blur(14px); box-shadow: 0 12px 30px rgba(0,0,0,.12); }
  .nav-mobile button:not(.btn), .nav-mobile a:not(.btn) { text-align: left; background: none; border: none; padding: 13px 6px; font-size: 1.05rem; font-weight: 600; color: var(--ink); border-bottom: 1px solid var(--hairline); }
  .nav-mobile-phone { display: flex; align-items: center; gap: 8px; color: var(--lake-deep) !important; }
  .nav-mobile .btn { margin-top: 12px; }
}

/* ---------- WORDMARK ---------- */
.wordmark { flex: none; }
.wordmark > div > div:first-child { white-space: nowrap; }

/* ---------- HERO ---------- */
.hero { position: relative; isolation: isolate; overflow: hidden;
  background: linear-gradient(168deg, var(--sky-2) 0%, var(--lake) 50%, var(--lake-deep) 100%); }
[data-theme="golden"] .hero { background: linear-gradient(168deg, var(--sky-2) 0%, var(--lake) 46%, var(--lake-deep) 100%); }
.hero-classic, .hero-panorama { min-height: 100svh; display: flex; flex-direction: column; }
.hero-split { min-height: 100svh; }
.hero-bg { position: absolute !important; inset: 0; width: 100%; height: 100%; border-radius: 0 !important; z-index: -2; background: transparent !important; }

/* slow "almost-video" drift on the baked-in hero photo */
.hero-photo { will-change: transform; transform-origin: center; animation: heroPan 34s ease-in-out infinite alternate; backface-visibility: hidden; }
@keyframes heroPan {
  0%   { transform: scale(1.16) translate(-3%, -1.2%); }
  100% { transform: scale(1.16) translate(3%, 1.2%); }
}
@media (prefers-reduced-motion: reduce) {
  .hero-photo { animation: none; transform: scale(1.04); }
}
.hero-scrim { position: absolute; inset: 0; z-index: -1; pointer-events: none;
  background: linear-gradient(180deg, color-mix(in oklab, var(--lake-ink) 30%, transparent) 0%, transparent 30%, transparent 38%, color-mix(in oklab, var(--lake-ink) 64%, transparent) 78%, color-mix(in oklab, var(--lake-ink) 80%, transparent) 100%); }
.hero-classic-copy, .hero-pano-copy { padding-bottom: clamp(90px, 14vh, 150px); padding-top: 120px; position: relative; z-index: 2; margin-top: auto; flex: 0 0 auto; }
.hero-classic-copy { max-width: 760px; }
.hero-classic-copy > * + *, .hero-pano-copy > * + * { margin-top: 22px; }
.hero-pano-copy { text-align: center; }
.hero-pano-copy .chip, .hero-pano-copy .video-cue { margin-inline: auto; }
.hero-pano-copy .hero-trust { justify-content: center; }
.hero h1 em { font-style: italic; }
.hero h1 { line-height: 1.08; }
/* heavy blue glow/drop-shadow so the headline reads over the bright photo */
.hero-classic h1, .hero-panorama h1 {
  text-shadow:
    0 2px 10px var(--lake-ink),
    0 6px 26px color-mix(in oklab, var(--lake-deep) 92%, transparent),
    0 12px 48px color-mix(in oklab, var(--lake-ink) 80%, transparent);
}
.hero-classic h1 em, .hero-panorama h1 em { color: var(--on-lake); }
.hero-classic .lead, .hero-panorama .lead {
  text-shadow: 0 1px 4px var(--lake-ink), 0 3px 16px color-mix(in oklab, var(--lake-ink) 75%, transparent);
}
.hero .lead { max-width: 600px; }
.hero-classic-copy .chip { display: inline-flex; }
.hero-pano-copy .lead { margin-top: 0; }

.hero-cta { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 6px; }
.hero-pano-copy .hero-cta { justify-content: center; }

.video-cue { display: inline-flex; align-items: center; gap: 13px; margin-top: 4px; background: color-mix(in oklab, var(--surface) 18%, transparent); border: 1px solid color-mix(in oklab, var(--on-lake) 34%, transparent); backdrop-filter: blur(8px); border-radius: 999px; padding: 8px 22px 8px 8px; color: var(--on-lake); transition: background .25s, transform .2s; align-self: flex-start; }
.video-cue:hover { background: color-mix(in oklab, var(--surface) 30%, transparent); transform: translateY(-2px); }
.video-cue-play { width: 40px; height: 40px; border-radius: 50%; background: var(--on-lake); color: var(--lake-deep); display: grid; place-items: center; flex: none; box-shadow: var(--shadow-sm); }
.video-cue span:last-child { display: flex; flex-direction: column; text-align: left; line-height: 1.25; gap: 3px; }
.video-cue strong { font-size: 0.95rem; font-weight: 700; line-height: 1.2; white-space: nowrap; }
.video-cue em { font-style: normal; font-size: 0.78rem; opacity: .8; line-height: 1.2; white-space: nowrap; }
.hero-split .video-cue { color: var(--ink); border-color: var(--hairline); background: transparent; }
.hero-split .video-cue:hover { background: color-mix(in oklab, var(--lake) 8%, transparent); }
.hero-split .video-cue-play { background: var(--lake); color: var(--on-lake); }

.hero-trust { display: flex; align-items: center; flex-wrap: wrap; gap: 9px; margin-top: 2px; color: var(--on-lake); font-size: 0.9rem; font-weight: 500; }
.hero-trust-dot { opacity: .5; }
.hero-split .hero-trust { color: var(--ink-soft); }

/* split layout */
.hero-split { display: grid; grid-template-columns: 1.05fr 1fr; align-items: center; gap: clamp(30px, 5vw, 70px); padding-top: 96px; padding-bottom: 80px; }
.hero-split .hero-copy { padding-block: 30px; }
.hero-split .chip { margin-bottom: 8px; }
.hero-media { position: relative; aspect-ratio: 4/5; min-height: 420px; }
.hero-float { position: absolute; bottom: -18px; left: -18px; display: flex; align-items: center; gap: 12px; padding: 14px 20px; border-radius: 16px; color: var(--lake-deep); }
.hero-float strong { display: block; font-size: 1.1rem; } .hero-float span { font-size: 0.8rem; color: var(--muted); }

.hero-wave { position: absolute; bottom: -1px; left: 0; right: 0; z-index: 3; pointer-events: none; }
.hero-split .hero-wave { display: none; }

@media (max-width: 860px) {
  .hero-split { grid-template-columns: 1fr; min-height: auto; padding-top: 100px; }
  .hero-media { order: -1; aspect-ratio: 4/3; min-height: 300px; }
  .hero-float { left: auto; right: -8px; }
}

/* ---------- VIDEO LIGHTBOX ---------- */
.video-overlay { position: fixed; inset: 0; z-index: 90; background: rgba(8,18,30,.82); backdrop-filter: blur(8px); display: grid; place-items: center; padding: 20px; animation: fade .3s ease; }
.video-frame { position: relative; width: min(960px, 100%); aspect-ratio: 16/9; border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-lg); background: #000; }
.video-frame iframe { width: 100%; height: 100%; border: 0; }
.video-close { position: absolute; top: -46px; right: 0; background: none; border: none; color: #fff; font-size: 1.6rem; line-height: 1; }
@keyframes fade { from { opacity: 0; } }

/* ---------- EXPERIENCE ---------- */
.include-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 52px; }
.include-card { padding: 30px 26px; display: flex; flex-direction: column; gap: 12px; }
.include-ico { width: 52px; height: 52px; border-radius: 14px; display: grid; place-items: center; color: var(--lake-deep);
  background: color-mix(in oklab, var(--lake) 12%, var(--surface)); box-shadow: inset 0 0 0 1px color-mix(in oklab, var(--lake) 18%, transparent); }
[data-theme="golden"] .include-ico { color: var(--sun-deep); background: color-mix(in oklab, var(--sun) 18%, var(--surface)); }
@media (max-width: 800px) { .include-grid { grid-template-columns: 1fr; gap: 14px; } }

/* ---------- ROUTE MAP ---------- */
.route-sec { background: var(--paper-2); }
.routemap-grid { display: grid; grid-template-columns: 1.45fr 1fr; gap: 26px; align-items: stretch; }
.routemap-canvas { position: relative; padding: 14px; overflow: hidden; }
.routemap-svg { width: 100%; height: 100%; display: block; border-radius: 12px; min-height: 360px; }
.routemap-compass { position: absolute; left: 24px; bottom: 24px; display: flex; align-items: center; gap: 7px; font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: .12em; text-transform: uppercase; color: var(--on-lake); background: color-mix(in oklab, var(--lake-ink) 55%, transparent); padding: 7px 13px; border-radius: 999px; backdrop-filter: blur(4px); }
.route-pin .pin-halo { transition: r .3s ease; }
.route-pin:hover circle:nth-child(2) { filter: brightness(1.05); }
.routemap-list { display: flex; flex-direction: column; gap: 8px; }
.route-step { display: flex; gap: 16px; text-align: left; background: var(--surface); border: 1px solid var(--hairline); border-radius: 16px; padding: 16px 18px; transition: border-color .25s, box-shadow .25s, transform .2s; cursor: pointer; }
.route-step:hover { border-color: color-mix(in oklab, var(--lake) 40%, transparent); }
.route-step.on { border-color: var(--sun); box-shadow: var(--shadow-md); }
.route-step-num { width: 30px; height: 30px; flex: none; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-mono); font-weight: 700; font-size: 0.9rem; background: color-mix(in oklab, var(--lake) 12%, var(--surface)); color: var(--lake-deep); transition: background .25s, color .25s; }
.route-step.on .route-step-num { background: var(--sun); color: var(--on-sun); }
.route-step-body { flex: 1; }
.route-step-top { display: flex; justify-content: space-between; gap: 10px; align-items: baseline; }
.route-step-label { font-family: var(--font-mono); font-size: 0.66rem; letter-spacing: .18em; text-transform: uppercase; color: var(--lake-deep); }
.route-step-time { font-size: 0.8rem; color: var(--muted); font-variant-numeric: tabular-nums; }
.route-step-name { font-family: var(--font-display); font-weight: var(--display-weight); font-size: 1.3rem; margin-top: 2px; }
.route-step-blurb { font-size: 0.92rem; color: var(--ink-soft); overflow: hidden; transition: max-height .4s ease, opacity .35s ease, margin .35s; line-height: 1.45; }
.route-step.on .route-step-blurb { margin-top: 7px; }
@media (max-width: 900px) { .routemap-grid { grid-template-columns: 1fr; } .routemap-svg { min-height: 300px; } }

/* ---------- PRICING ---------- */
.pricing-sec { background: linear-gradient(180deg, var(--paper) 0%, var(--sky) 100%); }
.calc { display: grid; grid-template-columns: 1.5fr 1fr; overflow: hidden; max-width: 1000px; margin-inline: auto; }
.calc-main { padding: clamp(26px, 4vw, 42px); }
.calc-head { display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; flex-wrap: wrap; padding-bottom: 24px; border-bottom: 1px solid var(--hairline); }
.calc-base { font-family: var(--font-display); font-weight: var(--display-weight); font-size: clamp(2.4rem, 6vw, 3.2rem); color: var(--ink); line-height: 1; margin-top: 4px; }
.calc-base span { font-family: var(--font-body); font-size: 1rem; font-weight: 500; color: var(--muted); }
.calc-block { padding-block: 22px; border-bottom: 1px solid var(--hairline); }
.calc-block:last-child { border-bottom: none; padding-bottom: 4px; }
.calc-row-label { display: flex; align-items: center; gap: 9px; font-weight: 700; color: var(--ink); margin-bottom: 14px; }
.calc-addons { display: flex; flex-direction: column; gap: 8px; }
.calc-addon { display: flex; align-items: center; gap: 12px; background: var(--paper); border: 1px solid var(--hairline); border-radius: 12px; padding: 12px 14px; text-align: left; transition: border-color .2s, background .2s; }
.calc-addon:hover { border-color: color-mix(in oklab, var(--lake) 36%, transparent); }
.calc-addon.on { border-color: var(--lake); background: color-mix(in oklab, var(--lake) 7%, var(--surface)); }
.calc-addon .addon-check { color: var(--on-lake); }
.calc-addon.on .addon-check { background: var(--lake); border-color: var(--lake); }
.calc-addon-name { flex: 1; font-weight: 500; font-size: 0.96rem; }
.calc-addon-price { font-weight: 700; color: var(--lake-deep); font-variant-numeric: tabular-nums; }
.calc-addon-price em { font-style: normal; font-weight: 500; font-size: 0.78rem; color: var(--muted); }

.calc-rail { background: var(--lake-ink); color: var(--on-lake); padding: clamp(26px, 4vw, 38px); display: flex; flex-direction: column; }
[data-theme="golden"] .calc-rail { background: var(--lake-deep); }
.calc-lines { display: flex; flex-direction: column; gap: 11px; padding-bottom: 18px; }
.calc-line { display: flex; justify-content: space-between; gap: 12px; font-size: 0.92rem; }
.calc-line span:first-child { opacity: .82; }
.calc-line span:last-child { font-variant-numeric: tabular-nums; font-weight: 600; }
.calc-line.muted { opacity: .62; font-size: 0.84rem; }
.calc-total { display: flex; justify-content: space-between; align-items: baseline; padding-top: 18px; border-top: 1px solid color-mix(in oklab, var(--on-lake) 22%, transparent); margin-top: auto; }
.calc-total span { font-size: 1rem; opacity: .85; }
.calc-total strong { font-family: var(--font-display); font-weight: var(--display-weight); font-size: 2.4rem; line-height: 1; }
.calc-per { text-align: right; font-size: 0.82rem; opacity: .7; margin-top: 4px; }
.calc-rail .btn { margin-top: 20px; }
.calc-trust { display: flex; align-items: center; justify-content: center; gap: 6px; color: color-mix(in oklab, var(--on-lake) 75%, transparent) !important; margin-top: 14px; }
.counter { display: flex; align-items: center; justify-content: space-between; gap: 14px; }
.counter-ctrl { display: flex; align-items: center; gap: 4px; background: var(--paper); border: 1px solid var(--hairline); border-radius: 999px; padding: 4px; }
.counter-ctrl button { width: 40px; height: 40px; border-radius: 50%; border: none; background: var(--surface); color: var(--lake-deep); font-size: 1.4rem; line-height: 1; display: grid; place-items: center; box-shadow: var(--shadow-sm); transition: filter .2s; }
.counter-ctrl button:hover:not([disabled]) { filter: brightness(.96); }
.counter-ctrl button[disabled] { opacity: .35; box-shadow: none; }
.counter-ctrl span { min-width: 30px; text-align: center; font-weight: 700; font-size: 1.15rem; font-variant-numeric: tabular-nums; }
@media (max-width: 820px) { .calc { grid-template-columns: 1fr; } }

/* package cards */
.pack-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; align-items: start; }
.pack { padding: 32px 28px; display: flex; flex-direction: column; gap: 12px; position: relative; }
.pack.featured { border: 2px solid var(--sun); box-shadow: var(--shadow-lg); transform: translateY(-8px); }
.pack-ribbon { position: absolute; top: -13px; left: 28px; background: var(--sun); color: var(--on-sun); font-size: 0.72rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; padding: 6px 14px; border-radius: 999px; }
.pack-price { font-family: var(--font-display); font-weight: var(--display-weight); font-size: 2.3rem; color: var(--ink); line-height: 1; }
.pack-price span { font-family: var(--font-body); font-size: 0.92rem; font-weight: 500; color: var(--muted); }
.pack-feats { list-style: none; padding: 0; margin: 6px 0 16px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.pack-feats li { display: flex; align-items: flex-start; gap: 9px; font-size: 0.94rem; color: var(--ink-soft); }
.pack-feats li svg { color: var(--lake); flex: none; margin-top: 3px; }
@media (max-width: 820px) { .pack-grid { grid-template-columns: 1fr; } .pack.featured { transform: none; } }

/* ---------- WINERIES ---------- */
.winery-list { display: flex; flex-direction: column; gap: 24px; margin-top: 48px; }
.winery { display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; }
.winery-img { width: 100%; height: 100%; min-height: 340px; border-radius: 0 !important; }
.winery.flip .winery-img { order: 2; }
.winery-body { padding: clamp(28px, 4vw, 50px); display: flex; flex-direction: column; gap: 14px; justify-content: center; }
.winery-facts { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 6px; }
.winery-facts .chip svg { color: var(--lake); }
@media (max-width: 820px) { .winery { grid-template-columns: 1fr; } .winery.flip .winery-img { order: -1; } .winery-img { min-height: 240px; } }

/* ---------- BOAT ---------- */
.boat-sec { background: var(--paper-2); }
.boat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(30px, 5vw, 64px); align-items: center; }
.boat-media { aspect-ratio: 5/4; }
.spec-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 22px; }
.spec { background: var(--surface); border: 1px solid var(--hairline); border-radius: 14px; padding: 18px 20px; }
.spec-v { font-family: var(--font-display); font-weight: var(--display-weight); font-size: 1.6rem; color: var(--lake-deep); line-height: 1; }
.spec-k { font-size: 0.84rem; color: var(--muted); margin-top: 5px; }
@media (max-width: 820px) { .boat-grid { grid-template-columns: 1fr; } .boat-media { order: -1; } }

/* ---------- GALLERY ---------- */
.gallery-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; gap: 14px; margin-top: 46px; }
.gal { width: 100%; height: 100%; }
.gal.tall { grid-row: span 2; }
.gal.wide { grid-column: span 2; }
@media (max-width: 820px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 150px; } .gal.wide { grid-column: span 2; } .gal.tall { grid-row: span 1; } }

/* ---------- TESTIMONIALS ---------- */
.testi-sec { background: linear-gradient(165deg, var(--lake) 0%, var(--lake-deep) 100%); position: relative; overflow: hidden; }
.testi-sec h2 { white-space: pre-line; }
.testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 50px; }
.testi { padding: 30px 28px; display: flex; flex-direction: column; gap: 16px; }
.testi blockquote { margin: 0; font-family: var(--font-display); font-size: 1.32rem; line-height: 1.35; color: var(--ink); font-weight: var(--display-weight); }
.testi figcaption { display: flex; flex-direction: column; gap: 2px; margin-top: auto; }
.testi figcaption strong { font-weight: 700; }
.testi figcaption span { font-size: 0.86rem; color: var(--muted); }
@media (max-width: 820px) { .testi-grid { grid-template-columns: 1fr; } }

/* ---------- FAQ ---------- */
.faq-grid { display: grid; grid-template-columns: 0.8fr 1.2fr; gap: clamp(30px, 5vw, 70px); align-items: start; }
.faq-aside { position: sticky; top: 100px; display: flex; flex-direction: column; gap: 14px; }
.faq-aside .btn { align-self: flex-start; margin-top: 8px; }
.faq-list { display: flex; flex-direction: column; }
.faq-item { border-bottom: 1px solid var(--hairline); }
.faq-q { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: 16px; background: none; border: none; padding: 22px 4px; text-align: left; font-family: var(--font-body); font-weight: 600; font-size: 1.1rem; color: var(--ink); }
.faq-chev { color: var(--lake); transition: transform .3s ease; flex: none; }
.faq-item.open .faq-chev { transform: rotate(180deg); }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .4s ease; }
.faq-item.open .faq-a { max-height: 220px; }
.faq-a p { padding: 0 4px 22px; color: var(--ink-soft); font-size: 1rem; max-width: 56ch; }
@media (max-width: 820px) { .faq-grid { grid-template-columns: 1fr; } .faq-aside { position: static; } }

/* ---------- FOOTER ---------- */
.footer { background: var(--lake-ink); color: var(--on-lake); }
[data-theme="golden"] .footer { background: oklch(0.26 0.05 252); }
.footer-cta { text-align: center; padding-block: clamp(60px, 10vw, 110px); display: flex; flex-direction: column; align-items: center; gap: 16px; position: relative; overflow: hidden; }
.footer-cta .btn { margin-top: 10px; }
.footer-main { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; padding-block: 50px; border-top: 1px solid color-mix(in oklab, var(--on-lake) 16%, transparent); }
.footer-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.footer-h { font-family: var(--font-mono); font-size: 0.72rem; letter-spacing: .2em; text-transform: uppercase; color: color-mix(in oklab, var(--on-lake) 60%, transparent); margin-bottom: 14px; font-weight: 500; }
.footer-cols a, .footer-cols span { display: block; color: color-mix(in oklab, var(--on-lake) 86%, transparent); padding: 6px 0; font-size: 0.96rem; }
.footer-cols a:hover { color: var(--sun); }
.footer-fine { display: flex; justify-content: space-between; gap: 14px; padding-block: 24px; border-top: 1px solid color-mix(in oklab, var(--on-lake) 16%, transparent); font-size: 0.82rem; color: color-mix(in oklab, var(--on-lake) 60%, transparent); flex-wrap: wrap; }
@media (max-width: 760px) { .footer-main { grid-template-columns: 1fr; gap: 28px; } }

/* ---------- MOBILE BOOK BAR ---------- */
.mobile-bar { position: fixed; left: 12px; right: 12px; bottom: 12px; z-index: 55; display: none; align-items: center; justify-content: space-between; gap: 12px; background: color-mix(in oklab, var(--surface) 92%, transparent); backdrop-filter: blur(14px); border: 1px solid var(--hairline); border-radius: 18px; padding: 12px 12px 12px 18px; box-shadow: var(--shadow-lg); transform: translateY(140%); transition: transform .4s cubic-bezier(.2,.8,.2,1); }
.mobile-bar.show { transform: none; }
.mobile-bar strong { font-size: 1rem; } .mobile-bar span { font-size: 0.8rem; color: var(--muted); }
.mobile-bar .btn { min-height: 46px; padding: 12px 22px; }
@media (max-width: 880px) { .mobile-bar { display: flex; } }

/* ---------- BOOKING OVERLAY ---------- */
.booking-overlay { position: fixed; inset: 0; z-index: 80; background: rgba(10,22,36,.55); backdrop-filter: blur(6px); display: flex; align-items: center; justify-content: center; padding: 20px; animation: fade .3s ease; }
.booking-sheet { width: min(560px, 100%); max-height: 92svh; display: flex; flex-direction: column; overflow: hidden; border-radius: var(--radius-lg); }
.booking-head { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px; border-bottom: 1px solid var(--hairline); }
.booking-close { width: 38px; height: 38px; border-radius: 50%; border: none; background: var(--paper-2); color: var(--ink-soft); font-size: 1rem; }
.booking-close:hover { background: var(--hairline); }
.booking-stepwrap { padding: 16px 22px 4px; }
.booking-body { padding: 8px 22px 22px; overflow-y: auto; flex: 1; }
.step-pane { display: flex; flex-direction: column; gap: 14px; }
.step-pane h3 { margin-bottom: 2px; }
.booking-foot { border-top: 1px solid var(--hairline); padding: 16px 22px; display: flex; flex-direction: column; gap: 12px; background: color-mix(in oklab, var(--paper) 60%, var(--surface)); }
.booking-summary { display: flex; align-items: center; justify-content: space-between; }
.booking-total { font-weight: 700; font-size: 1.15rem; font-variant-numeric: tabular-nums; }
.booking-total span { font-weight: 500; font-size: 0.85rem; color: var(--muted); }
@media (max-width: 560px) {
  .booking-overlay { padding: 0; }
  .booking-sheet { width: 100%; height: 100svh; max-height: 100svh; border-radius: 0; }
}

/* stepper */
.stepper { display: flex; gap: 0; }
.step-dot { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 6px; position: relative; }
.step-dot::before { content: ""; position: absolute; top: 13px; left: -50%; width: 100%; height: 2px; background: var(--hairline); z-index: 0; }
.step-dot:first-child::before { display: none; }
.step-dot.done::before, .step-dot.on::before { background: var(--lake); }
.step-dot span { width: 28px; height: 28px; border-radius: 50%; display: grid; place-items: center; background: var(--paper-2); color: var(--muted); font-weight: 700; font-size: 0.85rem; z-index: 1; transition: background .25s, color .25s; }
.step-dot.on span { background: var(--lake); color: var(--on-lake); }
.step-dot.done span { background: color-mix(in oklab, var(--lake) 20%, var(--surface)); color: var(--lake-deep); }
.step-dot label { font-size: 0.72rem; color: var(--muted); font-weight: 600; }
.step-dot.on label { color: var(--ink); }

/* calendar */
.cal { background: var(--paper); border: 1px solid var(--hairline); border-radius: 16px; padding: 16px; }
.cal-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.cal-title { font-weight: 700; font-size: 1.05rem; }
.cal-nav { width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--hairline); background: var(--surface); color: var(--ink); display: grid; place-items: center; }
.cal-nav:hover:not([disabled]) { border-color: var(--lake); color: var(--lake-deep); }
.cal-nav[disabled] { opacity: .3; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px; }
.cal-dow { margin-bottom: 4px; }
.cal-dowcell { text-align: center; font-size: 0.72rem; font-weight: 700; color: var(--muted); padding: 4px 0; }
.cal-day { aspect-ratio: 1; border: none; background: var(--surface); border-radius: 10px; font-weight: 600; font-size: 0.95rem; color: var(--ink); transition: background .15s, color .15s; }
.cal-day:hover:not([disabled]) { background: color-mix(in oklab, var(--lake) 14%, var(--surface)); color: var(--lake-deep); }
.cal-day.sel { background: var(--lake); color: var(--on-lake); }
.cal-day.past { color: var(--hairline); pointer-events: none; }

/* slots */
.slot-list { display: flex; flex-direction: column; gap: 10px; }
.slot { display: flex; align-items: center; gap: 14px; background: var(--paper); border: 1.5px solid var(--hairline); border-radius: 14px; padding: 16px 18px; text-align: left; transition: border-color .2s, background .2s; }
.slot:hover { border-color: color-mix(in oklab, var(--lake) 40%, transparent); }
.slot.on { border-color: var(--lake); background: color-mix(in oklab, var(--lake) 7%, var(--surface)); }
.slot-radio { width: 22px; height: 22px; border-radius: 50%; border: 2px solid var(--hairline); flex: none; transition: border-color .2s; position: relative; }
.slot.on .slot-radio { border-color: var(--lake); }
.slot.on .slot-radio::after { content: ""; position: absolute; inset: 4px; border-radius: 50%; background: var(--lake); }
.slot-label { font-weight: 700; display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.slot-time { font-size: 0.88rem; color: var(--muted); margin-top: 2px; font-variant-numeric: tabular-nums; }
.slot-tag { font-size: 0.66rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase; padding: 3px 8px; border-radius: 999px; background: color-mix(in oklab, var(--lake) 16%, var(--surface)); color: var(--lake-deep); }
.slot-tag.sun { background: color-mix(in oklab, var(--sun) 26%, var(--surface)); color: var(--sun-ink); }

/* addons in booking */
.addon-list { display: flex; flex-direction: column; gap: 9px; }
.addon { display: flex; align-items: center; gap: 13px; background: var(--paper); border: 1.5px solid var(--hairline); border-radius: 13px; padding: 14px 16px; text-align: left; transition: border-color .2s, background .2s; }
.addon:hover { border-color: color-mix(in oklab, var(--lake) 36%, transparent); }
.addon.on { border-color: var(--lake); background: color-mix(in oklab, var(--lake) 7%, var(--surface)); }
.addon-check { width: 24px; height: 24px; border-radius: 7px; border: 2px solid var(--hairline); flex: none; display: grid; place-items: center; color: var(--on-lake); transition: background .2s, border-color .2s; }
.addon.on .addon-check { background: var(--lake); border-color: var(--lake); }
.addon-name { font-weight: 600; }
.addon-price { font-weight: 700; color: var(--lake-deep); text-align: right; font-variant-numeric: tabular-nums; }
.addon-price span { display: block; font-weight: 500; font-size: 0.74rem; color: var(--muted); }

/* fields */
.field { display: flex; flex-direction: column; gap: 7px; }
.field-label { font-weight: 600; font-size: 0.92rem; color: var(--ink); }
.field-hint { font-size: 0.8rem; color: var(--muted); }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.input { width: 100%; font-family: inherit; font-size: 1rem; padding: 14px 16px; border: 1.5px solid var(--hairline); border-radius: 12px; background: var(--paper); color: var(--ink); transition: border-color .2s, box-shadow .2s; }
.input:focus { outline: none; border-color: var(--lake); box-shadow: 0 0 0 4px color-mix(in oklab, var(--lake) 16%, transparent); }
.input-icon { position: relative; display: flex; align-items: center; }
.input-icon svg { position: absolute; left: 14px; color: var(--muted); }
.input-icon .input { padding-left: 44px; }
.pay-secure { display: flex; align-items: center; gap: 8px; font-size: 0.84rem; color: var(--lake-deep); background: color-mix(in oklab, var(--lake) 9%, var(--surface)); padding: 10px 14px; border-radius: 10px; margin-bottom: 4px; }

/* confirm */
.step-pane.confirm { align-items: center; gap: 18px; padding-top: 10px; }
.confirm-badge { width: 84px; height: 84px; border-radius: 50%; background: color-mix(in oklab, var(--lake) 14%, var(--surface)); color: var(--lake); display: grid; place-items: center; animation: pop .5s cubic-bezier(.2,1.4,.4,1); }
@keyframes pop { from { transform: scale(0); } }
.confirm-card { width: 100%; background: var(--paper); border: 1px solid var(--hairline); border-radius: 16px; padding: 8px 20px; }
.confirm-row { display: flex; justify-content: space-between; gap: 12px; padding: 13px 0; border-bottom: 1px solid var(--hairline); font-size: 0.96rem; }
.confirm-row:last-child { border-bottom: none; }
.confirm-row span { color: var(--muted); }

/* spinner */
.spinner { width: 18px; height: 18px; border-radius: 50%; border: 2.5px solid color-mix(in oklab, var(--on-lake) 40%, transparent); border-top-color: var(--on-lake); animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
