:root {
    --white: #FFFFFF;
    --bg: #FAF6EE;
    --bg-soft: #F2EBDB;
    --bg-deep: #EBE2CC;
    --ink: #1F1B16;
    --ink-soft: #5A5147;
    --ink-mute: #8E867B;
    --sand: #C5A572;
    --sand-soft: #DCC59A;
    --sand-pale: #ECDDBE;
    --sand-dark: #9A7E4D;
    --moss: #2F4A3A;
    --moss-soft: #4A6852;
    --moss-dark: #1F3327;
    --line: rgba(31, 27, 22, 0.10);
    --line-mid: rgba(31, 27, 22, 0.18);
    --line-sand: rgba(197, 165, 114, 0.4);
    --line-light: rgba(255, 255, 255, 0.15);

    --body-font: 'Manrope', sans-serif;
    --heading-font: 'Cormorant Garamond', serif;

    --container: 1320px;
    --section-pad: 7rem 5%;
    --rounded: 8px;
    --rounded-lg: 18px;
    --rounded-pill: 999px;
    --shadow-soft: 0 10px 28px -18px rgba(31, 27, 22, 0.18);
    --shadow: 0 24px 50px -28px rgba(31, 27, 22, 0.35), 0 8px 20px -14px rgba(31, 27, 22, 0.12);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    font-family: var(--body-font);
    background-color: var(--bg);
    color: var(--ink-soft);
    line-height: 1.7;
    font-size: 16px;
    -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

h1, h2, h3, h4, h5 {
    font-family: var(--heading-font);
    font-weight: 500;
    color: var(--ink);
    line-height: 1.15;
    letter-spacing: -0.5px;
}
h1 { font-size: clamp(2.6rem, 5.5vw, 4.4rem); }
h2 { font-size: clamp(2rem, 4vw, 3.2rem); }
h3 { font-size: 1.75rem; }
h4 { font-size: 1.25rem; font-weight: 500; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 5%; }
.container-narrow { max-width: 880px; margin: 0 auto; padding: 0 5%; }

/* ============================================================
   TOP BAR
   ============================================================ */
.top-bar { background: var(--moss); color: rgba(255, 255, 255, 0.7); font-size: 0.82rem; }
.top-bar-inner { max-width: var(--container); margin: 0 auto; padding: 0.7rem 5%; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; }
.top-info { display: flex; gap: 2rem; flex-wrap: wrap; }
.top-info span { display: inline-flex; align-items: center; gap: 0.5rem; }
.top-info .ico { color: var(--sand-soft); }
.top-info a { color: inherit; }
.top-info a:hover { color: var(--sand-soft); }
.top-socials { display: flex; gap: 0.7rem; }
.top-socials a { color: rgba(255, 255, 255, 0.75); transition: color 0.2s; }
.top-socials a:hover { color: var(--sand-soft); }

/* ============================================================
   HEADER
   ============================================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(250, 246, 238, 0.96);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    border-bottom: 1px solid var(--line);
}
.site-header-inner { max-width: var(--container); margin: 0 auto; padding: 1.4rem 5%; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.brand { font-family: var(--heading-font); font-size: 2rem; color: var(--ink); letter-spacing: 0; }
.brand em { font-style: italic; color: var(--sand-dark); }
.main-nav { display: flex; align-items: center; gap: 2.2rem; }
.main-nav a { color: var(--ink); font-size: 0.92rem; font-weight: 500; letter-spacing: 0.5px; transition: color 0.2s; position: relative; }
.main-nav a:hover { color: var(--sand-dark); }
.header-meta { display: flex; align-items: center; gap: 1.5rem; }
.header-meta .meta-item { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.85rem; color: var(--ink-soft); }
.header-meta .meta-item .ico { color: var(--sand-dark); font-size: 1.1rem; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    padding: 1rem 2rem;
    border-radius: var(--rounded-pill);
    font-size: 0.85rem;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    text-decoration: none;
    transition: all 0.3s ease;
    border: 1px solid transparent;
    cursor: pointer;
    font-family: var(--body-font);
}
.btn-primary { background: var(--sand); color: var(--ink); }
.btn-primary:hover { background: var(--moss); color: var(--white); }
.btn-moss { background: var(--moss); color: var(--white); }
.btn-moss:hover { background: var(--sand); color: var(--ink); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--white); }
.btn-light { background: rgba(255, 255, 255, 0.15); color: var(--white); border-color: rgba(255, 255, 255, 0.3); backdrop-filter: blur(8px); }
.btn-light:hover { background: var(--white); color: var(--ink); border-color: transparent; }
.btn .arrow { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 50%; background: rgba(0, 0, 0, 0.08); font-size: 0.85rem; transition: transform 0.3s; }
.btn-primary:hover .arrow, .btn-moss:hover .arrow { background: rgba(255, 255, 255, 0.2); }
.btn:hover .arrow { transform: rotate(-45deg); }

/* ============================================================
   EYEBROW
   ============================================================ */
.eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 0.7rem;
    font-size: 0.78rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--sand-dark);
    font-weight: 600;
    margin-bottom: 1.2rem;
    font-family: var(--body-font);
}
.eyebrow::before { content: '◆'; font-size: 0.6rem; color: var(--sand); }
.eyebrow.center { justify-content: center; }
.eyebrow.center::after { content: '◆'; font-size: 0.6rem; color: var(--sand); }

/* Decorative SVG shape backgrounds */
.deco-shape-left, .deco-shape-right {
    position: absolute;
    pointer-events: none;
    z-index: 0;
    opacity: 0.45;
}
.deco-shape-left { left: -30px; top: 10%; width: 180px; height: 180px; }
.deco-shape-right { right: -30px; bottom: 15%; width: 220px; height: 220px; }

/* ============================================================
   SECTION
   ============================================================ */
.section { padding: var(--section-pad); position: relative; }
.section.tight { padding: 4rem 5%; }
.section.bg-deep { background: var(--bg-deep); }
.section.bg-soft { background: var(--bg-soft); }
.section.bg-white { background: var(--white); }
.section.bg-moss { background: var(--moss); color: rgba(255, 255, 255, 0.78); }
.section.bg-moss h1, .section.bg-moss h2, .section.bg-moss h3, .section.bg-moss h4 { color: var(--white); }

.sec-head { max-width: 760px; margin: 0 auto 4rem; text-align: center; position: relative; z-index: 1; }
.sec-head.left { text-align: left; margin: 0 0 3.5rem; max-width: 720px; }
.sec-head h2 em { font-style: italic; color: var(--sand-dark); }
.sec-head p { margin-top: 1.2rem; line-height: 1.85; color: var(--ink-soft); }
.section.bg-moss .sec-head p { color: rgba(255, 255, 255, 0.7); }

/* ============================================================
   HERO STATIC
   ============================================================ */
.hero-static {
    min-height: 88vh;
    display: flex;
    align-items: center;
    background-size: cover;
    background-position: center;
    position: relative;
    color: var(--white);
}
.hero-static::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31, 27, 22, 0.3) 0%, rgba(31, 27, 22, 0.7) 100%); }
.hero-static .hero-inner { position: relative; z-index: 1; max-width: var(--container); margin: 0 auto; padding: 5rem 5%; width: 100%; }
.hero-static.center .hero-inner { text-align: center; }
.hero-static .eyebrow { color: var(--sand-soft); }
.hero-static .eyebrow::before { color: var(--sand-soft); }
.hero-static.center .eyebrow { justify-content: center; }
.hero-static.center .eyebrow::after { content: '◆'; font-size: 0.6rem; color: var(--sand-soft); }
.hero-static h1 { color: var(--white); font-size: clamp(2.8rem, 7vw, 5.4rem); max-width: 920px; margin-bottom: 1.5rem; font-weight: 500; }
.hero-static.center h1 { margin: 0 auto 1.5rem; }
.hero-static h1 em { font-style: italic; color: var(--sand-soft); }
.hero-static .lede { color: rgba(255, 255, 255, 0.88); max-width: 600px; line-height: 1.85; font-size: 1.08rem; }
.hero-static.center .lede { margin: 0 auto; }
.hero-actions { margin-top: 2.6rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-static.center .hero-actions { justify-content: center; }

/* HERO SLIDER */
.hero-swiper { min-height: 90vh; position: relative; }
.hero-swiper .swiper-slide { min-height: 90vh; display: flex; align-items: center; background-size: cover; background-position: center; position: relative; }
.hero-swiper .swiper-slide::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31, 27, 22, 0.3) 0%, rgba(31, 27, 22, 0.7) 100%); }
.hero-swiper .slide-inner { position: relative; z-index: 1; max-width: var(--container); margin: 0 auto; padding: 5rem 5%; width: 100%; color: var(--white); }
.hero-swiper h1 { color: var(--white); font-size: clamp(2.8rem, 7vw, 5.4rem); max-width: 920px; margin-bottom: 1.5rem; font-weight: 500; }
.hero-swiper h1 em { font-style: italic; color: var(--sand-soft); }
.hero-swiper .lede { color: rgba(255, 255, 255, 0.88); max-width: 600px; line-height: 1.85; font-size: 1.08rem; }
.hero-swiper .slide-actions { margin-top: 2.6rem; display: flex; gap: 1rem; flex-wrap: wrap; }
.hero-swiper .swiper-pagination { bottom: 2rem !important; }
.hero-swiper .swiper-pagination-bullet { background: var(--white); opacity: 0.45; width: 12px; height: 12px; transition: all 0.3s; }
.hero-swiper .swiper-pagination-bullet-active { background: var(--sand); opacity: 1; width: 36px; border-radius: 6px; }

/* ============================================================
   HERO BOOKING (in-hero widget — Hotelo signature)
   ============================================================ */
.hero-booking { max-width: var(--container); margin: -3rem auto 0; padding: 0 5%; position: relative; z-index: 10; }
.hero-booking-inner { background: var(--white); border-radius: var(--rounded-lg); box-shadow: var(--shadow); padding: 1.8rem; display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.2rem; align-items: end; }
.hero-booking .bw-field label { display: block; font-size: 0.7rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 0.4rem; font-weight: 600; }
.hero-booking input, .hero-booking select { width: 100%; padding: 0.85rem 1rem; border: 1px solid var(--line-mid); background: var(--bg); font-family: var(--body-font); font-size: 0.92rem; color: var(--ink); border-radius: var(--rounded); }
.hero-booking input:focus, .hero-booking select:focus { outline: none; border-color: var(--sand); }
.hero-booking .btn { width: 100%; justify-content: center; }

/* ============================================================
   ABOUT INTRO (image pairs + stat blocks)
   ============================================================ */
.about-intro { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; gap: 5rem; align-items: center; }
.about-intro.reverse > .ai-visual { order: 2; }
.ai-visual { position: relative; aspect-ratio: 4 / 5; }
.ai-visual .ph-main { position: absolute; inset: 0; background-size: cover; background-position: center; border-radius: var(--rounded-lg); background-color: var(--bg-soft); }
.ai-visual .ph-mini { position: absolute; bottom: -3rem; right: -3rem; width: 50%; aspect-ratio: 4 / 3; background-size: cover; background-position: center; border-radius: var(--rounded-lg); border: 10px solid var(--bg); box-shadow: var(--shadow); }
.ai-text h2 em { font-style: italic; color: var(--sand-dark); }
.ai-text > p { margin: 1.5rem 0; line-height: 1.85; }
.ai-quote {
    padding: 1.5rem 2rem;
    border-left: 4px solid var(--sand);
    background: var(--bg-soft);
    margin: 2rem 0;
    font-family: var(--heading-font);
    font-style: italic;
    font-size: 1.25rem;
    line-height: 1.6;
    color: var(--ink);
}
.ai-quote-author { margin-top: 1.2rem; display: flex; align-items: center; gap: 1rem; font-size: 0.85rem; }
.ai-quote-author .name { font-family: var(--heading-font); font-style: italic; font-size: 1.1rem; color: var(--ink); }
.ai-quote-author .role { color: var(--sand-dark); letter-spacing: 1.5px; text-transform: uppercase; font-size: 0.72rem; font-weight: 600; }

/* ============================================================
   STAT BLOCKS (oversized numerals — Hotelo-distinctive)
   ============================================================ */
.stat-blocks {
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
}
.stat-block {
    padding: 3rem 2rem;
    border-right: 1px solid var(--line);
    text-align: center;
}
.stat-block:last-child { border-right: none; }
.stat-block .num {
    font-family: var(--heading-font);
    font-size: clamp(3.4rem, 6vw, 5rem);
    font-weight: 500;
    color: var(--sand-dark);
    line-height: 1;
    margin-bottom: 0.6rem;
    letter-spacing: -1px;
}
.stat-block .num em { font-style: italic; color: var(--moss); }
.stat-block .lbl {
    font-size: 0.78rem;
    letter-spacing: 2px;
    text-transform: uppercase;
    color: var(--ink-soft);
    font-weight: 600;
}
.stat-block .desc {
    margin-top: 0.4rem;
    font-size: 0.85rem;
    color: var(--ink-mute);
}

/* ============================================================
   ROOMS GRID
   ============================================================ */
.rooms-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.room-card {
    background: var(--white);
    border-radius: var(--rounded-lg);
    overflow: hidden;
    transition: all 0.4s;
    text-decoration: none;
    color: inherit;
    display: block;
    border: 1px solid var(--line);
}
.room-card:hover { transform: translateY(-6px); box-shadow: var(--shadow); border-color: var(--sand); }
.room-card .ph { aspect-ratio: 4 / 3; background-size: cover; background-position: center; background-color: var(--bg-soft); position: relative; overflow: hidden; }
.room-card .ph::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(31, 27, 22, 0.65) 100%); opacity: 0; transition: opacity 0.3s; }
.room-card:hover .ph::after { opacity: 1; }
.room-card .badge {
    position: absolute;
    top: 1rem;
    left: 1rem;
    background: var(--sand);
    color: var(--ink);
    padding: 0.4rem 1rem;
    border-radius: var(--rounded-pill);
    font-size: 0.7rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    font-weight: 700;
    z-index: 1;
}
.room-card .price-tag {
    position: absolute;
    bottom: 1rem;
    left: 1rem;
    background: var(--white);
    color: var(--ink);
    padding: 0.6rem 1.1rem;
    border-radius: var(--rounded-pill);
    font-family: var(--heading-font);
    font-size: 1.1rem;
    z-index: 1;
}
.room-card .price-tag small { font-family: var(--body-font); font-size: 0.72rem; color: var(--ink-soft); margin-left: 0.2rem; letter-spacing: 1px; }
.room-card .info { padding: 1.8rem; }
.room-card h3 { color: var(--ink); margin-bottom: 0.7rem; font-size: 1.6rem; }
.room-card .specs { display: flex; gap: 1.3rem; padding-top: 1.1rem; border-top: 1px solid var(--line); font-size: 0.82rem; color: var(--ink-soft); flex-wrap: wrap; }
.room-card .specs span { display: inline-flex; align-items: center; gap: 0.35rem; }
.room-card .specs span::before { content: '◆'; color: var(--sand); font-size: 0.55rem; }
.room-card .book { display: inline-block; margin-top: 1.3rem; font-size: 0.78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-dark); font-weight: 700; border-bottom: 1px solid var(--sand); padding-bottom: 2px; }

/* ============================================================
   WHY CHOOSE US (4-tile benefits)
   ============================================================ */
.benefits-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem; }
.benefit-tile {
    background: var(--white);
    border-radius: var(--rounded-lg);
    padding: 2.5rem 1.8rem;
    text-align: center;
    border: 1px solid var(--line);
    transition: all 0.3s;
}
.benefit-tile:hover { transform: translateY(-4px); box-shadow: var(--shadow-soft); border-color: var(--sand); }
.benefit-tile .ico {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--bg-soft);
    color: var(--sand-dark);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 1.6rem;
    margin-bottom: 1.4rem;
    transition: all 0.3s;
}
.benefit-tile:hover .ico { background: var(--sand); color: var(--white); }
.benefit-tile h4 { margin-bottom: 0.6rem; }
.benefit-tile p { font-size: 0.9rem; line-height: 1.7; }

/* ============================================================
   FACILITIES (4-up mixed-size — Hotelo variant)
   ============================================================ */
.facilities-mixed { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: 1.4fr 1fr 1fr; grid-template-rows: 1fr 1fr; gap: 1.5rem; min-height: 600px; }
.facility-tile-mixed {
    position: relative;
    border-radius: var(--rounded-lg);
    overflow: hidden;
    background-size: cover;
    background-position: center;
    background-color: var(--bg-soft);
    color: var(--white);
    text-decoration: none;
    display: block;
    transition: transform 0.4s;
}
.facility-tile-mixed:hover { transform: translateY(-4px); }
.facility-tile-mixed::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 45%, rgba(31, 27, 22, 0.85) 100%); }
.facility-tile-mixed:nth-child(1) { grid-row: 1 / 3; }
.facility-tile-mixed .info { position: absolute; bottom: 1.6rem; left: 1.6rem; right: 1.6rem; z-index: 1; }
.facility-tile-mixed .lbl { font-size: 0.72rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-soft); margin-bottom: 0.5rem; font-weight: 600; }
.facility-tile-mixed h3 { color: var(--white); font-size: 1.4rem; margin: 0; }

/* ============================================================
   MARQUEE (Hotelo-distinctive — repeating tag text)
   ============================================================ */
.marquee {
    overflow: hidden;
    background: var(--moss);
    color: var(--white);
    padding: 1.8rem 0;
    border-top: 1px solid var(--line-light);
    border-bottom: 1px solid var(--line-light);
}
.marquee.bg-sand { background: var(--sand); color: var(--ink); }
.marquee.bg-bg-soft { background: var(--bg-soft); color: var(--ink); }
.marquee-track {
    display: flex;
    gap: 4rem;
    white-space: nowrap;
    animation: marquee-scroll 30s linear infinite;
    width: fit-content;
}
.marquee-item {
    font-family: var(--heading-font);
    font-style: italic;
    font-size: clamp(1.8rem, 3.5vw, 3.2rem);
    line-height: 1;
    display: inline-flex;
    align-items: center;
    gap: 4rem;
}
.marquee-item::after { content: '◆'; font-size: 0.6em; opacity: 0.6; }
@keyframes marquee-scroll {
    from { transform: translateX(0); }
    to { transform: translateX(-50%); }
}
.marquee:hover .marquee-track { animation-play-state: paused; }

/* ============================================================
   CTA TRIPLE BANNER (Hotelo-distinctive — 3 stacked promos)
   ============================================================ */
.cta-triple { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.cta-banner {
    position: relative;
    aspect-ratio: 4 / 5;
    border-radius: var(--rounded-lg);
    overflow: hidden;
    background-size: cover;
    background-position: center;
    background-color: var(--bg-soft);
    color: var(--white);
    text-decoration: none;
    display: block;
    transition: transform 0.4s;
}
.cta-banner:hover { transform: translateY(-4px); }
.cta-banner::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31, 27, 22, 0.2) 0%, rgba(31, 27, 22, 0.85) 100%); transition: background 0.3s; }
.cta-banner:hover::after { background: linear-gradient(180deg, rgba(31, 27, 22, 0.35) 0%, rgba(31, 27, 22, 0.9) 100%); }
.cta-banner .inner { position: absolute; bottom: 2rem; left: 2rem; right: 2rem; z-index: 1; }
.cta-banner .eb { font-size: 0.72rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-soft); margin-bottom: 0.5rem; font-weight: 600; }
.cta-banner h3 { color: var(--white); font-size: 1.8rem; line-height: 1.2; margin-bottom: 0.6rem; }
.cta-banner h3 em { font-style: italic; color: var(--sand-soft); }
.cta-banner p { color: rgba(255, 255, 255, 0.85); font-size: 0.92rem; margin-bottom: 1rem; line-height: 1.6; }
.cta-banner .cta { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 0.78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-soft); font-weight: 700; border-bottom: 1px solid var(--sand-soft); padding-bottom: 2px; }

/* ============================================================
   VIDEO + TAG CAROUSEL
   ============================================================ */
.video-section {
    position: relative;
    min-height: 540px;
    background-size: cover;
    background-position: center;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--white);
}
.video-section::before { content: ''; position: absolute; inset: 0; background: rgba(31, 27, 22, 0.5); }
.video-inner { position: relative; z-index: 1; text-align: center; max-width: 720px; padding: 0 5%; }
.video-inner h2 { color: var(--white); margin-bottom: 1.4rem; }
.video-inner h2 em { font-style: italic; color: var(--sand-soft); }
.video-inner p { color: rgba(255, 255, 255, 0.85); margin-bottom: 2rem; }
.play-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 96px;
    height: 96px;
    border-radius: 50%;
    background: var(--sand);
    color: var(--ink);
    margin: 0 auto 1.5rem;
    transition: all 0.3s;
    box-shadow: 0 0 0 10px rgba(197, 165, 114, 0.22);
    text-decoration: none;
}
.play-btn:hover { transform: scale(1.08); box-shadow: 0 0 0 16px rgba(197, 165, 114, 0.35); }
.play-btn::after { content: '▶'; font-size: 1.5rem; margin-left: 5px; }

/* ============================================================
   TEAM GRID
   ============================================================ */
.team-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.team-card {
    text-align: center;
    transition: transform 0.4s;
}
.team-card:hover { transform: translateY(-4px); }
.team-card .ph { aspect-ratio: 4 / 5; background-size: cover; background-position: center; background-color: var(--bg-soft); border-radius: var(--rounded-lg); margin-bottom: 1.2rem; position: relative; overflow: hidden; }
.team-card .socials {
    position: absolute;
    bottom: 1.2rem;
    left: 50%;
    transform: translateX(-50%) translateY(20px);
    display: flex;
    gap: 0.5rem;
    opacity: 0;
    transition: all 0.3s;
}
.team-card:hover .socials { transform: translateX(-50%) translateY(0); opacity: 1; }
.team-card .socials a { width: 36px; height: 36px; border-radius: 50%; background: var(--white); color: var(--ink); display: inline-flex; align-items: center; justify-content: center; font-size: 0.85rem; }
.team-card .socials a:hover { background: var(--sand); color: var(--white); }
.team-card h4 { font-size: 1.4rem; margin-bottom: 0.3rem; }
.team-card .role { font-size: 0.78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-dark); font-weight: 600; }

/* ============================================================
   TESTIMONIALS CAROUSEL
   ============================================================ */
.testimonials-wrap { max-width: var(--container); margin: 0 auto; position: relative; }
.swiper.testimonial-swiper { padding-bottom: 4rem; }
.testimonial-card {
    background: var(--white);
    border-radius: var(--rounded-lg);
    padding: 3rem 2.5rem;
    border: 1px solid var(--line);
    position: relative;
}
.testimonial-card::before {
    content: '"';
    font-family: var(--heading-font);
    position: absolute;
    top: -10px;
    right: 2rem;
    font-size: 7rem;
    color: var(--sand);
    opacity: 0.25;
    line-height: 1;
}
.testimonial-card .stars { color: var(--sand-dark); letter-spacing: 3px; margin-bottom: 1.2rem; font-size: 1.1rem; }
.testimonial-card .quote { font-family: var(--heading-font); font-size: 1.3rem; line-height: 1.55; color: var(--ink); margin-bottom: 1.8rem; font-style: italic; }
.testimonial-card .who { display: flex; align-items: center; gap: 1rem; padding-top: 1.5rem; border-top: 1px solid var(--line); }
.testimonial-card .avatar { width: 56px; height: 56px; border-radius: 50%; background: var(--bg-soft); color: var(--sand-dark); display: flex; align-items: center; justify-content: center; font-family: var(--heading-font); font-size: 1.4rem; background-size: cover; flex-shrink: 0; }
.testimonial-card .name { font-family: var(--heading-font); font-size: 1.2rem; color: var(--ink); }
.testimonial-card .place { font-size: 0.78rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sand-dark); margin-top: 0.2rem; font-weight: 600; }
.swiper-pagination-bullet { background: var(--sand) !important; }

/* ============================================================
   PRICING TIERS
   ============================================================ */
.pricing-grid { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.pricing-card {
    background: var(--white);
    border-radius: var(--rounded-lg);
    padding: 2.8rem 2.2rem;
    border: 1px solid var(--line);
    text-align: center;
    transition: all 0.3s;
}
.pricing-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.pricing-card.featured { border-color: var(--sand); transform: scale(1.04); box-shadow: var(--shadow); position: relative; }
.pricing-card.featured::before { content: 'Most Popular'; position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: var(--sand); color: var(--ink); padding: 0.4rem 1rem; border-radius: var(--rounded-pill); font-size: 0.7rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700; }
.pricing-card .tier { font-size: 0.78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-dark); margin-bottom: 1rem; font-weight: 600; }
.pricing-card .price { font-family: var(--heading-font); font-size: 3.4rem; color: var(--ink); line-height: 1; margin-bottom: 0.4rem; }
.pricing-card .price small { font-family: var(--body-font); font-size: 0.85rem; color: var(--ink-soft); }
.pricing-card .desc { color: var(--ink-soft); font-size: 0.92rem; margin-bottom: 2rem; }
.pricing-card ul { list-style: none; margin: 0 0 2rem; padding: 1.5rem 0 0; border-top: 1px solid var(--line); }
.pricing-card li { padding: 0.6rem 0; font-size: 0.92rem; color: var(--ink-soft); display: flex; align-items: center; gap: 0.6rem; justify-content: center; }
.pricing-card li::before { content: '✓'; color: var(--sand-dark); font-weight: 700; }
.pricing-card .btn { width: 100%; justify-content: center; }

/* ============================================================
   BLOG GRID
   ============================================================ */
.blog-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem; }
.post-card {
    background: var(--white);
    border-radius: var(--rounded-lg);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    border: 1px solid var(--line);
    transition: all 0.3s;
    display: block;
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); border-color: var(--sand); }
.post-card .ph { aspect-ratio: 16 / 10; background-size: cover; background-position: center; background-color: var(--bg-soft); position: relative; }
.post-card .date-tag { position: absolute; bottom: 1rem; left: 1rem; background: var(--sand); color: var(--ink); padding: 0.6rem 1rem; border-radius: var(--rounded); text-align: center; font-family: var(--heading-font); font-weight: 600; }
.post-card .date-tag .day { display: block; font-size: 1.4rem; line-height: 1; }
.post-card .date-tag .mon { display: block; font-size: 0.7rem; letter-spacing: 1.5px; text-transform: uppercase; font-family: var(--body-font); margin-top: 0.2rem; }
.post-card .body { padding: 1.7rem; }
.post-card .meta { font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sand-dark); margin-bottom: 0.6rem; font-weight: 700; display: flex; gap: 1rem; }
.post-card h3 { font-size: 1.3rem; color: var(--ink); line-height: 1.35; margin-bottom: 0.6rem; }
.post-card .more { font-size: 0.78rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand-dark); font-weight: 700; }

/* ============================================================
   IG GRID
   ============================================================ */
.ig-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(9, 1fr); gap: 4px; }
.ig-tile { aspect-ratio: 1; background-size: cover; background-position: center; background-color: var(--bg-soft); position: relative; overflow: hidden; transition: transform 0.4s; display: block; }
.ig-tile::after { content: ''; position: absolute; inset: 0; background: rgba(197, 165, 114, 0.7); opacity: 0; transition: opacity 0.3s; }
.ig-tile::before { content: '◯'; position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: var(--white); font-size: 2rem; z-index: 1; opacity: 0; transition: opacity 0.3s; font-weight: 700; }
.ig-tile:hover::after, .ig-tile:hover::before { opacity: 1; }

/* ============================================================
   GALLERY (filterable)
   ============================================================ */
.gallery-filters { display: flex; justify-content: center; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 3rem; }
.gallery-filter { padding: 0.7rem 1.5rem; background: transparent; border: 1px solid var(--line-mid); border-radius: var(--rounded-pill); font-size: 0.78rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink); cursor: pointer; font-family: var(--body-font); font-weight: 600; transition: all 0.3s; }
.gallery-filter.active, .gallery-filter:hover { background: var(--sand); color: var(--ink); border-color: var(--sand); }
.gallery-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.8rem; }
.gallery-item { position: relative; aspect-ratio: 4 / 5; overflow: hidden; border-radius: var(--rounded-lg); background-size: cover; background-position: center; transition: transform 0.4s; }
.gallery-item.tall { grid-row: span 2; aspect-ratio: 4 / 7; }
.gallery-item.wide { grid-column: span 2; aspect-ratio: auto; }
.gallery-item:hover { transform: scale(1.02); }
.gallery-item::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 50%, rgba(31, 27, 22, 0.65) 100%); opacity: 0; transition: opacity 0.3s; }
.gallery-item:hover::after { opacity: 1; }
.gallery-item.hidden { display: none; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; align-items: start; }
.contact-info-list { list-style: none; }
.contact-info-list li { display: flex; gap: 1.2rem; align-items: flex-start; padding: 1.4rem 0; border-bottom: 1px solid var(--line); }
.contact-info-list .ico { width: 50px; height: 50px; border-radius: 50%; background: var(--bg-soft); color: var(--sand-dark); display: inline-flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.contact-info-list .lbl { font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sand-dark); margin-bottom: 0.3rem; font-weight: 700; }
.contact-info-list .val { font-family: var(--heading-font); font-size: 1.3rem; color: var(--ink); line-height: 1.4; }
.contact-info-list a { color: inherit; text-decoration: none; }
.contact-info-list a:hover { color: var(--sand-dark); }

.contact-form-wrap { background: var(--white); padding: 3rem; border-radius: var(--rounded-lg); border: 1px solid var(--line); }
.contact-form-wrap label { display: block; font-size: 0.72rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-soft); margin-bottom: 0.5rem; font-weight: 600; }
.contact-form-wrap input, .contact-form-wrap select, .contact-form-wrap textarea {
    width: 100%;
    padding: 0.95rem 1rem;
    border: 1px solid var(--line-mid);
    background: var(--bg);
    font-family: var(--body-font);
    font-size: 0.95rem;
    color: var(--ink);
    border-radius: var(--rounded);
    margin-bottom: 1.2rem;
    transition: border-color 0.3s;
}
.contact-form-wrap input:focus, .contact-form-wrap select:focus, .contact-form-wrap textarea:focus { outline: none; border-color: var(--sand); }
.contact-form-wrap textarea { resize: vertical; min-height: 140px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list { max-width: 800px; margin: 0 auto; }
.faq-item {
    border: 1px solid var(--line);
    border-radius: var(--rounded);
    margin-bottom: 1rem;
    background: var(--white);
    transition: border-color 0.3s;
}
.faq-item[open] { border-color: var(--sand); }
.faq-item summary {
    font-family: var(--heading-font);
    font-size: 1.3rem;
    cursor: pointer;
    list-style: none;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 1rem;
    color: var(--ink);
    padding: 1.5rem 2rem;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: '+'; font-size: 1.8rem; color: var(--sand-dark); transition: transform 0.3s; font-weight: 300; line-height: 0.8; }
.faq-item[open] summary::after { transform: rotate(45deg); }
.faq-item p { padding: 0 2rem 1.5rem; color: var(--ink-soft); line-height: 1.8; }

/* ============================================================
   NEWSLETTER
   ============================================================ */
.newsletter {
    background: var(--moss);
    color: var(--white);
    padding: 5rem 5%;
    text-align: center;
    border-radius: var(--rounded-lg);
    background-size: cover;
    background-position: center;
    position: relative;
    overflow: hidden;
    max-width: var(--container);
    margin: 0 auto;
}
.newsletter::before { content: ''; position: absolute; inset: 0; background: rgba(31, 51, 39, 0.88); }
.newsletter > * { position: relative; z-index: 1; }
.newsletter h2 { color: var(--white); margin-bottom: 1rem; }
.newsletter h2 em { font-style: italic; color: var(--sand-soft); }
.newsletter p { color: rgba(255, 255, 255, 0.78); margin-bottom: 2rem; max-width: 540px; margin-left: auto; margin-right: auto; }
.newsletter-form { max-width: 560px; margin: 0 auto; display: flex; gap: 0.6rem; flex-wrap: wrap; }
.newsletter-form input { flex: 1; padding: 1.1rem 1.4rem; border: 1px solid rgba(255, 255, 255, 0.2); background: rgba(255, 255, 255, 0.08); color: var(--white); font-family: var(--body-font); border-radius: var(--rounded-pill); min-width: 220px; }
.newsletter-form input::placeholder { color: rgba(255, 255, 255, 0.5); }

/* ============================================================
   PAGE HEADER
   ============================================================ */
.page-header {
    background: var(--moss);
    color: var(--white);
    padding: 6rem 5% 4.5rem;
    text-align: center;
    background-size: cover;
    background-position: center;
    position: relative;
}
.page-header::before { content: ''; position: absolute; inset: 0; background: rgba(31, 51, 39, 0.78); }
.page-header > * { position: relative; z-index: 1; }
.page-header h1 { color: var(--white); margin-bottom: 0.8rem; font-size: clamp(2.4rem, 5vw, 3.6rem); }
.page-header .breadcrumb { display: inline-flex; gap: 0.6rem; font-size: 0.82rem; letter-spacing: 1.5px; text-transform: uppercase; color: rgba(255, 255, 255, 0.78); font-weight: 600; }
.page-header .breadcrumb a { color: rgba(255, 255, 255, 0.78); }
.page-header .breadcrumb a:hover { color: var(--sand-soft); }
.page-header .breadcrumb .sep { color: var(--sand-soft); }

/* ============================================================
   ROOM SINGLE (with booking sidebar + extras calc)
   ============================================================ */
.room-single { max-width: var(--container); margin: 0 auto; padding: 4rem 5%; }
.room-gallery-swiper { margin-bottom: 1rem; border-radius: var(--rounded-lg); overflow: hidden; }
.room-gallery-swiper .swiper-slide { aspect-ratio: 16 / 9; background-size: cover; background-position: center; background-color: var(--bg-soft); }
.room-gallery-thumbs { margin-top: 0.5rem; }
.room-gallery-thumbs .swiper-slide { aspect-ratio: 4 / 3; background-size: cover; background-position: center; background-color: var(--bg-soft); cursor: pointer; opacity: 0.5; transition: opacity 0.3s; border-radius: var(--rounded); }
.room-gallery-thumbs .swiper-slide-thumb-active { opacity: 1; outline: 2px solid var(--sand); }

.room-single-grid { display: grid; grid-template-columns: 1fr 380px; gap: 3rem; align-items: start; margin-top: 3rem; }
.room-info h1 { margin-bottom: 1.5rem; }
.room-specs-strip { display: flex; gap: 2rem; padding: 1.5rem 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 2rem; flex-wrap: wrap; }
.room-specs-strip > div { font-size: 0.78rem; color: var(--ink-soft); letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; }
.room-specs-strip strong { display: block; font-family: var(--heading-font); font-size: 1.4rem; color: var(--ink); margin-bottom: 0.2rem; text-transform: none; letter-spacing: 0; font-weight: 500; }
.room-info .content { line-height: 1.9; }
.room-info .content p { margin-bottom: 1.4rem; }
.room-info .content h2 { margin: 2rem 0 1rem; }
.room-facilities-icons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem; margin: 2rem 0; }
.room-facilities-icons .item { display: flex; align-items: center; gap: 0.7rem; padding: 0.9rem 1rem; background: var(--bg-soft); border-radius: var(--rounded); font-size: 0.92rem; color: var(--ink); }
.room-facilities-icons .item .ico { color: var(--sand-dark); font-size: 1.1rem; }

.room-sidebar { position: sticky; top: 100px; }
.sidebar-booking { background: var(--white); border-radius: var(--rounded-lg); padding: 2.2rem; border: 1px solid var(--line); box-shadow: var(--shadow-soft); }
.sidebar-booking .ba-price-head { padding-bottom: 1.5rem; border-bottom: 1px solid var(--line); margin-bottom: 1.5rem; text-align: center; }
.sidebar-booking .ba-price-head .price { font-family: var(--heading-font); font-size: 2.4rem; color: var(--sand-dark); line-height: 1; }
.sidebar-booking .ba-price-head .price small { font-family: var(--body-font); font-size: 0.85rem; color: var(--ink-soft); margin-left: 0.3rem; }
.sidebar-booking h4 { margin-bottom: 1.4rem; font-size: 1.3rem; }
.sidebar-booking .form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 0.8rem; margin-bottom: 1rem; }
.sidebar-booking input, .sidebar-booking select { width: 100%; padding: 0.85rem; border: 1px solid var(--line-mid); background: var(--bg); font-family: var(--body-font); font-size: 0.92rem; color: var(--ink); border-radius: var(--rounded); }
.sidebar-booking input:focus, .sidebar-booking select:focus { outline: none; border-color: var(--sand); }
.sidebar-booking .extras { list-style: none; margin-top: 0.5rem; padding-top: 1.4rem; border-top: 1px solid var(--line); }
.sidebar-booking .extras li { display: flex; justify-content: space-between; align-items: center; padding: 0.7rem 0; border-bottom: 1px dashed var(--line); gap: 0.8rem; }
.sidebar-booking .extras li:last-child { border-bottom: none; }
.sidebar-booking .extras label { display: flex; align-items: center; gap: 0.7rem; cursor: pointer; font-size: 0.92rem; margin: 0; text-transform: none; letter-spacing: 0; color: var(--ink); font-weight: 400; flex: 1; }
.sidebar-booking .extras input[type="checkbox"] { width: 18px; height: 18px; accent-color: var(--sand); cursor: pointer; }
.sidebar-booking .extras .price-tag { font-family: var(--heading-font); color: var(--sand-dark); font-size: 1rem; font-weight: 500; flex-shrink: 0; }
.sidebar-booking .extras .price-tag.free { color: var(--moss); font-style: italic; font-size: 0.85rem; }
.sidebar-booking .ba-total { display: flex; justify-content: space-between; align-items: center; margin: 1.5rem 0; padding: 1.2rem 1rem; background: var(--bg-soft); border-radius: var(--rounded); border: 1px solid var(--line-sand); }
.sidebar-booking .ba-total .lbl { font-size: 0.85rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-soft); font-weight: 700; }
.sidebar-booking .ba-total .val { font-family: var(--heading-font); font-size: 2rem; color: var(--sand-dark); }
.sidebar-booking .btn { width: 100%; justify-content: center; }

/* ============================================================
   BLOG SINGLE
   ============================================================ */
.single-post-wrap { max-width: 800px; margin: 0 auto; padding: 4rem 5%; }
.single-post-wrap .meta { font-size: 0.82rem; letter-spacing: 1.5px; text-transform: uppercase; color: var(--sand-dark); margin-bottom: 1.2rem; font-weight: 700; }
.single-post-wrap h1 { margin-bottom: 2rem; }
.single-post-wrap .feat-img { margin: 0 0 2rem; border-radius: var(--rounded-lg); overflow: hidden; }
.single-post-wrap .content { font-size: 1.05rem; line-height: 1.9; color: var(--ink-soft); }
.single-post-wrap .content h2, .single-post-wrap .content h3 { color: var(--ink); margin: 2.5rem 0 1rem; }
.single-post-wrap .content p { margin-bottom: 1.4rem; }
.single-post-wrap .content img { margin: 2rem 0; border-radius: var(--rounded-lg); }
.single-post-wrap .content blockquote { padding: 1.5rem 2rem; border-left: 4px solid var(--sand); background: var(--bg-soft); margin: 2rem 0; font-family: var(--heading-font); font-style: italic; font-size: 1.25rem; color: var(--ink); border-radius: var(--rounded); }

/* ============================================================
   FOOTER (4 cols)
   ============================================================ */
.site-footer { background: var(--moss); color: rgba(255, 255, 255, 0.72); padding: 5rem 5% 2rem; }
.foot-grid { max-width: var(--container); margin: 0 auto; display: grid; grid-template-columns: 1.6fr 1fr 1fr 1.2fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 1px solid var(--line-light); }
.foot-brand .brand { color: var(--white); display: inline-block; margin-bottom: 1rem; }
.foot-brand p { font-size: 0.92rem; line-height: 1.8; max-width: 320px; margin-bottom: 1.5rem; }
.foot-socials { display: flex; gap: 0.6rem; }
.foot-socials a { width: 42px; height: 42px; border-radius: 50%; background: rgba(255, 255, 255, 0.08); display: inline-flex; align-items: center; justify-content: center; color: rgba(255, 255, 255, 0.7); transition: all 0.2s; }
.foot-socials a:hover { background: var(--sand); color: var(--ink); }
.foot-col h6 { color: var(--white); font-family: var(--heading-font); font-size: 1.4rem; margin-bottom: 1.2rem; font-weight: 500; }
.foot-col a, .foot-col span { display: block; color: rgba(255, 255, 255, 0.7); font-size: 0.92rem; margin-bottom: 0.7rem; transition: color 0.2s; }
.foot-col a:hover { color: var(--sand-soft); }
.foot-col address { font-style: normal; }
.foot-bottom { max-width: var(--container); margin: 1.5rem auto 0; display: flex; justify-content: space-between; align-items: center; font-size: 0.85rem; flex-wrap: wrap; gap: 0.7rem; color: rgba(255, 255, 255, 0.55); }
.foot-bottom .legal { display: flex; gap: 1.5rem; }
.foot-bottom .legal a { color: rgba(255, 255, 255, 0.55); }
.foot-bottom .legal a:hover { color: var(--sand-soft); }

/* ============================================================
   PAGINATION
   ============================================================ */
.nav-pagination { max-width: var(--container); margin: 3rem auto 0; text-align: center; padding: 0 5%; }
.nav-pagination .page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px; padding: 0 12px; border-radius: var(--rounded); border: 1px solid var(--line-mid); margin: 0 0.2rem; text-decoration: none; color: var(--ink); font-weight: 600; transition: all 0.2s; }
.nav-pagination .page-numbers:hover, .nav-pagination .current { background: var(--sand); color: var(--ink); border-color: var(--sand); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px) {
    .rooms-grid, .blog-grid, .pricing-grid, .cta-triple, .team-grid { grid-template-columns: repeat(2, 1fr); }
    .benefits-grid { grid-template-columns: repeat(2, 1fr); }
    .stat-blocks { grid-template-columns: repeat(2, 1fr); }
    .stat-block:nth-child(2n) { border-right: none; }
    .stat-block:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
    .gallery-grid { grid-template-columns: repeat(3, 1fr); }
    .ig-grid { grid-template-columns: repeat(4, 1fr); }
    .hero-booking-inner { grid-template-columns: repeat(2, 1fr); }
    .room-single-grid, .about-intro, .contact-grid { grid-template-columns: 1fr; gap: 3rem; }
    .room-sidebar { position: static; }
    .about-intro.reverse > .ai-visual { order: 0; }
    .facilities-mixed { grid-template-columns: 1fr 1fr; min-height: auto; }
    .facility-tile-mixed:nth-child(1) { grid-row: auto; aspect-ratio: 4 / 3; }
    .facility-tile-mixed { aspect-ratio: 4 / 3; }
    .foot-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
    .section { padding: 4rem 5%; }
    .form-row, .room-facilities-icons { grid-template-columns: 1fr; }
    .main-nav { display: none; }
    .header-meta { display: none; }
    .hero-booking { margin-top: 0; }
    .marquee-item { gap: 2rem; }
    .room-facilities-icons { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
    .rooms-grid, .blog-grid, .pricing-grid, .cta-triple, .team-grid, .benefits-grid, .facilities-mixed { grid-template-columns: 1fr; }
    .stat-blocks { grid-template-columns: 1fr; }
    .stat-block { border-right: none; border-bottom: 1px solid var(--line); }
    .stat-block:last-child { border-bottom: none; }
    .gallery-grid { grid-template-columns: repeat(2, 1fr); }
    .ig-grid { grid-template-columns: repeat(3, 1fr); }
    .gallery-item.tall, .gallery-item.wide { grid-row: auto; grid-column: auto; aspect-ratio: 4 / 5; }
    .hero-booking-inner { grid-template-columns: 1fr; }
    .foot-grid { grid-template-columns: 1fr; }
    .pricing-card.featured { transform: none; }
    .room-facilities-icons { grid-template-columns: 1fr; }
    .ai-visual .ph-mini { right: 0; }
}

/* ============================================
 * WAVE 1 PARITY — partners, phone-cta, manager-block
 * ============================================ */

/* PARTNERS */
.partners-section { padding: 4rem 6%; background: var(--bg-soft); border-top: 1px solid rgba(31, 27, 22, 0.08); border-bottom: 1px solid rgba(31, 27, 22, 0.08); }
.partners-swiper { max-width: var(--container, 1320px); margin: 0 auto; }
.partners-swiper .swiper-slide { display: flex; align-items: center; justify-content: center; height: 80px; opacity: 0.55; filter: grayscale(1); transition: all 0.3s; }
.partners-swiper .swiper-slide:hover { opacity: 1; filter: grayscale(0); }
.partner-logo { display: flex; align-items: center; justify-content: center; height: 100%; text-decoration: none; color: var(--ink-soft); }
.partner-logo img { max-height: 50px; width: auto; object-fit: contain; }
.partner-logo .text { font-family: 'Cormorant Garamond', serif; font-size: 1.5rem; letter-spacing: 3px; text-transform: uppercase; font-weight: 500; }

/* PHONE CTA */
.phone-cta {
    background: var(--moss);
    background-size: cover; background-position: center;
    color: rgba(250, 246, 238, 0.88);
    text-align: center; padding: 6rem 6%;
    position: relative;
}
.phone-cta[style*='url']::before { content: ''; position: absolute; inset: 0; background: rgba(47, 74, 58, 0.82); }
.phone-cta > * { position: relative; z-index: 1; }
.phone-inner { max-width: 760px; margin: 0 auto; }
.phone-cta .eyebrow { color: var(--sand); }
.phone-cta h2 { color: var(--bg); font-size: clamp(2rem, 3.6vw, 2.8rem); margin-bottom: 1rem; }
.phone-cta h2 em { font-style: italic; color: var(--sand); }
.phone-cta .desc { color: rgba(250, 246, 238, 0.82); max-width: 560px; margin: 0 auto 2rem; }
.phone-link {
    display: inline-flex; align-items: center; gap: 1.2rem;
    color: var(--bg); text-decoration: none;
    font-family: 'Cormorant Garamond', serif; font-size: 2rem; letter-spacing: 1px; font-weight: 500;
    transition: opacity 0.2s;
}
.phone-link:hover { opacity: 0.78; }
.phone-ico {
    width: 56px; height: 56px;
    background: var(--sand); color: var(--moss);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
}

/* MANAGER BLOCK */
.manager-block { max-width: var(--container, 1320px); margin: 0 auto; display: grid; grid-template-columns: 1fr 1.1fr; gap: 4rem; align-items: center; }
.manager-block.reverse .mgr-visual { order: 2; }
.mgr-visual {
    min-height: 520px;
    background-size: cover; background-position: center; background-color: var(--bg-soft);
}
.mgr-text h2 em { font-style: italic; color: var(--sand); }
.mgr-text .quote {
    margin: 1.4rem 0;
    font-family: 'Cormorant Garamond', serif; font-size: 1.55rem; font-style: italic; line-height: 1.5;
    color: var(--ink);
    border-left: 3px solid var(--sand); padding-left: 1.4rem;
}
.mgr-text .body-text { color: var(--ink-soft); line-height: 1.85; }
.mgr-text .body-text p { margin-bottom: 1rem; }
.mgr-sign { display: flex; align-items: center; gap: 1.4rem; margin-top: 2rem; padding-top: 1.6rem; border-top: 1px solid rgba(31, 27, 22, 0.1); }
.mgr-sign .sig-img { max-width: 120px; height: auto; opacity: 0.85; }
.mgr-sign .sig-name { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.5rem; color: var(--moss); font-weight: 500; }
.mgr-sign .sig-role { font-size: 0.74rem; letter-spacing: 2px; text-transform: uppercase; color: var(--sand); margin-top: 0.3rem; font-weight: 600; }

@media (max-width: 768px) {
    .manager-block { grid-template-columns: 1fr; gap: 2.5rem; }
    .manager-block.reverse .mgr-visual { order: 0; }
    .mgr-visual { min-height: 340px; }
    .phone-link { font-size: 1.5rem; }
}

/* ============ COMING SOON — moss + sand, sprig SVGs, Cormorant italic ============ */
.ho-soon { padding: 7rem 0 5rem; background-size: cover; background-position: center; position: relative; color: var(--white); text-align: center; }
.ho-soon::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31,51,39,0.66), rgba(47,74,58,0.82)); }
.ho-soon-inner { position: relative; z-index: 2; max-width: 760px; margin: 0 auto; padding: 0 2rem; }
.ho-soon-eyebrow { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.1rem; color: var(--sand-soft); letter-spacing: 0.5px; display: inline-block; }
.ho-soon-sprig { display: block; width: 100px; height: 20px; color: var(--sand-soft); margin: 0.8rem auto; }
.ho-soon-h1 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2.4rem, 4.4vw, 3.6rem); line-height: 1.1; color: var(--white); margin: 0.4rem 0 1rem; }
.ho-soon-h1 em { font-style: italic; color: var(--sand-soft); }
.ho-soon-answer { color: rgba(255,255,255,0.85); line-height: 1.85; font-size: 1.05rem; max-width: 540px; margin: 0 auto 1.6rem; }
.ho-soon-meta { display: flex; justify-content: center; gap: 2.5rem; padding: 1.6rem 0; border-top: 1px solid rgba(220,197,154,0.35); border-bottom: 1px solid rgba(220,197,154,0.35); margin: 1.4rem auto 1.8rem; max-width: 480px; }
.ho-soon-meta-label { display: block; font-family: 'Cormorant Garamond', serif; font-size: 1rem; color: var(--sand-soft); font-style: italic; margin-bottom: 0.3rem; }
.ho-soon-meta-value { font-family: 'Cormorant Garamond', serif; font-size: 1.2rem; color: var(--white); }
.ho-soon-cta-row { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.ho-soon-btn { display: inline-block; padding: 0.9rem 2rem; border-radius: 999px; text-decoration: none; font-family: 'Cormorant Garamond', serif; font-size: 1.1rem; transition: background 0.25s, color 0.25s; }
.ho-soon-btn em { font-style: italic; }
.ho-soon-btn-primary { background: var(--sand); color: var(--ink); }
.ho-soon-btn-primary:hover { background: var(--sand-soft); color: var(--moss-dark); }
.ho-soon-btn-ghost { background: transparent; color: var(--sand-soft); border: 1px solid var(--sand-soft); }
.ho-soon-btn-ghost:hover { background: var(--sand-soft); color: var(--moss-dark); }
.ho-soon-highlights { padding: 4rem 2rem; background: var(--bg); }
.ho-soon-highlights-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.5rem; max-width: 1100px; margin: 0 auto; }
.ho-soon-highlight { padding: 2rem 1.6rem; background: var(--sand-pale); text-align: center; transition: background 0.25s; }
.ho-soon-highlight:hover { background: var(--sand-soft); }
.ho-soon-highlight .ho-soon-sprig { color: var(--sand-dark); width: 80px; }
.ho-soon-highlight-label { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1rem; color: var(--sand-dark); margin-bottom: 0.3rem; }
.ho-soon-highlight-value { display: block; font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; color: var(--ink); }
.ho-soon-faq { padding: 5rem 2rem; background: var(--bg-soft); }
.ho-soon-faq-head { text-align: center; max-width: 720px; margin: 0 auto 3rem; }
.ho-soon-faq-head .ho-soon-sprig { color: var(--sand-dark); margin-top: 0.8rem; }
.ho-soon-faq-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2rem, 3.6vw, 2.8rem); color: var(--ink); margin-top: 1rem; line-height: 1.15; }
.ho-soon-faq-h2 em { font-style: italic; color: var(--moss); }
.ho-soon-faq-list { max-width: 820px; margin: 0 auto; display: flex; flex-direction: column; gap: 1.4rem; }
.ho-soon-faq-item { padding: 1.8rem 2rem; background: var(--bg); border-top: 2px solid var(--sand); }
.ho-soon-faq-q { font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; color: var(--ink); margin: 0 0 0.6rem; font-weight: 400; }
.ho-soon-faq-q em { font-style: italic; }
.ho-soon-faq-a { color: var(--ink-soft); line-height: 1.85; margin: 0; }
.ho-soon-place { padding: 5rem 2rem; background: var(--moss); color: var(--white); text-align: center; }
.ho-soon-place .ho-soon-eyebrow { color: var(--sand-soft); }
.ho-soon-place-inner { max-width: 600px; margin: 0 auto; }
.ho-soon-place .ho-soon-sprig { color: var(--sand-soft); margin: 1rem auto 1.4rem; }
.ho-soon-place-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2rem, 3.4vw, 2.6rem); color: var(--white); margin: 0.4rem 0 0.6rem; }
.ho-soon-place-h2 em { font-style: italic; color: var(--sand-soft); }
.ho-soon-address { font-style: normal; line-height: 1.85; color: rgba(255,255,255,0.85); margin: 1.4rem 0; }
.ho-soon-final { padding: 5rem 2rem; background: var(--bg); text-align: center; }
.ho-soon-final .ho-soon-eyebrow { color: var(--sand-dark); }
.ho-soon-final-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(1.8rem, 3.2vw, 2.4rem); color: var(--ink); margin: 0.6rem 0 0.8rem; }
.ho-soon-final-desc { color: var(--ink-soft); line-height: 1.8; max-width: 480px; margin: 0 auto 1.6rem; }
@media (max-width: 600px) { .ho-soon-meta { flex-direction: column; gap: 1rem; } }

/* ============ PHONE CTA REDO — moss band + sprig SVGs + Cormorant italic ============ */
.ho-phone {
    padding: 5rem 0;
    background-size: cover; background-position: center;
    position: relative; color: var(--white);
    text-align: center;
}
.ho-phone::before {
    content: ''; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(31,51,39,0.78), rgba(47,74,58,0.85));
}
.ho-phone-inner { position: relative; z-index: 2; max-width: 720px; margin: 0 auto; padding: 0 2rem; }
.ho-phone-eyebrow {
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 1.1rem; color: var(--sand-soft);
    letter-spacing: 0.5px; margin-bottom: 1rem; display: block;
}
.ho-phone-h2 {
    font-family: 'Cormorant Garamond', serif; font-weight: 400;
    font-size: clamp(2rem, 4vw, 3rem); line-height: 1.15;
    color: var(--white); margin-bottom: 1rem;
}
.ho-phone-h2 em { color: var(--sand-soft); font-style: italic; }
.ho-phone-desc {
    color: rgba(255,255,255,0.78); line-height: 1.75;
    max-width: 460px; margin: 0 auto 2.2rem;
}
.ho-phone-row {
    display: inline-flex; align-items: center; gap: 1.2rem;
}
.ho-phone-sprig {
    width: 60px; height: 20px; color: var(--sand-soft);
    flex: 0 0 auto;
}
.ho-phone-sprig-l { transform: scaleX(1); }
.ho-phone-sprig-r { transform: scaleX(-1); }
.ho-phone-link {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 3.2vw, 2.4rem);
    color: var(--sand-soft); text-decoration: none;
    border-bottom: 1px solid var(--sand-soft);
    padding-bottom: 0.2rem;
    transition: color 0.25s, border-color 0.25s;
}
.ho-phone-link:hover { color: var(--white); border-color: var(--white); }
.ho-phone-link em { font-style: italic; }
@media (max-width: 600px) {
    .ho-phone-row { flex-direction: column; gap: 0.6rem; }
    .ho-phone-sprig { width: 80px; }
}

/* ============ PRICING TIERS REDO — sand-pale cards + sprig + Cormorant italic ============ */
.ho-pricing-section { padding: 5rem 0; background: var(--bg); }
.ho-pricing-head { text-align: center; max-width: 720px; margin: 0 auto 3.5rem; padding: 0 2rem; }
.ho-pricing-eyebrow {
    display: block;
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 1.05rem; color: var(--sand-dark);
    letter-spacing: 0.5px; margin-bottom: 0.8rem;
}
.ho-pricing-h2 {
    font-family: 'Cormorant Garamond', serif; font-weight: 400;
    font-size: clamp(2rem, 3.8vw, 3rem); line-height: 1.15;
    color: var(--ink); margin: 0 0 1rem;
}
.ho-pricing-h2 em { color: var(--sand-dark); font-style: italic; }
.ho-pricing-lede { color: var(--ink-soft); line-height: 1.75; }
.ho-pricing-grid {
    display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.6rem; max-width: 1200px; margin: 0 auto; padding: 0 2rem;
    align-items: start;
}
.ho-pricing-card {
    position: relative;
    padding: 2.6rem 2rem 2.2rem;
    background: var(--bg-soft);
    border-top: 2px solid var(--sand);
    text-align: center;
    transition: background 0.25s, transform 0.25s;
}
.ho-pricing-card:hover { background: var(--sand-pale); transform: translateY(-4px); }
.ho-pricing-card.is-featured {
    background: var(--moss); color: var(--white);
    border-top-color: var(--sand-soft);
}
.ho-pricing-card.is-featured:hover { background: var(--moss-dark); }
.ho-pricing-card.is-featured .ho-pricing-tier,
.ho-pricing-card.is-featured .ho-pricing-num { color: var(--sand-soft); }
.ho-pricing-card.is-featured .ho-pricing-desc,
.ho-pricing-card.is-featured .ho-pricing-features li,
.ho-pricing-card.is-featured .ho-pricing-suffix { color: rgba(255,255,255,0.78); }
.ho-pricing-card.is-featured .ho-pricing-sprig { color: var(--sand-soft); }
.ho-pricing-sprig {
    display: block; width: 80px; height: 30px;
    color: var(--sand-dark); margin: 0 auto 1rem;
}
.ho-pricing-tier {
    font-family: 'Cormorant Garamond', serif; font-weight: 400; font-style: italic;
    font-size: 1.5rem; color: var(--ink); margin: 0 0 0.8rem;
    letter-spacing: 0.3px;
}
.ho-pricing-badge {
    display: inline-block;
    padding: 0.3rem 0.9rem; margin-bottom: 1rem;
    background: var(--sand-pale); color: var(--ink);
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 0.85rem; letter-spacing: 0.5px;
    border-radius: 999px;
}
.ho-pricing-card.is-featured .ho-pricing-badge { background: rgba(220,197,154,0.25); color: var(--sand-soft); }
.ho-pricing-price { display: flex; align-items: baseline; justify-content: center; gap: 0.4rem; margin-bottom: 1rem; }
.ho-pricing-num {
    font-family: 'Cormorant Garamond', serif; font-style: italic; font-weight: 400;
    font-size: clamp(2.6rem, 4vw, 3.4rem); line-height: 1;
    color: var(--sand-dark);
}
.ho-pricing-suffix {
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 0.95rem; color: var(--ink-soft);
}
.ho-pricing-desc { color: var(--ink-soft); line-height: 1.75; font-size: 0.92rem; margin-bottom: 1.4rem; }
.ho-pricing-features { list-style: none; padding: 0; margin: 0 0 1.8rem; text-align: left; max-width: 220px; margin-left: auto; margin-right: auto; }
.ho-pricing-features li {
    padding: 0.45rem 0;
    color: var(--ink-soft); font-size: 0.92rem;
    display: flex; gap: 0.6rem; align-items: baseline;
}
.ho-pricing-leaf { color: var(--sand-dark); font-size: 0.7rem; }
.ho-pricing-card.is-featured .ho-pricing-leaf { color: var(--sand-soft); }
.ho-pricing-btn {
    display: inline-block;
    padding: 0.9rem 2rem;
    background: var(--sand); color: var(--ink);
    border-radius: 999px;
    text-decoration: none;
    font-family: 'Cormorant Garamond', serif; font-style: italic;
    font-size: 1.05rem; letter-spacing: 0.5px;
    transition: background 0.25s, color 0.25s;
}
.ho-pricing-btn:hover { background: var(--moss); color: var(--white); }
.ho-pricing-card.is-featured .ho-pricing-btn { background: var(--sand-soft); color: var(--moss-dark); }
.ho-pricing-card.is-featured .ho-pricing-btn:hover { background: var(--white); }

/* ============ BLOG GRID REDO — sand-pale base + sprig divider + Cormorant ============ */
.ho-blog-section { padding: 5rem 0; background: var(--bg-soft); }
.ho-blog-head { text-align: center; max-width: 720px; margin: 0 auto 3.5rem; padding: 0 2rem; }
.ho-blog-eyebrow { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.05rem; color: var(--sand-dark); margin-bottom: 0.8rem; }
.ho-blog-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2rem,3.8vw,3rem); color: var(--ink); margin: 0 0 1rem; line-height: 1.15; }
.ho-blog-h2 em { color: var(--sand-dark); font-style: italic; }
.ho-blog-lede { color: var(--ink-soft); line-height: 1.75; }
.ho-blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 2rem; max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.ho-blog-card { background: var(--bg); transition: background 0.25s; }
.ho-blog-card:hover { background: var(--sand-pale); }
.ho-blog-media { display: block; aspect-ratio: 4/3; background-size: cover; background-position: center; }
.ho-blog-body { padding: 1.6rem 1.4rem 1.8rem; text-align: center; }
.ho-blog-date { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--sand-dark); font-size: 0.95rem; margin-bottom: 0.6rem; }
.ho-blog-sprig { display: block; width: 80px; height: 16px; color: var(--sand-dark); margin: 0 auto 0.8rem; }
.ho-blog-title { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: 1.4rem; line-height: 1.3; margin: 0 0 0.8rem; }
.ho-blog-title a { color: var(--ink); text-decoration: none; transition: color 0.25s; }
.ho-blog-title a:hover { color: var(--moss); }
.ho-blog-excerpt { color: var(--ink-soft); line-height: 1.75; font-size: 0.92rem; margin-bottom: 1rem; }
.ho-blog-link { display: inline-block; font-family: 'Cormorant Garamond', serif; font-style: italic; color: var(--moss); text-decoration: none; font-size: 1.05rem; border-bottom: 1px solid var(--moss); padding-bottom: 0.2rem; transition: color 0.25s, border-color 0.25s; }
.ho-blog-link:hover { color: var(--sand-dark); border-color: var(--sand-dark); }

/* ============ GALLERY REDO — sand backplates + sprig overlay + Cormorant italic filters ============ */
.ho-gallery-section { padding: 5rem 0; background: var(--bg); }
.ho-gallery-head { text-align: center; max-width: 720px; margin: 0 auto 2.5rem; padding: 0 2rem; }
.ho-gallery-eyebrow { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.05rem; color: var(--sand-dark); margin-bottom: 0.8rem; }
.ho-gallery-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2rem,3.8vw,3rem); color: var(--ink); margin: 0 0 1rem; line-height: 1.15; }
.ho-gallery-lede { color: var(--ink-soft); line-height: 1.75; }
.ho-gallery-filters { display: flex; gap: 1.4rem; justify-content: center; flex-wrap: wrap; margin-bottom: 2.5rem; padding: 0 2rem; }
.ho-gallery-filter { background: transparent; border: 0; padding: 0.3rem 0; color: var(--ink-soft); font-family: 'Cormorant Garamond', serif; font-size: 1.15rem; cursor: pointer; transition: color 0.25s; }
.ho-gallery-filter em { font-style: italic; }
.ho-gallery-filter:hover, .ho-gallery-filter.is-active { color: var(--moss); border-bottom: 1px solid var(--moss); }
.ho-gallery-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 1.2rem; max-width: 1280px; margin: 0 auto; padding: 0 2rem; grid-auto-rows: 240px; }
.ho-gallery-item { position: relative; display: block; overflow: hidden; background: var(--sand-pale); transition: transform 0.25s; }
.ho-gallery-item:hover { transform: translateY(-3px); }
.ho-gallery-item.wide { grid-column: span 2; }
.ho-gallery-item.tall { grid-row: span 2; }
.ho-gallery-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.6s; }
.ho-gallery-item:hover .ho-gallery-img { transform: scale(1.05); }
.ho-gallery-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(31,51,39,0.78)); display: flex; flex-direction: column; align-items: center; justify-content: flex-end; padding: 1.4rem; color: var(--sand-soft); opacity: 0; transition: opacity 0.3s; }
.ho-gallery-item:hover .ho-gallery-overlay { opacity: 1; }
.ho-gallery-sprig { display: block; width: 80px; height: 16px; color: var(--sand-soft); margin-bottom: 0.4rem; }
.ho-gallery-view { font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.1rem; color: var(--white); }
@media (max-width: 720px) { .ho-gallery-item.wide, .ho-gallery-item.tall { grid-column: span 1; grid-row: span 1; } }

/* ============ VIDEO SECTION REDO — sprig-flanked play + Cormorant italic ============ */
.ho-video { padding: 7rem 0; background-size: cover; background-position: center; position: relative; color: var(--white); text-align: center; }
.ho-video::before { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(31,51,39,0.55), rgba(47,74,58,0.78)); }
.ho-video-inner { position: relative; z-index: 2; max-width: 720px; margin: 0 auto; padding: 0 2rem; }
.ho-video-play { display: inline-flex; align-items: center; gap: 1.2rem; margin-bottom: 2rem; color: var(--sand-soft); text-decoration: none; transition: color 0.25s, gap 0.25s; }
.ho-video-play:hover { color: var(--white); gap: 1.6rem; }
.ho-video-sprig { width: 60px; height: 20px; color: currentColor; flex: 0 0 auto; }
.ho-video-sprig-r { transform: scaleX(-1); }
.ho-video-play-ico { display: inline-flex; align-items: center; justify-content: center; width: 78px; height: 78px; border: 1px solid currentColor; border-radius: 50%; font-size: 1.4rem; transform: translateX(2px); }
.ho-video-eyebrow { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.1rem; color: var(--sand-soft); margin-bottom: 1rem; }
.ho-video-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2rem,4vw,3rem); line-height: 1.15; color: var(--white); margin: 0 0 1rem; }
.ho-video-h2 em { color: var(--sand-soft); font-style: italic; }
.ho-video-lede { color: rgba(255,255,255,0.78); line-height: 1.75; max-width: 480px; margin: 0 auto; }

/* ============ IG GRID REDO — sand-pale tiles + sprig + italic Cormorant overlay ============ */
.ho-ig-section { padding: 5rem 0; background: var(--bg); }
.ho-ig-head { text-align: center; max-width: 720px; margin: 0 auto 2.5rem; padding: 0 2rem; }
.ho-ig-eyebrow { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.05rem; color: var(--sand-dark); margin-bottom: 0.8rem; }
.ho-ig-h2 { font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: clamp(2rem,3.4vw,2.6rem); color: var(--ink); margin: 0 0 0.6rem; line-height: 1.15; }
.ho-ig-sprig { display: block; width: 100px; height: 16px; color: var(--sand-dark); margin: 0.4rem auto 0.6rem; }
.ho-ig-lede { color: var(--ink-soft); line-height: 1.75; }
.ho-ig-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 1rem; max-width: 1200px; margin: 0 auto; padding: 0 2rem; }
.ho-ig-tile { position: relative; display: block; aspect-ratio: 1/1; background: var(--sand-pale); overflow: hidden; transition: transform 0.25s; }
.ho-ig-tile:hover { transform: translateY(-3px); }
.ho-ig-img { position: absolute; inset: 0; background-size: cover; background-position: center; transition: transform 0.6s; }
.ho-ig-tile:hover .ho-ig-img { transform: scale(1.06); }
.ho-ig-overlay { position: absolute; inset: 0; background: rgba(31,51,39,0.65); display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity 0.3s; color: var(--sand-soft); font-family: 'Cormorant Garamond', serif; font-size: 1.4rem; }
.ho-ig-overlay em { font-style: italic; }
.ho-ig-tile:hover .ho-ig-overlay { opacity: 1; }

/* ============ PARTNERS REDO — sprig divider + Cormorant italic label ============ */
.ho-partners-section { padding: 4rem 0; background: var(--bg); text-align: center; }
.ho-partners-label { display: block; font-family: 'Cormorant Garamond', serif; font-style: italic; font-size: 1.15rem; color: var(--sand-dark); letter-spacing: 0.5px; }
.ho-partners-label em { font-style: italic; }
.ho-partners-sprig { display: block; width: 140px; height: 16px; color: var(--sand-dark); margin: 0.6rem auto 2rem; }
.ho-partners-swiper { max-width: 1180px; margin: 0 auto; padding: 0 2rem; }
.ho-partner-logo { display: flex; align-items: center; justify-content: center; height: 80px; color: var(--ink-soft); text-decoration: none; opacity: 0.65; transition: opacity 0.25s, color 0.25s; }
.ho-partner-logo:hover { opacity: 1; color: var(--moss); }
.ho-partner-logo img { max-height: 50px; max-width: 150px; object-fit: contain; filter: grayscale(100%) opacity(0.7); transition: filter 0.25s; }
.ho-partner-logo:hover img { filter: grayscale(0%) opacity(1); }
.ho-partner-text { font-family: 'Cormorant Garamond', serif; font-size: 1.3rem; color: var(--ink); }
.ho-partner-text em { font-style: italic; }

/* ============================================
 * WAVE 2 + 3 — hotelo VRS identity
 * Cormorant italic + sand backplates + sprig SVGs + moss anchor
 * ============================================ */

/* ============ MANAGER BLOCK REDO — asymmetric with sprig + sand backplate ============ */
.ho-manager-asymmetric {
    max-width: 1240px; margin: 0 auto;
    display: grid; grid-template-columns: 1.2fr 1fr; gap: 4rem;
    align-items: center;
}
.ho-manager-asymmetric.reverse { direction: rtl; }
.ho-manager-asymmetric.reverse > * { direction: ltr; }
.ho-manager-text-col { padding: 2rem 0; }
.ho-manager-sprig { width: 60px; height: 24px; color: var(--moss); margin-bottom: 0.8rem; }
.ho-manager-h {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 3.6vw, 2.8rem);
    color: var(--moss); line-height: 1.1;
    margin: 0.5rem 0 1rem;
}
.ho-manager-quote {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; color: var(--sand-dark); line-height: 1.55;
    margin-bottom: 1.4rem;
}
.ho-manager-quote em { font-style: italic; }
.ho-manager-body { color: var(--ink-soft); line-height: 1.75; margin-bottom: 1.6rem; }
.ho-manager-sign { display: flex; align-items: center; gap: 1.2rem; padding-top: 1.2rem; border-top: 1px dashed rgba(47,74,58,0.25); }
.ho-sig-img { max-width: 100px; opacity: 0.85; }
.ho-sig-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; color: var(--moss);
}
.ho-sig-role {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600; margin-top: 0.2rem;
}
.ho-manager-portrait-col { position: relative; }
.ho-manager-portrait {
    aspect-ratio: 4 / 5;
    background-size: cover; background-position: center;
    background-color: var(--bg-soft);
    border-radius: 16px;
    position: relative; z-index: 2;
}
.ho-manager-backplate {
    position: absolute;
    top: 20px; right: -20px; bottom: -20px; left: 20px;
    background: var(--sand-pale);
    border-radius: 16px;
    z-index: 1;
}
@media (max-width: 900px) {
    .ho-manager-asymmetric, .ho-manager-asymmetric.reverse { grid-template-columns: 1fr; gap: 2.5rem; direction: ltr; }
    .ho-manager-backplate { display: none; }
}

/* ============ TEAM GRID REDO — round portrait + sprig accent ============ */
.ho-team-grid {
    max-width: 1280px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 2rem;
}
.ho-team-card { text-align: center; }
.ho-team-portrait-wrap {
    width: 200px; height: 200px; margin: 0 auto 1rem;
    position: relative;
}
.ho-team-portrait {
    width: 100%; height: 100%; border-radius: 50%;
    background-size: cover; background-position: center;
    background-color: var(--bg-soft);
    transition: transform 0.35s ease;
}
.ho-team-card:hover .ho-team-portrait { transform: scale(1.03); }
.ho-team-sprig {
    position: absolute; bottom: -8px; left: 50%; transform: translateX(-50%);
    width: 50px; height: 18px;
    color: var(--moss);
}
.ho-team-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; color: var(--moss); margin-bottom: 0.3rem;
    margin-top: 0.6rem;
}
.ho-team-name em { font-style: italic; }
.ho-team-role {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600; margin-bottom: 0.9rem;
}
.ho-team-socials { display: flex; gap: 0.6rem; justify-content: center; }
.ho-team-socials a {
    width: 32px; height: 32px; border-radius: 50%;
    background: var(--bg-soft); color: var(--moss);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 0.78rem; text-decoration: none;
    transition: background 0.2s ease, color 0.2s ease;
}
.ho-team-socials a:hover { background: var(--moss); color: var(--bg); }
@media (max-width: 1024px) { .ho-team-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .ho-team-grid { grid-template-columns: repeat(2, 1fr); } .ho-team-portrait-wrap { width: 160px; height: 160px; } }
@media (max-width: 480px) { .ho-team-grid { grid-template-columns: 1fr; } }

/* ============ NEWSLETTER REDO — moss band with sprigs ============ */
.ho-newsletter-section { padding: 4rem 6%; background: var(--bg); }
.ho-newsletter-band {
    max-width: 880px; margin: 0 auto;
    background: var(--moss);
    color: var(--bg);
    padding: 3.5rem 2.5rem 3rem;
    border-radius: 24px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.ho-newsletter-sprig {
    position: absolute;
    width: 80px; height: 32px;
    color: var(--sand);
    opacity: 0.55;
}
.ho-sprig-l { top: 24px; left: 30px; }
.ho-sprig-r { bottom: 24px; right: 30px; }
.ho-newsletter-eb {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 4px; text-transform: uppercase;
    color: var(--sand-soft);
    margin-bottom: 0.6rem;
}
.ho-newsletter-h {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3.5vw, 2.6rem);
    color: var(--bg); line-height: 1.15;
    margin-bottom: 0.7rem;
}
.ho-newsletter-h em { font-style: italic; color: var(--sand); }
.ho-newsletter-lede {
    color: rgba(250,246,238,0.82); line-height: 1.7;
    max-width: 520px; margin: 0 auto 1.6rem;
}
.ho-newsletter-form {
    display: flex; gap: 0.6rem;
    max-width: 480px; margin: 0 auto;
    padding: 0.5rem;
    background: var(--bg);
    border-radius: 999px;
}
.ho-newsletter-form input {
    flex: 1; padding: 0.8rem 1.2rem;
    background: transparent; border: 0;
    font-family: 'Manrope', sans-serif;
    font-size: 0.92rem; color: var(--ink);
    outline: none;
}
.ho-newsletter-form input::placeholder { color: var(--ink-mute); }
.ho-newsletter-form button {
    background: var(--moss); color: var(--bg);
    border: 0;
    border-radius: 999px;
    padding: 0.8rem 1.5rem;
    font-family: 'Manrope', sans-serif;
    font-size: 0.78rem; letter-spacing: 2.5px; text-transform: uppercase;
    font-weight: 700; cursor: pointer;
    transition: background 0.3s ease;
}
.ho-newsletter-form button:hover { background: var(--sand-dark); }

/* ============ LOCATIONS — organic city carousel ============ */
.ho-locations-swiper { max-width: 1280px; margin: 0 auto; padding-bottom: 3rem; }
.ho-loc-card {
    display: block; text-decoration: none; color: inherit;
    background: var(--white);
    border-radius: 14px; overflow: hidden;
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.ho-loc-card:hover { transform: translateY(-6px); box-shadow: 0 18px 40px rgba(80,60,30,0.14); }
.ho-loc-ph-frame {
    position: relative; padding: 14px 14px 0;
    background: var(--bg-soft);
}
.ho-loc-ph {
    aspect-ratio: 4 / 5;
    background-size: cover; background-position: center;
    background-color: var(--bg-deep);
    border-radius: 12px;
}
.ho-loc-sprig {
    position: absolute; top: 22px; right: 22px;
    width: 32px; height: 32px;
    color: var(--moss);
    background: var(--white);
    border-radius: 50%;
    padding: 4px;
    box-shadow: 0 4px 12px rgba(47,74,58,0.18);
}
.ho-loc-meta { padding: 1.4rem 1.4rem 1.6rem; }
.ho-loc-country {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 3.5px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
    margin-bottom: 0.3rem;
}
.ho-loc-city {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2rem; color: var(--moss);
    line-height: 1.1; margin: 0;
}
.ho-loc-city em { font-style: italic; }
.ho-loc-note {
    color: var(--ink-soft); font-size: 0.9rem; line-height: 1.6;
    margin-top: 0.7rem;
    padding-top: 0.7rem;
    border-top: 1px solid rgba(197, 165, 114, 0.25);
}
.ho-loc-arrow {
    display: inline-block;
    margin-top: 0.9rem;
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--moss); font-weight: 600;
}

/* ============ SPECIAL OFFERS — alternating 50/50 cards ============ */
.ho-special-grid {
    max-width: 1240px; margin: 0 auto;
    display: flex; flex-direction: column; gap: 2.5rem;
}
.ho-special-card {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0;
    background: var(--white);
    border-radius: 16px; overflow: hidden;
    text-decoration: none; color: inherit;
    box-shadow: 0 10px 32px rgba(80,60,30,0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ho-special-card:hover { transform: translateY(-4px); box-shadow: 0 18px 44px rgba(80,60,30,0.14); }
.ho-special-card.reverse { direction: rtl; }
.ho-special-card.reverse > * { direction: ltr; }
.ho-special-ph {
    aspect-ratio: 4 / 3;
    background-size: cover; background-position: center;
    background-color: var(--bg-soft);
    position: relative;
    min-height: 280px;
}
.ho-special-discount {
    position: absolute; top: 20px; left: 20px;
    background: var(--moss); color: var(--bg);
    padding: 0.6rem 1rem;
    border-radius: 999px;
    font-family: 'Manrope', sans-serif;
    font-size: 0.75rem; letter-spacing: 2.5px; text-transform: uppercase;
    font-weight: 700;
}
.ho-special-body {
    padding: 2.4rem 2rem;
    display: flex; flex-direction: column; justify-content: center;
}
.ho-special-eb {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
    margin-bottom: 0.6rem;
}
.ho-special-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 2.5vw, 2.1rem);
    color: var(--moss);
    line-height: 1.15; margin-bottom: 0.8rem;
}
.ho-special-title em { font-style: italic; color: var(--sand-dark); }
.ho-special-desc { color: var(--ink-soft); font-size: 0.95rem; line-height: 1.7; margin-bottom: 1.2rem; }
.ho-special-link {
    font-family: 'Manrope', sans-serif;
    font-size: 0.78rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--moss); font-weight: 700;
}

/* ============ PROMO STRIP — moss band with sprig ============ */
.ho-promo-strip {
    background: var(--moss);
    color: var(--bg);
    padding: 3.5rem 6%;
    text-align: center;
}
.ho-promo-inner { max-width: 880px; margin: 0 auto; }
.ho-promo-sprig {
    width: 60px; height: 22px;
    color: var(--sand);
    margin: 0 auto 1rem;
    display: block;
}
.ho-promo-eb {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 4px; text-transform: uppercase;
    color: var(--sand-soft);
    margin-bottom: 0.7rem;
}
.ho-promo-h {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    color: var(--bg);
    line-height: 1.3;
    margin-bottom: 1.4rem;
}
.ho-promo-h em { font-style: italic; color: var(--sand); }
.ho-promo-btn {
    display: inline-block;
    padding: 0.95rem 2rem;
    background: var(--bg); color: var(--moss);
    border-radius: 999px;
    font-family: 'Manrope', sans-serif;
    font-size: 0.78rem; letter-spacing: 2.5px; text-transform: uppercase;
    font-weight: 600;
    text-decoration: none;
    transition: background 0.3s ease, color 0.3s ease;
}
.ho-promo-btn:hover { background: var(--sand); color: var(--moss); }

/* ============ DUAL PROMO — 50/50 sand+moss split ============ */
.ho-dual-grid {
    max-width: 1280px; margin: 0 auto;
    display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem;
}
.ho-dual-card {
    background: var(--white);
    border-radius: 16px; overflow: hidden;
    text-decoration: none; color: inherit;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ho-dual-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(80,60,30,0.14); }
.ho-dual-ph {
    aspect-ratio: 16 / 9;
    background-size: cover; background-position: center;
    background-color: var(--bg-soft);
}
.ho-dual-body { padding: 1.8rem 1.6rem 2rem; }
.ho-dual-eb {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
    margin-bottom: 0.5rem;
}
.ho-dual-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem; color: var(--moss);
    line-height: 1.15; margin-bottom: 0.7rem;
}
.ho-dual-title em { font-style: italic; color: var(--sand-dark); }
.ho-dual-desc { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.65; margin-bottom: 1rem; }
.ho-dual-link {
    font-family: 'Manrope', sans-serif;
    font-size: 0.74rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--moss); font-weight: 700;
}

/* ============ SUMMER BANNER — blob backdrop + price card ============ */
.ho-summer-banner {
    position: relative;
    overflow: hidden;
    background: var(--bg-soft);
}
.ho-summer-ph {
    height: 540px;
    background-size: cover; background-position: center;
    position: relative;
}
.ho-summer-blob {
    position: absolute;
    top: 50%; right: 6%;
    transform: translateY(-50%);
    width: 480px; height: 480px;
    color: var(--moss);
    opacity: 0.94;
}
.ho-summer-content {
    position: absolute;
    top: 50%; right: 10%;
    transform: translateY(-50%);
    max-width: 360px;
    color: var(--bg);
    text-align: left;
}
.ho-summer-eb {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 4px; text-transform: uppercase;
    color: var(--sand-soft);
    margin-bottom: 0.6rem;
}
.ho-summer-h {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 3.5vw, 2.8rem);
    color: var(--bg); line-height: 1.1;
    margin-bottom: 1rem;
}
.ho-summer-h em { font-style: italic; color: var(--sand); }
.ho-summer-desc { color: var(--sand-soft); line-height: 1.6; margin-bottom: 1.2rem; font-size: 0.95rem; }
.ho-summer-price-card {
    background: var(--bg);
    color: var(--moss);
    padding: 1rem 1.4rem;
    border-radius: 12px;
    display: inline-block;
    margin-bottom: 1.4rem;
}
.ho-summer-price-eb {
    font-family: 'Manrope', sans-serif;
    font-size: 0.65rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
    margin-bottom: 0.2rem;
}
.ho-summer-price {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem; color: var(--moss); font-weight: 600;
    line-height: 1;
}
.ho-summer-price small {
    font-family: 'Manrope', sans-serif;
    font-size: 0.7rem; color: var(--ink-soft); font-weight: 400;
    margin-left: 0.3rem;
}
.ho-summer-btn {
    display: inline-block;
    padding: 0.95rem 1.8rem;
    background: var(--sand); color: var(--moss);
    border-radius: 999px;
    font-family: 'Manrope', sans-serif;
    font-size: 0.78rem; letter-spacing: 2.5px; text-transform: uppercase;
    font-weight: 700; text-decoration: none;
    transition: background 0.3s ease;
}
.ho-summer-btn:hover { background: var(--bg); }

/* ============ HOURS BLOCK — sand-fill cards with sprig ============ */
.ho-hours-grid {
    max-width: 1240px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem;
}
.ho-hours-card {
    background: var(--sand-pale);
    border-radius: 12px;
    padding: 1.8rem 1.4rem;
    text-align: center;
    transition: transform 0.3s ease;
}
.ho-hours-card:hover { transform: translateY(-3px); }
.ho-hours-sprig {
    width: 40px; height: 16px;
    color: var(--moss);
    margin: 0 auto 0.5rem;
    display: block;
}
.ho-hours-day {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; color: var(--moss);
    margin-bottom: 1rem;
}
.ho-hours-day em { font-style: italic; }
.ho-hours-list { list-style: none; padding: 0; margin: 0; }
.ho-hours-list li {
    display: flex; justify-content: space-between;
    padding: 0.5rem 0;
    font-size: 0.88rem; color: var(--ink-soft);
    border-bottom: 1px dashed rgba(47, 74, 58, 0.25);
}
.ho-hours-list li:last-child { border-bottom: 0; }
.ho-hours-list .ho-meal { font-weight: 600; color: var(--moss); }
.ho-hours-list .ho-time { font-family: 'Cormorant Garamond', serif; font-style: italic; }

/* ============ MENU LIST — flat list with leaf bullets ============ */
.ho-menu-list { max-width: 880px; margin: 0 auto; }
.ho-menu-row {
    display: grid; grid-template-columns: 28px 1fr auto; gap: 1.2rem;
    align-items: baseline;
    padding: 1.1rem 0;
    border-bottom: 1px dashed rgba(47, 74, 58, 0.25);
}
.ho-menu-row:last-child { border-bottom: 0; }
.ho-menu-bullet {
    font-size: 1.2rem;
    color: var(--sand-dark);
    line-height: 1;
}
.ho-menu-text { display: flex; flex-direction: column; gap: 0.3rem; }
.ho-menu-name {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; color: var(--moss);
    margin: 0; line-height: 1.15;
}
.ho-menu-name em { font-style: italic; }
.ho-menu-desc { color: var(--ink-soft); font-size: 0.88rem; line-height: 1.5; margin: 0; }
.ho-menu-price {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; color: var(--sand-dark);
    font-weight: 600;
}

/* ============ MENU TABS ============ */
.ho-menu-tabs {
    display: flex; justify-content: center; flex-wrap: wrap; gap: 0.5rem;
    margin-bottom: 2.5rem;
}
.ho-menu-tab {
    background: transparent;
    border: 1px solid var(--moss);
    color: var(--moss);
    padding: 0.65rem 1.4rem;
    border-radius: 999px;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1rem;
    cursor: pointer;
    transition: all 0.25s ease;
}
.ho-menu-tab em { font-style: italic; }
.ho-menu-tab.active, .ho-menu-tab:hover {
    background: var(--moss); color: var(--bg);
}
.ho-menu-group { display: block; }
.ho-menu-group.hidden { display: none; }

/* ============ EVENTS — sprig date cards ============ */
.ho-events-grid {
    max-width: 1240px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(2, 1fr); gap: 1.5rem;
}
.ho-event-card {
    display: grid; grid-template-columns: 140px 1fr; gap: 0;
    background: var(--white);
    border-radius: 14px; overflow: hidden;
    text-decoration: none; color: inherit;
    box-shadow: 0 8px 24px rgba(80,60,30,0.06);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ho-event-card:hover { transform: translateY(-3px); box-shadow: 0 16px 36px rgba(80,60,30,0.12); }
.ho-event-date {
    background: var(--sand-pale);
    padding: 1.5rem 0.5rem;
    text-align: center;
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    border-right: 1px solid rgba(47,74,58,0.15);
}
.ho-event-sprig { width: 30px; height: 12px; color: var(--moss); margin-bottom: 0.5rem; display: block; }
.ho-event-day {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.8rem; color: var(--moss);
    line-height: 1;
}
.ho-event-mon {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
    margin-top: 0.3rem;
}
.ho-event-body { padding: 1.4rem 1.6rem; display: flex; flex-direction: column; justify-content: center; }
.ho-event-cat {
    font-family: 'Manrope', sans-serif;
    font-size: 0.7rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
    margin-bottom: 0.4rem;
}
.ho-event-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; color: var(--moss); line-height: 1.2;
    margin-bottom: 0.4rem;
}
.ho-event-title em { font-style: italic; color: var(--sand-dark); }
.ho-event-time { color: var(--ink-soft); font-size: 0.85rem; }

/* ============ FACILITIES BARS — moss on sand ============ */
.ho-bars-list { max-width: 880px; margin: 0 auto; display: flex; flex-direction: column; gap: 1.8rem; }
.ho-bar-row {}
.ho-bar-head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: 0.5rem;
}
.ho-bar-label {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem; color: var(--moss); margin: 0;
}
.ho-bar-label em { font-style: italic; }
.ho-bar-pct {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem; color: var(--sand-dark);
    font-weight: 600;
}
.ho-bar-track {
    height: 8px; background: var(--sand-pale);
    border-radius: 999px;
    overflow: hidden;
}
.ho-bar-fill {
    height: 100%; background: var(--moss);
    border-radius: 999px;
}
.ho-bar-note {
    color: var(--ink-soft); font-size: 0.85rem;
    margin-top: 0.5rem;
}

/* ============ FACILITIES GRID — 6 icon tiles ============ */
.ho-fac-grid {
    max-width: 1240px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem;
}
.ho-fac-tile {
    background: var(--white);
    padding: 2rem 1.6rem;
    border-radius: 12px;
    text-align: center;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    border: 1px solid rgba(197,165,114,0.18);
}
.ho-fac-tile:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 36px rgba(80,60,30,0.1);
    border-color: var(--sand);
}
.ho-fac-ico {
    font-size: 2rem; color: var(--moss);
    line-height: 1; margin-bottom: 0.9rem;
}
.ho-fac-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem; color: var(--moss);
    margin-bottom: 0.5rem;
}
.ho-fac-title em { font-style: italic; }
.ho-fac-body { color: var(--ink-soft); font-size: 0.88rem; line-height: 1.6; }

/* ============ HISTORY TIMELINE — sprig markers ============ */
.ho-history-section { background: var(--bg-soft); }
.ho-history-rail {
    position: relative;
    max-width: 1100px; margin: 0 auto;
    padding: 1rem 0;
}
.ho-history-spine {
    position: absolute;
    top: 0; bottom: 0; left: 50%;
    width: 1px;
    background: linear-gradient(to bottom, transparent, var(--sand) 8%, var(--sand) 92%, transparent);
    transform: translateX(-50%);
}
.ho-history-step {
    position: relative;
    width: 50%;
    padding: 2rem 3rem;
    box-sizing: border-box;
}
.ho-history-step.ho-step-left { margin-left: 0; }
.ho-history-step.ho-step-right { margin-left: 50%; }
.ho-history-sprig {
    position: absolute;
    top: 2.2rem;
    width: 32px; height: 32px;
    color: var(--moss);
    background: var(--bg-soft);
    border-radius: 50%;
    padding: 4px;
}
.ho-history-step.ho-step-left .ho-history-sprig { right: -16px; }
.ho-history-step.ho-step-right .ho-history-sprig { left: -16px; }
.ho-history-card {
    background: var(--white);
    border-radius: 12px;
    padding: 1.5rem 1.6rem;
    box-shadow: 0 10px 28px rgba(80,60,30,0.08);
}
.ho-history-year {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.8rem; color: var(--sand-dark);
    line-height: 1;
    margin-bottom: 0.4rem;
}
.ho-history-year em { font-style: italic; }
.ho-history-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem; color: var(--moss);
    margin-bottom: 0.6rem;
}
.ho-history-body { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.65; }

/* ============ FEATURE TRIO — circle icons ============ */
.ho-feature-trio {
    max-width: 1240px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
}
.ho-feature-card {
    text-align: center;
    padding: 2.2rem 1.6rem;
    transition: transform 0.3s ease;
}
.ho-feature-card:hover { transform: translateY(-3px); }
.ho-feature-ico {
    width: 80px; height: 80px;
    color: var(--moss);
    margin: 0 auto 1rem;
}
.ho-feature-ico svg { width: 100%; height: 100%; }
.ho-feature-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; color: var(--moss);
    margin-bottom: 0.7rem;
}
.ho-feature-title em { font-style: italic; }
.ho-feature-body { color: var(--ink-soft); line-height: 1.7; margin-bottom: 1rem; font-size: 0.95rem; }
.ho-feature-bullets { list-style: none; padding: 0; margin: 0; text-align: left; max-width: 240px; margin: 0 auto; }
.ho-feature-bullets li {
    padding: 0.35rem 0; color: var(--ink-soft); font-size: 0.88rem;
    display: flex; gap: 0.6rem;
}
.ho-feature-bullets li span { color: var(--sand-dark); flex-shrink: 0; }

/* ============ STATS COUNTERS — sand backplate ============ */
.ho-stats-counters-section {
    position: relative;
    padding: 5rem 6%;
    overflow: hidden;
}
.ho-stats-counters-backplate {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 80%; max-width: 1000px; height: 70%;
    background: var(--sand-pale);
    border-radius: 220px;
    z-index: 0;
}
.ho-stats-counters-section > * { position: relative; z-index: 1; }
.ho-stats-counters-grid {
    max-width: 1100px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem;
}
.ho-stat-counter { text-align: center; padding: 1rem; }
.ho-stat-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(3rem, 6vw, 4.6rem);
    color: var(--moss); line-height: 1;
    display: inline;
}
.ho-stat-suffix {
    font-family: 'Cormorant Garamond', serif;
    font-size: 0.6em; color: var(--sand-dark);
    margin-left: 0.1em;
}
.ho-stat-lbl {
    font-family: 'Manrope', sans-serif;
    font-size: 0.72rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--moss); font-weight: 600;
    margin-top: 0.8rem;
}

/* ============ STATS TRIO — italic row ============ */
.ho-stats-trio-section { padding: 5rem 6%; background: var(--bg-soft); }
.ho-stats-trio-grid {
    max-width: 1000px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
}
.ho-stat-trio { text-align: center; padding: 1rem; }
.ho-stat-trio-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(3.5rem, 6vw, 5rem);
    color: var(--moss); line-height: 1;
    margin-bottom: 0.6rem;
}
.ho-stat-trio-num em { font-style: italic; }
.ho-stat-trio-lbl {
    font-family: 'Manrope', sans-serif;
    font-size: 0.75rem; letter-spacing: 3px; text-transform: uppercase;
    color: var(--sand-dark); font-weight: 600;
}

/* ============ SERVICES GRID — image cards ============ */
.ho-services-grid {
    max-width: 1280px; margin: 0 auto;
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem;
}
.ho-service-card {
    background: var(--white);
    border-radius: 14px; overflow: hidden;
    text-decoration: none; color: inherit;
    box-shadow: 0 10px 28px rgba(80,60,30,0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.ho-service-card:hover { transform: translateY(-5px); box-shadow: 0 18px 40px rgba(80,60,30,0.14); }
.ho-service-ph {
    aspect-ratio: 4 / 3;
    background-size: cover; background-position: center;
    background-color: var(--bg-soft);
}
.ho-service-body { padding: 1.5rem 1.5rem 1.8rem; }
.ho-service-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; color: var(--moss); line-height: 1.15;
    margin-bottom: 0.6rem;
}
.ho-service-title em { font-style: italic; }
.ho-service-desc { color: var(--ink-soft); font-size: 0.92rem; line-height: 1.6; margin-bottom: 1rem; }
.ho-service-link {
    font-family: 'Manrope', sans-serif;
    font-size: 0.74rem; letter-spacing: 2.5px; text-transform: uppercase;
    color: var(--moss); font-weight: 700;
}

/* ============ RESPONSIVE — VRS Wave 2/3 ============ */
@media (max-width: 1100px) {
    .ho-special-card { grid-template-columns: 1fr; }
    .ho-special-card.reverse { direction: ltr; }
    .ho-dual-grid, .ho-feature-trio, .ho-services-grid, .ho-stats-trio-grid { grid-template-columns: repeat(2, 1fr); }
    .ho-fac-grid, .ho-stats-counters-grid { grid-template-columns: repeat(3, 1fr); }
    .ho-hours-grid { grid-template-columns: repeat(2, 1fr); }
    .ho-history-step { width: 100%; padding-left: 4rem; padding-right: 1rem; margin-left: 0 !important; }
    .ho-history-spine { left: 16px; transform: none; }
    .ho-history-step.ho-step-left .ho-history-sprig,
    .ho-history-step.ho-step-right .ho-history-sprig { left: 0; right: auto; }
    .ho-summer-content { right: 6%; max-width: 320px; }
    .ho-summer-blob { width: 380px; height: 380px; right: 0; }
}
@media (max-width: 700px) {
    .ho-events-grid, .ho-dual-grid, .ho-feature-trio, .ho-services-grid,
    .ho-stats-trio-grid, .ho-fac-grid, .ho-hours-grid { grid-template-columns: 1fr; }
    .ho-stats-counters-grid { grid-template-columns: repeat(2, 1fr); }
    .ho-event-card { grid-template-columns: 100px 1fr; }
    .ho-summer-blob { width: 320px; height: 320px; }
    .ho-summer-content { right: 5%; left: 5%; max-width: none; }
    .ho-menu-row { grid-template-columns: 20px 1fr; }
    .ho-menu-row .ho-menu-price { grid-column: 2; }
}
