/* ════════════════════════════════════════════════════════════
   Long Beach Chalets — Guided booking widget ("The Tide")
   One engine, two surfaces: a modal popup (any "Book now") and an
   inline mount (book.html). Container-query driven so the same
   markup adapts from a phone sheet to a wide desktop modal.
   Design: organic-luxe — Lora serif accents on Mulish, soft glass,
   generous whitespace, crisp SVG icons, tactile micro-interactions.
   ════════════════════════════════════════════════════════════ */
:root{
  --lbcb-serif:"Mulish",sans-serif;   /* match the site — no separate display face */
  --lbcb-shadow:0 50px 120px -28px rgba(14,24,21,.55),0 18px 44px -24px rgba(14,24,21,.4);
  --lbcb-card:0 1px 2px rgba(40,48,45,.05);
  --lbcb-lift:0 22px 48px -18px rgba(31,76,70,.28);
  --lbcb-r-sheet:30px; --lbcb-r-card:18px; --lbcb-r-field:14px;
}

/* ── overlay + sheet ───────────────────────────────── */
.lbcb-overlay{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  padding:28px;background:rgba(14,24,21,.5);backdrop-filter:blur(9px) saturate(1.1);-webkit-backdrop-filter:blur(9px) saturate(1.1)}
.lbcb-overlay.open{display:flex;animation:lbcbFade .4s ease}
@keyframes lbcbFade{from{opacity:0}to{opacity:1}}

.lbcb{container-type:inline-size;display:flex;flex-direction:column;width:100%;max-width:820px;max-height:min(920px,92vh);
  background:var(--foam);color:var(--ink);border-radius:var(--lbcb-r-sheet);overflow:hidden;position:relative;
  box-shadow:var(--lbcb-shadow);font-family:var(--body)}
.lbcb-overlay.open .lbcb{animation:lbcbPop .5s cubic-bezier(.22,.9,.31,1)}
@keyframes lbcbPop{from{opacity:0;transform:translateY(30px) scale(.965)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.lbcb-overlay.open,.lbcb-overlay.open .lbcb,.lbcb-step.on>*{animation:none!important}}

/* inline variant (book.html) — no card; full-viewport app layout:
   fixed bar on top, scrollable content, fixed footer — all within 100dvh */
.lbcb.inline{max-width:none;max-height:none;height:100dvh;box-shadow:none;border:0;border-radius:0;background:transparent}
.lbcb.inline .lbcb-x{display:none}
.lbcb.inline .lbcb-head{flex:0 0 auto;padding:0;border-radius:0}
.lbcb.inline .lbcb-body{flex:1 1 auto;min-height:0;overflow-y:auto;max-width:1240px;margin:0 auto;width:100%;padding:clamp(16px,3vh,28px) clamp(22px,2.6vw,40px)}
/* footer: full-width white bar; inner content matches the 1240 site width (back left · status centre · CTA right edge) */
.lbcb.inline .lbcb-foot{display:block;flex:0 0 auto;width:100%;background:rgba(253,252,248,.92);backdrop-filter:blur(10px);border-top:1px solid var(--hairline);padding:10px 0}
.lbcb-foot-in{max-width:1240px;margin:0 auto;padding:0 clamp(22px,2.6vw,40px);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:14px}
.lbcb.inline .lbcb-back{justify-self:start;grid-column:1}
.lbcb.inline .lbcb-status{justify-self:center;grid-column:2}
.lbcb.inline .lbcb-cta{justify-self:end;grid-column:3;padding:12px 24px;font-size:11.5px}
.lbcb.inline .lbcb-back{border:1px solid var(--hairline);background:var(--foam);border-radius:999px;padding:11px 20px;color:var(--ink);font-size:12.5px;font-weight:700;letter-spacing:.02em;text-transform:none}
.lbcb.inline .lbcb-back:hover{border-color:var(--lagoon);color:var(--lagoon);background:var(--mist)}
.lbcb-status{flex:1;min-width:0;text-align:center;font-size:13px;color:var(--drift);padding:0 10px;font-variant-numeric:tabular-nums}
@media(max-width:600px){
  .lbcb-status{display:none}
  .lbcb.inline .lbcb-foot-in{display:flex;gap:10px}
  .lbcb.inline .lbcb-cta{flex:1;justify-content:center;padding:13px 14px;letter-spacing:.06em}
  /* arrow-only back on mobile so the primary CTA always fits */
  .lbcb.inline .lbcb-back{flex:0 0 auto;gap:0;font-size:0;padding:12px 15px}
  .lbcb.inline .lbcb-back svg{width:16px;height:16px}
  /* slim mobile bar: arrow-only back, step label only (drop dots) */
  .lbcb.inline .lbcb-tohome{gap:0;font-size:0}
  .lbcb.inline .lbcb-tohome svg{width:17px;height:17px}
  .lbcb.inline .lbcb-prog .lbcb-dots{display:none}
  .lbcb.inline .lbcb-bar{gap:10px}
}

/* ── header: glass band, progress, trust ───────────── */
.lbcb-head{position:relative;padding:24px 30px 18px;color:var(--foam);flex:0 0 auto;
  background:var(--lagoon-deep)}
.lbcb-head .glow{position:absolute;inset:-55%;background:
  radial-gradient(42% 60% at 22% 6%,rgba(143,191,181,.5),transparent 60%),
  radial-gradient(48% 70% at 92% 100%,rgba(217,119,87,.26),transparent 58%);pointer-events:none}
.lbcb-head::after{content:"";position:absolute;left:0;right:0;top:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.35),transparent)}
.lbcb-x{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(255,255,255,.26);
  background:rgba(255,255,255,.1);color:#fff;cursor:pointer;transition:.25s;z-index:3;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
.lbcb-x:hover{background:rgba(255,255,255,.22)}
.lbcb-x svg{width:17px;height:17px}
.lbcb-cur{appearance:none;-webkit-appearance:none;
  background:rgba(255,255,255,.12) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23fff' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 9px center;
  background-size:12px;border:1px solid rgba(255,255,255,.28);color:#fff;font-family:var(--body);font-size:11px;font-weight:700;letter-spacing:.06em;
  border-radius:999px;padding:8px 27px 8px 13px;cursor:pointer;backdrop-filter:blur(4px);transition:background-color .25s;flex:0 0 auto}
.lbcb-cur:hover{background-color:rgba(255,255,255,.22)}
.lbcb-cur:focus-visible{outline:2px solid #fff;outline-offset:1px}
.lbcb-cur option{color:var(--ink)}
.lbcb-head>.lbcb-cur{position:absolute;top:17px;right:62px;z-index:3}   /* modal only */
/* one slim inline header bar: back · step+progress (inline, centred) · currency, slim trust below */
.lbcb.inline .lbcb-head{background:var(--lagoon-deep)}
.lbcb.inline .lbcb-head-in{max-width:1240px;margin:0 auto;padding:8px clamp(22px,2.6vw,40px)}
.lbcb-bar{display:flex;align-items:center;gap:14px}
.lbcb-bar .lbcb-cur{flex:0 0 auto;padding:6px 24px 6px 12px}
.lbcb-prog{flex:1;min-width:0;display:flex;flex-direction:column;align-items:center;gap:6px}
.lbcb-prog .lbcb-kick{color:#9FC1B8;white-space:nowrap;text-align:center}
.lbcb-prog .lbcb-dots{width:min(190px,70%);margin:0}
.lbcb-tohome{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#CFE3DD;transition:color .25s,gap .25s;white-space:nowrap;flex:0 0 auto;text-decoration:underline;text-underline-offset:3px;text-decoration-color:rgba(207,227,221,.4)}
.lbcb-tohome:hover{color:#fff;gap:9px;text-decoration-color:#fff}
.lbcb-tohome svg{width:13px;height:13px}
.lbcb-ext{display:none}   /* "to site" appended to Exit on desktop only */
.lbcb.inline .lbcb-trust{justify-content:center;margin-top:13px;gap:5px clamp(13px,2.2vw,24px)}
.lbcb-trust span{color:#AECBC3;font-size:10.5px}
.lbcb-trust b{color:#fff;font-weight:700}
.lbcb-trust svg{width:12px;height:12px;color:var(--seaglass)}
.lbcb-kick{position:relative;font-size:10.5px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--seaglass)}
.lbcb-dots{position:relative;display:flex;gap:7px;margin-top:13px;max-width:340px}
.lbcb-dots .d{height:4px;flex:1;border-radius:999px;background:rgba(255,255,255,.18);overflow:hidden}
.lbcb-dots .d i{display:block;height:100%;width:0;background:var(--seaglass);transition:width .55s cubic-bezier(.22,.9,.31,1)}
.lbcb-dots .d.on i{box-shadow:0 0 9px rgba(143,191,181,.7)}
.lbcb-dots .d.on i,.lbcb-dots .d.done i{width:100%}
.lbcb-trust{position:relative;display:flex;flex-wrap:wrap;gap:7px 18px;margin-top:15px}
.lbcb-trust span{font-size:11px;font-weight:600;letter-spacing:.005em;color:#D4E7E1;display:inline-flex;align-items:center;gap:6px}
.lbcb-trust svg{width:13px;height:13px;color:var(--seaglass);flex:0 0 auto}

/* ── body + steps ──────────────────────────────────── */
.lbcb-body{flex:1 1 auto;overflow-y:auto;padding:30px;scrollbar-width:thin;scrollbar-color:var(--sand) transparent}
.lbcb-body::-webkit-scrollbar{width:8px}.lbcb-body::-webkit-scrollbar-thumb{background:var(--sand);border-radius:8px}
.lbcb-step{display:none}
.lbcb-step.on{display:block}
/* choreographed entrance — elements rise in sequence, not all at once */
.lbcb-step.on>*{animation:lbcbRise .6s cubic-bezier(.2,.85,.3,1) backwards}
.lbcb-step.on>*:nth-child(1){animation-delay:.04s}
.lbcb-step.on>*:nth-child(2){animation-delay:.10s}
.lbcb-step.on>*:nth-child(3){animation-delay:.17s}
.lbcb-step.on>*:nth-child(4){animation-delay:.24s}
.lbcb-step.on>*:nth-child(5){animation-delay:.31s}
.lbcb-step.on>*:nth-child(n+6){animation-delay:.36s}
@keyframes lbcbRise{from{opacity:0;transform:translateY(13px)}to{opacity:1;transform:none}}
.lbcb-q{font-family:var(--display);font-weight:300;font-size:clamp(24px,3.6cqi,38px);line-height:1.1;letter-spacing:-.015em;color:var(--ink)}
.lbcb-q em{font-style:normal;font-weight:300;color:var(--lagoon)}
.lbcb-sub{color:var(--drift);font-size:14px;line-height:1.55;margin-top:12px;max-width:760px}
.lbcb.inline .lbcb-q,.lbcb.inline .lbcb-sub{text-align:center}
.lbcb.inline .lbcb-sub{margin-left:auto;margin-right:auto}
/* generous breathing space around the heading block */
.lbcb.inline .lbcb-q{margin-top:clamp(20px,4vh,46px)}
.lbcb.inline .lbcb-sub{margin-bottom:clamp(28px,5vh,52px)}
/* calendar lives in a soft raised card */
.lbcb-calcard{background:#FCFAF4;border:1px solid rgba(20,30,27,.06);border-radius:22px;padding:clamp(18px,2.2vw,28px);box-shadow:0 24px 54px -40px rgba(20,30,27,.45),0 2px 6px rgba(20,30,27,.04);max-width:700px;margin:0 auto}
.lbcb-calcard .lbcb-cal-top{max-width:none}
.lbcb-calcard .lbcb-months{max-width:none}

/* ── calendar ──────────────────────────────────────── */
.lbcb-cal-top{display:flex;align-items:center;justify-content:space-between;margin:0 auto 14px;max-width:320px}
.lbcb-cal-title{font-family:var(--lbcb-serif);font-size:16px;font-weight:600}
.lbcb-cal-nav{width:40px;height:40px;border-radius:50%;border:1px solid var(--hairline);background:var(--foam);color:var(--lagoon-deep);cursor:pointer;transition:.25s;display:flex;align-items:center;justify-content:center}
.lbcb-cal-nav:hover:not(:disabled){border-color:var(--lagoon);background:var(--mist);transform:translateY(-1px)}
.lbcb-cal-nav:disabled{opacity:.3;cursor:not-allowed}
.lbcb-cal-nav svg{width:16px;height:16px}
.lbcb-months{display:grid;grid-template-columns:1fr;gap:30px;max-width:320px;margin:0 auto}
.lbcb-months .lbcb-month:nth-child(2){display:none}
.lbcb-month .mhead{display:none;text-align:center;font-family:var(--lbcb-serif);font-size:14px;font-weight:600;margin-bottom:8px}
.lbcb-dow{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:5px}
.lbcb-dow span{text-align:center;font-size:9.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--drift)}
.lbcb-days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}
.lbcb-day{position:relative;aspect-ratio:1;border:0;background:none;font-family:var(--body);font-size:14px;font-variant-numeric:tabular-nums;color:var(--ink);cursor:pointer;border-radius:11px;transition:background .2s,color .2s,transform .12s;z-index:1}
.lbcb-day:hover:not(:disabled):not(.sel){background:var(--mist)}
.lbcb-day:active:not(:disabled){transform:scale(.92)}
.lbcb-day:focus-visible{outline:2px solid var(--lagoon);outline-offset:1px}
.lbcb-day.empty{visibility:hidden;cursor:default}
.lbcb-day:disabled{color:#C9C5B6;cursor:not-allowed}
.lbcb-day.in-range{background:rgba(143,191,181,.22);border-radius:0}
.lbcb-day.sel{background:var(--lagoon);color:#fff;font-weight:700;box-shadow:0 6px 16px -5px rgba(31,76,70,.55)}
.lbcb-day.sel.start{border-radius:11px 0 0 11px}
.lbcb-day.sel.end{border-radius:0 11px 11px 0}
.lbcb-day.sel.only{border-radius:11px}
.lbcb-day.today:not(.sel)::after{content:"";position:absolute;left:50%;bottom:6px;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--seaglass)}
.lbcb-cal-hint{margin-top:18px;text-align:center;font-size:14px;color:var(--drift)}
.lbcb-cal-hint b{color:var(--lagoon-deep);font-weight:700}
.lbcb-cal-hint .nights{color:var(--lagoon-deep);font-weight:700}
.lbcb-cal-hint .cal-l2{margin-top:7px}
.lbcb-cal-hint .cal-save{display:inline-flex;align-items:center;gap:6px;font-weight:700;color:var(--lagoon-deep)}
.lbcb-cal-hint .cal-save svg{width:14px;height:14px;color:var(--lagoon)}
.lbcb-cal-hint .cal-save.on{background:var(--mist);padding:5px 13px;border-radius:999px}

/* ── guests steppers ───────────────────────────────── */
.lbcb-counts{display:grid;gap:12px;max-width:700px;margin:0 auto}
.lbcb-count{display:flex;align-items:center;gap:16px;border:1px solid var(--hairline);border-radius:var(--lbcb-r-card);padding:16px 18px;background:var(--foam);transition:border-color .25s}
.lbcb-count:focus-within{border-color:var(--seaglass)}
.lbcb-count .c-ic{flex:0 0 auto;width:40px;height:40px;border-radius:12px;background:var(--mist);display:flex;align-items:center;justify-content:center;color:var(--lagoon-deep)}
.lbcb-count .c-ic svg{width:20px;height:20px}
.lbcb-count .ct{flex:1;min-width:0}
.lbcb-count .ct b{display:block;font-size:15px;font-weight:700}
.lbcb-count .ct span{font-size:12.5px;color:var(--drift)}
.lbcb-stepper{display:flex;align-items:center;gap:12px}
.lbcb-stepper button{width:38px;height:38px;border-radius:50%;border:1px solid var(--hairline);background:var(--foam);color:var(--lagoon-deep);font-size:20px;line-height:1;cursor:pointer;transition:.22s;display:flex;align-items:center;justify-content:center}
.lbcb-stepper button:hover:not(:disabled){border-color:var(--lagoon);background:var(--mist)}
.lbcb-stepper button:active:not(:disabled){transform:scale(.9)}
.lbcb-stepper button:disabled{opacity:.32;cursor:not-allowed}
.lbcb-stepper .v{font-family:var(--lbcb-serif);font-size:20px;font-weight:600;min-width:24px;text-align:center;font-variant-numeric:tabular-nums}

/* ── rooms (vertical cards, fluid grid) ────────────── */
.lbcb-rooms{display:grid;grid-template-columns:1fr;gap:14px}
.lbcb-room{position:relative;display:flex;flex-direction:column;border:1px solid var(--hairline);border-radius:var(--lbcb-r-card);overflow:hidden;background:var(--foam);cursor:pointer;transition:border-color .3s,box-shadow .3s,transform .18s;box-shadow:var(--lbcb-card)}
.lbcb-room:hover{border-color:var(--seaglass);box-shadow:var(--lbcb-lift);transform:translateY(-3px)}
.lbcb-room:active{transform:translateY(-1px) scale(.995)}
.lbcb-room:focus-visible{outline:2px solid var(--lagoon);outline-offset:2px}
.lbcb-room.sel{border-color:var(--lagoon);box-shadow:0 0 0 1.5px var(--lagoon),var(--lbcb-lift)}
.lbcb-room .ph{position:relative;overflow:hidden;aspect-ratio:16/10;border:0;padding:0;background:none;cursor:pointer;display:block;width:100%}
.lbcb-room .ph:focus-visible{outline:2px solid var(--lagoon);outline-offset:-2px}
.lbcb-room .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s cubic-bezier(.22,.9,.31,1)}
.lbcb-room:hover .ph img{transform:scale(1.06)}
.lbcb-room .ph::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,transparent 40%,rgba(16,34,30,.2) 58%,rgba(16,34,30,.82));pointer-events:none}
/* villa name + tagline sit on the photo with a soft gradient base */
.lbcb-room .ph-cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:13px 15px;text-align:left;pointer-events:none}
.lbcb-room .ph-nm{display:block;font-family:var(--lbcb-serif);font-size:19px;font-weight:700;color:#fff;line-height:1.18;text-shadow:0 1px 10px rgba(0,0,0,.45)}
.lbcb-room .ph-tag{display:block;font-size:12px;font-weight:600;color:#E7F1ED;margin-top:3px;line-height:1.3;text-shadow:0 1px 8px rgba(0,0,0,.5)}
/* one corner badge per side — left always white (zone), right always light green (status) */
.rcard-tl,.rcard-tr{position:absolute;top:10px;z-index:2;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 10px;border-radius:999px;backdrop-filter:blur(6px);box-shadow:0 4px 14px rgba(20,30,27,.2);white-space:nowrap}
.rcard-tl{left:10px;color:var(--lagoon-deep);background:rgba(253,252,248,.95)}
.rcard-tr{right:10px;color:var(--lagoon-deep);background:rgba(143,191,181,.92)}
.lbcb-room.sel .rcard-tr{display:none}
/* on the detail hero the badges only show on mobile (desktop uses the info column) */
.lbcb-gallery .main .rcard-tl,.lbcb-gallery .main .rcard-tr{display:none}
.lbcb-room .tick{position:absolute;top:10px;right:10px;width:28px;height:28px;border-radius:50%;background:var(--lagoon);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;transform:scale(.6);transition:.3s cubic-bezier(.22,1.4,.4,1);z-index:2;box-shadow:0 4px 12px rgba(31,76,70,.4)}
.lbcb-room .tick svg{width:15px;height:15px}
.lbcb-room.sel .tick{opacity:1;transform:scale(1)}
.lbcb-room .rbadge{position:absolute;right:10px;top:10px;z-index:2;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--lagoon-deep);background:rgba(253,252,248,.93);backdrop-filter:blur(6px);padding:5px 10px;border-radius:999px;box-shadow:0 4px 14px rgba(20,30,27,.2)}
.lbcb-room.sel .rbadge{display:none}
.lbcb-room .tagline{font-size:12px;font-weight:600;color:var(--lagoon);line-height:1.35;margin-bottom:7px}
.lbcb-room .av-tag{position:absolute;left:10px;top:10px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;backdrop-filter:blur(6px);z-index:2}
.lbcb-room .av-tag.ok{background:rgba(253,252,248,.86);color:var(--lagoon-deep)}
.lbcb-room .av-tag.low{background:rgba(217,119,87,.92);color:#fff}
.lbcb-room .bd{padding:15px 17px 17px;display:flex;flex-direction:column;flex:1}
.lbcb-room h4{font-family:var(--lbcb-serif);font-size:18px;font-weight:600;line-height:1.15;margin-bottom:3px;cursor:pointer}
.lbcb-room .rm{font-size:12px;color:var(--drift);margin-bottom:5px}
.lbcb-room .incl{font-size:11.5px;color:var(--drift);margin-bottom:0;opacity:.9}
.lbcb-room .pr{margin-bottom:11px;display:flex;align-items:baseline;gap:9px;flex-wrap:wrap}
.lbcb-room .pr .was{font-size:12.5px;color:var(--drift);text-decoration:line-through}
.lbcb-room .pr .now{font-family:var(--lbcb-serif);font-size:21px;font-weight:600;color:var(--lagoon-deep);font-variant-numeric:tabular-nums}
.lbcb-room .pr .now small{font-family:var(--body);font-size:11.5px;font-weight:400;color:var(--drift)}
.lbcb-room .pr .save{align-self:center;margin-left:auto;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--lagoon);background:var(--mist);padding:4px 10px;border-radius:999px}
.lbcb-room .acts{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:auto;padding-top:12px;border-top:1px solid var(--hairline)}
.lbcb-room .rdet{display:inline-flex;align-items:center;gap:5px;background:none;border:0;padding:2px 0;color:var(--lagoon);font-size:11.5px;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:gap .2s,color .2s;text-align:left}
.lbcb-room .rdet:hover{gap:9px;color:var(--lagoon-deep)}
.lbcb-room .rdet svg{width:13px;height:13px}
.lbcb-room .pick{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid var(--lagoon);color:var(--lagoon);background:none;border-radius:999px;padding:8px 15px;cursor:pointer;transition:.25s}
.lbcb-room .pick:hover{background:var(--mist)}
.lbcb-room .pick:active{transform:scale(.94)}
.lbcb-room.sel .pick{background:var(--lagoon);color:#fff;border-color:var(--lagoon)}
.lbcb-room .pick svg{width:12px;height:12px}
.lbcb-room .pick .s2{display:none}
.lbcb-room.sel .pick .s1{display:none}
.lbcb-room.sel .pick .s2{display:inline-flex;align-items:center;gap:6px}

/* ── room detail (discovery) ───────────────────────── */
.lbcb-detail-back{display:inline-flex;align-items:center;gap:6px;background:none;border:0;color:var(--drift);font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;margin-bottom:18px;transition:.2s}
.lbcb-detail-back:hover{color:var(--lagoon);gap:9px}
.lbcb-detail-back svg{width:14px;height:14px}
.lbcb-detail-grid{display:grid;grid-template-columns:1fr;gap:24px}
.lbcb-gallery .main{position:relative;aspect-ratio:16/11;border-radius:var(--lbcb-r-card);overflow:hidden;background:var(--mist)}
.lbcb-gallery .main img{width:100%;height:100%;object-fit:cover}
.lbcb-gallery .main .av-tag{position:absolute;left:12px;top:12px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:6px 12px;border-radius:999px;z-index:2;background:rgba(217,119,87,.94);color:#fff}
.lbcb-gallery .main .lbcb-gnav{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;display:grid;place-items:center;padding:0;border:0;border-radius:999px;background:rgba(252,250,244,.92);color:var(--lagoon-deep);cursor:pointer;box-shadow:0 6px 18px -8px rgba(20,30,27,.55);opacity:0;transition:opacity .25s,background .2s,transform .2s;z-index:3}
.lbcb-gallery .main .lbcb-gnav svg{width:18px;height:18px}
.lbcb-gallery .main .lbcb-gnav.prev{left:12px}
.lbcb-gallery .main .lbcb-gnav.next{right:12px}
.lbcb-gallery .main:hover .lbcb-gnav,.lbcb-gallery .main:focus-within .lbcb-gnav{opacity:1}
.lbcb-gallery .main .lbcb-gnav:hover{background:#fff;color:var(--lagoon)}
.lbcb-gallery .main .lbcb-gnav.prev:hover{transform:translateY(-50%) translateX(-2px)}
.lbcb-gallery .main .lbcb-gnav.next:hover{transform:translateY(-50%) translateX(2px)}
@media(hover:none){.lbcb-gallery .main .lbcb-gnav{opacity:.92}}
.lbcb-gallery .main .lbcb-gcount{position:absolute;right:12px;bottom:12px;z-index:2;font-size:11px;font-weight:600;letter-spacing:.04em;color:#fff;background:rgba(16,34,30,.6);backdrop-filter:blur(4px);padding:4px 10px;border-radius:999px}
.lbcb-gallery .main .lbcb-gcount b{font-weight:700}
.lbcb-gallery .main .g-cap{display:none}   /* shown only on mobile (single-column) */
.lbcb-gallery .thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:9px}
.lbcb-gallery .thumbs button{padding:0;border:0;border-radius:11px;overflow:hidden;aspect-ratio:1;cursor:pointer;opacity:.62;transition:opacity .2s,outline-color .2s;outline:2px solid transparent;outline-offset:1px}
.lbcb-gallery .thumbs button:hover{opacity:.9}
.lbcb-gallery .thumbs button.on{opacity:1;outline-color:var(--lagoon)}
.lbcb-gallery .thumbs img{width:100%;height:100%;object-fit:cover}
.lbcb-detail-info .d-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.lbcb-detail-info .idx{font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--lagoon)}
.lbcb-detail-info .d-badge{flex:0 0 auto;font-size:9.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--foam);background:var(--lagoon);padding:5px 11px;border-radius:999px;box-shadow:0 6px 16px -10px rgba(31,76,70,.7)}
.lbcb-detail-info .d-name{font-family:var(--lbcb-serif);font-size:clamp(22px,3cqi,27px);font-weight:600;margin:3px 0 8px;letter-spacing:-.01em}
.lbcb-detail-info .d-tag{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--lagoon-deep);background:var(--mist);padding:7px 13px;border-radius:999px;margin-bottom:13px}
.lbcb-detail-info .d-tag svg{width:14px;height:14px;color:var(--lagoon);flex:0 0 auto}
.lbcb-detail-info .d-pr{display:flex;align-items:baseline;gap:9px;flex-wrap:wrap;margin-bottom:14px}
.lbcb-detail-info .d-pr .was{font-size:13px;color:var(--drift);text-decoration:line-through}
.lbcb-detail-info .d-pr .now{font-family:var(--lbcb-serif);font-size:23px;font-weight:600;color:var(--lagoon-deep);font-variant-numeric:tabular-nums}
.lbcb-detail-info .d-pr .now small{font-family:var(--body);font-size:11.5px;font-weight:400;color:var(--drift)}
.lbcb-detail-info .d-pr .save{align-self:center;margin-left:auto;font-size:10.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--lagoon);background:var(--mist);padding:4px 10px;border-radius:999px}
.lbcb-detail-info .d-low{font-size:12px;font-weight:600;color:#b06a3f;margin:-6px 0 12px}
.lbcb-desc{font-size:14px;color:var(--drift);line-height:1.65}
.lbcb-feats{display:flex;flex-wrap:wrap;gap:7px;margin:14px 0 4px}
.lbcb-feats span{font-size:11.5px;font-weight:600;color:var(--lagoon-deep);background:var(--mist);padding:6px 12px;border-radius:999px}
.lbcb-amen-title{display:flex;align-items:center;gap:12px;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--drift);margin:22px 0 13px}
.lbcb-amen-title::after{content:"";flex:1;height:1px;background:var(--hairline)}
.lbcb-amen{display:grid;grid-template-columns:1fr 1fr;gap:10px 16px}
.lbcb-amen .a.x{display:none}
.lbcb-amen.open .a.x{display:flex}
.lbcb-amen-toggle{display:inline-flex;align-items:center;gap:6px;margin-top:13px;background:none;border:0;padding:4px 0;color:var(--lagoon);font-size:12px;font-weight:700;letter-spacing:.02em;cursor:pointer;transition:gap .2s,color .2s}
.lbcb-amen-toggle:hover{gap:9px;color:var(--lagoon-deep)}
.lbcb-amen-toggle .amt-chev{width:14px;height:14px;transition:transform .25s}
.lbcb-amen-toggle.open .amt-chev{transform:rotate(180deg)}
.lbcb-amen .a{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink)}
.lbcb-amen .a svg{width:14px;height:14px;color:var(--lagoon);flex:0 0 auto}
/* "where you'll be" location bar */
.lbcb-loc-bar{display:flex;align-items:center;gap:11px;margin-top:36px}
.lbcb-loc-end{font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--drift);white-space:nowrap;flex:0 0 auto}
.lbcb-loc-track{position:relative;flex:1;height:8px;border-radius:999px;background:linear-gradient(90deg,var(--seaglass),var(--mist) 52%,var(--sand))}
/* a dot for every room type so the order from the beach is clear; current one highlighted + labelled */
.lbcb-loc-mark{position:absolute;top:50%;width:9px;height:9px;border-radius:50%;background:#fff;border:2px solid var(--seaglass);transform:translate(-50%,-50%);box-shadow:0 1px 3px rgba(20,30,27,.2);z-index:1}
.lbcb-loc-mark.on{width:15px;height:15px;background:var(--lagoon);border-color:var(--foam);box-shadow:0 3px 10px rgba(31,76,70,.5),0 0 0 1px var(--lagoon);z-index:2}
.lbcb-loc-lbl{position:absolute;bottom:calc(100% + 10px);left:0;transform:translateX(-50%);white-space:nowrap;font-family:var(--display);font-size:12px;font-weight:600;color:var(--lagoon-deep);background:var(--foam);border:1px solid var(--hairline);padding:3px 10px;border-radius:999px;box-shadow:0 5px 14px rgba(20,30,27,.14);z-index:3}
.lbcb-loc-lbl::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);border:5px solid transparent;border-top-color:var(--foam)}
.lbcb-loc-note{display:flex;align-items:center;gap:7px;margin-top:15px;font-size:12.5px;color:var(--drift);flex-wrap:wrap}
.lbcb-loc-note>svg{width:15px;height:15px;color:var(--lagoon);flex:0 0 auto}
.lbcb-loc-note .loc-dist{flex:1;min-width:0}
.lbcb-loc-note a{flex-basis:100%;margin-top:5px;color:var(--lagoon);font-weight:700;display:inline-flex;align-items:center;gap:3px;cursor:pointer;text-decoration:underline;text-underline-offset:3px;text-decoration-color:var(--seaglass)}
.lbcb-loc-note a svg{width:12px;height:12px}
/* estate-map lightbox — decent sized, not full screen */
.lbcb-maplb{position:fixed;inset:0;z-index:240;display:none;align-items:center;justify-content:center;padding:26px;background:rgba(14,24,21,.72);backdrop-filter:blur(8px)}
.lbcb-maplb.open{display:flex;animation:lbcbFade .3s ease}
.lbcb-maplb-box{position:relative;background:var(--foam);border-radius:20px;padding:14px;max-width:min(940px,94vw);box-shadow:0 50px 120px -28px rgba(0,0,0,.6)}
.lbcb-maplb-box img{display:block;width:100%;height:auto;max-height:74vh;object-fit:contain;border-radius:12px;background:var(--mist)}
.lbcb-maplb-cap{text-align:center;font-size:11px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--drift);padding:12px 0 3px}
.lbcb-maplb-x{position:absolute;top:-14px;right:-14px;width:40px;height:40px;border-radius:50%;border:0;background:var(--foam);color:var(--ink);cursor:pointer;box-shadow:0 8px 26px rgba(0,0,0,.35);display:flex;align-items:center;justify-content:center;transition:.2s}
.lbcb-maplb-x:hover{background:#fff;transform:scale(1.06)}
.lbcb-maplb-x svg{width:18px;height:18px}
.lbcb-cta.block{display:flex;width:100%;justify-content:center;margin-top:22px;padding:16px 24px}

/* ── summary / value reinforcement ─────────────────── */
/* ── review (final step) — stay summary + price card ── */
.lbcb-review{display:grid;grid-template-columns:1fr;gap:16px;max-width:940px;margin:0 auto}
.rv-card{background:#FCFAF4;border:1px solid rgba(20,30,27,.06);border-radius:18px;box-shadow:0 18px 44px -34px rgba(20,30,27,.4);overflow:hidden}
/* compact recap card — small thumbnail header, facts, then cost */
.rv-head{display:flex;align-items:center;gap:13px;padding:14px 16px;background:var(--mist);border-bottom:1px solid var(--hairline);cursor:pointer}
/* recap accordion: header summary always shown; facts + breakdown collapse */
.rv-acc-chev{flex:0 0 auto;display:flex;align-self:center;color:var(--drift);transition:transform .25s}
.rv-acc-chev svg{width:18px;height:18px}
.rv-recap.open .rv-acc-chev{transform:rotate(180deg)}
.rv-acc-body{display:none}
.rv-recap.open .rv-acc-body{display:block}
.rv-recap:not(.open) .rv-head{border-bottom-color:transparent}
.rv-breakdown{padding:13px 20px;border-top:1px solid var(--hairline)}
.rv-thumb{flex:0 0 auto;width:56px;height:56px;border-radius:12px;object-fit:cover}
.rv-head-t{flex:1;min-width:0}
.rv-head-t .k{display:block;font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--lagoon)}
.rv-head-t .nm{display:block;font-family:var(--lbcb-serif);font-size:17px;font-weight:600;color:var(--ink);line-height:1.15}
.rv-head-t .meta{display:block;font-size:11px;color:var(--drift);margin-top:1px}
.rv-head .rv-edit{align-self:center}
.rv-facts{padding:4px 18px 10px}
.rv-fact{display:flex;align-items:baseline;gap:10px;padding:11px 0;border-bottom:1px solid var(--hairline)}
.rv-fact:last-child{border-bottom:0}
.rv-fact .l{flex:0 0 auto;width:62px;font-size:10.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--drift)}
.rv-fact .v{flex:1;min-width:0;font-size:14px;font-weight:600;color:var(--ink)}
.rv-fact .rv-sub{display:block;margin-top:2px;font-weight:600;color:var(--drift);font-size:11.5px}
.rv-edit{flex:0 0 auto;background:none;border:0;color:var(--lagoon);font-size:11.5px;font-weight:700;cursor:pointer;text-decoration:underline;text-underline-offset:2px}
.rv-edit:hover{color:var(--lagoon-deep)}
.rv-edit-ic{align-self:center;display:inline-flex;align-items:center;justify-content:center;padding:5px;text-decoration:none}
.rv-edit-ic svg{width:16px;height:16px}
.rv-price{padding:18px 20px;border-top:1px solid var(--hairline)}
.rv-line{display:flex;justify-content:space-between;gap:12px;padding:7px 0;font-size:14px;color:var(--drift)}
.rv-line>span:last-child{color:var(--ink);font-weight:600;font-variant-numeric:tabular-nums}
.rv-line.disc>span:last-child{color:var(--lagoon)}
.rv-total{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding:10px 20px;border-top:1px solid var(--hairline)}
.rv-total>span{font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--drift)}
.rv-total b{font-family:var(--display);font-size:26px;font-weight:300;color:var(--lagoon-deep);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
/* full-width band at the foot of the recap card (not a floating inset box) */
.rv-deposit{border-top:1px solid var(--hairline)}
.rv-deposit .dr{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:11px 20px;font-size:13.5px}
.rv-deposit .dr b,.rv-deposit .dr span{font-variant-numeric:tabular-nums}
.rv-deposit .dr.today{background:var(--mist);font-weight:700;color:var(--lagoon-deep)}
.rv-deposit .dr:not(.today){color:var(--drift)}
.rv-save{display:flex;align-items:center;gap:9px;margin-top:15px;font-size:13px;font-weight:600;color:var(--lagoon-deep)}
.rv-save svg{width:18px;height:18px;flex:0 0 auto;color:var(--lagoon)}
.rv-perks{list-style:none;margin:16px 0 0;display:grid;gap:9px}
.rv-perks li{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--drift)}
.rv-perks li svg{width:14px;height:14px;flex:0 0 auto;color:var(--lagoon)}
.lbcb-fine{margin-top:14px;font-size:11.5px;color:var(--drift);text-align:center}
/* pay step · two quiet accordions — they blend into the page when closed and
   only resolve into a card once a guest opens one; set well below the recap */
.rv-faq{max-width:680px;margin:clamp(44px,7vh,88px) auto 0;display:grid;gap:4px;grid-template-columns:1fr}
.rv-faq .lbcb-amen-title{margin:0 0 7px}
.rv-faq-i{background:rgba(20,30,27,.035);border:1px solid rgba(20,30,27,.07);border-radius:14px;overflow:hidden;transition:background-color .2s,border-color .2s}
.rv-faq-i[open]{background:#FCFAF4;border-color:rgba(20,30,27,.12)}
.rv-faq-i>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 14px;font-size:12.5px;font-weight:600;color:var(--drift);transition:color .2s}
.rv-faq-i>summary:hover,.rv-faq-i[open]>summary{color:var(--ink)}
.rv-faq-i>summary::-webkit-details-marker{display:none}
.rv-faq-chev{width:15px;height:15px;flex:0 0 auto;color:var(--drift);opacity:.55;transition:transform .25s,opacity .2s}
.rv-faq-i[open]>summary .rv-faq-chev{transform:rotate(180deg);opacity:1}
.rv-faq-i>.a{padding:0 14px 13px;font-size:12.5px;line-height:1.55;color:var(--drift)}

/* subtle in-flow reassurance notes sprinkled across the steps —
   no card chrome, so they sit quietly on the page and don't compete */
.lbcb-note{display:flex;gap:8px;align-items:flex-start;justify-content:center;max-width:620px;margin:clamp(30px,4.5vh,46px) auto 0;font-size:12px;line-height:1.55;color:var(--drift);text-align:left}
.lbcb-note svg{width:14px;height:14px;flex:0 0 auto;color:var(--drift);opacity:.55;margin-top:2px}
.lbcb-note b{color:var(--drift);font-weight:700}

/* ── details step: form — no card background; each field reads as white ── */
.lbcb-detform{max-width:760px;margin:0 auto;text-align:left;background:transparent;border:0;border-radius:0;padding:0;box-shadow:none}
.lbcb-detform .lbcb-amen-title{margin:24px 0 14px}
.lbcb-detform .lbcb-amen-title:first-child{margin-top:0}
.lbcb-detform .opt{letter-spacing:.02em;text-transform:none;font-weight:500;opacity:.75}
.lbcb-fgrid{display:grid;grid-template-columns:1fr;gap:12px}
.lbcb-fld{display:grid;gap:6px}
.lbcb-fld>span{font-size:12px;font-weight:600;color:var(--ink)}
.lbcb-fld input,.lbcb-fld select,.lbcb-area{width:100%;font:inherit;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--hairline);border-radius:12px;padding:12px 14px;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}
.lbcb-fld select{cursor:pointer;height:46px}
.lbcb-fld input::placeholder,.lbcb-area::placeholder{color:var(--drift);opacity:.6}
.lbcb-fld input:focus,.lbcb-fld select:focus,.lbcb-area:focus{outline:0;border-color:var(--lagoon);box-shadow:0 0 0 3px rgba(53,122,112,.14)}
.lbcb-area{resize:vertical;min-height:62px;line-height:1.5;background:#fff}
/* phone: country dialling-code selector + number, joined as one field */
.lbcb-phone{display:flex;align-items:stretch;background:#fff;border:1px solid var(--hairline);border-radius:12px;transition:border-color .2s,box-shadow .2s}
.lbcb-phone:focus-within{border-color:var(--lagoon);box-shadow:0 0 0 3px rgba(53,122,112,.14)}
.lbcb-phone .lbcb-dial{flex:0 0 auto;width:auto;appearance:none;-webkit-appearance:none;border:0;border-right:1px solid var(--hairline);border-radius:12px 0 0 12px;
  background:transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2359625D' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E") no-repeat right 5px center;background-size:9px;
  font:inherit;font-size:14px;color:var(--ink);padding:12px 16px 12px 9px;cursor:pointer;height:auto}
.lbcb-phone input{flex:1;min-width:0;border:0;border-radius:0 12px 12px 0;background:transparent;padding:12px 14px;font-size:14px}
.lbcb-phone .lbcb-dial:focus,.lbcb-phone input:focus{outline:0;border-color:transparent;box-shadow:none}
.lbcb-phone .lbcb-dial:focus{border-right-color:var(--hairline)}

/* ── guest accordion (Airbnb-style): white field that opens a white panel ── */
.lbcb-guestsel{position:relative}
.lbcb-guestsel-field{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;
  background:#fff;border:1px solid var(--hairline);border-radius:12px;padding:14px 16px;cursor:pointer;text-align:left;font:inherit;color:var(--ink);transition:border-color .2s,box-shadow .2s}
.lbcb-guestsel-field:hover{border-color:var(--seaglass)}
/* open: field squares its bottom and hands straight off to the panel — one joined shape */
.lbcb-guestsel.open .lbcb-guestsel-field{border-color:var(--lagoon);border-bottom-color:transparent;border-radius:12px 12px 0 0;box-shadow:none}
.lbcb-guestsel-field:focus-visible{outline:0;border-color:var(--lagoon);box-shadow:0 0 0 3px rgba(53,122,112,.14)}
.lbcb-guestsel.open .lbcb-guestsel-field:focus-visible{box-shadow:none}
.lbcb-guestsel-field .gs-val{font-size:14px;font-weight:600;color:var(--ink)}
.lbcb-guestsel-field .gs-chev{flex:0 0 auto;display:flex;color:var(--lagoon-deep);transition:transform .3s cubic-bezier(.22,.9,.31,1)}
.lbcb-guestsel-field .gs-chev svg{width:18px;height:18px}
.lbcb-guestsel.open .gs-chev{transform:rotate(180deg)}
.lbcb-guestsel-panel{margin-top:0;background:#fff;border:1px solid var(--lagoon);border-top:0;border-radius:0 0 12px 12px;padding:2px 16px 6px;
  box-shadow:0 18px 44px -30px rgba(20,30,27,.5);animation:lbcbFade .2s ease}
.lbcb-guestsel-panel[hidden]{display:none}
.gs-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:15px 2px;border-bottom:1px solid var(--hairline)}
.gs-row:last-child{border-bottom:0}
.gs-row-t b{display:block;font-size:14.5px;font-weight:700;color:var(--ink)}
.gs-row-t span{font-size:12.5px;color:var(--drift)}
/* compact stepper, proportional to the field (the shared one is calendar-sized) */
.gs-row .lbcb-stepper{gap:8px}
.gs-row .lbcb-stepper button{width:30px;height:30px;font-size:16px}
.gs-row .lbcb-stepper button svg{width:14px;height:14px}
.gs-row .lbcb-stepper .v{font-size:15px;min-width:18px}

/* ── payment step ──────────────────────────────────── */
.rv-demolabel{margin-top:11px;text-align:center;font-size:10.5px;font-weight:800;letter-spacing:.22em;text-transform:uppercase;color:var(--drift)}
.rv-pay{padding:20px 22px;display:grid;gap:13px;align-content:start}
.rv-pay-h{display:flex;align-items:center;gap:9px;font-size:11.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--lagoon-deep)}
.rv-pay-h svg{width:17px;height:17px;color:var(--lagoon)}
.rv-demo{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:#9a6a2f;background:rgba(217,160,87,.13);border:1px solid rgba(217,160,87,.34);border-radius:11px;padding:9px 12px}
.rv-demo svg{width:15px;height:15px;flex:0 0 auto}
.rv-pay .lbcb-fgrid.two{grid-template-columns:1fr 1fr;gap:11px}
.rv-paynote{display:flex;align-items:center;gap:8px;font-size:11.5px;color:var(--drift)}
.rv-paynote svg{width:14px;height:14px;color:var(--lagoon);flex:0 0 auto}
/* trust footer for the card-details panel */
.rv-secure{display:flex;align-items:center;gap:8px;margin-top:6px;font-size:11.5px;color:var(--drift)}
.rv-secure svg{width:15px;height:15px;color:var(--lagoon);flex:0 0 auto}
.rv-payerr{font-size:12.5px;font-weight:600;color:#b4402c;background:rgba(180,64,44,.08);border:1px solid rgba(180,64,44,.28);border-radius:11px;padding:10px 12px}
.rv-payerr[hidden]{display:none}

/* ── success screen ────────────────────────────────── */
.lbcb-success{max-width:540px;margin:0 auto;text-align:center;padding:8px 0 6px}
.lbcb-success .su-ok{width:66px;height:66px;margin:0 auto 22px;border-radius:50%;display:grid;place-items:center;color:var(--foam);background:var(--lagoon);box-shadow:0 16px 36px -14px rgba(31,76,70,.6);animation:lbcbPop .5s cubic-bezier(.22,1.1,.36,1)}
.lbcb-success .su-ok svg{width:32px;height:32px;stroke-width:2.4}
@keyframes lbcbPop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.lbcb-success .lbcb-q,.lbcb-success .lbcb-sub{text-align:center}
.lbcb-success .lbcb-sub{margin-left:auto;margin-right:auto;margin-bottom:24px}
.su-ref{display:inline-flex;flex-direction:column;gap:3px;padding:12px 26px;border:1px dashed var(--seaglass);border-radius:14px;background:var(--mist);margin-bottom:20px}
.su-ref span{font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--drift)}
.su-ref b{font-family:var(--lbcb-serif);font-size:22px;font-weight:600;color:var(--lagoon-deep);letter-spacing:.02em}
.su-card{text-align:left;background:#FCFAF4;border:1px solid rgba(20,30,27,.06);border-radius:16px;overflow:hidden;margin-bottom:18px}
.su-row{display:flex;justify-content:space-between;gap:14px;padding:12px 17px;font-size:13.5px;border-bottom:1px solid var(--hairline)}
.su-row:last-child{border-bottom:0}
.su-row>span:first-child{color:var(--drift);font-weight:600}
.su-row>span:last-child{color:var(--ink);font-weight:600;text-align:right}
.su-note{display:flex;align-items:center;gap:9px;justify-content:center;text-align:left;font-size:12px;color:var(--drift);line-height:1.5;margin-bottom:22px}
.su-note svg{width:15px;height:15px;color:var(--lagoon);flex:0 0 auto}
.su-home{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--foam);background:var(--lagoon);border-radius:999px;padding:14px 28px;transition:transform .3s,filter .3s}
.su-home:hover{filter:brightness(1.08);transform:translateY(-2px)}
.su-home svg{width:14px;height:14px}

/* ── footer nav + CTA ──────────────────────────────── */
.lbcb-foot{flex:0 0 auto;display:flex;align-items:center;gap:14px;padding:16px 30px;border-top:1px solid var(--hairline);background:rgba(246,241,230,.5);backdrop-filter:blur(6px)}
.lbcb-back{background:none;border:0;color:var(--drift);font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;padding:10px 4px;transition:.25s;display:inline-flex;align-items:center;gap:7px}
.lbcb-back:hover{color:var(--lagoon)}
.lbcb-back svg{width:14px;height:14px}
.lbcb-back[hidden]{display:none}
.lbcb-spacer{flex:1}
.lbcb-cta{display:inline-flex;align-items:center;gap:9px;font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  background:var(--lagoon);color:var(--foam);border:0;border-radius:999px;padding:15px 30px;cursor:pointer;
  box-shadow:0 10px 24px -12px rgba(31,76,70,.55),inset 0 1px 0 rgba(255,255,255,.12);
  transition:transform .35s cubic-bezier(.22,.9,.31,1),box-shadow .35s,filter .35s;white-space:nowrap}
.lbcb-cta:hover{filter:brightness(1.08);transform:translateY(-2px);box-shadow:0 18px 38px -12px rgba(31,76,70,.6),inset 0 1px 0 rgba(255,255,255,.18)}
.lbcb-cta:active{transform:translateY(0) scale(.98)}
.lbcb-cta:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}
.lbcb-cta svg{width:15px;height:15px}
.lbcb-cta.busy svg{animation:lbcbSpin .8s linear infinite}
@keyframes lbcbSpin{to{transform:rotate(360deg)}}
.lbcb-foot .price-peek{display:none;flex-direction:column;line-height:1.05}
.lbcb-foot .price-peek b{font-family:var(--lbcb-serif);font-size:20px;font-weight:600;color:var(--lagoon-deep);font-variant-numeric:tabular-nums}
.lbcb-foot .price-peek span{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--drift)}
.lbcb-foot.has-price .price-peek{display:flex}

/* ── container-query layout upgrades (wide modal / inline column) ── */
@container (min-width:600px){
  .lbcb-body{padding:34px 38px}
  .lbcb-months{grid-template-columns:1fr 1fr}
  .lbcb-month .mhead{display:block}
  .lbcb-cal-title{display:none}
  .lbcb-cal-top{max-width:660px}
  .lbcb-months{max-width:660px}
  .lbcb-months .lbcb-month:nth-child(2){display:block}
  .lbcb-rooms{grid-template-columns:repeat(auto-fill,minmax(330px,1fr))}
  .lbcb-grid2{grid-template-columns:1fr 1fr}
  .lbcb-review{grid-template-columns:1fr 1fr;align-items:start}
  .lbcb-fgrid{grid-template-columns:1fr 1fr}
  /* payment step: card form on the left, selection recap on the right */
  .lbcb-review .rv-paywrap{order:-1}
  .lbcb-ext{display:inline}
  .lbcb-q{font-size:clamp(30px,3.6cqi,42px)}
  .lbcb-detail-grid{grid-template-columns:2fr 3fr;gap:30px}
  .lbcb-gallery{position:sticky;top:0;align-self:start}
}

/* payment step on wide screens: card form pinned left, recap pinned right,
   spanning the full content width with breathing room down the middle */
@container (min-width:980px){
  .lbcb-review{max-width:none;grid-template-columns:0.95fr 1.05fr;gap:clamp(40px,6cqi,88px)}
  .rv-paywrap{align-self:start}
}

/* ── mobile: full-screen sheet ─────────────────────── */
@media(max-width:560px){
  .lbcb-overlay{padding:0;align-items:stretch}
  .lbcb{max-width:none;max-height:none;height:100%;border-radius:0}
  .lbcb-overlay.open .lbcb{animation:lbcbSheet .42s cubic-bezier(.22,.9,.31,1)}
  @keyframes lbcbSheet{from{transform:translateY(100%)}to{transform:none}}
  .lbcb-body{padding:22px}
  .lbcb-foot{padding:14px 20px;padding-bottom:max(14px,env(safe-area-inset-bottom))}
  .lbcb-badges{grid-template-columns:1fr}
}

/* ── phone optimisation: keep critical content high, legible, and zoom-safe ── */
@media(max-width:600px){
  /* iOS zooms the viewport when a focused field is <16px — keep inputs at 16px */
  .lbcb-fld input,.lbcb-fld select,.lbcb-area,.lbcb-phone input,.lbcb-phone .lbcb-dial{font-size:16px}
  /* reclaim vertical space so the calendar / cards / price sit higher on screen */
  .lbcb.inline .lbcb-head-in{padding:7px 16px}
  /* tidy aligned 2×2 grid so the four benefits read uniform, not an uneven wrap */
  .lbcb.inline .lbcb-trust{display:grid;grid-template-columns:auto auto;justify-content:center;justify-items:start;gap:6px 18px;margin-top:9px}
  .lbcb-trust span{font-size:10px;gap:5px}
  .lbcb-trust svg{width:12px;height:12px}
  .lbcb.inline .lbcb-body{padding:14px 12px 20px}
  .lbcb.inline .lbcb-foot-in{padding:0 12px}
  .lbcb.inline .lbcb-q{margin-top:8px;font-size:clamp(22px,6vw,28px)}
  .lbcb-sub{margin-top:8px}
  .lbcb.inline .lbcb-sub{margin-bottom:18px;font-size:13.5px}
  /* tighter calendar + form rhythm */
  .lbcb-calcard{padding:16px 13px;border-radius:18px}
  .lbcb-cal-hint{margin-top:14px;font-size:13px}
  .lbcb-note{margin-top:18px;font-size:11.5px}
  .lbcb-detform .lbcb-amen-title{margin:15px 0 9px}
  /* form fields: keep 16px text (no iOS zoom) but shrink the boxes & gaps */
  .lbcb-fld{gap:5px}
  .lbcb-fld>span{font-size:11.5px}
  .lbcb-fld input{padding:10px 13px;line-height:1.3}
  .lbcb-area{padding:10px 13px;line-height:1.45}
  .lbcb-fld input::placeholder,.lbcb-area::placeholder,.lbcb-phone input::placeholder{font-size:13.5px}
  .lbcb-fld select{height:44px}
  .lbcb-phone .lbcb-dial,.lbcb-phone input{line-height:1.3}
  .lbcb-fgrid{gap:10px}
  .lbcb-area{min-height:52px}
  .lbcb-phone input{padding:10px 13px}
  .lbcb-phone .lbcb-dial{padding:10px 14px 10px 9px}
  .lbcb-guestsel-field{padding:11px 14px}
  .gs-row{padding:12px 2px}
  /* primary CTA must fit the longest label even on a 320px screen */
  .lbcb.inline .lbcb-cta{font-size:11px;letter-spacing:.04em;padding:13px 14px}
  /* roomier tap target on calendar days */
  .lbcb-day{font-size:15px}
  /* compact villa cards — shorter image + tighter body so more shows per screen */
  .lbcb-rooms{gap:12px}
  .lbcb-room .ph{aspect-ratio:16/9}
  .lbcb-room .bd{padding:13px 15px 15px}
  .lbcb-room h4{font-size:17px}
  .lbcb-room .pr{margin-bottom:10px}
  .lbcb-room .rm{margin-bottom:4px}
  .lbcb-room .incl{margin-bottom:0}
  .lbcb-room .acts{margin-top:12px;padding-top:11px}
  /* payment: aggressively tighten the recap so the card-details form peeks below it */
  .lbcb-review{gap:14px}
  .rv-head{padding:9px 12px;gap:10px}
  .rv-thumb{width:42px;height:42px}
  .rv-head-t .k{display:none}   /* "Your villa" is redundant on mobile */
  .rv-head-t .nm{font-size:15.5px}
  .rv-facts{padding:0 14px 3px}
  .rv-fact{padding:7px 0}
  .rv-fact .l{width:54px;font-size:10px}
  .rv-fact .v{font-size:13.5px}
  .rv-breakdown{padding:9px 14px}
  .rv-line{padding:3px 0;font-size:13.5px}
  .rv-total{padding:6px 14px}
  .rv-total b{font-size:22px}
  .rv-deposit .dr{padding:9px 14px;font-size:13px}
  /* villa detail view: hero with the title on it, no thumbs (swipe instead) */
  .lbcb-detail-back{margin-bottom:12px}
  .lbcb-detail-grid{gap:14px}
  .lbcb-gallery .main{aspect-ratio:16/10}
  .lbcb-gallery .thumbs{display:none}
  /* zone badge + status badge on the hero (mobile only) */
  .lbcb-gallery .main .rcard-tl,.lbcb-gallery .main .rcard-tr{display:block}
  /* villa name + tagline sit on the photo */
  .lbcb-gallery .main .g-cap{display:block;position:absolute;left:0;right:0;bottom:0;z-index:2;padding:13px 15px;background:linear-gradient(180deg,transparent,rgba(16,34,30,.85));pointer-events:none}
  .lbcb-gallery .main .g-nm{display:block;font-family:var(--lbcb-serif);font-size:21px;font-weight:700;color:#fff;line-height:1.15;text-shadow:0 1px 10px rgba(0,0,0,.45)}
  .lbcb-gallery .main .g-tag{display:block;font-size:12px;font-weight:600;color:#E7F1ED;margin-top:3px;line-height:1.3;text-shadow:0 1px 8px rgba(0,0,0,.5)}
  .lbcb-detail-info .d-top,.lbcb-detail-info .d-name,.lbcb-detail-info .d-tag{display:none}
  /* clean arrows over the photo — no background plate */
  .lbcb-gallery .main .lbcb-gnav{background:transparent;box-shadow:none;opacity:.96;color:#fff}
  .lbcb-gallery .main .lbcb-gnav:hover{background:transparent;color:#fff}
  .lbcb-gallery .main .lbcb-gnav svg{filter:drop-shadow(0 1px 4px rgba(0,0,0,.65))}
  .lbcb-detail-info .d-pr{margin:2px 0 10px}
  .lbcb-desc{font-size:13.5px;line-height:1.6}
  .lbcb-feats{margin:12px 0 2px}
  .lbcb-amen-title{margin:18px 0 10px}
  /* extra clearance so the "Beachfront Villa" pill clears the WHERE YOU'LL BE title */
  .lbcb-loc-bar{margin-top:42px}
  .lbcb-loc-note{margin-top:12px}
  .lbcb-amen{gap:9px 14px}
}
@media(max-width:360px){
  .lbcb-trust span{font-size:9.5px}
  .lbcb.inline .lbcb-cta{letter-spacing:.02em;padding:13px 10px}
  .lbcb.inline .lbcb-back{padding:12px 13px}
}

/* ═══════ book.html — booking flow IS the page, locked to the viewport ═══════ */
body[data-page="book"]{overflow:hidden;background:radial-gradient(135% 110% at 50% 0%,#F7F2E8 0%,#EDE5D4 100%)}
/* whisper-fine grain for tactile depth (not flat colour) */
body[data-page="book"]::after{content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.bookmain{height:100dvh;position:relative;z-index:1}
/* lift the bar off the page so it reads as a header, not a block */
.lbcb.inline .lbcb-head{position:relative;z-index:2;box-shadow:0 18px 38px -26px rgba(20,30,27,.55)}
