* { box-sizing: border-box; } html, body { margin: 0; padding: 0; }
body { font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif; color: #0b1f17; line-height: 1.6; background: #f6f8f7; }
img { max-width: 100%; display: block; }
.skip-link { position: absolute; left: -9999px; top: auto; width: 1px; height: 1px; overflow: hidden; }
.skip-link:focus { left: 1rem; top: 1rem; width: auto; height: auto; padding: .5rem .75rem; background: #fff; border-radius: .375rem; box-shadow: 0 2px 8px rgba(0,0,0,.12); }
.container { max-width: 1100px; margin: 0 auto; padding: 0 1rem; }
.section { padding: 4rem 0; } .section.alt { background: #ffffff; }
.grid-2 { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 860px) { .grid-2 { grid-template-columns: 1.1fr .9fr; gap: 2rem; } }
.site-header { position: sticky; top: 0; z-index: 50; background: #0d4a3a; color: #fff; }
.site-header .nav { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.logo { display: inline-flex; align-items: center; gap: .5rem; color: #fff; text-decoration: none; font-weight: 800; letter-spacing: .2px; }
.menu { display: none; gap: 1rem; align-items: center; }
.menu a { color: #e6fff6; text-decoration: none; font-weight: 600; }
.menu .btn { color: #0d4a3a; background: #e6fff6; padding: .5rem .9rem; border-radius: .5rem; }
.nav-toggle { background: transparent; border: 0; color: #fff; font-size: 1.5rem; cursor: pointer; }
@media (min-width: 860px) { .nav-toggle { display: none; } .menu { display: flex; } }
.hero { background: radial-gradient(1200px 600px at 10% 10%, #116652 0%, #0d4a3a 40%, #0a342a 100%); color: #e8fff6; padding: 4.5rem 0 5rem; }
.hero-inner { text-align: center; }
.hero h1 { font-size: clamp(2rem, 3.5vw, 3rem); margin: 0 0 .5rem; }
.hero p { margin: 0 auto 1.25rem; max-width: 52ch; }
.hero-cta { display: flex; gap: .75rem; justify-content: center; flex-wrap: wrap; }
.card { background: #fff; border-radius: .75rem; box-shadow: 0 2px 10px rgba(0,0,0,.06); overflow: hidden; }
.map-embed iframe { width: 100%; height: 320px; border: 0; border-radius: .75rem; }
h2 { font-size: clamp(1.5rem, 2.5vw, 2rem); margin: 0 0 .75rem; }
h3 { margin: 0 0 .25rem; }
.checklist { padding-left: 1.25rem; } .checklist li { margin-bottom: .25rem; }
.note { margin-top: .5rem; font-size: .95rem; color: #1b3b31; }
.amenities { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: .75rem; }
.amenity { display: flex; gap: .5rem; align-items: center; background: #f2fbf8; border: 1px solid #e2f4ee; padding: .6rem .75rem; border-radius: .6rem; }
.amenity img { width: 22px; height: 22px; }
@media (min-width: 760px) { .amenities { grid-template-columns: repeat(3, minmax(0,1fr)); } }
.rates { display: grid; grid-template-columns: repeat(1, minmax(0,1fr)); gap: 1rem; }
.rate-card { padding: 1rem; text-align: center; }
.rate-card .price { font-size: 2rem; font-weight: 800; margin: .25rem 0 .5rem; }
@media (min-width: 760px) { .rates { grid-template-columns: repeat(3, minmax(0,1fr)); } }
label { display: grid; gap: .35rem; font-weight: 600; }
input, textarea { font: inherit; padding: .6rem .7rem; border: 1px solid #cfe3dc; border-radius: .5rem; background: #f9fdfb; }
.contact-form { padding: 1rem; display: grid; gap: .75rem; }
.site-footer { background: #0a342a; color: #cdeee3; }
.footer-inner { display: flex; flex-direction: column; gap: .5rem; align-items: center; justify-content: space-between; padding: 1.25rem 0; }
.footer-inner nav { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; text-align: center; }
.footer-inner a { color: #cdeee3; text-decoration: none; }
.btn { display: inline-flex; align-items: center; justify-content: center; padding: .7rem 1rem; border-radius: .6rem; background: #0d4a3a; color: #e6fff6; text-decoration: none; font-weight: 700; border: 2px solid transparent; }
.btn:hover { filter: brightness(1.05); } .btn.ghost { background: transparent; color: #0d4a3a; border-color: #0d4a3a; }
.fine-print { font-size: .9rem; color: #3c5b51; }
