*{margin:0;padding:0;box-sizing:border-box}
/* Brand = Book Now / primary CTA background (#0d5c52); accents are same hue, not cyan-blue */
:root{
  /* Measured on homepage (index.php) for hero height; fallback before JS runs */
  --header-height:72px;
  --brand:#0d5c52;
  --brand-hover:#0a4a42;
  --brand-focus:#0a5c54;
  --brand-hero-kicker:#9ed6cc;
  --brand-on-dark:#6abeb0;
  --brand-on-dark-hover:#92d4c9;
  /* White / light pills on dark hero or map band — hover must read clearly vs default white */
  --btn-inverse-bg:#fff;
  --btn-inverse-border:#fff;
  --btn-inverse-hover-bg:#e2e8f0;
  --btn-inverse-hover-border:#cbd5e1;
  --btn-inverse-hover-color:var(--brand);
}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;line-height:1.6;color:#1e293b;background:#f8fafc;min-height:100vh}
.App{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:.5rem;z-index:2000;padding:.5rem 1rem;background:var(--brand);color:#fff;text-decoration:none;border-radius:4px;font-weight:600;border:2px solid var(--brand)}
.skip-link:focus{left:.5rem}
.skip-link:focus-visible{outline:3px solid var(--brand-focus);outline-offset:2px}
html.dark-mode .skip-link:focus-visible{outline-color:var(--brand-on-dark-hover)}

/* Focus visible (WCAG 2.4.7) — default ring for light UI */
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{outline:3px solid var(--brand-focus);outline-offset:3px}
html.dark-mode a:focus-visible,html.dark-mode button:focus-visible,html.dark-mode input:focus-visible,html.dark-mode textarea:focus-visible,html.dark-mode select:focus-visible{outline-color:var(--brand-on-dark-hover)}

.header{position:sticky;top:0;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.08);z-index:1000}
.header-container{max-width:1200px;margin:0 auto;padding:0 20px}
.header-content{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;gap:1rem;position:relative}
.logo{font-size:1.35rem;font-weight:700;color:var(--brand);text-decoration:none;white-space:nowrap}
.logo:hover{color:var(--brand-hover)}
.nav{display:flex;gap:1.25rem;flex:1;justify-content:center;align-items:center;flex-wrap:wrap}
.nav-link{color:#1e293b;text-decoration:none;font-weight:500}
.nav-link:hover{color:var(--brand)}
.header-actions{display:flex;align-items:center;gap:.75rem}
.cta-button{background:var(--brand);color:#fff;padding:.65rem 1.25rem;border-radius:6px;font-weight:600;text-decoration:none;white-space:nowrap;border:2px solid var(--brand)}
.cta-button:hover{background:var(--brand-hover);border-color:var(--brand-hover);color:#fff}
.menu-toggle{display:none;background:transparent;border:2px solid transparent;cursor:pointer;padding:.5rem;color:#1e293b;border-radius:6px}
.menu-toggle:focus-visible{border-color:var(--brand-focus)}

.theme-toggle{width:44px;height:44px;padding:0;border:2px solid transparent;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.12);flex-shrink:0}
.theme-toggle:focus-visible{outline:3px solid var(--brand-on-dark-hover);outline-offset:3px}
html:not(.dark-mode) .theme-toggle.is-dark-mode:focus-visible,
html.dark-mode .theme-toggle.is-dark-mode:focus-visible{outline-color:var(--brand-focus)}
html:not(.dark-mode) .theme-toggle.is-light-mode:focus-visible{outline-color:var(--brand-focus)}
html.dark-mode .theme-toggle.is-light-mode:focus-visible{outline-color:var(--brand-on-dark-hover)}
.nav .theme-toggle{margin-left:.35rem}
.theme-toggle.is-light-mode{background:#1e293b}
.theme-toggle.is-light-mode svg{color:#fff}
.theme-toggle.is-dark-mode{background:#f1f5f9}
.theme-toggle.is-dark-mode svg{color:#1e293b}
.theme-toggle svg{width:22px;height:22px}
.theme-toggle .theme-icon-sun,.theme-toggle .theme-icon-moon{display:none}
.theme-toggle.is-dark-mode .theme-icon-sun{display:block}
.theme-toggle.is-light-mode .theme-icon-moon{display:block}

.hero{position:relative;min-height:420px;display:flex;align-items:center;overflow:hidden}
/* Homepage: hero fills viewport below sticky header; copy vertically centered on the image */
.hero--property{
  align-items:center;
  padding-bottom:0;
  overflow:hidden;
  /* Fallback then modern viewport units (svh = stable on mobile) */
  min-height:max(420px,calc(100vh - var(--header-height)));
  min-height:max(420px,calc(100svh - var(--header-height)));
}
.hero-bg{position:absolute;inset:0;background:var(--brand)}
.hero-bg img{width:100%;height:100%;object-fit:cover;display:block;opacity:.95}
.hero-bg--photo img{opacity:1}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,23,42,.82),rgba(15,23,42,.45))}
/* Small control to swap front-of-house vs pool hero (see index.php + localStorage) */
.hero-photo-toggle{position:absolute;top:max(1rem,env(safe-area-inset-top));right:max(1rem,env(safe-area-inset-right));z-index:2;margin:0;padding:.35rem .65rem;min-height:44px;min-width:44px;display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:#f8fafc;background:rgba(15,23,42,.72);border:1px solid rgba(255,255,255,.35);border-radius:8px;cursor:pointer;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.hero-photo-toggle:hover{background:rgba(15,23,42,.88);border-color:rgba(255,255,255,.5)}
.hero-photo-toggle:focus-visible{outline:3px solid #fff;outline-offset:3px}
.hero-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:3rem 20px;width:100%}
/* Centered column on screen; copy and buttons stay left-aligned inside it */
.hero-inner--property{max-width:min(100%,96rem);width:100%;margin-left:auto;margin-right:auto;padding-left:clamp(20px,4vw,48px);padding-right:clamp(20px,4vw,48px);padding-top:clamp(1.25rem,4vh,2.5rem);padding-bottom:clamp(1.25rem,4vh,2.5rem);text-align:left}
.hero-kicker{font-size:.85rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--brand-hero-kicker);margin-bottom:.5rem}
.hero-location{font-size:1rem;color:#cbd5e1;margin-bottom:.75rem}
.hero h1{font-size:2.75rem;font-weight:800;color:#fff;margin-bottom:.75rem;line-height:1.2;max-width:min(100%,44rem)}
/* Property homepage: headline uses full inner width */
.hero--property .hero-inner h1{max-width:none;width:100%;overflow-wrap:break-word;word-wrap:break-word}
.hero--property .hero-location{max-width:40rem}
.hero .lead{font-size:1.2rem;color:#e2e8f0;max-width:40rem;margin-bottom:1.5rem}
.intro-copy{font-size:1.05rem;color:#475569;margin-bottom:1.5rem;max-width:65ch}
.home-hospitable-pricing{font-size:1rem;color:#334155;margin-bottom:1.25rem;max-width:65ch;padding:.85rem 1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px}
.home-hospitable-pricing a{font-weight:600;color:var(--brand)}
.hospitable-pricing-snapshot{border:1px solid #e2e8f0;border-radius:12px;padding:1.15rem 1.35rem;margin-bottom:1.5rem;background:#fff;box-shadow:0 2px 8px rgba(0,0,0,.05)}
.channel-partners{display:flex;align-items:center;gap:.55rem;flex-wrap:wrap;margin:0 0 1rem}
.channel-partners-label{font-weight:700;color:#334155;margin-right:.2rem}
.channel-partner-btn{padding:.45rem .8rem;font-size:.9rem}
.hospitable-pricing-snapshot .h3-section{margin-top:0;margin-bottom:.5rem}
.hospitable-pricing-lead{font-size:.95rem;color:#64748b;margin-bottom:.75rem}
.hospitable-pricing-meta{font-size:.85rem;color:#475569;margin-top:.75rem;margin-bottom:0}
.booking-estimate{font-size:.95rem;color:#0f172a;margin:.75rem 0 0;padding:.75rem 1rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;max-width:100%}
.booking-estimate--warn{background:#fffbeb;border-color:#fde68a;color:#92400e}
.booking-estimate-disclaimer{display:block;font-size:.82rem;color:#64748b;font-weight:400;margin-top:.35rem;line-height:1.45}
.booking-estimate-head{font-weight:700;margin-bottom:.45rem}
.booking-estimate-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:.15rem 0}
.booking-estimate-row--total{margin-top:.3rem;padding-top:.45rem;border-top:1px solid #cbd5e1}
html.dark-mode .booking-estimate{background:#0f172a;border-color:#334155;color:#e2e8f0}
html.dark-mode .booking-estimate--warn{background:#422006;border-color:#b45309;color:#fde68a}
html.dark-mode .booking-estimate-disclaimer{color:#cbd5e1}
html.dark-mode .booking-estimate-row--total{border-top-color:#334155}
html.dark-mode .hospitable-pricing-snapshot{background:#0f172a;border-color:#334155;box-shadow:none}
html.dark-mode .channel-partners-label{color:#e2e8f0}
html.dark-mode .hospitable-pricing-lead{color:#cbd5e1}
html.dark-mode .hospitable-pricing-meta{color:#cbd5e1}
html.dark-mode .home-hospitable-pricing{background:#0f172a;border-color:#334155;color:#e2e8f0}
.h3-section{font-size:1.15rem;font-weight:700;color:#0f172a;margin-bottom:.65rem}
.property-about{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.property-about>h2{grid-column:1/-1;margin-bottom:0.75rem}
.property-about>.intro-copy{grid-column:1/-1;max-width:none;margin-bottom:1.25rem}
.property-about .h3-section{margin-top:0}
.hero-actions{display:flex;gap:1rem;flex-wrap:wrap}
.btn-primary{background:var(--btn-inverse-bg);color:var(--brand-hover);padding:.9rem 1.5rem;border-radius:6px;font-weight:700;text-decoration:none;border:2px solid var(--btn-inverse-border)}
.btn-primary:hover{background:var(--btn-inverse-hover-bg);color:var(--btn-inverse-hover-color);border-color:var(--btn-inverse-hover-border)}
.hero .btn-primary:focus-visible,.hero .cta-button:focus-visible{outline:3px solid #fff;outline-offset:3px}
.hero .cta-button{padding:.9rem 1.5rem;font-weight:700;font-size:1rem}
.btn-secondary{background:transparent;color:#fff;border:2px solid #fff;padding:.85rem 1.4rem;border-radius:6px;font-weight:600;text-decoration:none}
.btn-secondary:hover{background:#fff;color:var(--brand-hover);border-color:#fff}

.section{padding:4rem 20px}
.section-alt{background:#fff}
.container{max-width:1100px;margin:0 auto}
.section h2{font-size:2rem;margin-bottom:1rem;color:#0f172a}
.section p{color:#475569;margin-bottom:1rem}
.gallery-section{background:#f1f5f9}
.gallery-lead{font-size:.95rem;color:#64748b;margin-bottom:1.25rem}
.gallery-empty{padding:2rem;background:#fff;border:1px dashed #cbd5e1;border-radius:12px;color:#64748b;font-size:.95rem}
.gallery-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem;margin:0;padding:0}
.gallery-thumb-wrap{width:100%;padding:0;border:none;border-radius:10px;overflow:hidden;cursor:zoom-in;background:#e2e8f0;transition:transform .15s ease,box-shadow .15s ease;display:block}
.gallery-thumb-wrap:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.gallery-thumb-wrap:focus-visible{transform:translateY(-2px);box-shadow:0 0 0 3px #fff,0 0 0 6px var(--brand-focus);outline:none}
html.dark-mode .gallery-thumb-wrap:focus-visible{box-shadow:0 0 0 3px #0b1120,0 0 0 6px var(--brand-on-dark-hover)}
.gallery-thumb{width:100%;height:100%;aspect-ratio:4/3;object-fit:cover;display:block;filter:brightness(1.08) contrast(1.04) saturate(1.06)}
.lightbox{position:fixed;inset:0;z-index:5000;background:rgba(15,23,42,.92);box-sizing:border-box;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}
.lightbox[hidden]{display:none!important}
.lightbox-inner{flex:1;display:flex;flex-direction:row;align-items:stretch;min-height:0;width:100%}
.lightbox-nav{flex:0 0 clamp(3rem,12vw,7.5rem);min-width:3rem;border:none;background:rgba(255,255,255,.07);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:background .15s ease}
.lightbox-nav:hover{background:rgba(255,255,255,.14)}
.lightbox-nav:focus-visible{background:rgba(255,255,255,.2);outline:3px solid #fff;outline-offset:-1px}
.lightbox-nav-icon{font-size:clamp(2.25rem,6vw,3.5rem);line-height:1;font-weight:200;opacity:.92;user-select:none}
.lightbox-stage{flex:1;min-width:0;display:flex;align-items:center;justify-content:center;padding:4.5rem 0.75rem 1.25rem;box-sizing:border-box}
.lightbox-img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;border-radius:4px;vertical-align:middle;filter:brightness(1.12) contrast(1.12) saturate(1.14)}
.lightbox-close{position:absolute;top:1rem;right:1rem;z-index:2;width:48px;height:48px;border:none;border-radius:50%;background:rgba(255,255,255,.15);color:#fff;font-size:1.75rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}
.lightbox-close:hover{background:rgba(255,255,255,.25)}
.lightbox-close:focus-visible{background:rgba(255,255,255,.3);outline:3px solid #fff;outline-offset:2px}
html.dark-mode .lightbox{background:rgba(2,6,23,.94)}
html.dark-mode .lightbox-nav{background:rgba(255,255,255,.06)}
html.dark-mode .lightbox-nav:hover{background:rgba(255,255,255,.11)}
html.dark-mode .lightbox-nav:focus-visible{outline-color:var(--brand-on-dark-hover)}
html.dark-mode .lightbox-close:focus-visible{outline-color:var(--brand-on-dark-hover)}
html.dark-mode .lightbox-img{filter:brightness(1.16) contrast(1.15) saturate(1.18)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:2rem}
.card-list{margin:1rem 0 0 1.25rem;color:#475569}
.card-list li{margin-bottom:.5rem}

.map-section{background:#f1f5f9}
.map-lead{font-size:.95rem;color:#475569;margin-bottom:1.25rem}
.map-embed-wrap{position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 4px 20px rgba(0,0,0,.08);background:#e2e8f0}
.map-embed-wrap iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:0}
.map-actions{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:1rem;margin-top:1.25rem}
.map-actions .btn-primary,.map-actions .cta-button{padding:.9rem 1.5rem;font-weight:700;font-size:1rem}

.booking-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}
.embed-box{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem;min-height:200px}
.embed-box p{color:#64748b;font-size:.95rem}
.contact-form,.inquiry-form{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.06);border:1px solid #e2e8f0}
.form-group{margin-bottom:1.1rem}
.form-group label{display:block;font-weight:600;margin-bottom:.35rem;color:#334155}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:.65rem .85rem;border:1px solid #cbd5e1;border-radius:6px;font-size:1rem;font-family:inherit}
.form-group textarea{min-height:120px;resize:vertical}
.submit-btn{background:var(--brand);color:#fff;border:2px solid var(--brand);padding:.85rem 1.25rem;border-radius:6px;font-weight:600;cursor:pointer;width:100%;font-size:1rem}
.submit-btn:hover{background:var(--brand-hover);border-color:var(--brand-hover);color:#fff}
/* Solid CTA on content pages (e.g. external booking link) — not the hero “inverse” .btn-primary */
.btn-solid-teal{display:inline-block;padding:.65rem 1.2rem;border-radius:6px;text-decoration:none;background:var(--brand);color:#fff;font-weight:600;border:2px solid var(--brand)}
.btn-solid-teal:hover{background:var(--brand-hover);border-color:var(--brand-hover);color:#fff}
html.dark-mode .btn-solid-teal{background:var(--brand);color:#fff;border-color:var(--brand)}
html.dark-mode .btn-solid-teal:hover{background:var(--brand-hover);border-color:var(--brand-hover);color:#fff}
.form-message{margin-top:1rem;padding:.75rem;border-radius:6px;display:none}
.form-message.success{background:#d1fae5;color:#065f46;display:block}
.form-message.error{background:#fee2e2;color:#991b1b;display:block}
.booking-date-hint{color:#b91c1c;font-size:.9rem;margin:-0.25rem 0 0.75rem}
.booking-confirmation-details{margin-top:1.25rem;padding:1.25rem 1.5rem;border:1px solid #e2e8f0;border-radius:12px;background:#f8fafc}
.booking-detail-list{display:grid;grid-template-columns:auto 1fr;gap:0.35rem 1.25rem;align-items:start;margin:0;font-size:1rem}
.booking-detail-list dt{font-weight:600;color:#334155;margin:0}
.booking-detail-list dd{margin:0;color:#1e293b;overflow-wrap:break-word}
html.dark-mode .booking-confirmation-details{background:#0b1120;border-color:#334155}
html.dark-mode .booking-detail-list dt{color:#94a3b8}
html.dark-mode .booking-detail-list dd{color:#e5e7eb}
.booking-fp-input{cursor:pointer}

/* Flatpickr: show left + right month arrows (default hides prev on earliest minDate month) */
.flatpickr-months{position:relative;padding:10px 44px 14px;align-items:center}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month{
  display:flex!important;
  align-items:center;
  justify-content:center;
  width:40px;
  height:36px;
  border-radius:8px;
  top:10px!important;
  z-index:4;
  line-height:1;
}
.flatpickr-months .flatpickr-prev-month{left:4px!important}
.flatpickr-months .flatpickr-next-month{right:4px!important}
.flatpickr-months .flatpickr-prev-month:hover,
.flatpickr-months .flatpickr-next-month:hover{background:rgba(13,92,82,.14)}
.flatpickr-months .flatpickr-prev-month.flatpickr-disabled,
.flatpickr-months .flatpickr-next-month.flatpickr-disabled{opacity:.35;cursor:default}
.flatpickr-months .flatpickr-prev-month.flatpickr-disabled:hover,
.flatpickr-months .flatpickr-next-month.flatpickr-disabled:hover{background:transparent}
.flatpickr-months .flatpickr-prev-month svg,
.flatpickr-months .flatpickr-next-month svg{fill:#334155;width:15px;height:15px}
/* Flatpickr: don’t focus-edit the year (avoids quick year jumps); month nav + maxDate still apply */
.flatpickr-current-month .numInputWrapper .numInput.cur-year{pointer-events:none;user-select:none}
.flatpickr-calendar .flatpickr-day{
  position:relative;
  display:flex!important;
  flex-direction:column!important;
  align-items:center;
  justify-content:flex-start;
  padding:3px 2px 4px;
  min-height:2.85rem;
  height:auto!important;
  max-height:none!important;
  line-height:1.15;
}
.flatpickr-calendar .flatpickr-day .fp-day-price{
  position:static;
  margin-top:auto;
  padding-top:1px;
  display:block;
  width:100%;
  order:2;
  font-size:.62rem;
  line-height:1.15;
  color:var(--brand);
  pointer-events:none;
  white-space:nowrap;
  max-width:100%;
  text-align:center;
  overflow:hidden;
  text-overflow:ellipsis;
}
.flatpickr-calendar .flatpickr-day .fp-day-price--blocked{
  color:#b91c1c;
  font-weight:700;
  letter-spacing:0;
}
/* Must beat .flatpickr-calendar .flatpickr-day { display:flex!important } */
.flatpickr-calendar .flatpickr-day.sc-hide-overflow-day{display:none!important}
.flatpickr-day.selected .fp-day-price{color:rgba(255,255,255,.95)}
.flatpickr-day.selected .fp-day-price--blocked{color:#fecaca}
html.dark-mode .flatpickr-day .fp-day-price{color:var(--brand-on-dark-hover)}
html.dark-mode .flatpickr-day.selected .fp-day-price{color:rgba(255,255,255,.95)}
html.dark-mode .flatpickr-calendar .flatpickr-day .fp-day-price--blocked{color:#f87171}
html.dark-mode .flatpickr-day.selected .fp-day-price--blocked{color:#fecaca}

.pay-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.pay-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:1.25rem}
.pay-card h3{font-size:1.1rem;margin-bottom:.5rem;color:#0f172a}
.pay-card p{color:#64748b;font-size:.95rem;word-break:break-word}
.pay-card a{color:var(--brand);font-weight:600;text-decoration:none}
.pay-card a:hover{color:var(--brand-hover);text-decoration:underline}
html.dark-mode .pay-card a{color:var(--brand-on-dark-hover)}
html.dark-mode .pay-card a:hover{color:var(--brand-hero-kicker)}

.page-content{max-width:720px;margin:0 auto;padding:3rem 20px}
.page-content .lead{font-size:1.15rem;color:var(--brand);font-weight:600;margin-bottom:1rem}
.page-content h1{font-size:2rem;margin-bottom:.75rem;color:#0f172a}
.legal-page h2{font-size:1.2rem;margin-top:1.75rem;margin-bottom:.5rem;color:#0f172a}
.legal-page p,.legal-page li{color:#475569;margin-bottom:.75rem}

.footer{background:#0f172a;color:#e2e8f0;padding:3rem 20px 1.5rem;margin-top:auto}
.footer-container{max-width:1200px;margin:0 auto}
.footer-content{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:2rem}
.footer-brand-name{font-size:1.35rem;font-weight:700;color:#fff;margin-bottom:.5rem}
.footer-tagline{color:#94a3b8;font-size:.95rem}
.footer-heading{font-size:.95rem;font-weight:600;color:#fff;margin-bottom:.5rem}
.footer-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}
.footer-list a{color:#cbd5e1;text-decoration:none}
.footer-list a:hover{color:#fff}
.footer-bottom{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #334155;font-size:.875rem;color:#94a3b8}

html.dark-mode{color-scheme:dark}
html.dark-mode,html.dark-mode body{background:#020617;color:#e5e7eb}
html.dark-mode .header{background:#020617;box-shadow:0 2px 8px rgba(0,0,0,.4)}
html.dark-mode .logo{color:var(--brand-on-dark-hover)}
html.dark-mode .logo:hover{color:var(--brand-hero-kicker)}
html.dark-mode .nav-link{color:#e5e7eb}
html.dark-mode .nav-link:hover{color:var(--brand-on-dark-hover)}
html.dark-mode .menu-toggle{color:#e5e7eb}
html.dark-mode .menu-toggle:focus-visible{border-color:var(--brand-on-dark-hover)}
html.dark-mode .cta-button:focus-visible{outline-color:var(--brand-on-dark-hover)}
html.dark-mode .section-alt{background:#0b1120}
html.dark-mode .section h2{color:#f1f5f9}
html.dark-mode .section p,html.dark-mode .card-list{color:#94a3b8}
html.dark-mode main .section a:not(.btn-primary):not(.btn-secondary):not(.cta-button){color:var(--brand-on-dark);font-weight:600;text-decoration:underline;text-decoration-color:rgba(106,190,176,.5);text-underline-offset:2px}
html.dark-mode main .section a:not(.btn-primary):not(.btn-secondary):not(.cta-button):hover{color:var(--brand-on-dark-hover);text-decoration-color:var(--brand-on-dark-hover)}
html.dark-mode main .section a:not(.btn-primary):not(.btn-secondary):not(.cta-button):visited{color:var(--brand-on-dark)}
html.dark-mode .page-content a:not([class]){color:var(--brand-on-dark);font-weight:600;text-decoration:underline;text-decoration-color:rgba(106,190,176,.5);text-underline-offset:2px}
html.dark-mode .page-content a:not([class]):hover{color:var(--brand-on-dark-hover);text-decoration-color:var(--brand-on-dark-hover)}
html.dark-mode .page-content a:not([class]):visited{color:var(--brand-on-dark)}
html.dark-mode .intro-copy{color:#cbd5e1}
html.dark-mode .h3-section{color:#f1f5f9}
html.dark-mode .gallery-section{background:#0b1120}
html.dark-mode .gallery-lead{color:#94a3b8}
html.dark-mode .gallery-empty{background:#020617;border-color:#334155;color:#94a3b8}
html.dark-mode .gallery-thumb-wrap{background:#334155}
html.dark-mode .gallery-thumb{filter:brightness(1.12) contrast(1.06) saturate(1.08)}
html.dark-mode .map-section{background:#0b1120}
html.dark-mode .map-lead{color:#cbd5e1}
html.dark-mode .map-embed-wrap{border-color:#334155;background:#1e293b;box-shadow:0 4px 24px rgba(0,0,0,.35)}
html.dark-mode .embed-box{background:#0b1120;border-color:#334155}
html.dark-mode .page-content .contact-form,
html.dark-mode .page-content .inquiry-form{background:#0b1120!important;border:1px solid #334155!important;box-shadow:0 4px 12px rgba(0,0,0,.35)!important}
html.dark-mode .form-group label{color:#e5e7eb}
html.dark-mode .form-group input,
html.dark-mode .form-group textarea,
html.dark-mode .form-group select{background:#020617!important;border-color:#475569!important;color:#e5e7eb!important}
html.dark-mode .form-message.success{background:#064e3b;color:#a7f3d0}
html.dark-mode .form-message.error{background:#7f1d1d;color:#fecaca}
html.dark-mode .booking-date-hint{color:#f87171;font-size:.9rem;margin:-0.25rem 0 0.75rem}
html.dark-mode .flatpickr-calendar{background:#0f172a;border:1px solid #334155;box-shadow:0 8px 24px rgba(0,0,0,.5)}
html.dark-mode .flatpickr-months .flatpickr-month{background:#0f172a;color:#e5e7eb}
html.dark-mode .flatpickr-current-month .flatpickr-monthDropdown-months,
html.dark-mode .flatpickr-current-month .numInputWrapper{background:#0f172a;color:#e5e7eb}
html.dark-mode span.flatpickr-weekday{color:#94a3b8}
html.dark-mode .flatpickr-day{color:#e5e7eb}
html.dark-mode .flatpickr-day:hover{background:#1e293b;border-color:#334155}
html.dark-mode .flatpickr-day.today{border-color:var(--brand-on-dark-hover)}
html.dark-mode .flatpickr-day.selected{background:var(--brand);border-color:var(--brand);color:#fff}
html.dark-mode .flatpickr-day.flatpickr-disabled{color:#475569}
html.dark-mode .flatpickr-months .flatpickr-prev-month:hover,
html.dark-mode .flatpickr-months .flatpickr-next-month:hover{background:rgba(106,190,176,.14)}
html.dark-mode .flatpickr-months .flatpickr-prev-month svg,
html.dark-mode .flatpickr-months .flatpickr-next-month svg{fill:#e5e7eb}
html.dark-mode .flatpickr-months .flatpickr-prev-month.flatpickr-disabled svg,
html.dark-mode .flatpickr-months .flatpickr-next-month.flatpickr-disabled svg{fill:#64748b}
html.dark-mode .flatpickr-current-month .numInputWrapper .numInput.cur-year{color:#e5e7eb}
html.dark-mode .hero-photo-toggle{background:rgba(2,6,23,.78);border-color:rgba(146,212,201,.5);color:#f1f5f9}
html.dark-mode .hero-photo-toggle:hover{background:rgba(15,23,42,.9);border-color:rgba(146,212,201,.72)}
html.dark-mode .hero-photo-toggle:focus-visible{outline-color:var(--brand-on-dark-hover)}
html.dark-mode .pay-card{background:#0b1120;border-color:#334155}
html.dark-mode .pay-card h3{color:#f1f5f9}
html.dark-mode .pay-card p{color:#94a3b8}
html.dark-mode .page-content .lead{color:var(--brand-on-dark-hover)}
html.dark-mode .page-content h1,html.dark-mode .legal-page h2{color:#f1f5f9}
html.dark-mode .legal-page p,html.dark-mode .legal-page li{color:#cbd5e1}

@media (max-width:900px){
  .booking-layout{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .property-about{grid-template-columns:1fr}
}
@media (max-width:768px){
  .menu-toggle{display:block}
  .nav{position:absolute;top:100%;left:0;right:0;background:#fff;flex-direction:column;padding:1rem;box-shadow:0 8px 16px rgba(0,0,0,.12);display:none;gap:.75rem;align-items:flex-start}
  html.dark-mode .nav{background:#0b1120;box-shadow:0 8px 16px rgba(0,0,0,.45)}
  .nav.nav-open{display:flex}
  .nav .theme-toggle{margin-left:0;margin-top:.25rem}
  .header-actions .cta-button{font-size:.9rem;padding:.55rem .9rem}
  .hero h1{font-size:2rem}
  .form-row{grid-template-columns:1fr}
  .footer-content{grid-template-columns:1fr}
  .flatpickr-day{min-height:3.1rem;padding-left:1px;padding-right:1px}
  .flatpickr-day .fp-day-price{font-size:.58rem;line-height:1.2}
}
