:root { --bg: #f3f7f3; --surface: #ffffff; --primary: #2f6b57; --secondary: #5f8ea8; --accent: #d9b87a; --text: #183228; --section: clamp(2rem, 4vw, 4rem); --gutter: clamp(1rem, 3vw, 2rem); }
* { box-sizing: border-box; }
body.template-nature-escape { margin: 0; font-family: "Source Sans 3", "Segoe UI", sans-serif; background: linear-gradient(180deg, #eaf3ef 0%, var(--bg) 45%, #eef5f7 100%); color: var(--text); }
.site-shell, .page-content, .site-footer { width: min(1120px, calc(100% - 2rem)); margin: 0 auto; }
.site-shell { padding: 1.5rem 0 var(--section); }
.site-topbar, .site-nav ul, .amenities, .map-details { display: flex; flex-wrap: wrap; gap: .75rem; align-items: center; padding: 0; margin: 0; list-style: none; }
.site-brand { font: 700 1.25rem "Poppins", "Segoe UI", sans-serif; color: var(--primary); text-decoration: none; }
.site-location, .page-meta, .subheader { color: #4f675a; }
.site-location { background: rgba(47,107,87,.08); border-radius: 999px; padding: .45rem .8rem; font-size: .95rem; }
.site-nav ul { margin-top: 1rem; row-gap: .75rem; align-items: flex-start; flex-wrap: nowrap; overflow-x: auto; padding-bottom: .15rem; scrollbar-width: thin; }
.site-nav li { flex: 0 0 auto; display: flex; }
.site-nav a, .block-button { display: inline-flex; align-items: center; justify-content: center; padding: .8rem 1rem; border-radius: 999px; text-decoration: none; transition: transform .18s ease, background-color .18s ease, box-shadow .18s ease, border-color .18s ease, color .18s ease; }
.site-nav a { background: rgba(47,107,87,.08); color: var(--primary); white-space: nowrap; line-height: 1.2; border: 1px solid rgba(47,107,87,.12); font-weight: 600; }
.site-nav a:hover, .site-nav a:focus-visible { background: rgba(47,107,87,.14); border-color: rgba(47,107,87,.3); box-shadow: 0 10px 24px rgba(47,107,87,.12); transform: translateY(-1px); }
.site-nav li.nav-utility-first { margin-left: auto; }
.site-nav a.nav-book-now-link, .site-nav a.booking-lookup-link { min-width: 8.75rem; color: var(--text); background: var(--accent); border-color: rgba(24,50,40,.16); box-shadow: 0 10px 22px rgba(217,184,122,.24); }
.site-nav a.nav-book-now-link:hover, .site-nav a.nav-book-now-link:focus-visible, .site-nav a.booking-lookup-link:hover, .site-nav a.booking-lookup-link:focus-visible { background: #cfaa64; border-color: rgba(24,50,40,.24); box-shadow: 0 14px 28px rgba(217,184,122,.3); }
.page-hero { padding: var(--section) 0 0; }
.eyebrow { text-transform: uppercase; letter-spacing: .16em; font-size: .75rem; color: var(--secondary); }
h1, h2 { font-family: "Poppins", "Segoe UI", sans-serif; margin: 0 0 .75rem; }
h1 { font-size: clamp(2.6rem, 6vw, 5rem); line-height: .95; max-width: 12ch; }
h2 { font-size: clamp(1.6rem, 3vw, 2.5rem); }
.page-summary { max-width: 48rem; font-size: 1.1rem; }
.amenities li { background: rgba(95,142,168,.12); border-radius: 999px; padding: .5rem .9rem; }
.page-actions, .block-actions { margin-top: 1rem; display: flex; flex-wrap: wrap; gap: .75rem; }
.page-content { display: grid; gap: 1.25rem; padding-bottom: var(--section); }
.product-family-entry { display: grid; gap: 1rem; }
.family-actions { margin-top: 0; }
.block { background: rgba(255,255,255,.86); backdrop-filter: blur(8px); border-radius: 28px; padding: clamp(1.25rem, 3vw, 2rem); box-shadow: 0 18px 50px rgba(31,60,47,.12); }
.hero-block, .cta-block, .map-block { display: grid; gap: 1.2rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.info-block.layout-two-column, .info-block.layout-split, .cta-block.layout-split { display: grid; gap: 1rem; grid-template-columns: repeat(2, minmax(0, 1fr)); }
.info-secondary { display: grid; gap: .85rem; align-content: start; }
.photo-grid { display: grid; gap: .85rem; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.photo-card { margin: 0; background: #f7faf8; border-radius: 20px; overflow: hidden; }
.photo-card img { width: 100%; height: 220px; object-fit: cover; display: block; }
.info-block.layout-split .photo-card img, .info-block.layout-two-column .photo-card img { height: auto; max-height: 360px; object-fit: contain; background: #eef5f1; }
.photo-card figcaption { padding: .7rem .9rem; font-size: .92rem; }
.block-button { background: var(--primary); color: white; margin-top: .6rem; font-weight: 700; box-shadow: 0 14px 28px rgba(47,107,87,.18); }
.block-button:hover, .block-button:focus-visible { background: #255545; box-shadow: 0 18px 34px rgba(37,85,69,.22); transform: translateY(-1px); }
.block-button.booking-primary { color: var(--text); background: var(--accent); border: 1px solid rgba(24,50,40,.16); box-shadow: 0 14px 28px rgba(217,184,122,.24); }
.block-button.booking-primary:hover, .block-button.booking-primary:focus-visible { color: var(--text); background: #cfaa64; border-color: rgba(24,50,40,.24); box-shadow: 0 18px 34px rgba(217,184,122,.3); }
.block-button.secondary { color: var(--primary); background: rgba(47,107,87,.08); border: 1px solid rgba(47,107,87,.14); box-shadow: 0 8px 18px rgba(47,107,87,.08); }
.block-button.secondary:hover, .block-button.secondary:focus-visible { color: var(--primary); background: rgba(47,107,87,.14); border-color: rgba(47,107,87,.28); box-shadow: 0 12px 24px rgba(47,107,87,.12); }
.block-metadata { display: grid; gap: .75rem; margin: 1rem 0 0; }
.meta-item { background: #edf5f1; border-radius: 18px; padding: .75rem .9rem; }
.meta-item dt { font-weight: 700; margin-bottom: .2rem; }
.map-embed { width: 100%; min-height: 260px; border: 0; border-radius: 22px; margin-top: 1rem; box-shadow: 0 12px 30px rgba(31,60,47,.12); }
.site-footer { padding: 0 0 2rem; color: #4f675a; display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
@media (max-width: 760px) { .hero-block, .cta-block, .map-block, .info-block.layout-two-column, .info-block.layout-split, .cta-block.layout-split { grid-template-columns: 1fr; } h1 { max-width: none; } .site-nav li.nav-utility-first { margin-left: 0; } }
