* { box-sizing: border-box; }

:root {
--bg: #f4efe8;
--panel: #ffffff;
--text: #241f1b;
--muted: #675f58;
--dark: #2e2925;
--line: #e5ddd4;
--shadow: 0 12px 30px rgba(0,0,0,.08);
--radius: 20px;
}

html { scroll-behavior: smooth; }

body {
margin: 0;
font-family: Arial, Helvetica, sans-serif;
color: var(--text);
background: var(--bg);
line-height: 1.65;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

.container {
width: min(1180px, calc(100% - 40px));
margin: 0 auto;
}

.narrow-container,
.content-narrow {
width: min(860px, calc(100% - 40px));
margin: 0 auto;
}

.site-header {
position: sticky;
top: 0;
z-index: 50;
background: rgba(46, 41, 37, .95);
backdrop-filter: blur(10px);
color: #fff;
box-shadow: 0 8px 20px rgba(0,0,0,.10);
}

.header-inner {
display: flex;
gap: 12px;
justify-content: space-between;
align-items: center;
padding: 10px 0;
}

.logo {
font-size: 1rem;
font-weight: 700;
letter-spacing: .02em;
line-height: 1.1;
white-space: nowrap;
}

.main-nav {
display: flex;
gap: 10px;
flex-wrap: wrap;
justify-content: flex-end;
}

.main-nav a {
opacity: 1;
display: inline-flex;
align-items: center;
justify-content: center;
min-height: 38px;
padding: 8px 12px;
border-radius: 10px;
background: rgba(255,255,255,.08);
border: 1px solid rgba(255,255,255,.12);
color: #fff;
line-height: 1.2;
text-align: center;
transition: transform .2s ease, background .2s ease, border-color .2s ease;
}

.main-nav a:hover,
.main-nav a:focus-visible {
background: rgba(255,255,255,.16);
border-color: rgba(255,255,255,.24);
transform: translateY(-1px);
}

.hero,
.page-hero {
height: 440px;
display: flex;
align-items: end;
color: #fff;
background:
linear-gradient(rgba(0,0,0,.22), rgba(0,0,0,.56)),
var(--hero-image) center center / cover no-repeat;
}

.hero-content,
.hero-inner {
padding: 0 0 48px;
width: 100%;
max-width: 820px;
}

.hero-copy {
max-width: 820px;
}

.hero-eyebrow,
.eyebrow {
text-transform: uppercase;
letter-spacing: .12em;
font-size: .78rem;
opacity: .9;
margin-bottom: 14px;
}

.hero h1 {
margin: 0 0 14px;
font-size: clamp(2.5rem, 6vw, 4.8rem);
line-height: 1.03;
}

.hero p,
.hero-text {
margin: 0;
font-size: 1.1rem;
max-width: 700px;
}

.section {
padding: 56px 0;
}

.section-soft {
background: #efe7dd;
}

.section-heading {
margin-bottom: 22px;
}

.section-heading h2 {
margin: 0 0 8px;
}

.section-heading p {
margin: 0;
color: var(--muted);
}

.intro,
.content-panel,
.page-intro {
background: var(--panel);
border-radius: var(--radius);
box-shadow: var(--shadow);
}

.intro {
padding: 28px;
}

.intro h2,
.section h2 {
margin: 0 0 12px;
font-size: clamp(1.8rem, 4vw, 2.5rem);
}

.card-grid,
.room-grid {
display: grid;
grid-template-columns: repeat(4, 1fr);
gap: 22px;
}

.card {
display: block;
background: var(--panel);
border-radius: var(--radius);
overflow: hidden;
box-shadow: var(--shadow);
transition: transform .2s ease, box-shadow .2s ease;
}

.card:hover {
transform: translateY(-3px);
box-shadow: 0 16px 34px rgba(0,0,0,.12);
}

.card-image {
aspect-ratio: 4 / 3;
background: #d8d0c7;
}

.card-image img {
width: 100%;
height: 100%;
object-fit: cover;
}

.card-content {
padding: 18px;
}

.card-content h3 {
margin: 0 0 8px;
font-size: 1.2rem;
}

.card-content p {
margin: 0;
color: var(--muted);
}

.page-intro {
padding: 26px;
margin-top: -36px;
position: relative;
}

.page-intro p {
margin: .4rem 0 0;
color: var(--muted);
}

.room-header {
padding: 42px 0 18px;
}

.room-header h1 {
margin: 0 0 10px;
font-size: clamp(2.2rem, 5vw, 3.6rem);
}

.breadcrumbs {
font-size: .92rem;
color: var(--muted);
margin-bottom: 10px;
}

.content-panel {
padding: 24px;
}

.section-block + .section-block {
margin-top: 24px;
padding-top: 24px;
border-top: 1px solid var(--line);
}

.section-block h2 {
margin: 0 0 10px;
font-size: 1.35rem;
}

.gallery-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
gap: 14px;
}

.gallery-grid figure {
margin: 0;
background: #eee3d8;
border-radius: 14px;
overflow: hidden;
aspect-ratio: 4 / 3;
}

.gallery-grid a {
display: block;
width: 100%;
height: 100%;
cursor: zoom-in;
}

.gallery-grid img {
width: 100%;
height: 100%;
object-fit: cover;
transition: transform .2s ease;
}

.gallery-grid a:hover img {
transform: scale(1.03);
}

.embed-wrap {
position: relative;
padding-top: 56.25%;
border-radius: 18px;
overflow: hidden;
background: #000;
}

.embed-wrap iframe {
position: absolute;
inset: 0;
width: 100%;
height: 100%;
border: 0;
}

.lightbox-dialog {
border: none;
padding: 18px;
border-radius: 18px;
background: #171311;
color: #fff;
width: min(92vw, 1200px);
max-width: 1200px;
}

.lightbox-dialog::backdrop {
background: rgba(0,0,0,.82);
}

.lightbox-dialog img {
width: 100%;
height: auto;
max-height: 80vh;
object-fit: contain;
}

.lightbox-dialog p {
margin: 12px 0 0;
color: #ddd2c8;
}

.lightbox-close {
position: absolute;
top: 10px;
right: 12px;
width: 40px;
height: 40px;
border: none;
border-radius: 999px;
background: rgba(255,255,255,.12);
color: #fff;
font-size: 1.5rem;
cursor: pointer;
}

.site-footer {
margin-top: 60px;
background: var(--dark);
color: #fff;
padding: 28px 0;
}

.footer-grid {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 20px;
}

@media (max-width: 1080px) {
.card-grid,
.room-grid {
grid-template-columns: repeat(2, 1fr);
}
}

@media (max-width: 860px) {
.header-inner {
flex-direction: column;
align-items: stretch;
gap: 6px;
padding: 6px 0 8px;
}

.logo {
font-size: 0.82rem;
line-height: 1;
white-space: normal;
}

.main-nav {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 6px;
}

.main-nav a {
min-height: 27px;
padding: 4px 7px;
font-size: 0.78rem;
line-height: 1.1;
border-radius: 8px;
}

.main-nav a:last-child:nth-child(odd) {
grid-column: 1 / -1;
}

.hero,
.page-hero {
height: 320px;
}

.hero-content,
.hero-inner {
padding: 0 0 32px;
}
}

@media (max-width: 680px) {
.card-grid,
.room-grid,
.gallery-grid,
.footer-grid {
grid-template-columns: 1fr;
}

.hero,
.page-hero {
height: 260px;
}

.hero-content,
.hero-inner {
padding: 0 0 24px;
}

.hero h1 {
font-size: clamp(2.1rem, 10vw, 3.4rem);
}

.hero p,
.hero-text {
font-size: 0.98rem;
}

.card-content {
padding: 16px;
}
}

@media (max-width: 420px) {
.container,
.narrow-container,
.content-narrow {
width: min(100% - 24px, 1180px);
}

.header-inner {
gap: 5px;
padding: 5px 0 7px;
}

.logo {
font-size: 0.78rem;
}

.main-nav {
gap: 5px;
}

.main-nav a {
min-height: 25px;
padding: 3px 6px;
font-size: 0.74rem;
line-height: 1.05;
border-radius: 7px;
}

.hero,
.page-hero {
height: 220px;
}

.hero-content,
.hero-inner {
padding: 0 0 18px;
}

.section {
padding: 44px 0;
}

.intro,
.content-panel,
.page-intro {
padding: 20px;
}
}
