/* UniqBnB Brand Standards
   navy #0B2343 headers/nav · royal #1665C1 buttons/links/CTAs
   accent #1CB7F0 sparingly · white bg · #F5F7FA cards
   Montserrat Bold headlines · Open Sans body
   Feel: luxury boutique hospitality — rounded, photographic, minimal shadows */
:root {
  --navy: #0B2343;
  --royal: #1665C1;
  --royal-dark: #1254A1;
  --accent: #1CB7F0;
  --card: #F5F7FA;
  --line: #E4E9F0;
  --muted: #5C6B7F;
  --danger: #B3402E;
  --radius: 18px;
  --shadow: 0 6px 24px rgba(11, 35, 67, 0.08);
  --head: "Montserrat", "Poppins", ui-sans-serif, system-ui, sans-serif;
  --body: "Open Sans", ui-sans-serif, system-ui, sans-serif;
}
* { box-sizing: border-box; margin: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--body); color: var(--navy); background: #fff; line-height: 1.6; }
h1, h2, h3, h4 { font-family: var(--head); font-weight: 700; letter-spacing: -0.01em; }
img { max-width: 100%; display: block; }
a { color: var(--royal); text-decoration: none; }
button { font: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--accent); outline-offset: 2px; }

/* ---------- chrome ---------- */
#topbar {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 28px; background: var(--navy);
}
.brand { display: inline-flex; align-items: center; }
.brand img { height: 40px; filter: brightness(0) invert(1); }
#topbar nav { display: flex; gap: 26px; align-items: center; }
#topbar nav a { color: #fff; font-weight: 600; font-size: .93rem; opacity: .92; }
#topbar nav a:hover { opacity: 1; }
#topbar nav a.cta {
  background: var(--royal); color: #fff; padding: 10px 20px; border-radius: 999px; opacity: 1;
}
#topbar nav a.cta:hover { background: var(--royal-dark); }

footer { background: var(--navy); color: #C6D2E1; margin-top: 90px; padding: 54px 28px 26px; }
.foot-inner { display: flex; gap: 64px; flex-wrap: wrap; max-width: 1100px; margin: 0 auto; }
footer .brand img { height: 34px; }
footer h4 { color: #fff; margin-bottom: 10px; font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; }
footer a { display: block; color: #C6D2E1; margin: 5px 0; }
footer a:hover { color: #fff; }
.tagline { font-style: italic; opacity: .85; margin-top: 10px; }
.fineprint { text-align: center; margin-top: 40px; font-size: .78rem; opacity: .5; }

/* ---------- hero ---------- */
.hero {
  position: relative; min-height: 68vh; display: flex; align-items: center; justify-content: center;
  background:
    linear-gradient(180deg, rgba(11,35,67,.62) 0%, rgba(11,35,67,.38) 55%, rgba(11,35,67,.66) 100%),
    var(--hero-img, var(--navy)) center/cover;
  color: #fff; text-align: center; padding: 96px 20px;
}
.hero h1 { font-size: clamp(2.1rem, 5vw, 3.6rem); font-weight: 800; }
.hero p.sub { font-size: clamp(1rem, 2vw, 1.25rem); margin-top: 12px; opacity: .94; font-weight: 400; }

.searchbar {
  margin: 38px auto 0; background: #fff; border-radius: var(--radius);
  box-shadow: var(--shadow); display: flex; flex-wrap: wrap;
  max-width: 880px; overflow: hidden;
}
.searchbar .field { flex: 1 1 160px; padding: 13px 18px; text-align: left; border-right: 1px solid var(--line); }
.searchbar label { display: block; font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); font-family: var(--head); }
.searchbar input, .searchbar select { border: 0; outline: 0; font: inherit; width: 100%; color: var(--navy); background: none; padding: 2px 0; }
.searchbar .go { flex: 0 0 auto; background: var(--royal); color: #fff; border: 0; padding: 0 36px; font-weight: 700; font-size: 1rem; font-family: var(--head); }
.searchbar .go:hover { background: var(--royal-dark); }

/* ---------- sections ---------- */
section.wrap { max-width: 1100px; margin: 0 auto; padding: 64px 24px 0; }
section.wrap h2 { font-size: 1.75rem; margin-bottom: 6px; }
section.wrap p.lede { color: var(--muted); margin-bottom: 30px; }

.about { background: var(--card); border-radius: var(--radius); padding: 48px; margin-top: 72px; }
.about p { max-width: 72ch; font-size: 1.05rem; }

/* ---------- cards ---------- */
.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 28px; }
.card {
  border-radius: var(--radius); overflow: hidden; background: var(--card);
  border: 1px solid var(--line); transition: transform .18s ease, box-shadow .18s ease;
  display: flex; flex-direction: column; color: var(--navy);
}
.card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.card .ph { aspect-ratio: 4/3; background: #dfe6ee center/cover; }
.card .body { padding: 16px 18px 20px; }
.card h3 { font-size: 1rem; line-height: 1.4; }
.card .loc { color: var(--muted); font-size: .87rem; margin: 3px 0 9px; }
.card .meta { font-size: .87rem; display: flex; gap: 12px; }
.card .price { margin-top: 12px; font-weight: 700; font-family: var(--head); }
.card .price small { font-weight: 400; color: var(--muted); font-family: var(--body); }

/* ---------- filters ---------- */
.filters { display: flex; gap: 12px; flex-wrap: wrap; margin: 20px 0 30px; }
.filters select, .filters input { padding: 10px 14px; border: 1px solid var(--line); border-radius: 10px; font: inherit; background: #fff; color: var(--navy); }

/* ---------- listing detail ---------- */
.detail { max-width: 1100px; margin: 0 auto; padding: 32px 24px 0; }
.gallery { display: grid; grid-template-columns: 2fr 1fr; gap: 10px; border-radius: var(--radius); overflow: hidden; }
.gallery .main { aspect-ratio: 4/3; background: var(--card) center/cover; cursor: pointer; }
.gallery .side { display: grid; grid-template-rows: 1fr 1fr; gap: 10px; }
.gallery .side div { background: var(--card) center/cover; cursor: pointer; }
.thumbstrip { display: flex; gap: 8px; margin-top: 10px; overflow-x: auto; padding-bottom: 6px; }
.thumbstrip img { height: 64px; width: 92px; object-fit: cover; border-radius: 8px; cursor: pointer; opacity: .7; flex: 0 0 auto; }
.thumbstrip img.sel { opacity: 1; outline: 2px solid var(--royal); }

.detail-cols { display: grid; grid-template-columns: 1.6fr 1fr; gap: 44px; margin-top: 32px; }
@media (max-width: 900px) { .detail-cols { grid-template-columns: 1fr; } .gallery { grid-template-columns: 1fr; } .gallery .side { display: none; } }
.detail h1 { font-size: 1.75rem; }
.detail .loc { color: var(--muted); margin-bottom: 16px; }
.detail .stats { display: flex; gap: 20px; font-weight: 600; font-size: .93rem; border-bottom: 1px solid var(--line); padding-bottom: 20px; margin-bottom: 20px; flex-wrap: wrap; }
.detail .desc { white-space: pre-line; }
.amen { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px; }
.amen span { background: var(--card); border: 1px solid var(--line); padding: 6px 14px; border-radius: 999px; font-size: .84rem; }
details.more { margin-top: 16px; }
details.more summary { cursor: pointer; font-weight: 600; color: var(--royal); }

/* ---------- booking box ---------- */
.bookbox {
  position: sticky; top: 84px; border: 1px solid var(--line); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 22px; background: #fff;
}
.bookbox h3 { margin-bottom: 14px; }
.bookbox h3 small { font-weight: 400; color: var(--muted); font-family: var(--body); }
.bb-row { display: flex; gap: 10px; margin-bottom: 10px; }
.bb-row > div { flex: 1; }
.bookbox label { font-size: .7rem; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--muted); display: block; font-family: var(--head); }
.bookbox input, .bookbox select { width: 100%; padding: 9px 11px; border: 1px solid var(--line); border-radius: 10px; font: inherit; color: var(--navy); }
.bookbox .quote-lines { margin: 15px 0; font-size: .92rem; }
.bookbox .quote-lines div { display: flex; justify-content: space-between; padding: 3px 0; }
.bookbox .quote-lines .total { border-top: 1px solid var(--line); margin-top: 8px; padding-top: 9px; font-weight: 800; font-size: 1.05rem; font-family: var(--head); }
.bookbox .policy { font-size: .8rem; color: var(--muted); margin-top: 9px; }
.bigbtn {
  width: 100%; background: var(--royal); border: 0; color: #fff; padding: 14px;
  border-radius: 12px; font-weight: 700; font-size: 1rem; margin-top: 8px; font-family: var(--head);
}
.bigbtn:hover { background: var(--royal-dark); }
.bigbtn:disabled { background: #A7B8CC; cursor: not-allowed; }
.coupon-row { display: flex; gap: 8px; margin-top: 10px; }
.coupon-row input { flex: 1; }
.coupon-row button { border: 1px solid var(--royal); background: #fff; color: var(--royal); border-radius: 10px; padding: 0 16px; font-weight: 600; }

/* ---------- calendar ---------- */
.cal { margin-top: 28px; }
.cal-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.cal-head strong { font-family: var(--head); }
.cal-head button { border: 1px solid var(--line); background: #fff; border-radius: 10px; padding: 4px 14px; color: var(--navy); }
.cal-months { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
@media (max-width: 700px) { .cal-months { grid-template-columns: 1fr; } }
.cal-month h4 { text-align: center; margin-bottom: 8px; font-size: .95rem; }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 2px; font-size: .84rem; }
.cal-grid .dow { text-align: center; color: var(--muted); font-size: .68rem; padding: 4px 0; }
.cal-grid .day { aspect-ratio: 1; display: flex; align-items: center; justify-content: center; border-radius: 10px; cursor: pointer; border: 1px solid transparent; }
.cal-grid .day.avail:hover { border-color: var(--royal); }
.cal-grid .day.unavail { color: #B9C4D2; text-decoration: line-through; cursor: default; }
.cal-grid .day.blocked-min { color: #B9C4D2; cursor: default; }
.cal-grid .day.sel { background: var(--royal); color: #fff; }
.cal-grid .day.inrange { background: rgba(28, 183, 240, .16); }
.cal-legend { font-size: .78rem; color: var(--muted); margin-top: 8px; }

/* ---------- checkout / confirm ---------- */
.narrow { max-width: 760px; margin: 0 auto; padding: 44px 24px 0; }
.narrow h1 { margin-bottom: 20px; }
.formgrid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.formgrid .full { grid-column: 1 / -1; }
.formgrid label { font-size: .78rem; font-weight: 700; display: block; margin-bottom: 4px; font-family: var(--head); }
.formgrid input { width: 100%; padding: 11px 13px; border: 1px solid var(--line); border-radius: 10px; font: inherit; color: var(--navy); }
.paybox { border: 1px dashed var(--line); border-radius: 12px; padding: 20px; margin: 24px 0; background: var(--card); }
.paybox label { font-family: var(--head); font-weight: 700; font-size: .8rem; display: block; margin-bottom: 8px; }
.paybox .StripeElement { background: #fff; border: 1px solid var(--line); border-radius: 10px; padding: 12px 13px; }
.paybox .StripeElement--focus { outline: 2px solid var(--accent); outline-offset: 2px; }
.paybox .StripeElement--invalid { border-color: var(--danger); }
.notice { background: var(--card); border-left: 3px solid var(--accent); border-radius: 10px; padding: 15px 17px; margin: 20px 0; font-size: .94rem; }
.summary { border: 1px solid var(--line); border-radius: var(--radius); padding: 20px; margin-bottom: 26px; background: var(--card); }
.summary div { display: flex; justify-content: space-between; padding: 3px 0; }
.summary .total { font-weight: 800; border-top: 1px solid var(--line); margin-top: 7px; padding-top: 9px; font-family: var(--head); }
.confirm-hero { text-align: center; padding: 76px 20px 20px; }
.confirm-hero .big { font-size: 3rem; }

.legal h2 { font-size: 1.1rem; margin: 26px 0 6px; }
.legal p { margin: 8px 0; }
.legal .lede { color: var(--muted); font-size: .88rem; }

.spinner { text-align: center; color: var(--muted); padding: 60px 0; }
.err { color: var(--danger); font-size: .9rem; margin-top: 8px; }

/* ---------- mobile ---------- */
/* the topbar has no wrap by design (sticky, single row) — at phone widths
   everything inside must shrink instead of overflowing onto the content */
@media (max-width: 720px) {
  #topbar { padding: 10px 14px; gap: 10px; }
  .brand { min-width: 0; flex: 0 1 auto; }
  .brand img { height: 28px; width: auto; }
  #topbar nav { gap: 13px; flex: 0 0 auto; }
  #topbar nav a { font-size: .84rem; white-space: nowrap; }
  #topbar nav a.cta { padding: 8px 13px; }

  .hero { min-height: 55vh; padding: 60px 16px; }
  .searchbar { border-radius: 14px; }
  .searchbar .field { flex: 1 1 45%; border-right: 0; border-bottom: 1px solid var(--line); }
  .searchbar .go { flex: 1 1 100%; padding: 14px 0; }

  section.wrap { padding: 44px 16px 0; }
  .about { padding: 28px 22px; margin-top: 48px; }
  .grid { gap: 18px; }

  .detail { padding: 18px 14px 0; }
  .detail-cols { gap: 26px; margin-top: 22px; }
  .bookbox { position: static; }
  .stats { gap: 12px; }

  .narrow { padding: 26px 16px 0; }
  .formgrid { grid-template-columns: 1fr; }

  footer { margin-top: 56px; padding: 38px 20px 22px; }
  .foot-inner { gap: 26px; }
}
@media (max-width: 400px) {
  #topbar nav a[href="#/#about"] { display: none; }
  .bb-row { flex-wrap: wrap; }
  .bb-row > div { flex: 1 1 100%; }
}
.skeleton { background: linear-gradient(90deg, var(--card) 25%, #E9EEF4 40%, var(--card) 60%); background-size: 300% 100%; animation: sk 1.2s infinite; border-radius: var(--radius); }
@keyframes sk { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }
