:root { --sage: #6f826e; --pine: #385247; --rose: #d1a6a2; --ink: #29332e; --line: rgba(41,51,46,0.12); }
* { box-sizing: border-box; }
body { margin: 0; color: var(--ink); font-family: Georgia, "Times New Roman", serif; background: radial-gradient(circle at top right, rgba(209,166,162,0.24), transparent 30%), linear-gradient(180deg, #fffaf3, #edf2ea 55%, #f3ecdf); }
a { color: inherit; }
.page-header, .welcome-row, .postcard, .details-ribbon, .visit-row { width: min(1220px, calc(100% - 1rem)); margin: 0 auto; }
.page-header { padding: 1rem 0; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.back-link, .switcher select, .crest-card, .welcome-copy, .postcard-note, .copy-card, .detail-card, .contact-card, .map-card { border: 1px solid var(--line); border-radius: 24px; }
.back-link { text-decoration: none; padding: 0.85rem 1rem; background: rgba(255,255,255,0.72); }
.switcher { display: grid; gap: 0.35rem; justify-items: end; font-family: "Trebuchet MS", Arial, sans-serif; font-size: 0.82rem; }
.switcher span, .eyebrow, figcaption { text-transform: uppercase; letter-spacing: 0.16em; font-weight: 800; color: var(--pine); font-family: "Trebuchet MS", Arial, sans-serif; }
.switcher select { min-width: min(360px,72vw); padding: 0.9rem 1rem; background: rgba(255,255,255,0.82); }
.inn-page { display: grid; gap: 1rem; padding-bottom: 2rem; }
.welcome-row { display: grid; grid-template-columns: 0.56fr 1.44fr; gap: 1rem; align-items: start; }
.crest-card, .welcome-copy, .postcard-note, .copy-card, .detail-card, .contact-card, .map-card { background: rgba(255,255,255,0.74); padding: 1.2rem; box-shadow: 0 24px 60px rgba(56,82,71,0.12); }
.crest-card img, .hero-image, .detail-card img { width: 100%; object-fit: cover; border-radius: 18px; background: linear-gradient(135deg, #e7ddd0, #cbd7c9); }
.crest-card img { aspect-ratio: 1 / 1; margin-top: 0.6rem; }
h1, h2 { margin: 0 0 0.8rem; line-height: 0.95; overflow-wrap: anywhere; color: #26352f; }
h1 { font-size: clamp(3rem, 7vw, 6rem); max-width: 10ch; }
h2 { font-size: clamp(1.8rem, 3vw, 3rem); }
p, span { line-height: 1.75; overflow-wrap: anywhere; }
.postcard { display: grid; grid-template-columns: 1.2fr 0.8fr; gap: 1rem; align-items: stretch; }
.hero-image { min-height: 500px; }
.postcard-note { display: grid; align-content: start; }
.hours-list { display: grid; gap: 0.6rem; margin-top: 1rem; }
.hours-list span { display: inline-flex; width: fit-content; padding: 0.65rem 0.85rem; border-radius: 999px; background: rgba(111,130,110,0.12); }
.details-ribbon { display: grid; grid-template-columns: 1fr 0.78fr 0.78fr 0.78fr; gap: 1rem; align-items: start; }
.detail-card img { min-height: 230px; }
.visit-row { display: grid; grid-template-columns: 1fr 0.9fr; gap: 1rem; }
.map-card { position: relative; min-height: 280px; overflow: hidden; background: linear-gradient(135deg, rgba(255,255,255,0.9), rgba(111,130,110,0.16)); }
.map-grid { position: absolute; inset: 0; background: linear-gradient(90deg, transparent 0 24%, rgba(56,82,71,0.14) 24% 28%, transparent 28% 52%, rgba(56,82,71,0.14) 52% 56%, transparent 56%), linear-gradient(transparent 0 20%, rgba(56,82,71,0.14) 20% 24%, transparent 24% 58%, rgba(56,82,71,0.14) 58% 62%, transparent 62%); }
.pin { position: absolute; top: 44%; left: 58%; width: 20px; height: 20px; border-radius: 50%; background: var(--rose); box-shadow: 0 0 0 10px rgba(209,166,162,0.2); }
.map-card span { position: absolute; left: 1rem; bottom: 1rem; padding: 0.55rem 0.8rem; border-radius: 999px; background: rgba(255,255,255,0.84); }
@media (max-width: 920px) { .page-header, .welcome-row, .postcard, .details-ribbon, .visit-row { grid-template-columns: 1fr; display: grid; } .switcher { justify-items: start; } }
