/*
 * home.css — Haras Santa Amelia (rediseño luxury-hotel)
 * ------------------------------------------------------------
 * Paleta: cream base, charcoal oscuro para secciones dark,
 * dorado como acento. Tipografía: serif fina uppercase.
 * ------------------------------------------------------------
 */

:root {
    --cream:            #f5f1ea;
    --cream-soft:       #faf7f1;
    --ink:              #431321;
    --ink-soft:         #5a1a2a;
    --ink-deep:         #2f0a15;
    --gold:             #b89968;
    --gold-bright:      #c9a25a;
    --gold-soft:        #d9c198;
    --line:             rgba(184,153,104,.3);
    --text-muted-hotel: #8b8273;

    --color-primary:       var(--gold);
    --color-primary-hover: var(--ink);
    --color-primary-text:  #ffffff;

    --font-display:     "Jost", "Josefin Sans", "Inter", system-ui, -apple-system, sans-serif;
    --font-serif:       var(--font-display); /* alias retrocompatible */
    --font-sans:        "Jost", "Inter", system-ui, -apple-system, sans-serif;
    --container-max:    1280px;
}

@import url('https://fonts.googleapis.com/css2?family=Jost:wght@200;300;400;500;600&family=Josefin+Sans:wght@200;300;400&display=swap');

body.home {
    font-family: var(--font-sans);
    font-weight: 400;
    color: var(--ink);
    background: var(--cream-soft);
    font-size: 15px;
    line-height: 1.7;
}

body.home h1, body.home h2, body.home h3, body.home h4 {
    font-family: var(--font-display);
    font-weight: 200;
    letter-spacing: .04em;
    color: var(--ink);
}
body.home .section--dark h1,
body.home .section--dark h2,
body.home .section--dark h3,
body.home .section--dark h4,
body.home .section__title--light,
body.home .act-card__body h3,
body.home .noticias-cover__title,
body.home .noticia-hero__title,
body.home .actividad-hero__title,
body.home .hero__title,
body.home .eventos-cover__title,
body.home .evento-hero__title,
body.home .hgw-hero__title,
body.home .hgw-hero__kicker,
body.home .hgw-hero__lede,
body.home .ce-hero__title,
body.home .ce-hero__kicker,
body.home .ce-hero__lede,
body.home .hist-hero__title,
body.home .hist-hero__kicker,
body.home .hist-hero__lede,
body.home .gastro-hero__title,
body.home .gastro-hero__kicker,
body.home .gastro-hero__lede,
body.home .contacto-hero__title,
body.home .contacto-hero__kicker,
body.home .contacto-hero__lede { color: #fff; }

.container { max-width: var(--container-max); margin: 0 auto; padding: 0 2rem; }

/* =======================================================
   Top bar
   ======================================================= */
.topbar {
    background: var(--ink-deep);
    color: rgba(255,255,255,.85);
    font-size: .72rem;
    letter-spacing: .18em;
    text-transform: uppercase;
}
.topbar__inner { display: flex; align-items: center; justify-content: space-between; height: 38px; }
.topbar__horarios { background: transparent; border: 0; color: inherit; cursor: pointer;
    display: inline-flex; align-items: center; gap: .9rem; font: inherit; letter-spacing: inherit; text-transform: inherit; padding: 0; }
.topbar__status { display: inline-flex; align-items: center; gap: .5rem; }
.topbar__dot { width: 5px; height: 5px; border-radius: 50%; display: inline-block; position: relative; }
.topbar__status--open .topbar__dot { background: #4ade80; box-shadow: 0 0 0 0 rgba(74,222,128,.6); animation: tbpulse 2s infinite; }
.topbar__status--closed .topbar__dot { background: #ef4444; }
@keyframes tbpulse { 0%{box-shadow:0 0 0 0 rgba(74,222,128,.55)} 70%{box-shadow:0 0 0 6px rgba(74,222,128,0)} 100%{box-shadow:0 0 0 0 rgba(74,222,128,0)} }
.topbar__status-text { font-weight: 600; }
.topbar__today { color: rgba(255,255,255,.55); letter-spacing: .15em; padding-left: .9rem; border-left: 1px solid rgba(255,255,255,.15); }
.topbar__toggle { display: inline-flex; align-items: center; gap: .4rem; padding-left: .9rem; border-left: 1px solid rgba(255,255,255,.15); color: var(--gold); transition: color .2s ease; }
.topbar__horarios:hover .topbar__toggle { color: #fff; }
.topbar__chevron { transition: transform .35s ease; }
.topbar__horarios.is-open .topbar__chevron { transform: rotate(180deg); }

.topbar__social { display: flex; gap: .55rem; align-items: center; }
.topbar__social > a {
    color: rgba(255,255,255,.85); text-decoration: none; width: 30px; height: 30px;
    border: 1px solid rgba(255,255,255,.18); border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease;
}
.topbar__social > a svg { display: block; }
.topbar__social > a:hover { background: var(--gold); border-color: var(--gold); color: var(--ink-deep); transform: translateY(-1px); }
.topbar__social > a.topbar__ta-pill {
    width: auto; height: auto; border-radius: 0;
    padding: .55rem 1.4rem; font-size: .7rem; letter-spacing: .22em;
    background: var(--ink); border: 1px solid var(--ink); color: #fff;
    text-transform: uppercase; font-weight: 500;
}
.topbar__social > a.topbar__ta-pill:hover {
    background: var(--ink-deep); border-color: var(--ink-deep); color: #fff;
}

/* Topbar lang-switch (mobile only) */
.lang-switch--topbar { display: none; position: relative; }
.lang-switch--topbar .lang-switch__trigger {
    display: inline-flex; align-items: center; gap: .3rem;
    background: transparent; border: 1px solid rgba(255,255,255,.18);
    padding: 0 .5rem; height: 26px; color: rgba(255,255,255,.85);
    cursor: pointer; font: inherit; letter-spacing: inherit; text-transform: inherit;
    font-size: .65rem; font-weight: 600; border-radius: 999px;
    transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.lang-switch--topbar .lang-switch__trigger:hover { background: var(--gold); border-color: var(--gold); color: var(--ink-deep); }
.lang-switch--topbar .lang-switch__trigger svg { opacity: .85; }
.lang-switch--topbar .lang-switch__menu {
    position: absolute; right: 0; top: calc(100% + .35rem); left: auto;
    min-width: 150px; background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 12px 28px rgba(0,0,0,.18);
    list-style: none; padding: .35rem 0; margin: 0; z-index: 40;
    opacity: 0; visibility: hidden; transform: translateY(-6px);
    transition: .25s;
    text-transform: none; letter-spacing: 0;
}
.lang-switch--topbar.is-open .lang-switch__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-switch--topbar .lang-switch__menu a {
    display: block; padding: .55rem .9rem; text-decoration: none;
    color: var(--ink); font-size: .85rem; transition: .2s;
}
.lang-switch--topbar .lang-switch__menu a:hover { background: var(--cream); color: var(--gold); }
.lang-switch--topbar .lang-switch__menu a.is-active { color: var(--gold); font-weight: 500; }
.topbar__horarios-panel { background: var(--ink); color: #fff; font-size: .8rem; text-transform: none; letter-spacing: 0; max-height: 0; overflow: hidden; opacity: 0; transition: max-height .45s ease, opacity .35s ease, padding .35s ease; padding: 0; }
.topbar__horarios-panel.is-open { max-height: 240px; opacity: 1; padding: 1.1rem 0; }
.topbar__horarios-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: .9rem 2rem; margin: 0; }
.topbar__horarios-item { display: flex; flex-direction: column; gap: .2rem; padding-right: 1rem; border-right: 1px solid rgba(255,255,255,.08); }
.topbar__horarios-item:last-child { border-right: 0; }
.topbar__horarios-label { font-weight: 600; color: var(--gold-soft); letter-spacing: .08em; text-transform: uppercase; font-size: .7rem; }
.topbar__horarios-time { font-size: .92rem; opacity: .92; font-variant-numeric: tabular-nums; }
@media (max-width: 720px){ .topbar__today { display: none; } }
@media (max-width: 600px){
    .topbar { font-size: .62rem; letter-spacing: .12em; }
    .topbar__inner { height: 34px; gap: .5rem; }
    .topbar .container { padding: 0 .85rem; }
    .topbar__horarios { gap: .5rem; }
    .topbar__status { gap: .35rem; }
    .topbar__toggle { padding-left: .55rem; gap: .25rem; }
    .topbar__toggle-text { display: none; }
    .topbar__social { gap: .35rem; }
    .topbar__social > a { width: 26px; height: 26px; }
    .topbar__social > a.topbar__ta-pill { padding: .35rem .7rem; font-size: .6rem; letter-spacing: .14em; }
    .topbar__horarios-grid { grid-template-columns: 1fr 1fr; gap: .7rem 1rem; }
    .topbar__horarios-item { padding-right: .5rem; }
    .topbar__horarios-item:nth-child(2n) { border-right: 0; }
}
@media (max-width: 460px){
    .topbar__horarios-grid { grid-template-columns: 1fr; gap: .55rem 0; }
    .topbar__horarios-item { border-right: 0; padding-right: 0; }
}

/* =======================================================
   Navbar blanca sticky con logo centrado
   ======================================================= */
.navbar {
    position: sticky; top: 0; z-index: 30;
    background: #fff;
    box-shadow: 0 1px 0 rgba(0,0,0,.06);
}
.navbar__inner {
    display: grid; grid-template-columns: 1fr auto 1fr;
    align-items: center; height: 64px;
}
.navbar__logo {
    justify-self: center;
    display: block; text-decoration: none; line-height: 0;
}
.navbar__logo img { max-height: 42px; width: auto; display: block; }
.navbar__logo-text {
    font-family: var(--font-display); color: var(--ink-deep);
    display: flex; flex-direction: column; line-height: 1; letter-spacing: .05em;
    align-items: center;
}
.navbar__logo-text span { font-size: .7rem; text-transform: uppercase; letter-spacing: .3em; color: var(--gold); }
.navbar__logo-text strong { font-size: 1.35rem; font-weight: 300; margin-top: .35rem; letter-spacing: .12em; }

/* Burger (izquierda) */
.burger {
    justify-self: start;
    display: inline-flex; align-items: center; gap: .9rem;
    background: transparent; border: 0; padding: .5rem;
    cursor: pointer; color: var(--ink);
    font-family: var(--font-sans);
    font-size: .75rem; letter-spacing: .28em; text-transform: uppercase; font-weight: 500;
}
.burger__label { transition: color .25s; }
.burger__icon {
    position: relative; width: 28px; height: 18px; display: inline-block;
}
.burger__icon span {
    position: absolute; left: 0; right: 0; height: 1.5px; background: var(--ink);
    transform-origin: center; transition: transform .4s cubic-bezier(.77,0,.18,1), top .3s .1s, opacity .2s, width .4s cubic-bezier(.77,0,.18,1);
}
.burger__icon span:nth-child(1) { top: 0; }
.burger__icon span:nth-child(2) { top: 8px; width: 70%; }
.burger__icon span:nth-child(3) { top: 16px; }
.burger:hover .burger__icon span { background: var(--gold); }
.burger:hover .burger__icon span:nth-child(2) { width: 100%; }
.burger:hover .burger__label { color: var(--gold); }
.burger.is-active .burger__icon span:nth-child(1) { top: 8px; transform: rotate(45deg); transition: top .3s, transform .4s .2s cubic-bezier(.77,0,.18,1); }
.burger.is-active .burger__icon span:nth-child(2) { opacity: 0; width: 0; }
.burger.is-active .burger__icon span:nth-child(3) { top: 8px; transform: rotate(-45deg); transition: top .3s, transform .4s .2s cubic-bezier(.77,0,.18,1); }

/* Language switcher */
.lang-switch { justify-self: end; position: relative; }
.lang-switch__trigger {
    display: inline-flex; align-items: center; gap: .5rem;
    background: transparent; border: 1px solid rgba(0,0,0,.1);
    padding: .55rem .9rem; cursor: pointer; color: var(--ink);
    font-family: var(--font-sans);
    font-size: .72rem; letter-spacing: .2em; text-transform: uppercase; font-weight: 500;
    transition: .25s;
}
.lang-switch__trigger:hover { border-color: var(--gold); color: var(--gold); }
.lang-switch__trigger svg { opacity: .7; }
.lang-switch__menu {
    position: absolute; right: 0; top: calc(100% + .4rem);
    min-width: 160px; background: #fff;
    border: 1px solid rgba(0,0,0,.08);
    box-shadow: 0 12px 28px rgba(0,0,0,.08);
    list-style: none; padding: .4rem 0; margin: 0;
    opacity: 0; visibility: hidden; transform: translateY(-6px);
    transition: .25s;
}
.lang-switch.is-open .lang-switch__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.lang-switch__menu a {
    display: block; padding: .6rem 1rem; text-decoration: none;
    color: var(--ink); font-size: .85rem;
    transition: .2s;
}
.lang-switch__menu a:hover { background: var(--cream); color: var(--gold); }
.lang-switch__menu a.is-active { color: var(--gold); font-weight: 500; }

/* =======================================================
   Off-canvas menu (hamburguesa)
   ======================================================= */
.off-canvas {
    position: fixed; inset: 0; z-index: 50;
    pointer-events: none;
}
.off-canvas.is-open { pointer-events: auto; }
.off-canvas__backdrop {
    position: absolute; inset: 0;
    background: rgba(15,12,10,.65);
    opacity: 0; transition: opacity .4s ease;
}
.off-canvas.is-open .off-canvas__backdrop { opacity: 1; }
.off-canvas__panel {
    position: absolute; top: 0; bottom: 0; left: 0;
    width: min(440px, 90vw);
    background: var(--ink-deep); color: #fff;
    padding: 3rem 3rem 2rem;
    display: flex; flex-direction: column;
    transform: translateX(-100%);
    transition: transform .55s cubic-bezier(.77,0,.18,1);
    overflow-y: auto;
}
.off-canvas.is-open .off-canvas__panel { transform: translateX(0); }
.off-canvas__panel { scrollbar-width: thin; scrollbar-color: var(--gold) transparent; }
.off-canvas__panel::-webkit-scrollbar { width: 6px; }
.off-canvas__panel::-webkit-scrollbar-track { background: transparent; margin: 1.5rem 0; }
.off-canvas__panel::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, var(--gold), var(--gold-bright));
    border-radius: 10px;
}
.off-canvas__panel::-webkit-scrollbar-thumb:hover { background: var(--gold-bright); }
.off-canvas__close {
    position: absolute; top: 1.8rem; right: 2rem;
    width: 32px; height: 32px; background: transparent; border: 0; cursor: pointer; padding: 0;
}
.off-canvas__close span {
    position: absolute; left: 4px; right: 4px; top: 50%; height: 1.5px; background: #fff;
    transition: background .25s;
}
.off-canvas__close span:nth-child(1) { transform: rotate(45deg); }
.off-canvas__close span:nth-child(2) { transform: rotate(-45deg); }
.off-canvas__close:hover span { background: var(--gold); }

.off-canvas__brand { margin-bottom: 2rem; padding-top: .5rem; }
.off-canvas__brand img { max-height: 56px; width: auto; filter: brightness(0) invert(1) drop-shadow(0 0 1px var(--gold)); }
@media (max-width: 600px){
    .off-canvas__brand img { max-height: 42px; }
    .off-canvas__brand { margin-bottom: 1.4rem; }
}
.off-canvas__brand .navbar__logo-text { align-items: flex-start; color: #fff; }
.off-canvas__brand .navbar__logo-text span { color: var(--gold); }
.off-canvas__brand .navbar__logo-text strong { color: #fff; }

.off-canvas__list { list-style: none; padding: 0; margin: 0; flex: 1; }
.off-canvas__list li {
    opacity: 0; transform: translateX(-20px);
    transition: opacity .5s, transform .5s;
    transition-delay: calc(var(--i, 1) * 60ms);
}
.off-canvas.is-open .off-canvas__list li { opacity: 1; transform: translateX(0); }
.off-canvas__list a {
    display: block; padding: .9rem 0;
    color: rgba(255,255,255,.9); text-decoration: none;
    font-family: var(--font-display);
    font-size: 1.7rem; font-weight: 200; letter-spacing: .04em;
    border-bottom: 1px solid rgba(255,255,255,.08);
    transition: color .25s, padding-left .35s ease;
    position: relative;
}
.off-canvas__list a::before {
    content: ""; position: absolute; left: 0; top: 50%; width: 0; height: 1px;
    background: var(--gold); transition: width .35s ease;
}
.off-canvas__list a:hover { color: var(--gold); padding-left: 2.2rem; }
.off-canvas__list a:hover::before { width: 1.5rem; }

.off-canvas__foot {
    margin-top: 2.5rem; padding-top: 2rem;
    border-top: 1px solid rgba(255,255,255,.1);
    display: flex; flex-direction: column; gap: .5rem;
    font-size: .88rem; color: rgba(255,255,255,.65);
}
.off-canvas__foot a { color: var(--gold); text-decoration: none; }
.off-canvas__foot a:hover { color: #fff; }

@media (max-width: 600px) {
    .burger__label { display: none; }
    .navbar .container { padding: 0 .85rem; }
    .navbar__inner { height: 64px; gap: .75rem; grid-template-columns: 1fr auto 1fr; }
    .navbar__logo img { max-height: 36px; }
    .burger { padding: .45rem .25rem; gap: 0; }
    .burger__icon { width: 24px; height: 16px; }
    .burger__icon span:nth-child(3) { top: 14px; }
    .navbar__right { gap: .25rem; }
    .navbar__right .lang-switch { display: none; }
    .navbar__cart { width: 36px; height: 36px; }
    .lang-switch--topbar { display: inline-block; }
    .off-canvas__panel { padding: 2.5rem 2rem; }
    .off-canvas__list a { font-size: 1.35rem; }
}

/* =======================================================
   Hero
   ======================================================= */
.hero {
    min-height: calc(100vh - 132px);
    background:
        linear-gradient(135deg, var(--ink-deep) 0%, var(--ink) 55%, var(--ink-soft) 100%)
        center/cover no-repeat;
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    text-align: center;
    padding: 5rem 1rem;
    position: relative;
}
.hero[style*="background-image"] { background-color: var(--ink-deep); }
.hero__slides { position: absolute; inset: 0; overflow: hidden; z-index: 0; }
.hero__slide {
    position: absolute; inset: 0;
    background-position: center; background-size: cover; background-repeat: no-repeat;
    opacity: 0; transition: opacity 1.4s ease-in-out;
    transform: scale(1.05);
}
.hero__slide.is-active { opacity: 1; animation: heroKenBurns 8s ease-out forwards; }
@keyframes heroKenBurns {
    from { transform: scale(1.08); }
    to   { transform: scale(1.0); }
}
.hero::before {
    content: ""; position: absolute; inset: 0; z-index: 1;
    background: linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.45) 40%, rgba(0,0,0,.70) 100%);
}
.hero__inner, .hero__scroll { position: relative; z-index: 2; }
.hero, .hero *,
.hero__title, .hero__tagline, .hero__sub, .hero__eyebrow,
.hero__stars, .hero__scroll,
.hero .btn, .hero__ctas .btn, .hero__ctas .btn--brand { color: #fff !important; }
.hero__ctas .btn,
.hero__ctas .btn--brand {
    background: var(--ink) !important;
    border: 1px solid rgba(255,255,255,.35) !important;
    color: #fff !important;
    padding: .55rem 1.8rem;
    letter-spacing: .2em;
    font-size: .78rem;
    font-weight: 500;
    text-transform: uppercase;
    border-radius: 0;
    transition: background .25s ease, transform .25s ease, border-color .25s ease;
}
.hero__ctas .btn:hover,
.hero__ctas .btn--brand:hover {
    background: var(--ink-deep) !important;
    border-color: #fff !important;
    color: #fff !important;
    transform: translateY(-2px);
}
.hero__eyebrow { padding: .55rem 2rem; border: 1px solid rgba(255,255,255,.3); }
.hero__sub { color: rgba(255,255,255,.75) !important; }
.hero__title { text-shadow: 0 4px 30px rgba(0,0,0,.5); }
.hero__tagline { text-shadow: 0 2px 20px rgba(0,0,0,.4); }
.hero__inner { max-width: 1000px; position: relative; z-index: 2; }
.hero__stars { display: none; }
.hero__eyebrow {
    display: inline-block;
    background: var(--ink);
    color: #fff !important;
    font-size: .85rem; letter-spacing: .22em; text-transform: uppercase;
    padding: .95rem 3rem; margin: 0 auto 2.5rem; font-weight: 500;
    box-shadow: 0 10px 30px -10px rgba(0,0,0,.5);
}
.hero__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2.8rem, 7vw, 5.5rem);
    color: #fff;
    margin: 0 0 1.8rem;
    text-transform: uppercase;
    letter-spacing: .18em;
    line-height: 1.1;
}
.hero__tagline { font-size: 1rem; max-width: 620px; margin: 0 auto 2.5rem; line-height: 1.7; color: rgba(255,255,255,.88); }
.hero__ctas { display: flex; gap: 1rem; flex-wrap: wrap; justify-content: center; margin-bottom: 2.5rem; }
.hero__sub { font-size: .8rem; letter-spacing: .15em; text-transform: uppercase; color: rgba(255,255,255,.6); margin: 0; }
.hero__scroll {
    position: absolute; right: 2rem; top: 50%; transform: rotate(90deg) translateX(50%); transform-origin: right top;
    color: rgba(255,255,255,.55); font-size: .7rem; letter-spacing: .4em; text-transform: uppercase; z-index: 2;
}
.hero__scroll::after { content: ""; display: block; width: 80px; height: 1px; background: rgba(255,255,255,.3); margin-top: .7rem; }
@media (max-width: 800px) { .hero__scroll { display: none; } }
@media (max-width: 720px) {
    .hero {
        min-height: calc(100svh - 60px);
        padding: 3.5rem 1.25rem 4rem;
    }
    .hero__inner { padding: 0; }
    .hero__eyebrow {
        font-size: .68rem; letter-spacing: .18em;
        padding: .65rem 1.4rem; margin-bottom: 1.5rem;
    }
    .hero__title {
        font-size: clamp(1.9rem, 9vw, 2.6rem);
        letter-spacing: .12em;
        margin: 0 0 1.1rem;
        line-height: 1.15;
    }
    .hero__tagline {
        font-size: .92rem; line-height: 1.6;
        margin: 0 auto 1.8rem;
        max-width: 90%;
    }
    .hero__ctas { gap: .6rem; margin-bottom: 1.8rem; }
    .hero__ctas .btn,
    .hero__ctas .btn--brand {
        padding: .7rem 1.3rem !important;
        font-size: .72rem;
        letter-spacing: .16em;
    }
    .hero__sub { font-size: .7rem; letter-spacing: .12em; }
}
@media (max-width: 420px) {
    .hero__title { font-size: clamp(1.7rem, 8.5vw, 2.1rem); letter-spacing: .08em; }
    .hero__ctas { display: grid; grid-template-columns: 1fr; gap: .55rem; width: 100%; max-width: 280px; margin-left: auto; margin-right: auto; }
    .hero__ctas .btn,
    .hero__ctas .btn--brand { width: 100%; text-align: center; padding: .7rem .8rem !important; font-size: .68rem; letter-spacing: .14em; white-space: nowrap; }
}
@media (max-width: 640px) {
    .hero__title .hero__title-w1,
    .hero__title .hero__title-w2 { display: block; }
    .hero__title .hero__title-w1 { font-size: .82em; letter-spacing: .12em; }
}

/* =======================================================
   Feature strip (4 columnas debajo del hero)
   ======================================================= */
.feature-strip {
    background: #fff;
    border-top: 1px solid var(--line);
    border-bottom: 1px solid var(--line);
    padding: 3rem 0;
}
.feature-strip__grid {
    display: grid; grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 900px) { .feature-strip__grid { grid-template-columns: repeat(2, 1fr); gap: 2rem 1rem; } }
@media (max-width: 500px) {
    .feature-strip { padding: 2rem 0; }
    .feature-strip__grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem .5rem; }
    .feature-strip__item { padding: 1rem .6rem; }
    .feature-strip__icon { width: 36px; height: 36px; margin: 0 auto .7rem; }
    .feature-strip__title { font-size: 1rem; }
    .feature-strip__desc { font-size: .78rem; line-height: 1.5; }
    .feature-strip__more { font-size: .6rem; letter-spacing: .16em; opacity: 1; transform: none; margin-top: .55rem; }
}
.feature-strip__item {
    text-align: center; padding: 1.25rem 1.5rem; position: relative;
    background: transparent; border: 0; cursor: pointer; font: inherit; color: inherit;
    display: flex; flex-direction: column; align-items: center; justify-content: flex-start;
    transition: transform .45s cubic-bezier(.2,.7,.2,1), background .35s ease;
    border-radius: 4px;
}
.feature-strip__item:hover { transform: translateY(-6px); background: rgba(184,153,104,.04); }
.feature-strip__item:focus-visible { outline: 2px solid var(--gold); outline-offset: 4px; }
.feature-strip__item + .feature-strip__item::before {
    content: ""; position: absolute; left: 0; top: 10%; bottom: 10%; width: 1px; background: var(--line);
    transition: opacity .3s ease;
}
.feature-strip__item:hover + .feature-strip__item::before,
.feature-strip__item:hover::before { opacity: 0; }
@media (max-width: 900px) { .feature-strip__item + .feature-strip__item::before { display: none; } }
.feature-strip__icon {
    width: 44px; height: 44px; color: var(--gold); margin: 0 auto 1rem;
    display: flex; align-items: center; justify-content: center;
    transition: transform .5s cubic-bezier(.2,.7,.2,1), color .3s ease;
}
.feature-strip__item:hover .feature-strip__icon { transform: scale(1.12) rotate(-3deg); color: var(--gold-bright); }
.feature-strip__icon svg { width: 100%; height: 100%; stroke: currentColor; stroke-width: 1.2; fill: none; }
.feature-strip__title {
    font-family: var(--font-display); font-size: 1.2rem; font-weight: 300; margin: 0 0 .5rem; color: var(--ink); letter-spacing: .04em;
    position: relative; display: inline-block;
}
.feature-strip__title::after {
    content: ""; position: absolute; left: 50%; bottom: -6px; width: 0; height: 1px;
    background: var(--gold); transform: translateX(-50%);
    transition: width .4s cubic-bezier(.2,.7,.2,1);
}
.feature-strip__item:hover .feature-strip__title::after { width: 38px; }
.feature-strip__desc { font-size: .88rem; color: var(--text-muted-hotel); margin: 0; line-height: 1.6; }
.feature-strip__more {
    margin-top: .8rem; font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
    color: var(--gold); opacity: 0; transform: translateY(4px);
    transition: opacity .35s ease, transform .35s ease;
}
.feature-strip__more span { display: inline-block; transition: transform .3s ease; }
.feature-strip__item:hover .feature-strip__more { opacity: 1; transform: translateY(0); }
.feature-strip__item:hover .feature-strip__more span { transform: translateX(4px); }

/* =======================================================
   Feature-strip modal
   ======================================================= */
.fs-modal {
    position: fixed; inset: 0; z-index: 80;
    display: flex; align-items: center; justify-content: center;
    pointer-events: none;
}
.fs-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(15,12,10,.72); opacity: 0;
    transition: opacity .35s ease;
}
.fs-modal.is-open { pointer-events: auto; }
.fs-modal.is-open .fs-modal__backdrop { opacity: 1; }
.fs-modal__panel {
    position: relative; z-index: 1;
    background: var(--cream-soft); color: var(--ink);
    width: min(560px, 92vw); max-height: 86vh; overflow-y: auto;
    padding: 3rem 2.5rem 2.5rem;
    border: 1px solid var(--line);
    box-shadow: 0 30px 80px rgba(15,12,10,.45);
    transform: translateY(20px) scale(.96); opacity: 0;
    transition: transform .45s cubic-bezier(.2,.7,.2,1), opacity .35s ease;
    display: none;
}
.fs-modal.is-open .fs-modal__panel.is-active {
    display: block;
}
.fs-modal.is-open .fs-modal__panel.is-active {
    animation: fsModalIn .45s cubic-bezier(.2,.7,.2,1) forwards;
}
@keyframes fsModalIn {
    from { transform: translateY(20px) scale(.96); opacity: 0; }
    to   { transform: translateY(0) scale(1); opacity: 1; }
}
.fs-modal__close {
    position: absolute; top: 1rem; right: 1rem;
    width: 36px; height: 36px; border-radius: 50%;
    background: transparent; border: 1px solid var(--line); color: var(--ink);
    display: inline-flex; align-items: center; justify-content: center; cursor: pointer;
    transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.fs-modal__close:hover { background: var(--ink-deep); color: #fff; border-color: var(--ink-deep); }
.fs-modal__icon {
    width: 52px; height: 52px; color: var(--gold); margin: 0 0 1.2rem;
}
.fs-modal__icon svg { width: 100%; height: 100%; stroke: currentColor; stroke-width: 1.2; fill: none; }
.fs-modal__title {
    font-family: var(--font-display); font-weight: 200; font-size: 2rem; letter-spacing: .03em;
    margin: 0 0 1.2rem; color: var(--ink);
}
.fs-modal__body { font-size: .95rem; line-height: 1.75; color: var(--ink-soft); }
.fs-modal__body p { margin: 0 0 .9rem; }
.fs-modal__body strong { color: var(--ink); font-weight: 500; }
.fs-modal__cta {
    display: inline-flex; align-items: center; gap: .6rem;
    margin-top: 1.5rem; padding: .8rem 1.6rem;
    background: var(--ink-deep); color: #fff; text-decoration: none;
    font-size: .78rem; letter-spacing: .22em; text-transform: uppercase; font-weight: 500;
    border: 1px solid var(--ink-deep);
    transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.fs-modal__cta:hover { background: var(--gold); border-color: var(--gold); color: var(--ink-deep); }
@media (max-width: 600px){
    .fs-modal__panel { padding: 2.5rem 1.5rem 2rem; }
    .fs-modal__title { font-size: 1.5rem; }
}

/* =======================================================
   Section scaffolding
   ======================================================= */
.section { padding: 7rem 0; background: var(--cream-soft); }
.section--welcome { background: #F0EFF0; padding: 6rem 0; }

/* Welcome territorio layout */
.welcome-grid {
    display: grid; grid-template-columns: 1fr 1.3fr; gap: 5rem;
    align-items: center;
}
@media (max-width: 1000px) { .welcome-grid { grid-template-columns: 1fr; gap: 3rem; } }
.welcome-text { max-width: 460px; }
.welcome-logo { max-width: 120px; height: auto; margin-bottom: 2rem; display: block; }
.welcome-title {
    font-family: var(--font-display); font-weight: 300;
    font-size: clamp(2.4rem, 4.2vw, 3.6rem);
    text-transform: uppercase; letter-spacing: .02em;
    color: var(--ink); line-height: 1.05; margin: 0 0 2rem;
}
.welcome-lede {
    color: #5a5a5a; font-size: 1rem; line-height: 1.7;
    margin: 0 0 2rem;
}
.welcome-btn {
    background: var(--ink) !important; color: #fff !important;
    border: 1px solid var(--ink) !important; border-radius: 0;
    padding: .95rem 2rem; font-size: .75rem; letter-spacing: .22em;
    text-transform: uppercase; font-weight: 500;
}
.welcome-btn:hover { background: var(--ink-deep) !important; border-color: var(--ink-deep) !important; }

.welcome-visual { display: flex; flex-direction: column; gap: 0; }
.welcome-image {
    width: 100%; aspect-ratio: 16/10;
    background: #e5e0d6 center/cover no-repeat;
    box-shadow: 0 20px 50px -25px rgba(47,10,21,.35);
}
.welcome-hours {
    background: #fff; padding: 1.5rem 2rem;
    margin: -3rem 2rem 0 auto; width: calc(100% - 4rem); max-width: 560px;
    position: relative; z-index: 2;
    box-shadow: 0 15px 40px -20px rgba(47,10,21,.3);
    border-top: 2px solid var(--gold);
}
.welcome-hours__head {
    display: flex; align-items: center; gap: .8rem;
    padding-bottom: .8rem; margin-bottom: .8rem;
    border-bottom: 1px solid rgba(0,0,0,.08);
}
.welcome-hours__ico {
    width: 22px; height: 22px; color: var(--gold);
    display: inline-flex; align-items: center; justify-content: center;
}
.welcome-hours__ico svg { width: 100%; height: 100%; }
.welcome-hours__head h4 {
    font-family: var(--font-display); font-weight: 500;
    font-size: .82rem; letter-spacing: .22em; text-transform: uppercase;
    color: var(--ink); margin: 0;
}
.welcome-hours ul { list-style: none; padding: 0; margin: 0; }
.welcome-hours li {
    display: flex; align-items: center; gap: .5rem;
    padding: .4rem 0; font-size: .82rem;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--ink);
}
.welcome-hours__day { font-weight: 500; flex-shrink: 0; }
.welcome-hours__leader {
    flex: 1; border-bottom: 2px dotted rgba(67,19,33,.3);
    margin: 0 .3rem; height: 1px; align-self: center;
}
.welcome-hours__time { font-weight: 400; flex-shrink: 0; color: #5a5a5a; }
@media (max-width: 600px) {
    .welcome-hours { margin: -2rem 1rem 0; width: calc(100% - 2rem); padding: 1.2rem 1.2rem; }
    .welcome-hours li { font-size: .72rem; letter-spacing: .1em; }
}

/* =======================================================
   Ubicación + Contacto (fusionados)
   ======================================================= */
.section--contacto { padding: 6rem 0; position: relative; overflow: hidden; }
.section--contacto::before {
    content: ""; position: absolute; top: -180px; left: -180px;
    width: 520px; height: 520px; border-radius: 50%;
    background: radial-gradient(circle, rgba(184,153,104,.08), transparent 70%);
    pointer-events: none;
}
.contacto-grid {
    display: grid; grid-template-columns: 1fr 1.1fr; gap: 5rem;
    align-items: start; position: relative; z-index: 1;
}
@media (max-width: 1000px) { .contacto-grid { grid-template-columns: 1fr; gap: 3rem; } }
.contacto-info .section__title { margin-bottom: .5rem; }
.contacto-lede {
    color: rgba(255,255,255,.78); font-size: 1.02rem; line-height: 1.75;
    max-width: 480px; margin: 1.5rem 0 2.5rem;
}
.contacto-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1.1rem; }
.contacto-list li {
    display: flex; align-items: center; gap: 1rem;
    padding: .9rem 1.2rem;
    background: rgba(255,255,255,.03);
    border-left: 2px solid var(--gold);
    transition: background .25s, transform .25s;
}
.contacto-list li:hover { background: rgba(255,255,255,.06); transform: translateX(4px); }
.contacto-list__ico {
    width: 38px; height: 38px; color: var(--gold); flex-shrink: 0;
    display: inline-flex; align-items: center; justify-content: center;
}
.contacto-list__ico svg { width: 22px; height: 22px; }
.contacto-list li div { display: flex; flex-direction: column; line-height: 1.3; }
.contacto-list li small {
    color: rgba(255,255,255,.5); font-size: .68rem;
    letter-spacing: .22em; text-transform: uppercase; margin-bottom: .15rem;
}
.contacto-list li a, .contacto-list li span { color: #fff; text-decoration: none; font-size: .98rem; }
.contacto-list li a:hover { color: var(--gold); }

.contacto-visual { display: flex; flex-direction: column; gap: 1.2rem; }

.contacto-switch {
    position: relative; display: inline-flex; gap: 0;
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(184,153,104,.3);
    padding: 4px; align-self: flex-start;
}
.contacto-switch__btn {
    position: relative; z-index: 2;
    background: transparent; border: 0; cursor: pointer;
    padding: .65rem 1.4rem; color: rgba(255,255,255,.65);
    font: inherit; font-size: .72rem; letter-spacing: .22em;
    text-transform: uppercase; font-weight: 500;
    display: inline-flex; align-items: center; gap: .5rem;
    transition: color .3s ease;
}
.contacto-switch__btn svg { width: 14px; height: 14px; }
.contacto-switch__btn.is-active { color: var(--ink-deep); }
.contacto-switch__thumb {
    position: absolute; top: 4px; bottom: 4px; left: 4px;
    background: var(--gold);
    transition: left .35s cubic-bezier(.77,0,.18,1), width .35s cubic-bezier(.77,0,.18,1);
    z-index: 1;
}

.contacto-panels { position: relative; }
.contacto-panel { display: none; animation: contFade .4s ease; }
.contacto-panel.is-active { display: block; }
@keyframes contFade { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }
.contacto-map {
    aspect-ratio: 16/10; background: #000;
    border: 1px solid rgba(184,153,104,.25);
    box-shadow: 0 20px 50px -20px rgba(0,0,0,.6);
    overflow: hidden;
}
.contacto-map iframe { width: 100%; height: 100%; border: 0; display: block; filter: grayscale(.35) contrast(1.05); }
.contacto-map__placeholder {
    display: flex; align-items: center; justify-content: center; height: 100%;
    color: rgba(255,255,255,.4); font-size: .9rem;
}

.contacto-form {
    background: rgba(255,255,255,.04);
    border: 1px solid rgba(184,153,104,.2);
    padding: 2rem;
}
.contacto-form h3 {
    font-family: var(--font-display); font-weight: 300; font-size: 1.4rem;
    color: #fff; margin: 0 0 1.2rem; letter-spacing: .05em;
}
.contacto-form input, .contacto-form textarea {
    width: 100%; background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.15);
    color: #fff; padding: .8rem 1rem; font: inherit; margin-bottom: .8rem;
}
.contacto-form input::placeholder, .contacto-form textarea::placeholder { color: rgba(255,255,255,.4); }
.contacto-form input:focus, .contacto-form textarea:focus { outline: 0; border-color: var(--gold); }
.contacto-form button, .contacto-form .btn {
    background: var(--gold) !important; border-color: var(--gold) !important;
    color: var(--ink-deep) !important;
}
.section--center { text-align: center; }
.section--cream { background: var(--cream); }
.section--dark { background: var(--ink-deep); color: rgba(255,255,255,.88); }
.section--dark h2, .section--dark h3 { color: #fff; }
.section__eyebrow {
    font-size: .75rem; letter-spacing: .35em; text-transform: uppercase;
    color: var(--gold); margin: 0 0 1.2rem; font-weight: 400;
}
.section__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2rem, 4vw, 3.2rem);
    margin: 0 0 1.5rem; line-height: 1.2;
    letter-spacing: .04em;
}
.section__title--light { color: #fff; }
.section__title--xl { font-size: clamp(3rem, 6vw, 5rem); font-weight: 200; letter-spacing: -.005em; }
.section__lede { max-width: 680px; margin: 0 0 2.5rem; font-size: 1rem; color: var(--text-muted-hotel); line-height: 1.8; }
.section--center .section__lede { margin-left: auto; margin-right: auto; }
.section__divider {
    width: 40px; height: 1px; background: var(--gold); margin: 0 0 2rem;
}
.section--center .section__divider { margin-left: auto; margin-right: auto; }

/* =======================================================
   Welcome (2 imágenes overlapping + texto)
   ======================================================= */
.welcome-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center;
}
@media (max-width: 900px) { .welcome-grid { grid-template-columns: 1fr; gap: 3rem; } }
.welcome-images { position: relative; height: 560px; }
.welcome-images__a, .welcome-images__b {
    position: absolute; background: #3a2a1e center/cover no-repeat;
    box-shadow: 0 20px 50px rgba(0,0,0,.18);
}
.welcome-images__a { width: 62%; height: 70%; top: 0; left: 0; }
.welcome-images__b { width: 62%; height: 70%; bottom: 0; right: 0; }
@media (max-width: 900px) { .welcome-images { height: 420px; } }

/* =======================================================
   Reviews bar
   ======================================================= */
.reviews-bar {
    background: #fff; padding: 2.5rem 0;
    border-bottom: 1px solid var(--line);
}
.reviews-bar__grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
    align-items: center;
}
@media (max-width: 700px) {
    .reviews-bar { padding: 1.4rem 0; }
    .reviews-bar .container { padding: 0 .75rem; }
    .reviews-bar__grid { grid-template-columns: repeat(3, 1fr); gap: 0; align-items: stretch; }
    .review-badge { flex-direction: column; align-items: center; text-align: center; gap: .35rem; padding: .25rem .35rem; position: relative; }
    .review-badge + .review-badge::before { content: ""; position: absolute; left: 0; top: 15%; bottom: 15%; width: 1px; background: var(--line); }
    .review-badge__mark { display: none; }
    .review-badge > div { display: flex; flex-direction: column; align-items: center; gap: .3rem; }
    .review-badge__score { font-size: 1.1rem; line-height: 1; }
    .review-badge__score small { display: block; margin: .25rem 0 0; font-size: .58rem; letter-spacing: .14em; text-transform: uppercase; color: #2e8a3a; }
    .review-badge__meta { font-size: .55rem; letter-spacing: .14em; line-height: 1.3; }
}
.review-badge {
    display: flex; align-items: center; gap: 1rem;
    justify-content: center;
}
.review-badge__mark {
    width: 38px; height: 38px;
    background: transparent; color: var(--gold);
    display: flex; align-items: center; justify-content: center;
}
.review-badge__mark svg { width: 26px; height: 26px; }
.review-badge__score { font-family: var(--font-display); font-size: 1.4rem; color: var(--ink); }
.review-badge__score small { color: #2e8a3a; font-size: .8rem; letter-spacing: .05em; margin-left: .3rem; }
.review-badge__meta { font-size: .75rem; color: var(--text-muted-hotel); text-transform: uppercase; letter-spacing: .1em; }

/* =======================================================
   Rooms / Bungalows (dark card con imagen al lado)
   ======================================================= */
.rooms-block {
    background: #fff; display: grid; grid-template-columns: 5fr 7fr;
    box-shadow: 0 30px 60px rgba(0,0,0,.08);
}
@media (max-width: 900px) { .rooms-block { grid-template-columns: 1fr; } }
.rooms-block__info { padding: 3rem 2.8rem; }
.rooms-block__price {
    font-size: .78rem; letter-spacing: .2em; text-transform: uppercase; color: var(--text-muted-hotel); margin: 0 0 .4rem;
}
.rooms-block__price strong { font-family: var(--font-display); font-size: 2.5rem; color: var(--ink); letter-spacing: 0; display: block; margin-top: .2rem; }
.rooms-block__name { font-family: var(--font-display); font-size: 2rem; font-weight: 300; margin: 1rem 0 1.2rem; letter-spacing: .04em; }
.rooms-block__desc { color: var(--text-muted-hotel); font-size: .95rem; line-height: 1.7; margin-bottom: 2rem; }
.rooms-block__specs {
    display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.5rem;
    border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
    padding: 1.2rem 0; margin-bottom: 2rem;
}
.rooms-block__spec {
    display: flex; align-items: center; gap: .6rem;
    font-size: .78rem; letter-spacing: .15em; text-transform: uppercase; color: var(--ink);
}
.rooms-block__spec svg { width: 18px; height: 18px; color: var(--gold); flex-shrink: 0; }
.rooms-block__actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.rooms-block__media { background: #222 center/cover no-repeat; min-height: 500px; }
/* Imagen inline (entre desc y specs) sólo se ve en mobile; en desktop manda la externa */
.rooms-block__media--inline { display: none; }

/* =======================================================
   Activity cards (actividades en el haras — grid oscuro)
   ======================================================= */
.act-grid {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 2rem; margin-top: 3rem;
}
.act-grid > .act-card { flex: 0 1 calc((100% - 6rem) / 4); max-width: calc((100% - 6rem) / 4); }
@media (max-width: 1100px) { .act-grid > .act-card { flex-basis: calc((100% - 4rem) / 3); max-width: calc((100% - 4rem) / 3); } }
@media (max-width: 800px)  { .act-grid > .act-card { flex-basis: calc((100% - 2rem) / 2); max-width: calc((100% - 2rem) / 2); } }
@media (max-width: 520px)  { .act-grid > .act-card { flex-basis: 100%; max-width: 100%; } }

/* Botón calendario de actividades */
.act-calendar-cta { display: flex; justify-content: center; margin-top: 3rem; }
.act-calendar-cta--top { margin-top: 1.5rem; margin-bottom: 0; }
.act-calendar-btn {
    display: inline-flex; align-items: center; gap: .9rem;
    padding: 1rem 2rem; background: transparent; cursor: pointer;
    border: 1px solid rgba(217,193,152,.45); color: var(--gold-soft);
    font-family: var(--font-sans); font-size: .78rem; letter-spacing: .22em;
    text-transform: uppercase; font-weight: 500;
    transition: background .3s ease, color .3s ease, border-color .3s ease, transform .3s ease;
}
.act-calendar-btn:hover { background: var(--gold); border-color: var(--gold); color: var(--ink-deep); transform: translateY(-2px); }
.act-calendar-btn__arrow { transition: transform .35s ease; display: inline-block; }
.act-calendar-btn:hover .act-calendar-btn__arrow { transform: translateX(4px); }

/* Modal calendario */
.cal-modal { position: fixed; inset: 0; z-index: 80; display: flex; align-items: center; justify-content: center; pointer-events: none; }
.cal-modal__backdrop { position: absolute; inset: 0; background: rgba(15,12,10,.78); opacity: 0; transition: opacity .35s ease; }
.cal-modal.is-open { pointer-events: auto; }
.cal-modal.is-open .cal-modal__backdrop { opacity: 1; }
.cal-modal__panel {
    position: relative; z-index: 1; background: var(--cream-soft); color: var(--ink);
    width: min(720px, 94vw); max-height: 88vh; overflow-y: auto;
    padding: 3rem 2.5rem 2.5rem;
    border: 1px solid var(--line);
    box-shadow: 0 30px 80px rgba(15,12,10,.5);
    transform: translateY(20px) scale(.97); opacity: 0;
    transition: transform .45s cubic-bezier(.2,.7,.2,1), opacity .35s ease;
}
.cal-modal.is-open .cal-modal__panel { transform: translateY(0) scale(1); opacity: 1; }
.cal-modal__close {
    position: absolute; top: 1rem; right: 1rem;
    width: 36px; height: 36px; border-radius: 50%;
    background: transparent; border: 1px solid var(--line); color: var(--ink); cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .25s, color .25s, border-color .25s;
}
.cal-modal__close:hover { background: var(--ink-deep); color: #fff; border-color: var(--ink-deep); }
.cal-modal__eyebrow { font-size: .72rem; letter-spacing: .3em; text-transform: uppercase; color: var(--gold); margin: 0 0 .6rem; }
.cal-modal__title { font-family: var(--font-display); font-weight: 200; font-size: 2rem; margin: 0 0 1rem; letter-spacing: .03em; color: var(--ink); }
.cal-modal__divider { width: 50px; height: 1px; background: var(--gold); margin: 0 0 2rem; }
.cal-modal__list { display: flex; flex-direction: column; gap: 2rem; }
.cal-month__title { font-family: var(--font-display); font-weight: 300; font-size: 1.1rem; letter-spacing: .18em; text-transform: uppercase; color: var(--ink); margin: 0 0 1rem; padding-bottom: .6rem; border-bottom: 1px solid var(--line); }
.cal-month__items { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .4rem; }
.cal-item {
    display: grid; grid-template-columns: auto 1fr auto; gap: 1.2rem; align-items: center;
    padding: .9rem 1rem; text-decoration: none; color: inherit;
    border: 1px solid transparent; border-radius: 4px;
    transition: background .25s ease, border-color .25s ease, transform .25s ease;
}
.cal-item:hover { background: #fff; border-color: var(--line); transform: translateX(4px); }
.cal-item__date {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    width: 56px; padding: .4rem 0;
    background: var(--ink-deep); color: #fff; border-radius: 4px;
}
.cal-item__day { font-family: var(--font-display); font-size: 1.5rem; font-weight: 300; line-height: 1; }
.cal-item__dow { font-size: .62rem; letter-spacing: .2em; text-transform: uppercase; color: var(--gold-soft); margin-top: .25rem; }
.cal-item__body { display: flex; flex-direction: column; gap: .2rem; min-width: 0; }
.cal-item__title { font-family: var(--font-display); font-size: 1.05rem; font-weight: 300; color: var(--ink); }
.cal-item__meta { font-size: .8rem; color: var(--text-muted-hotel); }
.cal-item__arrow { color: var(--gold); font-size: 1.1rem; transition: transform .25s ease; }
.cal-item:hover .cal-item__arrow { transform: translateX(4px); }
@media (max-width: 600px){
    .cal-modal__panel { padding: 2.5rem 1.25rem 2rem; }
    .cal-modal__title { font-size: 1.5rem; }
    .cal-item { grid-template-columns: auto 1fr; gap: .9rem; padding: .7rem .5rem; }
    .cal-item__arrow { display: none; }
}
.act-card {
    background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
    border: 1px solid rgba(217,193,152,.18);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform .4s ease, border-color .3s ease, box-shadow .3s ease;
    position: relative;
}
.act-card::after {
    content: ""; position: absolute; left: 0; right: 0; top: 0; height: 1px;
    background: linear-gradient(90deg, transparent, var(--gold), transparent);
    opacity: .5; transition: opacity .3s;
}
.act-card:hover { border-color: var(--gold); transform: translateY(-6px); box-shadow: 0 20px 40px -20px rgba(0,0,0,.6); }
.act-card:hover::after { opacity: 1; }
.act-card__media { aspect-ratio: 4/3; overflow: hidden; background: #222; }
.act-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: .6s; }
.act-card:hover .act-card__media img { transform: scale(1.06); }
.act-card__body { padding: 1.6rem 1.8rem 1.8rem; }
.act-card__body h3 {
    font-family: var(--font-display); font-size: 1.35rem; font-weight: 300;
    color: #fff; margin: 0 0 .6rem; letter-spacing: .06em; line-height: 1.3;
}
.act-card__sub { font-size: .88rem; color: rgba(255,255,255,.65); margin: 0 0 1rem; }
.act-card__date {
    font-size: .72rem; color: var(--gold); letter-spacing: .2em;
    text-transform: uppercase; font-weight: 500; margin: 0 0 .3rem;
    display: flex; align-items: center; gap: .5rem;
}
.act-card__date::before { content: ""; width: 16px; height: 1px; background: var(--gold); }
.act-card__time { font-size: .8rem; color: rgba(255,255,255,.6); margin: 0; }

/* =======================================================
   Amenities grid (íconos)
   ======================================================= */
.amen-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem 3rem;
    margin-top: 3rem;
}
@media (max-width: 900px) { .amen-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .amen-grid { grid-template-columns: 1fr; } }
.amen-item {
    display: flex; gap: 1.2rem; align-items: flex-start;
    padding: 1.1rem .4rem;
    border: 0; background: transparent; text-align: left; width: 100%;
    font: inherit; color: inherit; cursor: pointer;
    border-bottom: 1px solid var(--line);
    border-radius: 8px;
    transition: background .25s ease, transform .25s ease, padding-left .25s ease, box-shadow .25s ease;
    position: relative;
}
.amen-item:hover {
    background: rgba(182, 145, 89, .08);
    padding-left: 1rem;
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(40,30,15,.08);
}
.amen-item:focus-visible { outline: 2px solid var(--gold, #b69159); outline-offset: 2px; }
.amen-item__icon {
    width: 46px; height: 46px; color: var(--gold); flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    transition: transform .35s ease;
}
.amen-item:hover .amen-item__icon { transform: scale(1.12) rotate(-4deg); }
.amen-item__icon svg { width: 100%; height: 100%; stroke: currentColor; stroke-width: 1.2; fill: none; }
.amen-item h4 { font-family: var(--font-display); font-size: 1.15rem; font-weight: 300; margin: 0 0 .3rem; color: var(--ink); letter-spacing: .05em; }
.amen-item p { margin: 0; font-size: .88rem; color: var(--text-muted-hotel); line-height: 1.6; }
.amen-item__more {
    display: inline-flex; align-items: center; gap: .35rem;
    margin-top: .6rem;
    font-size: .75rem; text-transform: uppercase; letter-spacing: .14em;
    color: var(--gold, #b69159);
    opacity: 0; transform: translateX(-6px);
    transition: opacity .25s ease, transform .25s ease;
}
.amen-item:hover .amen-item__more { opacity: 1; transform: translateX(0); }

/* Modal de amenidades (mismo patrón que feature-strip modal) */
.amen-modal {
    position: fixed; inset: 0; z-index: 1100;
    display: none;
    align-items: center; justify-content: center;
    padding: 1rem;
}
.amen-modal.is-open { display: flex; }
.amen-modal__backdrop {
    position: absolute; inset: 0;
    background: rgba(20, 16, 12, .72);
    backdrop-filter: blur(4px);
    animation: amenFade .2s ease;
}
@keyframes amenFade { from { opacity: 0; } to { opacity: 1; } }
.amen-modal__panel {
    position: relative;
    display: none;
    background: #fff;
    color: var(--ink, #1d1815);
    border-radius: 16px;
    padding: 2.5rem 2.2rem 2rem;
    max-width: 520px;
    width: 100%;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 30px 80px rgba(0,0,0,.45);
    text-align: center;
    animation: amenPop .3s cubic-bezier(.2,.9,.3,1.2);
}
.amen-modal__panel.is-active { display: block; }
@keyframes amenPop {
    from { opacity: 0; transform: translateY(20px) scale(.95); }
    to   { opacity: 1; transform: translateY(0) scale(1); }
}
.amen-modal__close {
    position: absolute; top: 1rem; right: 1rem;
    width: 36px; height: 36px;
    border: 0; border-radius: 50%;
    background: #f5efe2; color: var(--ink);
    cursor: pointer;
    display: inline-flex; align-items: center; justify-content: center;
    transition: background .2s, color .2s;
}
.amen-modal__close:hover { background: var(--gold, #b69159); color: #fff; }
.amen-modal__icon {
    width: 56px; height: 56px;
    margin: .2rem auto 1.1rem;
    color: var(--gold, #b69159);
}
.amen-modal__icon svg { width: 100%; height: 100%; stroke: currentColor; stroke-width: 1.3; fill: none; }
.amen-modal__title {
    font-family: var(--font-display, Georgia, serif);
    font-size: clamp(1.4rem, 2.6vw, 1.8rem);
    margin: 0 0 1rem;
    line-height: 1.2;
}
.amen-modal__body {
    color: #4a4036;
    line-height: 1.7;
    font-size: .98rem;
    text-align: left;
}
.amen-modal__body p { margin: 0 0 .9rem; }
.amen-modal__cta {
    display: inline-block;
    margin-top: 1.2rem;
}

/* =======================================================
   Video / experience block
   ======================================================= */
.video-block {
    background: #1a0f08 center/cover no-repeat;
    min-height: 480px;
    color: #fff;
    position: relative;
    display: flex; align-items: center; justify-content: center;
    text-align: center;
    padding: 6rem 1rem;
}
.video-block::before {
    content: ""; position: absolute; inset: 0; background: rgba(0,0,0,.18); z-index: 1;
}
.video-block__inner { display: none; }
.video-block__eyebrow { color: var(--gold-soft); font-size: .75rem; letter-spacing: .35em; text-transform: uppercase; margin: 0 0 1rem; }
.video-block__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2rem, 4.5vw, 3.4rem);
    color: #fff; margin: 0 0 2.5rem; line-height: 1.15;
    letter-spacing: .04em;
}
.video-block__play {
    width: 84px; height: 84px; border-radius: 50%;
    border: 1px solid rgba(255,255,255,.4); background: rgba(255,255,255,.06);
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff; cursor: pointer; transition: .3s;
}
.video-block__play:hover { background: var(--gold); border-color: var(--gold); color: var(--ink-deep); }
.video-block__play svg { width: 26px; height: 26px; margin-left: 4px; }
.video-block { overflow: hidden; }
.video-block__bg {
    position: absolute; inset: 0; width: 100%; height: 100%;
    object-fit: cover; z-index: 0; pointer-events: none;
}
.video-block::before { z-index: 1; }
.video-modal {
    position: fixed; inset: 0; background: rgba(0,0,0,.92);
    z-index: 9999; display: flex; align-items: center; justify-content: center;
    padding: 2rem;
}
.video-modal[hidden] { display: none; }
.video-modal__player {
    width: min(1100px, 100%); max-height: 85vh; background: #000;
    box-shadow: 0 30px 80px rgba(0,0,0,.6);
}
.video-modal__close {
    position: absolute; top: 1.2rem; right: 1.5rem;
    background: transparent; border: 1px solid rgba(255,255,255,.3);
    color: #fff; width: 44px; height: 44px; border-radius: 50%;
    font-size: 1.6rem; line-height: 1; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: .2s;
}
.video-modal__close:hover { background: var(--gold); border-color: var(--gold); color: var(--ink-deep); }

/* =======================================================
   Gastro split
   ======================================================= */
.split-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.split-grid--reverse .split-grid__side { order: 2; }
.split-grid--reverse .split-grid__text { order: 1; }
@media (max-width: 900px) {
    .split-grid { grid-template-columns: 1fr; gap: 3rem; }
    .split-grid--reverse .split-grid__side { order: 0; }
}
.split-grid__img { width: 100%; height: 520px; object-fit: cover; }
.placeholder-img { width: 100%; height: 520px; background: linear-gradient(135deg, #d8c9a8, #b89968); position: relative; }
.placeholder-img--dark { background: linear-gradient(135deg, #2a1e15, var(--ink-deep)); height: 300px; }
.placeholder-img::after {
    content: "Imagen"; position: absolute; inset: 0;
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,.75); font-size: .8rem; letter-spacing: .25em; text-transform: uppercase;
}

/* =======================================================
   Gastronomía — rediseño moderno
   ======================================================= */
.section--gastro {
    background: linear-gradient(180deg, var(--cream-soft) 0%, #ece7dc 100%);
    position: relative;
    overflow: hidden;
}
.section--gastro::before {
    content: ""; position: absolute; top: -80px; right: -120px;
    width: 420px; height: 420px; border-radius: 50%;
    background: radial-gradient(circle, rgba(184,153,104,.12), transparent 70%);
    pointer-events: none;
}
.gastro-grid {
    display: grid; grid-template-columns: 1.05fr 1fr;
    gap: 6rem; align-items: center;
}
@media (max-width: 1000px) { .gastro-grid { grid-template-columns: 1fr; gap: 3.5rem; } }

.gastro-media {
    position: relative; height: 640px;
}
@media (max-width: 1000px) { .gastro-media { height: 520px; } }
@media (max-width: 560px)  { .gastro-media { height: 440px; } }
.gastro-media__frame {
    position: absolute; margin: 0; overflow: hidden;
    box-shadow: 0 30px 60px -30px rgba(47,10,21,.45);
    transition: transform .6s cubic-bezier(.2,.7,.2,1);
    text-decoration: none; color: inherit; cursor: pointer;
}
.gastro-media__frame img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .8s ease; }
.gastro-media__frame:hover img { transform: scale(1.05); }
.gastro-media__frame figcaption {
    position: absolute; left: 1rem; bottom: 1rem;
    background: rgba(47,10,21,.85); color: #fff;
    font-size: .68rem; letter-spacing: .28em; text-transform: uppercase;
    padding: .5rem .9rem; font-weight: 400;
}
.gastro-media__frame--a {
    top: 0; left: 0; width: 62%; height: 72%;
    border: 1px solid rgba(184,153,104,.35);
}
.gastro-media__frame--b {
    bottom: 0; right: 0; width: 60%; height: 62%;
    border: 1px solid rgba(184,153,104,.35);
}
.gastro-media__frame--a:hover { transform: translateY(-6px); }
.gastro-media__frame--b:hover { transform: translateY(-6px); }
.gastro-media__placeholder {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--ink) 0%, var(--ink-deep) 100%);
    color: var(--gold-soft); display: flex; align-items: center; justify-content: center;
    font-family: var(--font-display); font-weight: 200; font-size: 2rem; letter-spacing: .2em;
    text-transform: uppercase;
}
.gastro-media__tag {
    position: absolute; top: 50%; left: 50%;
    transform: translate(-50%,-50%) rotate(-90deg);
    font-size: .65rem; letter-spacing: .45em; text-transform: uppercase;
    color: var(--gold); white-space: nowrap; font-weight: 500;
    background: var(--cream-soft); padding: .3rem .8rem;
    border-top: 1px solid var(--gold); border-bottom: 1px solid var(--gold);
    z-index: 2;
}
@media (max-width: 1000px) { .gastro-media__tag { display: none; } }

.gastro-text { padding: 1rem 0; }
.gastro-title-accent {
    display: block; font-style: italic; color: var(--gold);
    font-weight: 200; letter-spacing: .02em;
}
.gastro-lede {
    font-size: 1.05rem; color: var(--text-muted-hotel);
    max-width: 520px; margin: 0 0 2.5rem; line-height: 1.75;
}
.gastro-cards { display: flex; flex-direction: column; gap: 1.5rem; }
.gastro-card {
    position: relative; padding: 1.6rem 1.8rem 1.6rem 4.5rem;
    background: #fff; border: 1px solid var(--line);
    transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease;
    text-decoration: none; color: inherit; display: block;
}
.gastro-card:hover { transform: translateX(4px); border-color: var(--gold); box-shadow: 0 10px 30px -15px rgba(67,19,33,.25); }
.gastro-card header { display: flex; align-items: baseline; gap: 1rem; margin-bottom: .7rem; }
.gastro-card__num {
    position: absolute; left: 1.6rem; top: 1.5rem;
    font-family: var(--font-display); font-size: 1.1rem;
    color: var(--gold); letter-spacing: .15em; font-weight: 400;
}
.gastro-card h3 {
    font-family: var(--font-display); font-size: 1.4rem; font-weight: 300;
    color: var(--ink); margin: 0; letter-spacing: .04em;
}
.gastro-card p { margin: 0; font-size: .92rem; color: var(--text-muted-hotel); line-height: 1.7; }
.gastro-cta { margin-top: 2.5rem; }

.gastro-item { border-top: 1px solid var(--line); padding: 1.4rem 0; }
.gastro-item:last-child { border-bottom: 1px solid var(--line); }
.gastro-item h3 {
    font-family: var(--font-display); font-size: 1.4rem; font-weight: 300; color: var(--ink); margin: 0 0 .5rem; letter-spacing: .04em;
}
.gastro-item p { color: var(--text-muted-hotel); margin: 0; font-size: .95rem; line-height: 1.7; }

/* =======================================================
   Map
   ======================================================= */
.map-wrap { margin-top: 3rem; border: 8px solid #fff; box-shadow: 0 20px 50px rgba(0,0,0,.1); }

/* =======================================================
   Contact form (dark)
   ======================================================= */
.contact-form-wrap .lead-form { max-width: none; margin: 0; }
.contact-form-wrap label { color: rgba(255,255,255,.8); font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; }
.contact-form-wrap input,
.contact-form-wrap textarea {
    background: transparent;
    border: 0;
    border-bottom: 1px solid rgba(255,255,255,.2);
    border-radius: 0;
    color: #fff;
    padding: .8rem 0;
}
.contact-form-wrap input:focus,
.contact-form-wrap textarea:focus {
    border-color: var(--gold); box-shadow: none; outline: none;
}
.contact-form-wrap .btn { margin-top: 1rem; }

/* =======================================================
   Botones
   ======================================================= */
.btn--brand,
.btn--outline {
    position: relative;
    display: inline-flex; align-items: center; justify-content: center; gap: .85rem;
    text-transform: uppercase; letter-spacing: .22em;
    font-size: .72rem; font-weight: 600;
    padding: 1.05rem 2.1rem;
    border-radius: 2px;
    border: 1px solid transparent;
    transition: background .35s ease, color .35s ease, border-color .35s ease, transform .25s ease, box-shadow .35s ease;
    cursor: pointer;
}
.btn--brand {
    background: var(--ink-deep); border-color: var(--ink-deep); color: #fff;
    box-shadow: 0 8px 22px rgba(47, 10, 21, .18);
}
.btn--brand::after {
    content: ""; width: 18px; height: 1px; background: currentColor;
    position: relative; transition: width .3s ease;
}
.btn--brand::before {
    content: ""; width: 0; height: 0;
    border-left: 5px solid currentColor;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    order: 3; margin-left: -.6rem;
    transition: transform .3s ease;
}
.btn--brand:hover {
    background: var(--gold); border-color: var(--gold); color: var(--ink-deep);
    box-shadow: 0 12px 28px rgba(189, 152, 92, .35);
    transform: translateY(-1px);
}
.btn--brand:hover::after { width: 24px; }
.btn--brand:hover::before { transform: translateX(4px); }

.btn--outline {
    background: transparent; border-color: var(--ink); color: var(--ink);
}
.btn--outline::after {
    content: ""; width: 18px; height: 1px; background: currentColor;
    transition: width .3s ease;
}
.btn--outline::before {
    content: ""; width: 0; height: 0;
    border-left: 5px solid currentColor;
    border-top: 4px solid transparent;
    border-bottom: 4px solid transparent;
    order: 3; margin-left: -.6rem;
    transition: transform .3s ease;
}
.btn--outline:hover {
    background: var(--ink); border-color: var(--ink); color: #fff;
    box-shadow: 0 10px 24px rgba(47, 10, 21, .22);
    transform: translateY(-1px);
}
.btn--outline:hover::after { width: 24px; }
.btn--outline:hover::before { transform: translateX(4px); }

.hero__ctas .btn--brand { background: transparent; border-color: var(--gold); color: var(--gold); box-shadow: none; }
.hero__ctas .btn--brand:hover { background: var(--gold); color: var(--ink-deep); }

/* =======================================================
   Footer brand
   ======================================================= */
.site-footer-brand {
    background: var(--ink-deep); color: rgba(255,255,255,.72);
    padding: 5rem 0 0; margin-top: 0; border-top: 0;
    font-size: .92rem; position: relative;
}
.footer-ta-badge {
    position: absolute; top: 1.5rem; right: 2rem; z-index: 2;
    display: inline-flex; opacity: .85; transition: opacity .2s;
}
.footer-ta-badge:hover { opacity: 1; }
.site-footer-brand__grid {
    display: grid; grid-template-columns: 1.6fr 1fr 1.1fr 1.2fr; gap: 3rem;
    padding-bottom: 3.5rem;
}
@media (max-width: 1000px) { .site-footer-brand__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px)  { .site-footer-brand__grid { grid-template-columns: 1fr; } }
.footer-col h4 {
    color: var(--gold, #d9c198); font-family: var(--font-display); font-size: .78rem;
    margin: 0 0 1.4rem; font-weight: 600; letter-spacing: .22em; text-transform: uppercase;
    padding-bottom: .8rem; border-bottom: 1px solid rgba(217,193,152,.25);
}
.site-footer-brand ul { list-style: none; padding: 0; margin: 0; }
.site-footer-brand a { color: rgba(255,255,255,.78); text-decoration: none; transition: color .2s; }
.site-footer-brand a:hover { color: var(--gold); }

.footer-logo { margin-bottom: 1.5rem; }
.footer-logo img {
    max-width: 180px; height: auto; display: block;
    filter: brightness(0) invert(1);
}
.footer-about {
    font-size: .92rem; line-height: 1.65; color: rgba(255,255,255,.72);
    margin: 0 0 1.8rem; max-width: 360px;
}
.footer-about strong { color: #fff; font-weight: 600; }

.footer-newsletter {
    display: flex; max-width: 380px;
    background: transparent; border: 1px solid rgba(255,255,255,.2);
}
.footer-newsletter input {
    flex: 1; background: transparent; border: 0; padding: .9rem 1rem;
    color: #fff; font: inherit; outline: none; min-width: 0;
}
.footer-newsletter input::placeholder { color: rgba(255,255,255,.45); }
.footer-newsletter button {
    background: #fff; color: var(--ink-deep); border: 0; cursor: pointer;
    padding: 0 1.6rem; font: inherit; font-size: .78rem;
    letter-spacing: .22em; text-transform: uppercase; font-weight: 500;
    transition: background .2s, color .2s;
}
.footer-newsletter button:hover { background: var(--gold); }

.footer-links li { padding: .55rem 0; position: relative; padding-left: 1.2rem; }
.footer-links li::before {
    content: "›"; position: absolute; left: 0; top: .55rem;
    color: var(--gold); font-size: 1rem;
}

.footer-hours li {
    display: flex; align-items: center; gap: .7rem;
    padding: .4rem 0; color: #fff; font-size: .92rem;
}
.footer-hours li.footer-hours__time { color: rgba(255,255,255,.72); padding-bottom: .8rem; }
.footer-ico {
    width: 18px; height: 18px; color: var(--gold);
    display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.footer-ico svg { width: 100%; height: 100%; }

.footer-contact li {
    display: flex; align-items: center; gap: .8rem;
    padding: .55rem 0;
}

.site-footer-brand__base {
    border-top: 1px solid rgba(255,255,255,.08); padding: 1.2rem 0;
    font-size: .78rem; color: rgba(255,255,255,.5);
}
.site-footer-brand__base .container {
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: .5rem;
}
.site-footer-brand__credit strong { color: rgba(255,255,255,.85); font-weight: 500; }

/* =======================================================
   Brand mark
   ======================================================= */
.brand-mark {
    display: inline-flex; flex-direction: column; color: var(--gold);
    font-family: var(--font-display); line-height: 1; margin-bottom: 1.2rem;
}
.brand-mark span { font-size: .7rem; text-transform: uppercase; letter-spacing: .3em; }
.brand-mark strong { font-size: 1.3rem; font-weight: 400; margin-top: .4rem; }
.brand-mark--footer { color: var(--gold); }

/* =======================================================
   Misc overrides
   ======================================================= */
body.home .site-header { display: none; }
body.home main { padding: 0; }

/* =======================================================
   Centro de Eventos — listado y detalle
   ======================================================= */
.eventos-hero {
    background: var(--ink-deep); color: #fff;
    padding: 5rem 0 3rem; text-align: center;
}
.eventos-hero .section__eyebrow { color: var(--gold-soft); }
.eventos-hero__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2.4rem, 5vw, 4rem); color: #fff;
    letter-spacing: .06em; margin: .5rem 0 1rem;
}
.eventos-hero__lede {
    color: rgba(255,255,255,.75); max-width: 640px; margin: 0 auto;
    font-size: 1rem; line-height: 1.7;
}
.section--eventos { padding: 5rem 0 6rem; background: var(--cream-soft); }

.eventos-grid {
    display: flex; flex-wrap: wrap; justify-content: center;
    gap: 2rem;
}
.eventos-grid > .evento-card { flex: 0 1 calc((100% - 4rem) / 3); max-width: calc((100% - 4rem) / 3); }
@media (max-width: 1000px) { .eventos-grid > .evento-card { flex-basis: calc((100% - 2rem) / 2); max-width: calc((100% - 2rem) / 2); } }
@media (max-width: 640px)  { .eventos-grid > .evento-card { flex-basis: 100%; max-width: 100%; } }
.eventos-grid--small { gap: 1.5rem; }
.eventos-grid--small > .evento-card { flex-basis: calc((100% - 3rem) / 3); max-width: calc((100% - 3rem) / 3); }
@media (max-width: 1000px) { .eventos-grid--small > .evento-card { flex-basis: calc((100% - 1.5rem) / 2); max-width: calc((100% - 1.5rem) / 2); } }
@media (max-width: 640px)  { .eventos-grid--small > .evento-card { flex-basis: 100%; max-width: 100%; } }
.eventos-grid--small .evento-card__media { aspect-ratio: 16/10; }
.eventos-grid--small .evento-card__body p { display: none; }

.evento-card {
    display: flex; flex-direction: column;
    background: #fff; border: 1px solid rgba(0,0,0,.06);
    text-decoration: none; color: inherit;
    transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease;
    overflow: hidden;
}
.evento-card:hover {
    transform: translateY(-6px); border-color: var(--gold);
    box-shadow: 0 25px 50px -25px rgba(47,10,21,.35);
}
.evento-card__media {
    aspect-ratio: 4/3; background: #1a0f14 center/cover no-repeat;
    display: flex; align-items: center; justify-content: center;
    position: relative; overflow: hidden;
}
.evento-card__media::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(0,0,0,.35));
    opacity: 0; transition: opacity .4s;
}
.evento-card:hover .evento-card__media::after { opacity: 1; }
.evento-card__placeholder {
    color: var(--gold-soft); font-family: var(--font-display);
    letter-spacing: .2em; text-transform: uppercase; font-size: 1.2rem;
}
.evento-card__body { padding: 1.6rem 1.8rem 1.8rem; }
.evento-card__body h3 {
    font-family: var(--font-display); font-weight: 300;
    font-size: 1.4rem; color: var(--ink); margin: 0 0 .7rem;
    letter-spacing: .04em;
}
.evento-card__body p {
    color: var(--text-muted-hotel); font-size: .92rem; line-height: 1.65;
    margin: 0 0 1.2rem;
}
.evento-card__cta {
    font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
    color: var(--gold); font-weight: 500;
}
.evento-card--dark { background: rgba(255,255,255,.03); border-color: rgba(255,255,255,.1); }
.evento-card--dark .evento-card__body h3 { color: #fff; }

.evento-hero {
    min-height: 56vh; background: var(--ink-deep) center/cover no-repeat;
    color: #fff; position: relative;
    display: flex; align-items: center; padding: 5rem 0;
}
.evento-hero__overlay {
    position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,.45), rgba(0,0,0,.75));
}
.evento-hero__inner { position: relative; z-index: 2; text-align: center; }
.evento-hero__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2.4rem, 6vw, 5rem); color: #fff;
    letter-spacing: .08em; text-transform: uppercase; margin: .5rem 0 .8rem;
}
.evento-hero__tagline {
    color: rgba(255,255,255,.82); font-size: 1.05rem;
    letter-spacing: .04em; max-width: 680px; margin: 0 auto;
}

.evento-detail {
    display: grid; grid-template-columns: 1.6fr 1fr; gap: 4rem;
    align-items: start;
}
@media (max-width: 1000px) { .evento-detail { grid-template-columns: 1fr; gap: 2.5rem; } }
.evento-detail__lede {
    font-size: 1.1rem; line-height: 1.7; color: var(--ink);
    margin: 0 0 1.5rem; font-weight: 300;
}
.evento-detail__content p { color: #4a4a4a; line-height: 1.75; margin: 0 0 1rem; }
.evento-aside-card {
    background: #fff; border: 1px solid var(--line);
    padding: 1.5rem; margin-bottom: 1.2rem; border-top: 3px solid var(--gold);
}
.evento-aside-card h4 {
    font-family: var(--font-display); font-weight: 500;
    font-size: .72rem; letter-spacing: .22em; text-transform: uppercase;
    color: var(--gold); margin: 0 0 .6rem;
}
.evento-aside-card p { margin: 0; color: var(--ink); font-size: 1.05rem; }
.evento-aside-card ul { list-style: none; padding: 0; margin: 0; }
.evento-aside-card li {
    padding: .5rem 0; border-bottom: 1px solid rgba(0,0,0,.05);
    color: #4a4a4a; font-size: .92rem; position: relative; padding-left: 1.2rem;
}
.evento-aside-card li::before {
    content: ""; position: absolute; left: 0; top: 50%;
    width: 6px; height: 1px; background: var(--gold);
}

/* =======================================================
   Animación sutil hero eyebrow
   ======================================================= */
.hero__eyebrow {
    position: relative; overflow: hidden;
    animation: heroPillPulse 3.4s ease-in-out infinite;
}
.hero__eyebrow::after {
    content: ""; position: absolute; top: 0; bottom: 0; left: -60%;
    width: 50%;
    background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent);
    animation: heroPillShimmer 3.8s ease-in-out infinite;
    pointer-events: none;
}
@keyframes heroPillPulse {
    0%, 100% { box-shadow: 0 0 0 0 rgba(255,255,255,0), 0 10px 30px -10px rgba(0,0,0,.5); }
    50%      { box-shadow: 0 0 0 6px rgba(255,255,255,.06), 0 10px 30px -10px rgba(0,0,0,.6); }
}
@keyframes heroPillShimmer {
    0%   { left: -60%; }
    60%  { left: 110%; }
    100% { left: 110%; }
}

/* =======================================================
   Centro de Eventos — rediseño moderno
   ======================================================= */
.eventos-cover {
    position: relative; min-height: 82vh;
    display: flex; align-items: center; color: #fff;
    overflow: hidden; padding: 6rem 0 4rem;
}
.eventos-cover__bg { position: absolute; inset: 0; z-index: 0; }
.eventos-cover__img {
    position: absolute; inset: 0;
    background: center/cover no-repeat;
    animation: eventosZoom 22s ease-in-out infinite alternate;
    filter: saturate(.92);
}
@keyframes eventosZoom {
    0%   { transform: scale(1); }
    100% { transform: scale(1.12); }
}
.eventos-cover__overlay {
    position: absolute; inset: 0;
    background:
        linear-gradient(110deg, rgba(47,10,21,.88) 0%, rgba(47,10,21,.55) 55%, rgba(0,0,0,.75) 100%);
}
.eventos-cover__inner { position: relative; z-index: 2; max-width: 880px; }
.eventos-cover__kicker {
    display: flex; align-items: center; gap: 1rem;
    color: var(--gold-soft); font-size: .75rem;
    letter-spacing: .3em; text-transform: uppercase; margin-bottom: 2rem;
    animation: eventosFadeIn .8s ease .1s backwards;
}
.eventos-cover__line {
    display: inline-block; height: 1px; background: var(--gold);
    width: 60px; animation: eventosLineExpand 1.2s ease .4s backwards;
}
@keyframes eventosLineExpand { from { width: 0; } to { width: 60px; } }
.eventos-cover__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2.8rem, 7.5vw, 6rem);
    line-height: 1; margin: 0 0 2rem; color: #fff;
    letter-spacing: -.01em;
}
.eventos-cover__word {
    display: inline-block; margin-right: .3em;
    opacity: 0; transform: translateY(30px);
    animation: eventosWordIn .9s cubic-bezier(.2,.7,.2,1) calc(.2s + var(--d) * .18s) forwards;
}
.eventos-cover__word--italic {
    font-style: italic; color: var(--gold-soft); font-weight: 300;
}
@keyframes eventosWordIn { to { opacity: 1; transform: none; } }
.eventos-cover__lede {
    max-width: 560px; font-size: 1.1rem; line-height: 1.75;
    color: rgba(255,255,255,.82); margin: 0 0 2.8rem;
    animation: eventosFadeIn 1s ease .8s backwards;
}
@keyframes eventosFadeIn { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
.eventos-cover__meta {
    display: flex; gap: 3rem; margin-bottom: 3rem;
    animation: eventosFadeIn 1s ease 1s backwards;
}
.eventos-cover__meta > div {
    display: flex; flex-direction: column; border-left: 1px solid rgba(217,193,152,.4);
    padding-left: 1.2rem;
}
.eventos-cover__meta strong {
    font-family: var(--font-display); font-weight: 300;
    font-size: 2rem; color: #fff; letter-spacing: .02em;
}
.eventos-cover__meta span {
    font-size: .7rem; letter-spacing: .25em; text-transform: uppercase;
    color: var(--gold-soft); margin-top: .3rem;
}
.eventos-cover__scroll {
    display: inline-flex; align-items: center; gap: 1rem;
    color: rgba(255,255,255,.7); text-decoration: none;
    font-size: .72rem; letter-spacing: .3em; text-transform: uppercase;
    transition: color .3s;
}
.eventos-cover__scroll:hover { color: var(--gold); }
.eventos-cover__scroll-line {
    display: inline-block; width: 60px; height: 1px; background: currentColor;
    position: relative; overflow: hidden;
}
.eventos-cover__scroll-line::after {
    content: ""; position: absolute; top: 0; left: -30%; width: 30%; height: 100%;
    background: var(--gold); animation: eventosScrollArrow 2s ease-in-out infinite;
}
@keyframes eventosScrollArrow { 0%,100% { left: -30%; } 50% { left: 100%; } }

@media (max-width: 720px) {
    .eventos-cover__meta { gap: 1.5rem; flex-wrap: wrap; }
    .eventos-cover__meta strong { font-size: 1.5rem; }
}

/* Showcase */
.eventos-showcase { padding: 7rem 0 6rem; background: var(--cream-soft); }
.eventos-showcase__head { text-align: center; max-width: 720px; margin: 0 auto 5rem; }
.eventos-showcase__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2rem, 4vw, 3rem); color: var(--ink);
    margin: .5rem 0 1rem; letter-spacing: .02em;
}

.eventos-stack { display: flex; flex-direction: column; gap: 6rem; }
.evento-row {
    display: grid; grid-template-columns: 1.1fr 1fr; gap: 4rem;
    align-items: center; text-decoration: none; color: inherit;
    opacity: 0; transform: translateY(40px);
    transition: opacity .9s ease, transform .9s cubic-bezier(.2,.7,.2,1);
}
.evento-row.is-visible { opacity: 1; transform: none; }
.evento-row--reverse { direction: rtl; }
.evento-row--reverse > * { direction: ltr; }
@media (max-width: 900px) {
    .evento-row, .evento-row--reverse { grid-template-columns: 1fr; direction: ltr; gap: 2rem; }
}

.evento-row__media {
    position: relative; aspect-ratio: 5/4;
    overflow: hidden; background: #1a0f14;
    box-shadow: 0 30px 60px -30px rgba(47,10,21,.5);
}
.evento-row__img {
    position: absolute; inset: 0; background: center/cover no-repeat;
    transition: transform 1.2s cubic-bezier(.2,.7,.2,1), filter .6s;
    filter: saturate(.9);
}
.evento-row:hover .evento-row__img { transform: scale(1.08); filter: saturate(1.1); }
.evento-row__media::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, transparent 60%, rgba(47,10,21,.55));
    opacity: 0; transition: opacity .5s;
}
.evento-row:hover .evento-row__media::after { opacity: 1; }
.evento-row__num {
    position: absolute; top: 1.2rem; left: 1.2rem; z-index: 2;
    font-family: var(--font-display); font-weight: 300;
    font-size: 2.2rem; color: #fff;
    padding: .4rem .9rem;
    background: rgba(47,10,21,.72); backdrop-filter: blur(6px);
    letter-spacing: .1em;
}
.evento-row__num::after {
    content: ""; display: block; width: 24px; height: 1px; background: var(--gold); margin-top: .3rem;
}

.evento-row__content { padding: 1rem 0; }
.evento-row__tag {
    color: var(--gold); font-size: .72rem; letter-spacing: .3em;
    text-transform: uppercase; margin: 0 0 1rem; font-weight: 500;
    display: inline-flex; align-items: center; gap: .6rem;
}
.evento-row__tag::before {
    content: ""; display: inline-block; width: 28px; height: 1px; background: var(--gold);
}
.evento-row__title {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2rem, 3.5vw, 2.8rem); color: var(--ink);
    margin: 0 0 1.2rem; letter-spacing: .02em; line-height: 1.1;
    position: relative;
}
.evento-row__title::after {
    content: ""; display: block; width: 0; height: 2px;
    background: var(--gold); margin-top: 1rem;
    transition: width .8s cubic-bezier(.2,.7,.2,1);
}
.evento-row.is-visible .evento-row__title::after { width: 60px; }
.evento-row:hover .evento-row__title::after { width: 120px; }

.evento-row__desc {
    color: #5a5a5a; font-size: 1rem; line-height: 1.75;
    margin: 0 0 1.5rem; max-width: 480px;
}
.evento-row__features {
    list-style: none; padding: 0; margin: 0 0 2rem;
    display: flex; flex-wrap: wrap; gap: .6rem;
}
.evento-row__features li {
    font-size: .75rem; letter-spacing: .08em;
    color: var(--ink); background: rgba(184,153,104,.12);
    padding: .4rem .9rem; border: 1px solid rgba(184,153,104,.3);
}
.evento-row__cta {
    display: inline-flex; align-items: center; gap: .8rem;
    color: var(--ink); font-size: .78rem; letter-spacing: .22em;
    text-transform: uppercase; font-weight: 500;
    padding-bottom: .4rem; border-bottom: 1px solid var(--ink);
    transition: color .3s, border-color .3s, gap .3s;
}
.evento-row:hover .evento-row__cta {
    color: var(--gold); border-color: var(--gold); gap: 1.2rem;
}
.evento-row__cta svg { transition: transform .3s; }
.evento-row:hover .evento-row__cta svg { transform: translateX(4px); }

/* CTA final */
.eventos-cta {
    background: var(--ink-deep); color: #fff;
    padding: 5rem 0; text-align: center; position: relative; overflow: hidden;
}
.eventos-cta::before {
    content: ""; position: absolute; inset: 0;
    background:
        radial-gradient(circle at 20% 30%, rgba(184,153,104,.15), transparent 40%),
        radial-gradient(circle at 80% 70%, rgba(184,153,104,.1), transparent 45%);
    pointer-events: none;
}
.eventos-cta__inner { position: relative; z-index: 1; max-width: 640px; margin: 0 auto; }
.eventos-cta h2,
body.home .eventos-cta h2 {
    font-family: var(--font-display); font-weight: 200;
    font-size: clamp(2rem, 4vw, 3rem); color: #fff;
    margin: .5rem 0 1rem; letter-spacing: .03em;
}
.eventos-cta p { color: rgba(255,255,255,.85); margin: 0 0 2rem; }
.eventos-cta .welcome-btn {
    background: var(--gold) !important; border-color: var(--gold) !important;
    color: var(--ink-deep) !important;
}
.eventos-cta .welcome-btn:hover {
    background: #fff !important; border-color: #fff !important;
}

/* ============================================
   ROOMS — Hotel Gran Wolf · minimal / sharp edges
   ============================================ */
.rooms-section{position:relative;background:var(--cream-soft);overflow:hidden}
.rooms-section .container{position:relative;z-index:1}
.rooms-section__decor{display:none}
.rooms-section__eyebrow{color:var(--gold)!important;font-weight:400;letter-spacing:.32em}
.rooms-section__title{color:var(--ink-deep);font-weight:200}
.rooms-section__divider{background:var(--ink-deep);height:1px;width:48px;margin:1.4rem auto;border:0;opacity:.35}
.rooms-section__lede{max-width:560px;margin:1rem auto 0;color:#6b5560;font-size:1rem;font-weight:300;line-height:1.7}

.rooms-badge-new{display:inline-block;background:transparent;color:var(--gold);padding:.3rem 0;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;font-weight:400;margin-bottom:.6rem;border-bottom:1px solid var(--gold)}

/* Booking inline — barra plana con hairlines */
.rooms-booking{display:grid;grid-template-columns:1.1fr 1fr 1fr 0.7fr auto;gap:0;background:#fff;padding:0;border:1px solid rgba(67,19,33,.12);border-radius:0;box-shadow:none;align-items:stretch;max-width:1100px;margin:0 auto;position:relative}
.rooms-booking__field{padding:1rem 1.2rem;border-right:1px solid rgba(67,19,33,.08);display:flex;flex-direction:column;justify-content:center}
.rooms-booking__field:last-of-type{border-right:0}
.rooms-booking__field label{display:block;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:#9a8a8f;margin-bottom:.4rem;font-weight:400}
.rooms-booking__field select,.rooms-booking__field input{width:100%;padding:.3rem 0;border:0;border-radius:0;font:inherit;background:transparent;color:var(--ink);font-size:.95rem;font-weight:400}
.rooms-booking__field select:focus,.rooms-booking__field input:focus{outline:none;color:var(--ink-deep)}
.rooms-booking__submit{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;background:var(--ink-deep);color:#fff;border:0;padding:1.2rem 1.8rem;border-radius:0;font-family:'Jost',sans-serif;font-weight:400;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;cursor:pointer;transition:background .2s;white-space:nowrap}
.rooms-booking__submit:hover{background:var(--ink)}
.rooms-booking__submit svg{opacity:.85}
@media (max-width:880px){.rooms-booking{grid-template-columns:1fr 1fr}.rooms-booking__field{border-right:0;border-bottom:1px solid rgba(67,19,33,.08)}.rooms-booking__field:nth-child(odd){border-right:1px solid rgba(67,19,33,.08)}.rooms-booking__submit{grid-column:1/-1;padding:1rem}}
@media (max-width:480px){.rooms-booking{grid-template-columns:1fr}.rooms-booking__field:nth-child(odd){border-right:0}}

/* Bar arriba del panel: tabs y tarifas apiladas y centradas (mismo eje que el título). */
.rooms-tabs-bar{display:flex;flex-direction:column;align-items:center;gap:1.4rem;margin:0 0 2.5rem;}
/* Tabs — underline minimal en lugar de pill */
.rooms-tabs{position:relative;display:flex;width:fit-content;align-items:center;background:transparent;border:0;border-bottom:1px solid rgba(67,19,33,.12);border-radius:0;padding:0;margin:0;gap:0;box-shadow:none}
.rooms-tab{position:relative;z-index:2;border:0;background:transparent;cursor:pointer;padding:1rem 2rem;border-radius:0;font-family:'Jost',sans-serif;font-weight:400;letter-spacing:.24em;text-transform:uppercase;font-size:.74rem;color:#9a8a8f;transition:color .25s ease}
.rooms-tab:hover{color:var(--ink)}
.rooms-tab.is-active{color:var(--ink-deep)}
.rooms-tab__thumb{position:absolute;left:0;bottom:-1px;height:1px;width:120px;background:var(--ink-deep);border-radius:0;transition:left .35s cubic-bezier(.6,.1,.2,1),width .35s cubic-bezier(.6,.1,.2,1);z-index:1;box-shadow:none;top:auto}
.rooms-panel{display:none;max-width:1100px;margin:0 auto}
.rooms-panel.is-active{display:block;animation:roomsFade .45s ease both}

/* Cluster de tarifas centrado debajo de los tabs */
.rates-pills{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap;justify-content:center;}
.rates-pills__label{font-family:'Jost',sans-serif;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:#6b5560;}
.rates-pills__row{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center;}
@media (max-width:560px){.rates-pills{flex-direction:column;align-items:center;}}
.rate-pill{position:relative;}
.rate-pill > summary{
    list-style:none; cursor:pointer;
    display:inline-flex; align-items:center; gap:.5rem;
    padding:.55rem .9rem;
    background:#fff;
    border:1px solid rgba(67,19,33,.18);
    border-radius:0;
    transition:background .2s,border-color .2s,color .2s;
}
.rate-pill > summary::-webkit-details-marker,
.rate-pill > summary::marker{display:none;content:'';}
.rate-pill > summary:hover{border-color:var(--gold,#bd985c);}
.rate-pill[open] > summary{background:var(--ink-deep,#2f0a15);border-color:var(--ink-deep,#2f0a15);color:#fff;}
.rate-pill__name{font-family:'Jost',sans-serif;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:inherit;}
.rate-pill__board{font-family:'Jost',sans-serif;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gold,#bd985c);padding:.15rem .45rem;border:1px solid currentColor;border-radius:0;}
.rate-pill[open] .rate-pill__board{color:var(--gold-soft,#d4b86a);}
.rate-pill__chev{transition:transform .25s ease;opacity:.7;}
.rate-pill[open] .rate-pill__chev{transform:rotate(180deg);}

/* Panel desplegable: flota debajo de la pill, encima del contenido */
.rate-pill__panel{
    position:absolute; right:0; top:calc(100% + 8px);
    width:340px; max-width:88vw;
    background:#fff;
    border:1px solid rgba(67,19,33,.12);
    box-shadow:0 30px 60px -20px rgba(47,10,21,.35);
    padding:1.4rem 1.4rem 1.5rem;
    z-index:20;
    animation:rateFade .25s ease-out;
}
@keyframes rateFade{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}
.rate-pill__eyebrow{font-family:'Jost',sans-serif;font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold,#bd985c);margin:0 0 .3rem;font-weight:500;}
.rate-pill__panel h4{font-family:var(--font-display,serif);font-weight:300;font-size:1.25rem;color:var(--ink-deep,#2f0a15);margin:0 0 .7rem;letter-spacing:.01em;}
.rate-pill__lede{font-size:.88rem;line-height:1.55;color:#5a4450;margin:0 0 1rem;font-weight:300;}
.rate-pill__sub{font-family:'Jost',sans-serif;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-deep,#2f0a15);margin:0 0 .5rem;font-weight:500;}
.rate-pill__list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.4rem;}
.rate-pill__list li{position:relative;padding-left:1.4rem;font-size:.86rem;line-height:1.4;color:#3d2c34;font-weight:300;}
.rate-pill__list li::before{
    content:'';position:absolute;left:0;top:.42rem;
    width:8px;height:5px;
    border-left:1.5px solid var(--gold,#bd985c);
    border-bottom:1.5px solid var(--gold,#bd985c);
    transform:rotate(-45deg);
}
.rate-pill__list strong{color:var(--ink-deep,#2f0a15);font-weight:500;}

/* Switch Información / Precios arriba del contenido del panel */
.rate-pill__switch{
    display:flex;gap:0;
    margin:0 0 1.1rem;padding:.25rem;
    background:rgba(184,153,104,.10);
    border:1px solid rgba(184,153,104,.25);
}
.rate-pill__switch-btn{
    appearance:none;background:transparent;border:0;cursor:pointer;
    flex:1;padding:.5rem .8rem;
    font-family:'Jost',sans-serif;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:500;
    color:#6b5560;
    transition:background .2s,color .2s;
}
.rate-pill__switch-btn.is-active{background:var(--ink-deep,#2f0a15);color:#fff;}
.rate-pill__view{display:none;animation:rateFade .2s ease-out;}
.rate-pill__view.is-active{display:block;}

/* Bloque de precios dentro del panel — tabs internos por unidad */
.rate-pill__rates{margin-top:0;padding-top:0;border-top:0;}
.rate-pill__rates-tabs{
    display:flex;gap:0;
    margin:0 0 .8rem;
    border-bottom:1px solid rgba(67,19,33,.12);
}
.rate-pill__rates-tab{
    appearance:none;background:transparent;border:0;cursor:pointer;
    padding:.55rem .8rem; margin-bottom:-1px;
    font-family:'Jost',sans-serif;font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
    color:#6b5560;font-weight:500;
    border-bottom:2px solid transparent;
    transition:color .2s,border-color .2s;
}
.rate-pill__rates-tab:hover{color:var(--ink-deep,#2f0a15);}
.rate-pill__rates-tab.is-active{color:var(--ink-deep,#2f0a15);border-bottom-color:var(--gold,#bd985c);}
.rate-pill__rates-panel{display:none;animation:rateFade .2s ease-out;}
.rate-pill__rates-panel.is-active{display:block;}
.rate-pill__rates-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.3rem;}
.rate-pill__rates-list li{
    display:flex;align-items:baseline;justify-content:space-between;gap:1rem;
    padding:.45rem 0;
    border-bottom:1px dashed rgba(67,19,33,.1);
    font-size:.86rem;
}
.rate-pill__rates-list li:last-child{border-bottom:0;}
.rate-pill__rates-pax{color:#6b5560;font-weight:300;}
.rate-pill__rates-price{font-family:var(--font-display,serif);font-weight:400;color:var(--ink-deep,#2f0a15);font-variant-numeric:tabular-nums;}
.rate-pill__hint{margin-top:1rem;padding:.7rem .9rem;background:rgba(184,153,104,.08);border:1px dashed rgba(184,153,104,.4);font-size:.78rem;color:#6b5560;line-height:1.4;}

@media (max-width:520px){
    /* En mobile el panel se abre INLINE bajo la pill (accordion natural):
       cierre tocando la misma pill (chev rota) o tocando afuera. */
    .rate-pill__panel{
        position:static;
        width:auto;
        max-width:none;
        max-height:none;
        margin-top:.4rem;
        padding:1.2rem 1.2rem 1.3rem;
        animation:none;
        box-shadow:0 8px 18px -10px rgba(47,10,21,.25);
    }
}
@keyframes roomsFade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* Card — bordes rectos, hairline border, sin sombras gruesas ni gradient sidebar */
.rooms-block--accent{background:#fff;border-radius:0;overflow:hidden;box-shadow:none;border:1px solid rgba(67,19,33,.1);position:relative}
.rooms-block--accent::before{display:none}
.rooms-block--accent .rooms-block__info{padding:3rem 3rem 2.5rem}
.rooms-block--accent .rooms-block__price{display:inline-block;background:transparent;color:var(--gold);padding:0 0 .4rem;border-radius:0;font-size:.7rem;font-weight:400;letter-spacing:.28em;text-transform:uppercase;margin-bottom:1rem;border-bottom:1px solid var(--gold)}
.rooms-block--accent .rooms-block__price strong{font-weight:400;font-family:var(--font-display);font-size:1rem;letter-spacing:0;color:var(--ink-deep);text-transform:none;margin-left:.4rem}
.rooms-block--accent .rooms-block__name{color:var(--ink-deep);font-weight:200;letter-spacing:.01em;font-size:2.2rem;margin:.8rem 0 1rem}
.rooms-block--accent .rooms-block__desc{color:#6b5560;font-weight:300}
.rooms-block--accent .rooms-block__spec{color:var(--ink);font-weight:400;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}
.rooms-block--accent .rooms-block__spec svg{color:var(--gold);width:16px;height:16px}

/* Botones del card — bordes rectos */
.rooms-block--accent .btn--brand{border-radius:0;padding:1rem 1.6rem;font-size:.74rem;letter-spacing:.24em;background:var(--ink-deep);border:1px solid var(--ink-deep);transition:background .2s,color .2s}
.rooms-block--accent .btn--brand:hover{background:transparent;color:var(--ink-deep)}
.rooms-block--accent .btn--outline{border-radius:0;padding:1rem 1.6rem;font-size:.74rem;letter-spacing:.24em;border:1px solid var(--ink-deep);color:var(--ink-deep);background:transparent;transition:background .2s,color .2s}
.rooms-block--accent .btn--outline:hover{background:var(--ink-deep);color:#fff}

/* Details / dropdown — full width hairlines */
.rooms-details{margin-top:1.8rem;border-top:1px solid rgba(67,19,33,.08);padding-top:0}
.rooms-details--full{grid-column:1 / -1;margin-top:0;border-top:1px solid rgba(67,19,33,.1);padding:0;background:#fff}
.rooms-details--full[open]{padding-bottom:0}
.rooms-details>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-deep);font-weight:400;padding:1.4rem 3rem;border-radius:0;transition:background .2s,color .2s}
.rooms-details>summary::-webkit-details-marker{display:none}
.rooms-details>summary:hover{background:#faf7f1}
.rooms-details__chev{transition:transform .3s ease;color:var(--gold);margin-left:.6rem}
.rooms-details[open]>summary .rooms-details__chev{transform:rotate(180deg)}
.rooms-details__body{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:0;padding:0;background:#faf7f1;border-radius:0;border:0;border-top:1px solid rgba(67,19,33,.08);animation:roomsDetailsFade .3s ease both}
@keyframes roomsDetailsFade{from{opacity:0}to{opacity:1}}
.rooms-details__col{padding:2rem 2.4rem;border-right:1px solid rgba(67,19,33,.08)}
.rooms-details__col:last-child{border-right:0}
.rooms-details__col h4{font-family:'Jost',sans-serif;font-weight:400;font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem;padding-bottom:0;border-bottom:0}
.rooms-details__col ul{list-style:none;padding:0;margin:0}
.rooms-details__col li{position:relative;padding:.35rem 0 .35rem 1rem;font-size:.88rem;color:var(--ink);line-height:1.55;font-weight:300}
.rooms-details__col li::before{content:"—";position:absolute;left:0;top:.4rem;color:var(--gold);font-weight:300;width:auto;height:auto;background:transparent;border-radius:0}
@media (max-width:760px){
    .rooms-details__body{grid-template-columns:1fr}
    .rooms-details__col{border-right:0;border-bottom:1px solid rgba(67,19,33,.08);padding:1.4rem 1.6rem}
    .rooms-details__col:last-child{border-bottom:0}
    .rooms-details>summary{padding:1.2rem 1.6rem}
    .rooms-block--accent .rooms-block__info{padding:2rem 1.6rem}
}

/* ============================================
   ACTIVITY CARD — clickable
   ============================================ */
.act-card{display:block;text-decoration:none;color:inherit;position:relative;transition:transform .4s ease}
.act-card:hover{transform:translateY(-4px)}
.act-card__media{position:relative;overflow:hidden}
.act-card__arrow{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--ink);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateX(-6px);transition:opacity .35s ease,transform .35s ease;z-index:2}
.act-card__arrow svg{width:16px;height:16px}
.act-card:hover .act-card__arrow{opacity:1;transform:translateX(0)}
.act-card__cta{display:inline-block;margin-top:.8rem;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);border-bottom:1px solid rgba(184,153,104,.4);padding-bottom:2px;transition:color .3s ease,border-color .3s ease}
.act-card:hover .act-card__cta{color:#fff;border-color:#fff}

/* ============================================
   ACTIVIDAD DETAIL PAGE
   ============================================ */
.page-actividad{background:var(--cream-soft)}
.actividad-hero{background:#2f0a15;color:#fff;padding:5rem 0 2.5rem;position:relative}
.actividad-hero__inner{max-width:1180px;margin:0 auto;padding:0 1rem;text-align:left;display:block}
.actividad-hero--split .actividad-hero__inner{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:2.5rem;align-items:center}
.actividad-hero__text{min-width:0}
.actividad-hero__media{aspect-ratio:4/3;border-radius:10px;overflow:hidden;box-shadow:0 16px 48px rgba(0,0,0,.35)}
.actividad-hero__media img{width:100%;height:100%;object-fit:cover;display:block}
@media (max-width:820px){
    .actividad-hero{padding:4rem 0 2rem}
    .actividad-hero--split .actividad-hero__inner{grid-template-columns:1fr;gap:1.5rem}
    .actividad-hero__media{aspect-ratio:16/10}
}
.actividad-hero__eyebrow{font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem}
.actividad-hero__title{font-family:'Josefin Sans','Jost',sans-serif;font-weight:200;font-size:clamp(2.2rem,5vw,4rem);line-height:1.05;margin:0 0 1rem;color:#fff}
.actividad-hero__sub{font-size:1.05rem;color:rgba(255,255,255,.82);max-width:640px;margin:0 0 1.5rem;font-weight:300}
.actividad-crumbs{font-size:.8rem;letter-spacing:.05em;color:rgba(255,255,255,.7)}
.actividad-crumbs a{color:rgba(255,255,255,.7);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .3s}
.actividad-crumbs a:hover{border-color:rgba(255,255,255,.5)}
.actividad-crumbs strong{color:#fff;font-weight:400}
.actividad-crumbs span{margin:0 .4rem;opacity:.5}

.actividad-body{padding:4rem 0 5rem}
.actividad-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:3.5rem;align-items:flex-start}
@media (max-width:900px){.actividad-grid{grid-template-columns:1fr;gap:2.5rem}}

.actividad-main{position:relative}
.actividad-datebadge{display:inline-flex;flex-direction:row;align-items:baseline;gap:.5rem;background:transparent;color:var(--ink);padding:0;margin:0 0 1.2rem;border-bottom:1px solid rgba(184,153,104,.45);padding-bottom:.6rem}
.actividad-datebadge__day{font-family:'Josefin Sans';font-weight:300;font-size:2.4rem;line-height:1;color:var(--ink)}
.actividad-datebadge__month{font-size:.72rem;letter-spacing:.28em;color:var(--gold);text-transform:uppercase}

.actividad-main__title{font-family:'Josefin Sans';font-weight:300;font-size:1.8rem;color:var(--ink);margin:0 0 1.2rem}
.actividad-main__body{font-size:1rem;line-height:1.75;color:#4b3540;max-width:62ch}
.actividad-main__body p{margin:0 0 1rem}

.actividad-include{list-style:none;padding:0;margin:2.2rem 0 0;display:grid;grid-template-columns:1fr 1fr;gap:.8rem 1.6rem;max-width:520px}
.actividad-include li{display:flex;align-items:center;gap:.65rem;font-size:.92rem;color:var(--ink);font-weight:300}
.actividad-include__ico{display:inline-flex;width:26px;height:26px;border-radius:50%;background:rgba(184,153,104,.18);color:var(--gold);align-items:center;justify-content:center}
.actividad-include__ico svg{width:14px;height:14px}

.actividad-side{position:sticky;top:100px}
@media (max-width:900px){.actividad-side{position:static}}
.actividad-card{background:#fff;border:1px solid rgba(67,19,33,.08);border-radius:4px;padding:2rem 1.8rem;box-shadow:0 30px 60px -30px rgba(47,10,21,.25)}
.actividad-card__kicker{font-size:.72rem;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);margin:0 0 .4rem}
.actividad-card__title{font-family:'Josefin Sans';font-weight:300;font-size:1.35rem;color:var(--ink);margin:0 0 1.3rem;line-height:1.25}
.actividad-meta{margin:0 0 1.5rem;padding:0}
.actividad-meta>div{display:flex;justify-content:space-between;align-items:baseline;padding:.7rem 0;border-bottom:1px dashed rgba(67,19,33,.15)}
.actividad-meta>div:last-child{border-bottom:0}
.actividad-meta dt{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#8a7480;font-weight:400}
.actividad-meta dd{margin:0;font-size:.92rem;color:var(--ink);font-weight:400;text-align:right}
.actividad-card__cta{display:block;text-align:center;width:100%;margin-bottom:.7rem}
.actividad-card__alt{display:block;text-align:center;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:#8a7480;text-decoration:none;padding:.5rem}
.actividad-card__alt:hover{color:var(--ink)}
.actividad-share{margin-top:1.5rem;display:flex;align-items:center;gap:.8rem;justify-content:center;color:#8a7480;font-size:.75rem;letter-spacing:.22em;text-transform:uppercase}
.actividad-share a{color:var(--ink);width:34px;height:34px;border-radius:50%;border:1px solid rgba(67,19,33,.15);display:inline-flex;align-items:center;justify-content:center;transition:background .3s,color .3s,border-color .3s}
.actividad-share a:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============================================
   NOTICIAS (Blog)
   ============================================ */
.page-noticias{background:var(--cream-soft)}
.noticias-cover{padding:7rem 0 3rem;background:linear-gradient(180deg,#2f0a15 0%,#431321 100%);color:#fff;text-align:left}
.noticias-cover__inner{max-width:none}
.noticias-cover__eyebrow{font-size:.8rem;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin:0 0 1rem}
.noticias-cover__title{font-family:'Josefin Sans';font-weight:200;font-size:clamp(2.6rem,5.5vw,4.6rem);line-height:1;margin:0 0 1.2rem;color:#fff;max-width:900px}
.noticias-cover__lede{color:rgba(255,255,255,.8);font-weight:300;line-height:1.7;max-width:620px;margin:0}

.noticias-listing{padding:3.5rem 0 5rem}

.news-feature{display:grid;grid-template-columns:1.2fr 1fr;gap:2.5rem;align-items:center;background:#fff;border:1px solid rgba(67,19,33,.06);border-radius:4px;overflow:hidden;margin-bottom:3rem;text-decoration:none;color:inherit;box-shadow:0 30px 60px -40px rgba(47,10,21,.25);transition:transform .4s ease,box-shadow .4s ease}
.news-feature:hover{transform:translateY(-3px);box-shadow:0 40px 80px -30px rgba(47,10,21,.35)}
.news-feature__media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#2f0a15}
.news-feature__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.news-feature:hover .news-feature__media img{transform:scale(1.04)}
.news-feature__ph{width:100%;height:100%;background:linear-gradient(135deg,#431321,#2f0a15)}
.news-feature__body{padding:2rem 2.4rem 2rem 0}
.news-feature__body h2{font-family:'Josefin Sans';font-weight:300;font-size:1.8rem;line-height:1.2;color:var(--ink);margin:.6rem 0 .8rem}
.news-feature__body p{color:#5a4450;line-height:1.7;margin:0 0 1rem}
@media (max-width:860px){.news-feature{grid-template-columns:1fr}.news-feature__body{padding:1.4rem 1.6rem 1.8rem}}

.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media (max-width:980px){.news-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.news-grid{grid-template-columns:1fr}}

.news-card{display:flex;flex-direction:column;background:#fff;border:1px solid rgba(67,19,33,.06);border-radius:4px;overflow:hidden;text-decoration:none;color:inherit;transition:transform .4s ease,box-shadow .4s ease}
.news-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(47,10,21,.3)}
.news-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#2f0a15}
.news-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .7s ease}
.news-card:hover .news-card__media img{transform:scale(1.05)}
.news-card__ph{width:100%;height:100%;background:linear-gradient(135deg,#431321,#2f0a15)}
.news-card__cat{position:absolute;top:14px;left:14px;background:rgba(255,255,255,.92);color:var(--ink);font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;padding:.35rem .7rem;border-radius:2px;font-weight:400}
.news-card__cat--solid{position:static;display:inline-block;background:var(--gold);color:#fff}
.news-card__body{padding:1.4rem 1.5rem 1.6rem;display:flex;flex-direction:column;flex:1}
.news-card__date{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:#8a7480;margin:0 0 .6rem}
.news-card__body h3{font-family:'Josefin Sans';font-weight:300;font-size:1.12rem;line-height:1.35;color:var(--ink);margin:0 0 .7rem}
.news-card__excerpt{font-size:.92rem;line-height:1.6;color:#5a4450;margin:0 0 1rem;flex:1}
.news-card__link{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-top:auto;border-bottom:1px solid rgba(184,153,104,.35);padding-bottom:3px;align-self:flex-start;transition:color .3s,border-color .3s}
.news-card:hover .news-card__link{color:var(--ink);border-color:var(--ink)}

/* NOTICIA (detail) */
.noticia-hero{min-height:60vh;display:flex;align-items:flex-end;background:#2f0a15 center/cover no-repeat;color:#fff;padding:7rem 0 3.5rem}
.noticia-hero__inner{max-width:none;text-align:left}
.noticia-hero__cat{display:inline-block;background:var(--gold);color:#fff;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;padding:.4rem .9rem;border-radius:2px;margin:0 0 1.2rem}
.noticia-hero__title{font-family:'Josefin Sans';font-weight:200;font-size:clamp(2rem,4.5vw,3.6rem);line-height:1.1;margin:0 0 1rem;color:#fff;max-width:900px}
.noticia-hero__meta{font-size:.82rem;letter-spacing:.08em;color:rgba(255,255,255,.75);margin:0 0 1.4rem;display:flex;gap:.6rem;flex-wrap:wrap;align-items:center}
.noticia-hero__meta span+span{color:rgba(255,255,255,.5)}

.noticia-article{padding:4rem 0 5rem}
.noticia-article__inner{max-width:740px;margin:0 auto}
.noticia-article__lede{font-family:'Josefin Sans';font-weight:300;font-size:1.35rem;line-height:1.55;color:var(--ink);margin:0 0 2rem;padding-bottom:2rem;border-bottom:1px solid rgba(67,19,33,.12)}
.noticia-article__body{font-size:1.05rem;line-height:1.85;color:#3d2b34}
.noticia-article__body p{margin:0 0 1.3rem}
.noticia-article__body h2,.noticia-article__body h3{font-family:'Josefin Sans';font-weight:300;color:var(--ink);margin:2rem 0 1rem}
.noticia-article__back{margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(67,19,33,.12);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase}
.noticia-article__back a{color:var(--gold);text-decoration:none}
.noticia-article__back a:hover{color:var(--ink)}

.noticias-related{background:#fff;padding:4rem 0}

/* ============= Cart icon en navbar ============= */
.navbar__right{justify-self:end;display:inline-flex;align-items:center;gap:.4rem}
.navbar__right .lang-switch{justify-self:auto;position:relative}
.navbar__cart{position:relative;display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;color:inherit;text-decoration:none;border-radius:50%;transition:background .15s}
.navbar__cart:hover{background:rgba(0,0,0,.06)}
.navbar__cart-badge{position:absolute;top:2px;right:0;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--gold,#b88a3e);color:#fff;font-size:.7rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;line-height:1}

/* ============= Shop / Cart / Checkout / Order ============= */
.shop-page{padding:3rem 1rem 5rem;max-width:1100px}
.shop-page__head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:1.6rem;flex-wrap:wrap}
.shop-page__head h1{font-size:2rem;margin:0}
.shop-page__back{color:var(--gold,#b88a3e);text-decoration:none;font-size:.9rem}
.shop-page__back:hover{text-decoration:underline}

.shop-grid{display:grid;grid-template-columns:1fr 340px;gap:2rem;align-items:start}
@media (max-width:840px){.shop-grid{grid-template-columns:1fr}}

.shop-empty{text-align:center;padding:4rem 1rem;background:#faf7f2;border-radius:8px}
.shop-empty p{margin-bottom:1rem;color:#666}

.shop-items{display:flex;flex-direction:column;gap:.8rem}
.shop-item{display:grid;grid-template-columns:90px 1fr auto;gap:1rem;padding:1rem;background:#fff;border:1px solid #ece7df;border-radius:8px;align-items:center}
.shop-item__media{width:90px;height:90px;border-radius:6px;overflow:hidden;background:#f0ebe2}
.shop-item__media img{width:100%;height:100%;object-fit:cover;display:block}
.shop-item__body h3{margin:0 0 .2rem;font-size:1.05rem}
.shop-item__meta{margin:0 0 .3rem;color:#888;font-size:.82rem}
.shop-item__price{margin:0 0 .5rem;font-weight:600;color:var(--ink,#2f0a15)}
.shop-item__qty{display:flex;align-items:end;gap:.5rem;flex-wrap:wrap;margin:0}
.shop-item__qty label{display:flex;flex-direction:column;font-size:.78rem;color:#666;gap:.2rem}
.shop-item__qty input{width:70px;padding:.35rem .5rem;border:1px solid #d6cfc1;border-radius:4px}
.shop-item__total{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:.5rem}
.shop-item__total strong{font-size:1.05rem}
.shop-item__remove{background:none;border:none;color:#a04;cursor:pointer;font-size:1.4rem;line-height:1;padding:0 .3rem}
.shop-item__remove:hover{color:#c33}
@media (max-width:600px){.shop-item{grid-template-columns:70px 1fr}.shop-item__total{grid-column:1/-1;flex-direction:row;justify-content:space-between;align-items:center}.shop-item__media{width:70px;height:70px}}

.shop-summary{background:#faf7f2;border:1px solid #ece7df;border-radius:8px;padding:1.4rem;position:sticky;top:1rem}
.shop-summary h3{margin:0 0 1rem;font-size:1.1rem}
.shop-summary dl{margin:0 0 1rem}
.shop-summary dl div{display:flex;justify-content:space-between;padding:.4rem 0;border-bottom:1px dashed #e0d8c8}
.shop-summary dl div:last-child{border-bottom:none;padding-top:.7rem;font-size:1.1rem}
.shop-summary dl dt{color:#666}
.shop-summary__items{list-style:none;margin:0 0 1rem;padding:0}
.shop-summary__items li{display:flex;justify-content:space-between;gap:1rem;padding:.4rem 0;border-bottom:1px dashed #e0d8c8;font-size:.9rem}
.shop-summary__cta{width:100%;display:flex;text-align:center;margin-top:.5rem}
.shop-summary__note{margin:.8rem 0 0;font-size:.78rem;color:#888;line-height:1.4}

.shop-form{background:#fff;border:1px solid #ece7df;border-radius:8px;padding:1.6rem}
.shop-form h3{margin:0 0 1rem;font-size:1.05rem;color:var(--ink,#2f0a15)}
.shop-form h3:not(:first-child){margin-top:1.4rem;padding-top:1.2rem;border-top:1px solid #ece7df}
.shop-form p{margin:0 0 .8rem}
.shop-form label{display:flex;flex-direction:column;gap:.3rem;font-size:.85rem;color:#555}
.shop-form input,.shop-form textarea{padding:.6rem .7rem;border:1px solid #d6cfc1;border-radius:4px;font:inherit;background:#fff}
.shop-form input:focus,.shop-form textarea:focus{outline:none;border-color:var(--gold,#b88a3e)}
.shop-form__row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
@media (max-width:520px){.shop-form__row{grid-template-columns:1fr}}
.shop-form__pay{background:#faf7f2;border-left:3px solid var(--gold,#b88a3e);padding:.8rem 1rem;border-radius:0 4px 4px 0;font-size:.9rem;line-height:1.45}
.shop-form .btn{margin-top:1rem;width:100%}

.shop-alert{padding:.8rem 1rem;background:#f5f0e3;border-left:3px solid var(--gold,#b88a3e);border-radius:0 4px 4px 0;margin:0 0 1.2rem;font-size:.9rem}
.shop-alert--error{background:#fdecec;border-left-color:#c33;color:#922}

.btn--sm{padding:.35rem .8rem;font-size:.8rem}

/* Activity add to cart */
.actividad-card__price{font-size:1.6rem;font-weight:700;color:var(--ink,#2f0a15);margin:0 0 .8rem}
.actividad-card__price small{font-size:.7rem;font-weight:400;color:#888;display:block;margin-top:-.2rem}
.actividad-card__alert{padding:.6rem .8rem;background:#f5f0e3;border-left:3px solid var(--gold,#b88a3e);border-radius:0 4px 4px 0;font-size:.82rem;margin:0 0 .8rem}
.actividad-card__sold{color:#a04;font-weight:600;margin:.4rem 0 .8rem;text-align:center}
.actividad-add{display:flex;flex-direction:column;gap:.6rem;margin:1rem 0 .6rem}
.actividad-add__qty{display:flex;flex-direction:column;font-size:.82rem;gap:.3rem;color:#666}
.actividad-add__qty input{padding:.5rem .6rem;border:1px solid #d6cfc1;border-radius:4px;font:inherit;width:100%}
.actividad-include__title{margin:1.5rem 0 .6rem;font-size:1.05rem;color:var(--ink,#2f0a15)}
.actividad-req{margin-top:1rem;padding:.7rem 1rem;background:#faf7f2;border-radius:6px;font-size:.88rem}

/* Order/thank-you */
.order-hero{text-align:center;padding:2rem 1rem;background:linear-gradient(180deg,#faf7f2,#fff);border-radius:8px;margin-bottom:1.5rem;border:1px solid #ece7df}
.order-hero h1{margin:0 0 .4rem;font-size:1.8rem}
.order-hero p{margin:.2rem 0;color:#555}
.order-hero__code{font-size:.95rem;color:#666;margin-top:.6rem}
.order-hero--paid{background:linear-gradient(180deg,#f0f7e8,#fff);border-color:#cde0a8}
.order-hero--expired,.order-hero--cancelled{background:linear-gradient(180deg,#fdecec,#fff);border-color:#f0c6c6}
.order-block{background:#fff;border:1px solid #ece7df;border-radius:8px;padding:1.4rem}
.order-block h3{margin:0 0 1rem}
.order-totals{margin:1rem 0 0}
.order-totals div{display:flex;justify-content:space-between;padding-top:.6rem;border-top:1px solid #ece7df;font-size:1.1rem}
.order-bank{margin-top:1.4rem;background:#faf7f2;padding:1rem 1.2rem;border-radius:6px;border:1px dashed #d6cfc1}
.order-bank h4{margin:0 0 .5rem;font-size:.95rem}
.order-bank pre{font-family:'Courier New',monospace;font-size:.88rem;background:#fff;padding:.8rem;border-radius:4px;white-space:pre-wrap;margin:0 0 .6rem}
.order-bank__hint{font-size:.82rem;color:#666;margin:0}
.order-side{background:#faf7f2;border:1px solid #ece7df;border-radius:8px;padding:1.4rem}
.order-side h3{margin:0 0 .8rem}
.order-side p{margin:0 0 1rem;line-height:1.6}

/* =======================================================
   Hotel Gran Wolf — landing
   ======================================================= */
.hgw-hero{
    position:relative;min-height:78vh;display:flex;align-items:flex-end;
    background:#2f0a15 center/cover no-repeat;color:#fff;padding:7rem 0 4rem;
}
.hgw-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,5,10,.55) 0%,rgba(20,5,10,.35) 40%,rgba(20,5,10,.85) 100%)}
.hgw-hero__inner{position:relative;z-index:2;max-width:780px}
.hgw-hero__kicker{font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold,#bd985c);margin:0 0 1.2rem;font-weight:600}
.hgw-hero__title{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(2.6rem,6vw,4.8rem);line-height:1.05;margin:0 0 1.4rem;letter-spacing:-.01em}
.hgw-hero__title span{font-style:italic;color:var(--gold,#bd985c);display:block}
.hgw-hero__lede{font-size:1.05rem;line-height:1.7;max-width:560px;color:rgba(255,255,255,.86);margin:0 0 2.2rem}
.hgw-hero__ctas{display:flex;gap:1rem;flex-wrap:wrap}
.btn--outline-light{border-color:rgba(255,255,255,.6);color:#fff}
.btn--outline-light:hover{background:#fff;color:var(--ink-deep,#2f0a15);border-color:#fff}

.hgw-intro{padding:5rem 0}
.hgw-intro__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:3.5rem;align-items:center}
.hgw-intro__media{aspect-ratio:4/3;overflow:hidden;border-radius:4px;box-shadow:0 24px 60px rgba(47,10,21,.18);background:#2f0a15}
.hgw-intro__media img{width:100%;height:100%;object-fit:cover;display:block}
.hgw-intro__placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:#fff;letter-spacing:.2em;text-transform:uppercase;font-size:.85rem}
.hgw-intro__text h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.15;margin:.6rem 0 1.2rem;color:var(--ink,#2f0a15)}
.hgw-intro__text p{font-size:1rem;line-height:1.75;color:#444;margin:0 0 1.8rem}
.hgw-features{list-style:none;margin:0 0 2rem;padding:0;display:grid;gap:1.1rem}
.hgw-features li{display:flex;gap:1rem;align-items:flex-start;padding:1rem 1.1rem;border:1px solid #ece7df;background:#fbf8f3}
.hgw-features svg{width:24px;height:24px;color:var(--gold,#bd985c);flex-shrink:0;margin-top:2px}
.hgw-features strong{display:block;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink,#2f0a15);margin-bottom:.25rem}
.hgw-features span{font-size:.92rem;color:#666;line-height:1.5}

.hgw-gallery{padding:0 0 5rem}
.hgw-gallery__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.8rem;grid-auto-rows:160px}
.hgw-gallery__item{margin:0;overflow:hidden;border-radius:3px;background:#2f0a15}
.hgw-gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.hgw-gallery__item:hover img{transform:scale(1.05)}
.hgw-gallery__item--0{grid-column:span 3;grid-row:span 2}
.hgw-gallery__item--1{grid-column:span 3}
.hgw-gallery__item--2{grid-column:span 2}
.hgw-gallery__item--3{grid-column:span 2}
.hgw-gallery__item--4{grid-column:span 2}

.hgw-options{padding:5rem 0;background:#fbf8f3}
.hgw-options__head{text-align:center;max-width:640px;margin:0 auto 3rem}
.hgw-options__head h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(2rem,3.5vw,2.8rem);margin:.5rem 0 .8rem;color:var(--ink,#2f0a15)}
.hgw-options__head p{font-size:1rem;color:#666;margin:0 0 1.4rem}
.hgw-options__grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.6rem}
.hgw-option-card{background:#fff;border:1px solid #ece7df;display:flex;flex-direction:column;transition:transform .3s ease,box-shadow .3s ease}
.hgw-option-card:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(47,10,21,.12)}
.hgw-option-card__media{position:relative;aspect-ratio:4/3;background:#2f0a15 center/cover no-repeat}
.hgw-option-card__num{position:absolute;top:1rem;left:1rem;background:rgba(255,255,255,.92);color:var(--ink,#2f0a15);font-size:.75rem;letter-spacing:.18em;font-weight:700;padding:.4rem .7rem}
.hgw-option-card__body{padding:1.6rem 1.4rem 1.8rem;display:flex;flex-direction:column;gap:.8rem;flex:1}
.hgw-option-card__body h3{margin:0;font-family:var(--font-display,serif);font-weight:400;font-size:1.5rem;color:var(--ink,#2f0a15)}
.hgw-option-card__body p{margin:0;font-size:.95rem;line-height:1.6;color:#666;flex:1}
.hgw-option-card__cta{margin-top:.6rem;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--ink,#2f0a15);text-decoration:none;display:inline-flex;align-items:center;gap:.6rem;transition:gap .25s ease}
.hgw-option-card__cta:hover{gap:1rem;color:var(--gold,#bd985c)}

.hgw-cta{background:var(--ink-deep,#2f0a15);color:#fff;padding:5rem 0}
.hgw-cta__inner{text-align:center;max-width:680px;margin:0 auto;color:#fff}
.hgw-cta__inner .section__eyebrow{color:var(--gold,#bd985c) !important}
.hgw-cta h2,
.hgw-cta__inner h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.8rem,3.2vw,2.6rem);margin:.6rem 0 .8rem;color:#fff !important}
.hgw-cta p,
.hgw-cta__inner p{margin:0 0 2rem;color:rgba(255,255,255,.82)}
.hgw-cta__row{display:flex;gap:1.4rem;justify-content:center;align-items:center;flex-wrap:wrap}
.hgw-cta__link{display:inline-flex;align-items:center;gap:.55rem;color:rgba(255,255,255,.85);text-decoration:none;font-size:.92rem}
.hgw-cta__link:hover{color:var(--gold,#bd985c)}

@media (max-width:840px){
    .hgw-hero{min-height:60vh;padding:6rem 0 3rem}
    .hgw-intro__grid{grid-template-columns:1fr;gap:2rem}
    .hgw-gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:140px}
    .hgw-gallery__item--0,.hgw-gallery__item--1,.hgw-gallery__item--2,.hgw-gallery__item--3,.hgw-gallery__item--4{grid-column:span 1;grid-row:auto}
    .hgw-gallery__item--0{grid-column:span 2;grid-row:span 2}
}


/* =======================================================
   Centro Ecuestre — landing
   ======================================================= */
.ce-hero{position:relative;min-height:72vh;display:flex;align-items:flex-end;background:#2f0a15 center/cover no-repeat;color:#fff;padding:7rem 0 4rem}
.ce-hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,5,10,.55) 0%,rgba(20,5,10,.4) 45%,rgba(20,5,10,.85) 100%)}
.ce-hero__inner{position:relative;z-index:2;max-width:780px}
.ce-hero__kicker{font-size:.78rem;letter-spacing:.28em;text-transform:uppercase;color:var(--gold,#bd985c);margin:0 0 1.2rem;font-weight:600}
.ce-hero__title{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(2.6rem,6vw,4.8rem);line-height:1.05;margin:0 0 1.4rem;letter-spacing:-.01em}
.ce-hero__title span{font-style:italic;color:var(--gold,#bd985c);display:block}
.ce-hero__lede{font-size:1.05rem;line-height:1.7;max-width:560px;color:rgba(255,255,255,.86);margin:0 0 2.2rem}

.ce-intro{padding:5rem 0}
.ce-intro__grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,1fr);gap:3.5rem;align-items:center}
.ce-intro__text h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.9rem,3.2vw,2.8rem);line-height:1.15;margin:.6rem 0 1.2rem;color:var(--ink,#2f0a15)}
.ce-intro__text p{font-size:1rem;line-height:1.75;color:#444;margin:0 0 1.2rem}
.ce-intro__text strong{color:var(--ink,#2f0a15)}
.ce-facilities{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.ce-facilities li{display:flex;gap:.9rem;padding:1.2rem 1.1rem;background:#fbf8f3;border:1px solid #ece7df}
.ce-facilities span{font-family:var(--font-display,serif);font-size:1.6rem;color:var(--gold,#bd985c);line-height:1;font-weight:300}
.ce-facilities strong{display:block;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink,#2f0a15);margin-bottom:.25rem}
.ce-facilities em{font-style:normal;font-size:.88rem;color:#666;line-height:1.4}

.ce-benefits{background:var(--ink-deep,#2f0a15);color:#fff;padding:5rem 0}
.ce-benefits__head{text-align:center;max-width:640px;margin:0 auto 3rem}
.ce-benefits__head h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.9rem,3.2vw,2.6rem);margin:.5rem 0 1rem;color:#fff}
.ce-benefits__head .section__divider{margin-left:auto;margin-right:auto;background:var(--gold,#bd985c)}
.ce-benefits__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.ce-benefit{display:flex;flex-direction:column;align-items:center;text-align:center;gap:.9rem;padding:1.6rem 1rem;border:1px solid rgba(217,193,152,.18);background:rgba(255,255,255,.02);transition:border-color .3s ease,transform .3s ease}
.ce-benefit:hover{border-color:var(--gold,#bd985c);transform:translateY(-3px)}
.ce-benefit__icon{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--gold,#bd985c);background:rgba(189,152,92,.1)}
.ce-benefit__icon svg{width:24px;height:24px}
.ce-benefit p{margin:0;font-size:.92rem;line-height:1.45;color:rgba(255,255,255,.85)}
@media (max-width:900px){.ce-benefits__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.ce-benefits__grid{grid-template-columns:1fr}}

.ce-services{padding:5rem 0;background:#fbf8f3}
.ce-services__head{text-align:center;max-width:640px;margin:0 auto 3rem}
.ce-services__head h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.9rem,3.2vw,2.6rem);margin:.5rem 0 1rem;color:var(--ink,#2f0a15)}
.ce-services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem}
.ce-service{background:#fff;border:1px solid #ece7df;padding:2rem 1.6rem;display:flex;flex-direction:column;gap:.7rem;transition:transform .3s ease,box-shadow .3s ease}
.ce-service:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(47,10,21,.12)}
.ce-service__num{font-family:var(--font-display,serif);font-size:1.4rem;color:var(--gold,#bd985c);font-weight:300}
.ce-service h3{margin:0;font-family:var(--font-display,serif);font-weight:400;font-size:1.35rem;color:var(--ink,#2f0a15)}
.ce-service p{margin:0;font-size:.92rem;line-height:1.6;color:#555;flex:1}
.ce-service__cta{margin-top:.6rem;font-size:.76rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--ink,#2f0a15);text-decoration:none;display:inline-flex;align-items:center;gap:.55rem;transition:gap .25s ease,color .25s ease}
.ce-service__cta:hover{gap:.95rem;color:var(--gold,#bd985c)}
@media (max-width:1000px){.ce-services__grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.ce-services__grid{grid-template-columns:1fr}}

.ce-gallery{padding:5rem 0;background:#fff}
.ce-gallery__head{text-align:center;max-width:640px;margin:0 auto 2.5rem}
.ce-gallery__head h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.7rem,3vw,2.4rem);margin:.5rem 0;color:var(--ink,#2f0a15)}
.ce-gallery__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.8rem;grid-auto-rows:200px;grid-auto-flow:dense}
.ce-gallery__item{margin:0;overflow:hidden;background:#2f0a15;position:relative}
.ce-gallery__item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .6s ease}
.ce-gallery__item:hover img{transform:scale(1.06)}
.ce-gallery__item:nth-child(7n+1){grid-column:span 2;grid-row:span 2}
.ce-gallery__item:nth-child(7n+5){grid-row:span 2}
.ce-gallery__empty{text-align:center;padding:3rem;border:1px dashed #d4cfc6;color:#888;font-size:.92rem}
.ce-gallery__empty code{background:#fbf8f3;padding:.15rem .4rem;font-size:.85rem}
@media (max-width:900px){.ce-gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px}.ce-gallery__item:nth-child(7n+1),.ce-gallery__item:nth-child(7n+5){grid-column:auto;grid-row:auto}}

.ce-cta{background:var(--ink-deep,#2f0a15);color:#fff;padding:5rem 0}
.ce-cta__inner{text-align:center;max-width:640px;margin:0 auto;color:#fff}
.ce-cta h2,
.ce-cta__inner h2{font-family:var(--font-display,serif);font-weight:300;font-size:clamp(1.8rem,3.2vw,2.6rem);margin:.6rem 0 .8rem;color:#fff !important}
.ce-cta p,
.ce-cta__inner p{margin:0 0 2rem;color:rgba(255,255,255,.82)}

@media (max-width:840px){
    .ce-hero{min-height:56vh;padding:6rem 0 3rem}
    .ce-intro__grid{grid-template-columns:1fr;gap:2rem}
    .ce-facilities{grid-template-columns:1fr}
}

/* Servicios CE con imagen opcional (cargada desde panel) */
.ce-service--has-img { padding: 0; overflow: hidden; }
.ce-service--has-img .ce-service__media { width:100%; aspect-ratio: 4/3; background-size:cover; background-position:center; }
.ce-service--has-img > :not(.ce-service__media) { padding-left:1.6rem; padding-right:1.6rem; }
.ce-service--has-img .ce-service__num { padding-top:1.4rem; }
.ce-service--has-img .ce-service__cta { padding-bottom:1.6rem; }

/* Stepper de cantidad (− N +) */
.qty-stepper { display:inline-flex; align-items:stretch; border:1px solid #d6cfc1; border-radius:6px; overflow:hidden; background:#fff; height:42px; }
.qty-stepper__label { display:block; font-size:.78rem; color:#666; margin-bottom:.3rem; }
.qty-stepper__btn { width:38px; flex-shrink:0; border:none; background:#faf7f0; color:#2f0a15; font-size:1.2rem; line-height:1; cursor:pointer; transition:background .18s; user-select:none; }
.qty-stepper__btn:hover { background:#f0e9d8; }
.qty-stepper__btn:active { background:#e6dec5; }
.qty-stepper input[type=number] { width:54px; border:none; border-left:1px solid #ece6d5; border-right:1px solid #ece6d5; text-align:center; font-size:1rem; font-weight:600; color:#2f0a15; padding:0; background:transparent; -moz-appearance:textfield; }
.qty-stepper input[type=number]::-webkit-outer-spin-button,
.qty-stepper input[type=number]::-webkit-inner-spin-button { -webkit-appearance:none; margin:0; }
.qty-stepper input[type=number]:focus { outline:none; background:#fffbef; }
/* En la ficha de actividad: stepper a ancho completo, input centrado entre - y + */
.actividad-add__qty .qty-stepper { display:flex; width:100%; height:48px; }
.actividad-add__qty .qty-stepper__btn { width:56px; font-size:1.4rem; }
.actividad-add__qty .qty-stepper input[type=number] { flex:1 1 auto; width:auto; font-size:1.1rem; }
.shop-item__qty .qty-stepper { margin-bottom:.4rem; }

/* ============================================
   Sustentabilidad — usa la base visual de .ce-* y agrega ajustes propios
   ============================================ */
/* Imagen del split en la intro (columna derecha) */
.sus-intro__media{
    width:100%;height:100%;min-height:380px;
    background:#2f0a15 center/cover no-repeat;
    border:1px solid rgba(67,19,33,.08);
    box-shadow:0 30px 60px -30px rgba(47,10,21,.35);
}
@media (max-width:900px){.sus-intro__media{min-height:240px;}}

/* Sección oscura: añade un toque verde editorial sin cambiar la paleta global */
.sus-benefits{background:linear-gradient(180deg,#1f3022 0%,#2a3a2c 100%);}
.sus-benefits .ce-benefit{position:relative;padding-top:2.4rem;}
.sus-benefits .ce-benefit__icon{background:rgba(189,152,92,.14);}
.sus-benefit__num{
    position:absolute;top:.7rem;right:.9rem;
    font-family:var(--font-display,serif);font-weight:200;
    font-size:1.1rem;color:rgba(217,193,152,.55);letter-spacing:.04em;
}
.sus-benefits .ce-benefit h3{
    font-family:var(--font-display,serif);font-weight:300;
    font-size:1.15rem;color:#fff;margin:0 0 .4rem;letter-spacing:.01em;
}

/* KPIs en banda cream */
.sus-kpis{padding:4.5rem 0;background:var(--cream-soft,#faf7f1);border-top:1px solid rgba(67,19,33,.06);border-bottom:1px solid rgba(67,19,33,.06);}
.sus-kpis__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;text-align:center;}
@media (max-width:720px){.sus-kpis__grid{grid-template-columns:1fr;gap:2.4rem;}}
.sus-kpi{position:relative;}
.sus-kpi:not(:last-child)::after{
    content:'';position:absolute;right:-1rem;top:20%;height:60%;width:1px;
    background:rgba(67,19,33,.12);
}
@media (max-width:720px){.sus-kpi:not(:last-child)::after{display:none;}}
.sus-kpi strong{display:block;font-family:var(--font-display,serif);font-weight:200;font-size:clamp(2.6rem,5vw,3.6rem);color:var(--ink-deep,#2f0a15);line-height:1;letter-spacing:-.01em;}
.sus-kpi span{display:block;margin-top:.7rem;font-family:'Jost',sans-serif;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold,#bd985c);font-weight:500;}


/* =======================================================
   MOBILE POLISH — secciones del home
   Da aire entre bloques y mejora la lectura en pantallas chicas
   sin tocar la versión desktop. Breakpoints:
     ≤900  : tablet vertical / phablet
     ≤640  : phone normal
     ≤420  : phone chico
   ======================================================= */

/* ── Section scaffolding ──────────────────────────────── */
@media (max-width: 900px) {
    .section { padding: 4.5rem 0; }
    .section--welcome { padding: 4rem 0; }
    .section--contacto { padding: 4.5rem 0; }
    .section__title { margin-bottom: 1.2rem; }
    .section__title--xl { font-size: clamp(2.2rem, 8vw, 3.4rem); }
    .section__lede { font-size: .95rem; line-height: 1.7; margin-bottom: 1.8rem; }
    .section__divider { margin: 0 0 1.4rem; }
    .section--center .section__divider { margin-left: auto; margin-right: auto; }
    .section__eyebrow { font-size: .68rem; letter-spacing: .28em; margin-bottom: .9rem; }
}
@media (max-width: 640px) {
    .section { padding: 3.5rem 0; }
    .section--welcome { padding: 3rem 0; }
    .section--contacto { padding: 3.5rem 0; }
}
@media (max-width: 420px) {
    .section { padding: 2.8rem 0; }
    .section--welcome { padding: 2.4rem 0; }
}

/* ── Sección Territorio (welcome) ─────────────────────── */
@media (max-width: 900px) {
    .welcome-grid { gap: 2.4rem; }
    .welcome-text { max-width: 100%; text-align: left; }
    .welcome-logo { max-width: 90px; margin-bottom: 1.4rem; }
    .welcome-title { font-size: clamp(1.9rem, 7vw, 2.6rem); margin-bottom: 1.2rem; line-height: 1.1; }
    .welcome-lede { font-size: .98rem; line-height: 1.7; margin-bottom: 1.6rem; }
    .welcome-image { aspect-ratio: 4/3; }
    /* Quitar el solapamiento agresivo de las horas con la imagen */
    .welcome-hours {
        margin: -1.2rem auto 0; width: calc(100% - 1.5rem); max-width: 100%;
        padding: 1.1rem 1.2rem;
    }
}
@media (max-width: 640px) {
    .welcome-grid { gap: 2rem; }
    .welcome-btn { width: 100%; padding: 1rem 1.2rem; }
    .welcome-image { aspect-ratio: 5/4; }
    .welcome-hours { margin: -1rem .5rem 0; width: calc(100% - 1rem); padding: 1rem 1rem 1.2rem; }
    .welcome-hours li { padding: .35rem 0; font-size: .7rem; letter-spacing: .08em; gap: .35rem; }
    .welcome-hours__day { max-width: 56%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
    .welcome-hours__time { font-size: .7rem; }
}

/* ── Sección Hotel Gran Wolf (rooms) ──────────────────── */
@media (max-width: 900px) {
    .rooms-section__title { font-size: clamp(2.4rem, 9vw, 3.6rem) !important; }
    .rooms-section__lede { font-size: .95rem; padding: 0 .25rem; }
    .rooms-badge-new { font-size: .65rem; letter-spacing: .26em; }
    /* Booking form: inputs un toque más grandes para tap */
    .rooms-booking__field { padding: .85rem 1rem; }
    .rooms-booking__field select,
    .rooms-booking__field input { font-size: 16px; /* evita zoom iOS */ }
    .rooms-booking__field label { font-size: .62rem; letter-spacing: .2em; margin-bottom: .35rem; }
    .rooms-booking__submit { padding: 1.1rem 1.4rem; font-size: .72rem; letter-spacing: .2em; }
    /* Tabs Pesebrera/Bungalows: menos padding lateral */
    .rooms-tabs-bar { gap: 1.1rem; margin-bottom: 1.8rem; }
    .rooms-tab { padding: .85rem 1.2rem; font-size: .7rem; letter-spacing: .2em; }
    /* Card del bloque: padding reducido y tipografía más contenida */
    .rooms-block--accent .rooms-block__info { padding: 1.8rem 1.4rem 1.6rem; }
    .rooms-block--accent .rooms-block__name { font-size: 1.7rem; margin: .6rem 0 .8rem; }
    .rooms-block__desc { font-size: .92rem; line-height: 1.65; margin-bottom: 1.4rem; }
    .rooms-block__media { min-height: 280px; aspect-ratio: 4/3; }
    /* En mobile mostramos la imagen entre desc y specs (no al final del bloque) */
    .rooms-block__media--outer { display: none; }
    .rooms-block__media--inline { display: block; margin: 0 -1.4rem 1.4rem; }
    /* Specs stack a 1 columna en pantallas chicas para que entren completos */
    .rooms-block__specs { grid-template-columns: 1fr 1fr; gap: .7rem 1rem; padding: 1rem 0; margin-bottom: 1.4rem; }
    .rooms-block__spec { font-size: .72rem; letter-spacing: .12em; gap: .5rem; }
    .rooms-block__spec svg { width: 16px; height: 16px; }
    /* CTAs: full-width para tap fácil */
    .rooms-block__actions { gap: .7rem; }
    .rooms-block__actions .btn { width: 100%; padding: 1rem 1rem; }
}
@media (max-width: 560px) {
    .rooms-block__specs { grid-template-columns: 1fr; gap: .6rem; }
    .rooms-block__spec { font-size: .76rem; }
    /* "Más detalles" panel: una columna y padding reducido */
    .rooms-details > summary { padding: 1.1rem 1.4rem; font-size: .7rem; letter-spacing: .2em; }
    .rooms-details__col { padding: 1.2rem 1.4rem; }
    .rooms-details__col h4 { font-size: .68rem; letter-spacing: .24em; margin-bottom: .8rem; }
    .rooms-details__col li { font-size: .85rem; padding: .3rem 0 .3rem .9rem; }
    /* Tabs: más compactos para que quepan */
    .rooms-tab { padding: .75rem .9rem; font-size: .68rem; }
    /* Plans pills: ocupan ancho completo */
    .rates-pills { width: 100%; }
    .rate-pill { width: 100%; }
    .rate-pill > summary { width: 100%; justify-content: flex-start; gap: .5rem; }
    .rate-pill > summary .rate-pill__board { margin-left: auto; }
}
@media (max-width: 420px) {
    .rooms-block--accent .rooms-block__info { padding: 1.6rem 1.1rem 1.4rem; }
    .rooms-block--accent .rooms-block__name { font-size: 1.5rem; }
    .rooms-block__media { min-height: 220px; }
    .rooms-block__media--inline { margin: 0 -1.1rem 1.2rem; }
}

/* ── Sección Gastronomía ──────────────────────────────── */
@media (max-width: 900px) {
    .gastro-grid { gap: 2.5rem; }
    .gastro-text { padding: 0; }
    .gastro-lede { font-size: 1rem; line-height: 1.7; margin-bottom: 1.8rem; max-width: 100%; }
    .gastro-cards { gap: 1.1rem; }
    .gastro-card { padding: 1.2rem 1.4rem 1.2rem 4rem; }
    .gastro-card__num { left: 1.2rem; top: 1.2rem; font-size: 1rem; }
    .gastro-card h3 { font-size: 1.2rem; }
    .gastro-card p { font-size: .9rem; line-height: 1.6; }
    .gastro-cta { margin-top: 1.8rem; }
    .gastro-cta .btn { display: block; text-align: center; }
    .gastro-media { height: 380px; }
}
@media (max-width: 640px) {
    .gastro-grid { gap: 2rem; }
    .gastro-media { height: 340px; }
    /* Frames un toque más grandes para que sean legibles */
    .gastro-media__frame--a { width: 70%; height: 68%; }
    .gastro-media__frame--b { width: 68%; height: 60%; }
    .gastro-media__frame figcaption { font-size: .6rem; letter-spacing: .22em; padding: .4rem .7rem; left: .7rem; bottom: .7rem; }
}
@media (max-width: 420px) {
    .gastro-media { height: 280px; }
    .gastro-card { padding: 1rem 1.2rem 1rem 3.4rem; }
    .gastro-card__num { left: 1rem; top: 1rem; }
    .gastro-card h3 { font-size: 1.1rem; }
}

/* ── Sección Ubicación + Contacto ─────────────────────── */
@media (max-width: 900px) {
    .contacto-grid { gap: 2.5rem; }
    .contacto-lede { font-size: .96rem; line-height: 1.7; margin: 1rem 0 1.8rem; max-width: 100%; }
    .contacto-list { gap: .8rem; }
    .contacto-list li { padding: .8rem 1rem; gap: .85rem; }
    .contacto-list__ico { width: 32px; height: 32px; }
    .contacto-list__ico svg { width: 20px; height: 20px; }
    .contacto-list li a, .contacto-list li span { font-size: .92rem; word-break: break-word; }
    .contacto-list li small { font-size: .62rem; letter-spacing: .2em; }
    /* Form más compacto */
    .contacto-form { padding: 1.4rem 1.2rem; }
    .contacto-form input, .contacto-form textarea { padding: .85rem .9rem; font-size: 16px; /* evita zoom iOS */ margin-bottom: .7rem; }
    .contacto-form h3 { font-size: 1.2rem; margin-bottom: .9rem; }
    /* Switch ubicación / escríbenos: más compacto */
    .contacto-switch { width: 100%; display: flex; }
    .contacto-switch__btn { flex: 1; padding: .7rem .8rem; font-size: .66rem; letter-spacing: .18em; justify-content: center; }
    /* Mapa con ratio más cuadrado para que no se vea muy chato */
    .contacto-map { aspect-ratio: 4/3; }
}
@media (max-width: 480px) {
    .contacto-list li { padding: .7rem .85rem; gap: .7rem; }
    .contacto-list__ico { width: 28px; height: 28px; }
    .contacto-list__ico svg { width: 18px; height: 18px; }
    .contacto-form { padding: 1.2rem 1rem; }
    .contacto-switch__btn { padding: .65rem .5rem; font-size: .62rem; letter-spacing: .14em; gap: .35rem; }
    .contacto-switch__btn svg { width: 12px; height: 12px; }
    .contacto-map { aspect-ratio: 1/1; }
}
