/* ============================================================
   MELI RECOMIENDA — main.css v1.9.6
   Refined elegant aesthetic + Elementor compatibility
   ============================================================ */

/* ── Design Tokens ────────────────────────────────────────── */
:root {
    /* Brand palette */
    --mr-olive-900:  #3A3F1F;
    --mr-olive-700:  #616832;
    --mr-olive-600:  #777D45;
    --mr-olive-400:  #ACB081;
    --mr-olive-200:  #D4D7B0;
    --mr-cream-100:  #F6F5EE;
    --mr-cream-200:  #EAEBDD;
    --mr-cream-300:  #DFE0CC;
    --mr-sand:       #E8E5D8;
    --mr-gold:       #C8A96E;
    --mr-gold-light: #E2C98A;
    --mr-text:       #2E3018;
    --mr-text-muted: rgba(46,48,24,.62);
    --mr-white:      #FFFFFF;
    --mr-black:      #111110;

    /* Semantic aliases (backward-compat) */
    --mr-color-olive-dark:  var(--mr-olive-600);
    --mr-color-olive-soft:  var(--mr-olive-400);
    --mr-color-cream:       var(--mr-cream-200);
    --mr-color-soft-white:  var(--mr-cream-100);
    --mr-color-text:        var(--mr-text);
    --mr-color-text-light:  var(--mr-white);
    --mr-color-border:      rgba(97,104,50,.14);

    /* Shadows */
    --mr-shadow-xs:   0 1px 3px rgba(30,32,16,.06), 0 1px 2px rgba(30,32,16,.04);
    --mr-shadow-sm:   0 4px 12px rgba(30,32,16,.07), 0 2px 4px rgba(30,32,16,.04);
    --mr-shadow-md:   0 12px 32px rgba(30,32,16,.09), 0 4px 8px rgba(30,32,16,.05);
    --mr-shadow-soft: var(--mr-shadow-md);
    --mr-shadow-lg:   0 24px 56px rgba(30,32,16,.12), 0 8px 16px rgba(30,32,16,.06);
    --mr-shadow-gold: 0 8px 28px rgba(200,169,110,.22);

    /* Layout */
    --mr-container: 1280px;
    --mr-radius:    6px;
    --mr-radius-lg: 16px;
    --mr-radius-xl: 24px;

    /* Typography */
    --mr-font-body:    "EB Garamond", Georgia, serif;
    --mr-font-heading: "EB Garamond", Georgia, serif;
    --mr-font-script:  "Luxurious Script", cursive;
    --mr-font-ui:      system-ui, -apple-system, sans-serif;

    /* Motion */
    --mr-ease:       cubic-bezier(0.22, 1, 0.36, 1);
    --mr-ease-out:   cubic-bezier(0.0, 0.0, 0.2, 1);
    --mr-transition: all .3s var(--mr-ease);
    --mr-trans-fast: all .18s var(--mr-ease-out);
}

/* ── Reset ───────────────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box
}
html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%
}
body {
    margin: 0;
    font-family: var(--mr-font-body);
    color: var(--mr-color-text);
    background: var(--mr-color-soft-white);
    line-height: 1.62;
    font-size: 18px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}
img, video {
    max-width: 100%;
    height: auto;
    display: block
}
a {
    color: inherit;
    text-decoration: none;
    transition: var(--mr-trans-fast)
}
button, input, select, textarea {
    font: inherit
}

/* ── Helpers ─────────────────────────────────────────────── */
.mr-container {
    width: min(100% - 48px, var(--mr-container));
    margin-inline: auto;
}
.screen-reader-text {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* ══════════════════════════════════════════════════════════
   HEADER
   ══════════════════════════════════════════════════════════ */

/* Variables del header — el JS las sobreescribe en el elemento */
.mr-site-header {
    --hdr-bg:           rgba(246,245,238,0.97);
    --hdr-blur:         blur(16px) saturate(1.4);
    --hdr-border:       rgba(97,104,50,0.1);
    --hdr-shadow:       none;
    --hdr-link-color:   var(--mr-olive-700);
    --hdr-brand-color:  var(--mr-olive-700);
    --hdr-brand-top:    var(--mr-olive-400);
    --hdr-bar-color:    var(--mr-olive-700);
    --hdr-social-color: var(--mr-olive-600);
    --hdr-inner-height: 88px;

    position: sticky;
    top: 0;
    z-index: 200;
    width: 100%;
    background: var(--hdr-bg);
    backdrop-filter: var(--hdr-blur);
    -webkit-backdrop-filter: var(--hdr-blur);
    border-bottom: 1px solid var(--hdr-border);
    box-shadow: var(--hdr-shadow);
    transition: background .3s ease, border-color .3s ease,
        box-shadow .3s ease, backdrop-filter .3s ease;
}

/* Estado: TRANSPARENTE (top de la página, sobre hero) */
.mr-site-header.is-transparent {
    --hdr-bg:           transparent;
    --hdr-blur:         none;
    --hdr-border:       transparent;
    --hdr-shadow:       none;
    --hdr-link-color:   rgba(255,255,255,0.92);
    --hdr-brand-color:  rgba(255,255,255,0.92);
    --hdr-brand-top:    rgba(255,255,255,0.5);
    --hdr-bar-color:    rgba(255,255,255,0.9);
    --hdr-social-color: rgba(255,255,255,0.85);
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
}

/* Estado: SCROLLED
   El header transparente pasa a sólido y reduce levemente su altura. */
.mr-site-header.is-transparent.is-scrolled {
    --hdr-bg:           rgba(246,245,238,0.97);
    --hdr-blur:         blur(16px) saturate(1.4);
    --hdr-border:       rgba(97,104,50,0.1);
    --hdr-shadow:       none;
    --hdr-link-color:   var(--mr-olive-700);
    --hdr-brand-color:  var(--mr-olive-700);
    --hdr-brand-top:    var(--mr-olive-400);
    --hdr-bar-color:    var(--mr-olive-700);
    --hdr-social-color: var(--mr-olive-600);
    --hdr-inner-height: 80px;
}

/* Aplicar variables a los elementos */
.mr-nav-menu a,
.mr-footer-menu a {
    color: var(--hdr-link-color, var(--mr-olive-700))
}

.mr-site-header .mr-brand-script {
    color: var(--hdr-brand-color, var(--mr-olive-700))
}
.mr-site-header .mr-brand-top    {
    color: var(--hdr-brand-top,   var(--mr-olive-400))
}

.mr-site-header .mr-menu-toggle__bar,
.mr-site-header .mr-menu-toggle span:not(.screen-reader-text) {
    background: var(--hdr-bar-color, var(--mr-olive-700));
}

.mr-site-header .mr-header-social__link {
    color: var(--hdr-social-color, var(--mr-olive-600))
}

.mr-site-header__inner {
    min-height: var(--hdr-inner-height, 88px);
    display: grid;
    transition: min-height .28s ease;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    align-items: center;
    gap: 24px;
}

/* Col izquierda: hamburger (oculto en desktop) + nav */
.mr-header-left {
    display: contents; /* en desktop el nav ocupa su lugar directo en el grid */
}

/* En desktop el nav ES la col izquierda */
.mr-site-nav {
    display: flex;
    align-items: center;
    justify-self: start;
    min-width: 0;
}

/* Col centro: logo */
.mr-site-branding {
    justify-self: center;
    text-align: center;
    white-space: nowrap;
}

/* Col derecha: redes + CTA */
.mr-header-right {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 16px;
    justify-self: end;
    min-width: 0;
}

/* Hamburger: oculto en desktop */
.mr-menu-toggle {
    display: none;
    width: 44px;
    height: 44px;
    padding: 0;
    background: transparent;
    border: 0;
    cursor: pointer;
    flex-shrink: 0;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
}
.mr-menu-toggle__bar {
    display: block;
    width: 22px;
    height: 1.5px;
    background: var(--mr-olive-700);
    transition: transform .25s var(--mr-ease), opacity .2s;
}
/* fallback para <span> (versiones anteriores) */
.mr-menu-toggle span:not(.screen-reader-text) {
    display: block;
    width: 22px;
    height: 1.5px;
    background: var(--mr-olive-700);
    transition: transform .25s var(--mr-ease), opacity .2s;
}

/* nav menu list */
.mr-nav-menu, .mr-footer-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    gap: 38px;
}

.mr-nav-menu a, .mr-footer-menu a {
    font-family: var(--mr-font-ui);
    font-size: 11.5px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: .16em;
    color: var(--mr-olive-700);
    position: relative;
    padding-bottom: 2px;
}
.mr-nav-menu a::after {
    content: "";
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--mr-gold);
    transition: width .3s var(--mr-ease);
}
.mr-nav-menu a:hover::after {
    width: 100%
}
.mr-nav-menu a:hover {
    color: var(--mr-text)
}

.mr-logo img {
    max-height: 56px;
    width: auto
}

.mr-brand-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    line-height: 1;
    color: var(--mr-olive-700);
    text-decoration: none;
}
.mr-brand-top {
    font-family: var(--mr-font-ui);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: .26em;
    text-transform: uppercase;
    color: var(--mr-olive-400);
    margin-bottom: 2px;
}
.mr-brand-script {
    font-family: var(--mr-font-script);
    font-size: 44px;
    font-weight: 400;
    color: var(--mr-olive-700);
    margin-top: -6px;
    line-height: 1.1;
}
.mr-brand-text--footer {
    align-items: flex-start
}
.mr-site-actions {
    justify-self: end
}

/* ── Buttons ─────────────────────────────────────────────── */
.mr-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 10px 24px;
    border-radius: 2px;
    border: 1px solid transparent;
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    transition: var(--mr-trans-fast);
    cursor: pointer;
}
.mr-btn--solid {
    background: var(--mr-olive-700);
    color: var(--mr-white);
    border-color: var(--mr-olive-700);
    box-shadow: 0 2px 12px rgba(97,104,50,.25);
}
.mr-btn--solid:hover {
    background: var(--mr-olive-900);
    border-color: var(--mr-olive-900);
    box-shadow: 0 4px 20px rgba(97,104,50,.35);
    transform: translateY(-1px);
}
.mr-btn--ghost {
    border-color: var(--mr-olive-700);
    color: var(--mr-olive-700);
    background: transparent;
}
.mr-btn--ghost:hover {
    background: var(--mr-olive-700);
    color: var(--mr-white);
    box-shadow: 0 4px 16px rgba(97,104,50,.22);
}
.mr-btn--gold {
    background: linear-gradient(135deg, var(--mr-gold) 0%, var(--mr-gold-light) 100%);
    color: var(--mr-white);
    border-color: transparent;
    box-shadow: var(--mr-shadow-gold);
}
.mr-btn--gold:hover {
    filter: brightness(1.06);
    transform: translateY(-1px)
}

/* ── Content ─────────────────────────────────────────────── */
.site-main {
    min-height: 40vh
}
.mr-content-wrap {
    padding-block: 80px
}

.entry-title, .page-title {
    margin: 0 0 22px;
    font-family: var(--mr-font-heading);
    font-size: clamp(36px, 4vw, 60px);
    line-height: 1;
    font-weight: 400;
    color: var(--mr-olive-700);
    letter-spacing: -.01em;
}

.mr-post-thumb {
    margin-bottom: 28px;
    border-radius: var(--mr-radius-lg);
    overflow: hidden
}

.mr-archive-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 28px
}

/* ── Cards ───────────────────────────────────────────────── */
.mr-card {
    background: var(--mr-white);
    border: 1px solid var(--mr-color-border);
    border-radius: var(--mr-radius-lg);
    overflow: hidden;
    box-shadow: var(--mr-shadow-sm);
    transition: transform .35s var(--mr-ease), box-shadow .35s var(--mr-ease);
}
.mr-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--mr-shadow-lg)
}
.mr-card__thumb {
    overflow: hidden
}
.mr-card__thumb img {
    aspect-ratio: 16 / 9;
    object-fit: cover;
    width: 100%;
    transition: transform .5s var(--mr-ease);
}
.mr-card:hover .mr-card__thumb img {
    transform: scale(1.04)
}
.mr-card__content {
    padding: 24px 26px
}
.mr-card__title {
    margin: 0 0 12px;
    font-size: 34px;
    line-height: 1.02;
    font-weight: 400;
    color: var(--mr-olive-700)
}
.mr-card__excerpt {
    margin-bottom: 18px
}

.no-results {
    padding: 48px;
    background: var(--mr-white);
    border-radius: var(--mr-radius-lg);
    border: 1px solid var(--mr-color-border)
}

/* ── Forms ───────────────────────────────────────────────── */
.search-form {
    display: flex;
    gap: 12px;
    flex-wrap: wrap
}
.search-form label {
    flex: 1 1 260px
}
.search-field,
input[type="text"], input[type="email"], input[type="tel"],
input[type="url"], input[type="date"], input[type="number"],
textarea, select {
    width: 100%;
    min-height: 52px;
    padding: 13px 18px;
    background: var(--mr-white);
    border: 1px solid rgba(97,104,50,.18);
    border-radius: var(--mr-radius);
    color: var(--mr-text);
    font-size: 17px;
    transition: border-color .2s, box-shadow .2s;
}
textarea {
    min-height: 140px;
    resize: vertical
}
input:focus, textarea:focus, select:focus {
    outline: none;
    border-color: var(--mr-olive-600);
    box-shadow: 0 0 0 3px rgba(119,125,69,.14);
}
input[type="submit"], button[type="submit"], .wp-element-button {
    cursor: pointer
}

/* ══════════════════════════════════════════════════════════
   FOOTER
   ══════════════════════════════════════════════════════════ */
.mr-site-footer {
    background: var(--mr-olive-900);
    color: var(--mr-white);
    margin-top: 96px;
    position: relative;
    overflow: hidden;
}
.mr-site-footer::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 10% 50%, rgba(200,169,110,.06) 0%, transparent 60%),
        radial-gradient(ellipse at 90% 20%, rgba(172,176,129,.06) 0%, transparent 50%);
    pointer-events: none;
}
.mr-site-footer__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.4fr 1fr .6fr;
    gap: 40px;
    align-items: start;
    padding: 72px 0 44px;
    border-bottom: 1px solid rgba(255,255,255,.08);
}
.mr-site-footer .mr-brand-top  {
    color: rgba(255,255,255,.45)
}
.mr-site-footer .mr-brand-script {
    color: var(--mr-white)
}
.mr-site-footer__tagline {
    margin: 12px 0 0;
    font-size: 16px;
    line-height: 1.5;
    color: rgba(255,255,255,.55);
    max-width: 28ch
}
.mr-footer-menu {
    flex-direction: column;
    align-items: flex-start;
    gap: 14px
}
.mr-site-footer .mr-footer-menu a {
    font-family: var(--mr-font-ui);
    font-size: 12px;
    font-weight: 500;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(255,255,255,.68);
    transition: color .2s;
}
.mr-site-footer .mr-footer-menu a:hover {
    color: var(--mr-white)
}
.mr-site-footer__social {
    display: flex;
    flex-direction: column;
    gap: 12px;
    justify-self: end;
    text-align: right
}
.mr-site-footer__social a {
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(255,255,255,.55);
    transition: color .2s;
}
.mr-site-footer__social a:hover {
    color: var(--mr-gold-light)
}
.mr-site-footer__bottom {
    position: relative;
    z-index: 1;
    padding: 22px 0;
    text-align: center;
    color: rgba(255,255,255,.32);
    font-family: var(--mr-font-ui);
    font-size: 12px;
    letter-spacing: .04em;
}

/* ── Misc ────────────────────────────────────────────────── */
.mr-404 {
    text-align: center;
    padding-block: 120px
}
.mr-hero-placeholder, .mr-section-placeholder {
    padding: 96px 0
}
.mr-section-title {
    font-family: var(--mr-font-heading);
    color: var(--mr-olive-700);
    font-size: clamp(30px, 4vw, 52px);
    line-height: 1.04;
    margin: 0 0 14px;
    text-align: center;
    font-weight: 400;
    letter-spacing: -.01em;
}
.mr-section-subtitle {
    font-size: 26px;
    line-height: 1.3;
    color: var(--mr-olive-400);
    margin: 0 0 36px;
    text-align: center;
    font-style: italic;
}
.mr-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 26px
}
.mr-grid-4 {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 26px
}
.mr-panel {
    background: var(--mr-white);
    border-radius: var(--mr-radius-lg);
    border: 1px solid var(--mr-color-border);
    box-shadow: var(--mr-shadow-sm);
    overflow: hidden
}
.mr-panel__body {
    padding: 26px
}
.mr-muted {
    color: var(--mr-text-muted)
}

/* ══════════════════════════════════════════════════════════
   HERO (shared rubro + recomendacion)
   ══════════════════════════════════════════════════════════ */
.mr-rubro-hero, .mr-rec-hero {
    position: relative;
    min-height: 520px;
    background: var(--mr-cream-300);
    overflow: hidden;
}
.mr-rubro-hero__image img, .mr-rec-hero__image img {
    width: 100%;
    height: clamp(460px, 54vw, 800px);
    object-fit: cover;
}
.mr-rubro-hero__overlay, .mr-rec-hero__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: flex-end;
    background: linear-gradient(to bottom, rgba(0,0,0,.06) 0%, rgba(0,0,0,.18) 40%, rgba(0,0,0,.6) 100%);
}
.mr-rec-hero__overlay.has-logo {
    align-items: center;
    justify-content: center
}
.mr-rubro-hero__overlay .mr-container, .mr-rec-hero__overlay .mr-container {
    padding-bottom: 52px
}
.mr-rec-hero__overlay.has-logo .mr-container {
    width: min(100% - 48px, 860px);
    padding-bottom: 0
}
.mr-rec-hero__logo-wrap {
    display: flex;
    align-items: center;
    justify-content: center
}
.mr-rec-hero__logo {
    display: flex;
    align-items: center;
    justify-content: center;
    width: min(100%, 520px);
    padding: 20px 24px
}
.mr-rec-hero__logo img {
    max-width: 100%;
    max-height: 180px;
    width: auto;
    height: auto;
    object-fit: contain;
    filter: drop-shadow(0 12px 40px rgba(0,0,0,.3))
}
.mr-rec-hero__fallback {
    max-width: 780px
}
.mr-rubro-hero__terms, .mr-rubro-main__terms, .mr-rubro-card__terms,
.mr-rec-hero__terms, .mr-rec-main__terms, .mr-rec-card__terms {
    display: flex;
    flex-wrap: wrap;
    gap: 8px
}
.mr-rubro-hero__terms span, .mr-rubro-main__terms span, .mr-rubro-card__terms span,
.mr-rec-hero__terms span, .mr-rec-main__terms span, .mr-rec-card__terms span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 5px 14px;
    border-radius: 999px;
    background: rgba(234,235,221,.88);
    color: var(--mr-olive-700);
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    backdrop-filter: blur(4px);
}
.mr-rubro-hero__title, .mr-rec-hero__title {
    margin: 16px 0 10px;
    color: var(--mr-white);
    font-size: clamp(44px, 6.5vw, 92px);
    line-height: .94;
    font-weight: 400;
    letter-spacing: -.02em;
}
.mr-rubro-hero__subtitle, .mr-rec-hero__subtitle {
    max-width: 780px;
    margin: 0;
    color: rgba(255,255,255,.88);
    font-size: clamp(20px, 2.2vw, 30px);
    font-style: italic;
    line-height: 1.3;
}

/* ══════════════════════════════════════════════════════════
   SINGLE RUBRO
   ══════════════════════════════════════════════════════════ */
.mr-rubro-main {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(320px, .82fr);
    gap: 64px;
    padding-block: 80px 56px;
    align-items: start;
}
.mr-rubro-main__subtitle {
    margin: -4px 0 26px;
    font-size: clamp(22px, 2.2vw, 36px);
    color: var(--mr-olive-600);
    font-style: italic
}
.mr-rubro-main__entry {
    font-size: 21px;
    line-height: 1.65
}
.mr-rubro-main__entry h2, .mr-rubro-main__entry h3, .mr-rubro-main__entry h4 {
    color: var(--mr-olive-700);
    font-weight: 400;
    letter-spacing: -.01em
}
.mr-rubro-main__entry ul {
    padding-left: 1.2em
}

.mr-rubro-booking__card {
    background: var(--mr-cream-200);
    border: 1px solid rgba(97,104,50,.1);
    border-radius: var(--mr-radius-xl);
    padding: 28px;
    position: sticky;
    top: 120px;
    box-shadow: var(--mr-shadow-md);
}
.mr-rubro-booking__image {
    margin: -6px -6px 24px;
    overflow: hidden;
    border-radius: var(--mr-radius-lg)
}
.mr-rubro-booking__image img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    transition: transform .45s var(--mr-ease)
}
.mr-rubro-booking__card:hover .mr-rubro-booking__image img {
    transform: scale(1.03)
}
.mr-rubro-booking__title {
    margin: 0 0 22px;
    color: var(--mr-olive-700);
    font-size: clamp(32px, 2.8vw, 50px);
    line-height: .96;
    font-weight: 400;
    text-align: center;
    letter-spacing: -.01em
}
.mr-rubro-booking__form .wpcf7-form p, .mr-rubro-booking__form .wpforms-field-container, .mr-rubro-booking__form .ff-el-group {
    margin-bottom: 14px
}
.mr-rubro-booking__form p:last-child, .mr-rubro-booking__form .wpcf7-submit, .mr-rubro-booking__form input[type="submit"] {
    margin-bottom: 0
}
.mr-rubro-booking__form input:not([type="submit"]), .mr-rubro-booking__form select, .mr-rubro-booking__form textarea {
    background: var(--mr-white)
}
.mr-rubro-booking__form input[type="submit"], .mr-rubro-booking__form button[type="submit"] {
    width: 100%;
    min-height: 56px;
    background: linear-gradient(135deg, var(--mr-olive-700) 0%, var(--mr-olive-600) 100%);
    color: var(--mr-white);
    border: 0;
    border-radius: var(--mr-radius);
    font-family: var(--mr-font-ui);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    cursor: pointer;
    box-shadow: 0 4px 18px rgba(97,104,50,.28);
    transition: filter .2s, transform .2s;
}
.mr-rubro-booking__form input[type="submit"]:hover, .mr-rubro-booking__form button[type="submit"]:hover {
    filter: brightness(1.06);
    transform: translateY(-1px)
}
.mr-rubro-booking__note {
    margin: 16px 0 0;
    text-align: center;
    color: var(--mr-text-muted);
    font-size: 15px
}
.mr-rubro-booking__placeholder {
    padding: 20px;
    background: var(--mr-white);
    border: 1px dashed rgba(97,104,50,.28);
    border-radius: var(--mr-radius)
}

.mr-rubro-gallery, .mr-rec-gallery {
    padding-bottom: 48px
}
.mr-rubro-gallery__grid, .mr-rec-gallery__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 16px
}
.mr-rubro-gallery__item, .mr-rec-gallery__item {
    display: block;
    overflow: hidden;
    border-radius: var(--mr-radius-lg);
    cursor: pointer;
    position: relative;
    isolation: isolate;
    box-shadow: var(--mr-shadow-sm)
}
.mr-rubro-gallery__item img {
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    transition: transform .45s var(--mr-ease)
}
.mr-rubro-gallery__item:hover img {
    transform: scale(1.06)
}
.mr-rec-gallery__item img, .mr-rec-gallery__item video {
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover;
    display: block;
    transition: transform .45s var(--mr-ease), filter .35s var(--mr-ease)
}
.mr-rec-gallery__item:hover img, .mr-rec-gallery__item:hover video {
    transform: scale(1.05);
    filter: saturate(1.06)
}
.mr-rec-gallery__item::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255,255,255,0) 50%, rgba(20,20,16,.18) 100%);
    opacity: .6;
    transition: opacity .3s;
    pointer-events: none
}
.mr-rec-gallery__item:hover::after {
    opacity: 1
}
.mr-rec-gallery__item.is-video::before {
    content: "";
    position: absolute;
    inset: auto auto 14px 14px;
    width: 52px;
    height: 52px;
    border-radius: 999px;
    background: rgba(0,0,0,.18);
    backdrop-filter: blur(8px);
    z-index: 1
}
.mr-rec-gallery__item.is-video::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-35%,-50%);
    width: 0;
    height: 0;
    border-top: 17px solid transparent;
    border-bottom: 17px solid transparent;
    border-left: 26px solid rgba(255,255,255,.95);
    z-index: 2;
    pointer-events: none;
    background: none
}

.mr-rubro-card__subtitle, .mr-rec-card__subtitle {
    margin: -4px 0 14px;
    color: var(--mr-olive-600);
    font-size: 23px;
    font-style: italic
}
.mr-rubro-card .mr-card__thumb img, .mr-rec-card .mr-card__thumb img {
    aspect-ratio: 16 / 9
}

/* ══════════════════════════════════════════════════════════
   SINGLE RECOMENDACION
   ══════════════════════════════════════════════════════════ */
.mr-rec-main {
    display: grid;
    grid-template-columns: minmax(0, 1.5fr) minmax(320px, .82fr);
    gap: 64px;
    padding-block: 80px 56px;
    align-items: start;
}
.mr-rec-main__title {
    margin: 0 0 14px;
    font-family: var(--mr-font-heading);
    font-size: clamp(44px, 4.6vw, 76px);
    line-height: .96;
    font-weight: 400;
    color: var(--mr-olive-700);
    letter-spacing: -.02em
}
.mr-rec-main__subtitle, .mr-rec-card__subtitle {
    margin: -4px 0 26px;
    font-size: clamp(22px, 2.2vw, 36px);
    color: var(--mr-olive-600);
    font-style: italic
}
.mr-rec-card__subtitle {
    font-size: 23px;
    margin-bottom: 14px
}

.mr-rec-rating {
    display: flex;
    align-items: center;
    gap: 16px;
    margin: 0 0 36px;
    color: var(--mr-gold)
}
.mr-rec-rating__stars {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 20px;
    line-height: 1
}
.mr-rec-rating__text {
    display: flex;
    align-items: baseline;
    gap: 8px;
    font-size: 17px;
    color: var(--mr-gold)
}
.mr-rec-rating__text strong {
    font-size: 22px;
    font-weight: 500
}

.mr-rec-main__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px 20px;
    margin: 0 0 30px;
    color: var(--mr-text-muted);
    font-size: 19px
}
.mr-rec-main__maps-link {
    color: var(--mr-olive-600);
    text-decoration: underline;
    text-underline-offset: 4px
}
.mr-rec-main__maps-link:hover {
    color: var(--mr-text)
}

.mr-rec-main__entry {
    font-size: 21px;
    line-height: 1.65
}
.mr-rec-main__entry h2, .mr-rec-main__entry h3, .mr-rec-main__entry h4 {
    color: var(--mr-olive-700);
    font-weight: 400
}
.mr-rec-main__entry ul {
    padding-left: 1.2em
}

.mr-rec-contact {
    position: sticky;
    top: 120px;
    align-self: start
}
.mr-rec-contact__card {
    background: var(--mr-cream-200);
    border: 1px solid rgba(97,104,50,.1);
    border-radius: var(--mr-radius-xl);
    padding: 28px;
    box-shadow: var(--mr-shadow-md)
}
.mr-rec-contact__image {
    margin: -6px -6px 24px;
    overflow: hidden;
    border-radius: var(--mr-radius-lg)
}
.mr-rec-contact__image img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    transition: transform .45s var(--mr-ease)
}
.mr-rec-contact__card:hover .mr-rec-contact__image img {
    transform: scale(1.03)
}
.mr-rec-contact__title {
    margin: 0 0 22px;
    color: var(--mr-olive-700);
    font-size: clamp(32px, 2.8vw, 50px);
    line-height: .96;
    font-weight: 400;
    text-align: center
}
.mr-rec-contact__form p:last-child {
    margin-bottom: 0
}
.mr-rec-contact__form input:not([type="submit"]), .mr-rec-contact__form textarea {
    background: var(--mr-white)
}
.mr-rec-contact__form button[type="submit"] {
    width: 100%;
    min-height: 56px;
    background: linear-gradient(135deg, var(--mr-olive-700) 0%, var(--mr-olive-600) 100%);
    color: var(--mr-white);
    border: 0;
    border-radius: var(--mr-radius);
    font-family: var(--mr-font-ui);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .14em;
    text-transform: uppercase;
    cursor: pointer;
    box-shadow: 0 4px 18px rgba(97,104,50,.28);
    transition: filter .2s, transform .2s;
}
.mr-rec-contact__form button[type="submit"]:hover {
    filter: brightness(1.06);
    transform: translateY(-1px)
}
.mr-rec-contact__note {
    margin: 16px 0 0;
    text-align: center;
    color: var(--mr-text-muted);
    font-size: 15px
}
.mr-rec-contact__placeholder, .mr-rec-contact__notice {
    padding: 18px;
    border-radius: var(--mr-radius-lg);
    margin-bottom: 16px
}
.mr-rec-contact__placeholder {
    background: var(--mr-white);
    border: 1px dashed rgba(97,104,50,.28)
}
.mr-rec-contact__notice {
    background: var(--mr-white);
    border: 1px solid rgba(97,104,50,.2)
}
.mr-rec-contact__notice.is-success {
    border-color: rgba(80,130,60,.35);
    background: rgba(80,130,60,.06)
}
.mr-rec-contact__notice.is-validation, .mr-rec-contact__notice.is-configuration, .mr-rec-contact__notice.is-error {
    border-color: rgba(183,90,56,.3);
    background: rgba(183,90,56,.06)
}

.mr-rec-map {
    padding-bottom: 38px
}
.mr-rec-map__inner {
    border-radius: var(--mr-radius-xl);
    overflow: hidden;
    box-shadow: var(--mr-shadow-md);
    border: 1px solid var(--mr-color-border)
}
.mr-rec-map__embed {
    position: relative;
    aspect-ratio: 16/9
}
.mr-rec-map__embed iframe {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0
}

.mr-rec-proposals {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid rgba(97,104,50,.14)
}
.mr-rec-proposals__heading {
    margin-bottom: 24px
}
.mr-rec-proposals__heading h2 {
    margin: 0 0 8px;
    color: var(--mr-olive-700);
    font-size: clamp(32px, 3.2vw, 52px);
    line-height: 1;
    font-weight: 400
}
.mr-rec-proposals__heading p {
    margin: 0;
    color: var(--mr-text-muted);
    font-size: 18px
}

.mr-rec-proposals__tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 22px
}
.mr-rec-proposals__tab {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 9px 20px;
    border: 1px solid rgba(97,104,50,.2);
    border-radius: 999px;
    background: var(--mr-white);
    color: var(--mr-olive-700);
    font-family: var(--mr-font-ui);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    transition: var(--mr-trans-fast);
    cursor: pointer;
}
.mr-rec-proposals__tab:hover, .mr-rec-proposals__tab.is-active {
    background: var(--mr-olive-700);
    color: var(--mr-white);
    border-color: var(--mr-olive-700);
    box-shadow: 0 4px 14px rgba(97,104,50,.25)
}

.mr-rec-proposals__panel {
    padding: 28px;
    border: 1px solid rgba(97,104,50,.14);
    border-radius: var(--mr-radius-xl);
    background: var(--mr-white);
    box-shadow: var(--mr-shadow-sm)
}
.mr-rec-proposals__panel[hidden] {
    display: none
}
.mr-rec-proposals__title {
    margin: 0 0 10px;
    color: var(--mr-olive-700);
    font-size: clamp(30px, 3vw, 46px);
    line-height: 1;
    font-weight: 400
}
.mr-rec-proposals__subtitle {
    margin: 0 0 18px;
    color: var(--mr-olive-600);
    font-size: clamp(20px, 2vw, 28px);
    font-style: italic
}
.mr-rec-proposals__content {
    font-size: 20px;
    line-height: 1.65
}
.mr-rec-proposals__content h2, .mr-rec-proposals__content h3, .mr-rec-proposals__content h4 {
    color: var(--mr-olive-700);
    font-weight: 400
}
.mr-rec-proposals__gallery {
    margin-top: 26px
}
.mr-rec-proposals--compact {
    margin-top: 48px
}
.mr-rec-proposals.is-single .mr-rec-proposals__tabs {
    display: none
}
.mr-rec-proposals.is-single .mr-rec-proposals__panel {
    padding-top: 24px
}
.mr-rec-proposals.has-tabs .mr-rec-proposals__tab {
    min-height: 40px;
    padding: 8px 16px
}

.mr-rec-contact__selected-proposal {
    margin: 0 0 18px;
    padding: 14px 16px;
    border-radius: var(--mr-radius-lg);
    background: rgba(255,255,255,.85);
    border: 1px solid rgba(97,104,50,.14);
    text-align: center
}
.mr-rec-contact__selected-proposal span {
    display: block;
    margin-bottom: 3px;
    color: var(--mr-text-muted);
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .08em
}
.mr-rec-contact__selected-proposal strong {
    display: block;
    color: var(--mr-olive-700);
    font-size: 17px;
    line-height: 1.2
}

.mr-rec-mobile-cta, .mr-rec-mobile-drawer, .mr-lightbox {
    display: none
}
.mr-lightbox.is-open {
    display: block
}

/* ══════════════════════════════════════════════════════════
   LIGHTBOX
   ══════════════════════════════════════════════════════════ */
.mr-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999
}
.mr-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.86)
}
.mr-lightbox__dialog {
    position: relative;
    z-index: 2;
    width: min(95vw, 1320px);
    margin: 2.5vh auto;
    max-height: 95vh;
    background: linear-gradient(180deg, #1a1b14 0%, #0f100d 100%);
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 32px 100px rgba(0,0,0,.5);
    border: 1px solid rgba(255,255,255,.06)
}
.mr-lightbox__topbar {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    padding: 22px 90px 14px 26px;
    color: var(--mr-white)
}
.mr-lightbox__meta {
    display: flex;
    flex-direction: column;
    gap: 5px;
    min-width: 0
}
.mr-lightbox__counter {
    color: rgba(255,255,255,.55);
    font-family: var(--mr-font-ui);
    font-size: 12px;
    letter-spacing: .1em;
    text-transform: uppercase
}
.mr-lightbox__caption {
    color: var(--mr-white);
    font-size: 18px;
    line-height: 1.35
}
.mr-lightbox__stage {
    position: relative;
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 0 22px
}
.mr-lightbox__content {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: min(68vh, 760px);
    width: 100%;
    background: rgba(255,255,255,.02);
    border-radius: 10px;
    overflow: hidden
}
.mr-lightbox__content img, .mr-lightbox__content video, .mr-lightbox__media {
    display: block;
    width: 100%;
    max-height: 68vh;
    object-fit: contain
}
.mr-lightbox__nav {
    flex: 0 0 52px;
    width: 52px;
    height: 52px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,.12);
    color: var(--mr-white);
    font-size: 34px;
    line-height: 1;
    cursor: pointer;
    transition: transform .2s, background .2s, opacity .2s
}
.mr-lightbox__nav:hover {
    transform: scale(1.06);
    background: rgba(255,255,255,.2)
}
.mr-lightbox__nav:disabled {
    opacity: .3;
    cursor: default
}
.mr-lightbox__thumbs {
    display: flex;
    gap: 12px;
    padding: 16px 26px 26px;
    overflow-x: auto;
    scrollbar-width: thin
}
.mr-lightbox__thumb {
    position: relative;
    flex: 0 0 106px;
    width: 106px;
    padding: 0;
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 12px;
    overflow: hidden;
    background: rgba(255,255,255,.05);
    cursor: pointer;
    opacity: .55;
    transition: opacity .2s, transform .2s, border-color .2s, box-shadow .2s
}
.mr-lightbox__thumb img, .mr-lightbox__thumb video {
    display: block;
    width: 100%;
    aspect-ratio: 16/9;
    object-fit: cover
}
.mr-lightbox__thumb.is-active {
    opacity: 1;
    transform: translateY(-2px);
    border-color: rgba(255,255,255,.38);
    box-shadow: 0 12px 30px rgba(0,0,0,.3)
}
.mr-lightbox__thumb.is-video::after {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-35%,-50%);
    width: 0;
    height: 0;
    border-top: 9px solid transparent;
    border-bottom: 9px solid transparent;
    border-left: 14px solid rgba(255,255,255,.95);
    pointer-events: none
}
.mr-lightbox__close {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 4;
    width: 44px;
    height: 44px;
    border: 0;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    color: var(--mr-white);
    font-size: 26px;
    line-height: 1;
    cursor: pointer;
    transition: background .2s, transform .2s
}
.mr-lightbox__close:hover {
    background: rgba(255,255,255,.22);
    transform: scale(1.06)
}
body.mr-lightbox-open, body.mr-contact-drawer-open {
    overflow: hidden
}

/* ══════════════════════════════════════════════════════════
   HOME SECTIONS
   ══════════════════════════════════════════════════════════ */
.mr-page-hero, .mr-home-hero {
    position: relative;
    overflow: hidden;
    background: var(--mr-cream-200)
}
.mr-page-hero__media, .mr-home-hero__media {
    position: absolute;
    inset: 0
}
.mr-page-hero__media img, .mr-home-hero__media img {
    width: 100%;
    height: 100%;
    object-fit: cover
}
.mr-page-hero.has-image {
    min-height: min(46vh, 440px)
}
.mr-home-hero {
    min-height: min(74vh, 800px)
}
.mr-page-hero.is-archive {
    min-height: 300px;
    background: linear-gradient(135deg, var(--mr-olive-900) 0%, var(--mr-olive-700) 100%)
}
.mr-page-hero__overlay, .mr-home-hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(20,22,12,.1) 0%, rgba(20,22,12,.65) 100%)
}
.mr-page-hero.is-archive .mr-page-hero__overlay {
    background: rgba(58,63,31,.28)
}
.mr-page-hero__inner {
    position: relative;
    z-index: 2;
    min-height: inherit;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 10px;
    padding: clamp(48px, 7vw, 88px) 0
}
.mr-home-hero__inner {
    position: relative;
    z-index: 2;
    min-height: inherit;
    display: flex;
    align-items: center;
    padding: clamp(80px, 10vw, 150px) 0
}
.mr-home-hero__content {
    max-width: 700px;
    color: var(--mr-white)
}
.mr-home-hero__eyebrow, .mr-home-section-head__kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    margin: 0 0 14px;
    color: rgba(248,247,241,.82);
    font-family: var(--mr-font-ui);
    font-size: 10.5px;
    font-weight: 700;
    letter-spacing: .26em;
    text-transform: uppercase
}
.mr-home-section-head__kicker {
    color: var(--mr-olive-600);
    margin-bottom: 10px
}
.mr-home-hero__eyebrow::before, .mr-home-section-head__kicker::before,
.mr-home-section-head__kicker::after {
    content: "";
    display: block;
    width: 28px;
    height: 1px;
    background: currentColor;
    opacity: .6
}
.mr-home-hero__title {
    margin: 0 0 16px;
    color: var(--mr-white);
    font-family: var(--mr-font-heading);
    font-size: clamp(46px, 6.5vw, 88px);
    line-height: .94;
    font-weight: 400;
    letter-spacing: -.02em
}
.mr-home-hero__text, .mr-page-hero__text {
    max-width: 620px;
    margin: 0 0 26px;
    color: rgba(255,255,255,.86);
    font-size: clamp(17px, 1.5vw, 22px);
    line-height: 1.45
}
.mr-page-hero.is-archive .page-title, .mr-page-hero.is-archive .mr-page-hero__text, .mr-page-hero.is-archive .mr-home-section-head__kicker,
.mr-page-hero.has-image .page-title, .mr-page-hero.has-image .mr-page-hero__text, .mr-page-hero.has-image .mr-home-section-head__kicker {
    color: var(--mr-white)
}
.mr-page-hero.is-archive .page-title, .mr-page-hero.has-image .page-title {
    max-width: 14ch;
    font-size: clamp(34px, 4.6vw, 62px);
    line-height: .97;
    font-weight: 400
}
.mr-home-hero__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px
}

.mr-home-categories, .mr-home-editorial, .mr-home-listing, .mr-page-section {
    padding: 80px 0
}
.mr-home-categories {
    background: var(--mr-olive-900);
    color: var(--mr-white)
}
.mr-home-categories .mr-section-title {
    color: var(--mr-white)
}
.mr-home-categories .mr-home-section-head__kicker {
    color: rgba(255,255,255,.5)
}
.mr-home-section-head {
    margin-bottom: 32px;
    text-align: center
}
.mr-home-section-head.is-between {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    text-align: left
}

.mr-home-categories__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0,1fr));
    gap: 20px
}
.mr-home-category-card {
    overflow: hidden;
    border-radius: 18px;
    background: rgba(255,255,255,.07);
    border: 1px solid rgba(255,255,255,.1);
    transition: transform .35s var(--mr-ease), box-shadow .35s var(--mr-ease)
}
.mr-home-category-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 48px rgba(0,0,0,.3)
}
.mr-home-category-card__media {
    display: block;
    aspect-ratio: 16 / 9;
    overflow: hidden
}
.mr-home-category-card__media img, .mr-home-category-card__placeholder {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    transition: transform .5s var(--mr-ease)
}
.mr-home-category-card:hover .mr-home-category-card__media img {
    transform: scale(1.06)
}
.mr-home-category-card__placeholder {
    background: rgba(255,255,255,.12)
}
.mr-home-category-card__body {
    display: grid;
    gap: 6px;
    padding: 20px 22px 24px
}
.mr-home-category-card__body strong {
    font-size: 26px;
    line-height: 1.04;
    color: var(--mr-white);
    font-weight: 400
}
.mr-home-category-card__body small {
    font-size: 15px;
    color: rgba(255,255,255,.78)
}

.mr-home-editorial__inner {
    display: grid;
    grid-template-columns: minmax(0,1.3fr) minmax(280px,.7fr);
    gap: 48px;
    align-items: start
}
.mr-home-editorial__entry {
    font-size: 20px;
    line-height: 1.7
}
.mr-home-editorial__quote {
    background: var(--mr-cream-200);
    border: 1px solid var(--mr-color-border);
    border-radius: 22px;
    padding: 36px;
    box-shadow: var(--mr-shadow-md);
    position: sticky;
    top: 120px
}
.mr-home-editorial__quote::before {
    content: "\201C";
    display: block;
    margin-bottom: -8px;
    font-family: var(--mr-font-script);
    font-size: 80px;
    line-height: 1;
    color: var(--mr-gold);
    opacity: .5
}
.mr-home-editorial__quote-text {
    margin: 0 0 20px;
    font-size: 32px;
    line-height: 1.14;
    font-style: italic;
    color: var(--mr-text)
}
.mr-home-editorial__quote-author {
    font-family: var(--mr-font-ui);
    font-size: 13px;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--mr-olive-600)
}

.mr-home-listing {
    background: var(--mr-white)
}
.mr-home-listing__slider {
    position: relative
}
.mr-home-listing__viewport {
    overflow: hidden
}
.mr-home-listing__grid {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 20px) / 2);
    gap: 20px;
    overflow-x: auto;
    padding: 4px 2px 16px;
    scroll-behavior: smooth;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    -ms-overflow-style: none;
    -webkit-overflow-scrolling: touch
}
.mr-home-listing__grid::-webkit-scrollbar {
    display: none
}
.mr-home-listing__nav {
    position: absolute;
    top: calc(50% - 8px);
    z-index: 3;
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(30,32,16,.12);
    border-radius: 999px;
    background: rgba(255,255,255,.96);
    color: var(--mr-text);
    box-shadow: 0 10px 30px rgba(30,32,16,.10);
    transform: translateY(-50%);
    transition: transform .28s var(--mr-ease), opacity .28s var(--mr-ease), background .28s var(--mr-ease), color .28s var(--mr-ease), border-color .28s var(--mr-ease);
    cursor: pointer
}
.mr-home-listing__nav:hover {
    background: var(--mr-olive-900);
    border-color: var(--mr-olive-900);
    color: var(--mr-white)
}
.mr-home-listing__slider:not(.has-slider) .mr-home-listing__nav {
    display: none
}
.mr-home-listing__nav.is-disabled {
    opacity: .28;
    pointer-events: none
}
.mr-home-listing__nav.is-prev {
    left: -24px
}
.mr-home-listing__nav.is-next {
    right: -24px
}
.mr-home-reco-card {
    min-height: 0;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    background: var(--mr-white);
    box-shadow: var(--mr-shadow-md);
    transition: transform .35s var(--mr-ease), box-shadow .35s var(--mr-ease);
    scroll-snap-align: start
}
.mr-home-reco-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--mr-shadow-lg)
}
.mr-home-reco-card.card-1 {
    min-height: 0
}
.mr-home-reco-card__link {
    display: grid;
    grid-template-rows: auto 1fr;
    height: 100%;
    background: var(--mr-white)
}
.mr-home-reco-card__media {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    background: linear-gradient(135deg, rgba(194,184,116,.12) 0%, rgba(124,123,90,.18) 100%)
}
.mr-home-reco-card__media img, .mr-home-reco-card__placeholder {
    display: block;
    width: 100%;
    height: 100%
}
.mr-home-reco-card__media img {
    object-fit: cover;
    transition: transform .5s var(--mr-ease)
}
.mr-home-reco-card:hover .mr-home-reco-card__media img {
    transform: scale(1.04)
}
.mr-home-reco-card__body {
    position: relative;
    inset: auto;
    display: grid;
    align-content: start;
    gap: 10px;
    padding: 24px 24px 26px;
    background: var(--mr-white)
}
.mr-home-reco-card__body strong {
    font-size: 32px;
    line-height: 1.05;
    color: var(--mr-text);
    font-weight: 400
}
.mr-home-reco-card__body small {
    font-size: 16px;
    line-height: 1.55;
    color: rgba(30,32,16,.72)
}
.mr-home-reco-card__pill {
    display: inline-flex;
    width: max-content;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(234,235,221,.9);
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--mr-text)
}

.mr-home-cta-strip {
    padding: 0 0 96px
}
.mr-home-cta-strip__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 24px;
    padding: 40px 44px;
    background: var(--mr-cream-200);
    border: 1px solid var(--mr-color-border);
    border-radius: 22px;
    box-shadow: var(--mr-shadow-sm);
    position: relative;
    overflow: hidden
}
.mr-home-cta-strip__inner::before {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 0% 50%, rgba(200,169,110,.08) 0%, transparent 60%);
    pointer-events: none
}
.mr-home-cta-strip__inner h2 {
    position: relative;
    margin: 0;
    color: var(--mr-olive-700);
    font-size: clamp(28px, 4vw, 46px);
    line-height: 1.04;
    font-weight: 400
}

/* ── Contact / FAQ ───────────────────────────────────────── */
.mr-contact-page__grid, .mr-faq-page__wrap {
    display: grid;
    grid-template-columns: minmax(0,1.2fr) minmax(280px,.8fr);
    gap: 36px
}
.mr-contact-page__content {
    margin-bottom: 28px;
    font-size: 21px;
    line-height: 1.65
}
.mr-contact-form-card, .mr-contact-info-card, .mr-contact-faq-preview, .mr-faq-cta {
    background: var(--mr-white);
    border: 1px solid var(--mr-color-border);
    border-radius: var(--mr-radius-xl);
    padding: 34px;
    box-shadow: var(--mr-shadow-sm)
}
.mr-contact-form-card h2, .mr-contact-info-card h2, .mr-faq-cta h2 {
    margin: 0 0 20px;
    color: var(--mr-olive-700);
    font-size: 36px;
    line-height: 1.04;
    font-weight: 400
}
.mr-contact-form__grid {
    display: grid;
    grid-template-columns: repeat(2,minmax(0,1fr));
    gap: 16px
}
.mr-contact-form label {
    display: block;
    margin-bottom: 8px;
    color: var(--mr-olive-700);
    font-family: var(--mr-font-ui);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase
}
.mr-contact-form button {
    width: 100%;
    margin-top: 8px
}
.mr-contact-page__aside {
    display: grid;
    gap: 24px;
    align-self: start;
    position: sticky;
    top: 120px
}
.mr-contact-info-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 20px
}
.mr-contact-info-list li {
    display: grid;
    gap: 4px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--mr-color-border)
}
.mr-contact-info-list li:last-child {
    border-bottom: 0;
    padding-bottom: 0
}
.mr-contact-info-list strong {
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--mr-olive-600)
}
.mr-contact-info-list span {
    font-size: 20px;
    line-height: 1.3
}
.mr-contact-info-card__links {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 24px
}

.mr-faq-page__intro {
    font-size: 21px;
    line-height: 1.65
}
.mr-faq-accordion {
    display: grid;
    gap: 14px
}
.mr-faq-item {
    background: var(--mr-white);
    border: 1px solid var(--mr-color-border);
    border-radius: 18px;
    box-shadow: var(--mr-shadow-xs);
    overflow: hidden;
    transition: box-shadow .25s
}
.mr-faq-item:hover {
    box-shadow: var(--mr-shadow-sm)
}
.mr-faq-item.is-open {
    box-shadow: var(--mr-shadow-md)
}
.mr-faq-item__trigger {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    padding: 22px 26px;
    background: var(--mr-white);
    border: 0;
    text-align: left;
    color: var(--mr-olive-700);
    font-size: 23px;
    line-height: 1.08;
    cursor: pointer;
    transition: color .2s
}
.mr-faq-item__trigger:hover {
    color: var(--mr-olive-900)
}
.mr-faq-item__trigger i {
    display: block;
    width: 16px;
    height: 16px;
    position: relative;
    flex: 0 0 16px
}
.mr-faq-item__trigger i::before, .mr-faq-item__trigger i::after {
    content: "";
    position: absolute;
    inset: 50% auto auto 50%;
    width: 16px;
    height: 1.5px;
    background: var(--mr-olive-600);
    transform: translate(-50%,-50%);
    transition: var(--mr-transition)
}
.mr-faq-item__trigger i::after {
    transform: translate(-50%,-50%) rotate(90deg)
}
.mr-faq-item.is-open .mr-faq-item__trigger i::after {
    transform: translate(-50%,-50%) rotate(0deg);
    opacity: 0
}
.mr-faq-item__content {
    padding: 0 28px 28px;
    font-size: 19px;
    line-height: 1.6
}
.mr-faq-cta {
    margin-top: 36px;
    text-align: center
}

.mr-form-status {
    margin-bottom: 20px;
    padding: 16px 20px;
    border-radius: 12px;
    border: 1px solid var(--mr-color-border);
    background: var(--mr-cream-200)
}
.mr-form-status.is-success {
    background: #eef6e3;
    border-color: rgba(90,140,60,.28)
}
.mr-form-status.is-error, .mr-form-status.is-validation, .mr-form-status.is-configuration {
    background: #fff4f1;
    border-color: rgba(186,90,66,.22)
}

.mr-archive-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 32px
}
.mr-archive-filters__item {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 9px 18px;
    border-radius: 999px;
    background: var(--mr-white);
    border: 1px solid var(--mr-color-border);
    color: var(--mr-olive-700);
    font-family: var(--mr-font-ui);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    transition: var(--mr-trans-fast);
    cursor: pointer
}
.mr-archive-filters__item.is-active, .mr-archive-filters__item:hover {
    background: var(--mr-olive-700);
    border-color: var(--mr-olive-700);
    color: var(--mr-white);
    box-shadow: 0 4px 16px rgba(97,104,50,.22)
}
.mr-rec-card__terms {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px
}
.mr-rec-card__terms span {
    display: inline-flex;
    align-items: center;
    padding: 5px 12px;
    border-radius: 999px;
    background: var(--mr-cream-200);
    font-family: var(--mr-font-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--mr-olive-700)
}

/* ══════════════════════════════════════════════════════════
   ELEMENTOR COMPATIBILITY
   ══════════════════════════════════════════════════════════ */
.elementor-section, .elementor-container, .elementor-column,
.elementor-widget-container {
    max-width: 100% !important
}

.elementor-section.elementor-section-boxed > .elementor-container {
    max-width: var(--mr-container) !important
}

.e-con, .elementor-section {
    --e-global-color-primary:   #777D45;
    --e-global-color-secondary: #ACB081;
    --e-global-color-accent:    #C8A96E;
    --e-global-color-text:      #2E3018;
}

.elementor-widget-heading .elementor-heading-title,
.elementor h1, .elementor h2, .elementor h3,
.elementor h4, .elementor h5, .elementor h6 {
    font-family: var(--mr-font-heading)
}

.elementor-button, .elementor-widget-button .elementor-button {
    border-radius: 2px !important;
    font-family: var(--mr-font-ui) !important;
    font-size: 11px !important;
    font-weight: 600 !important;
    letter-spacing: .18em !important;
    text-transform: uppercase !important;
}

.elementor-field-group .elementor-field {
    border-radius: var(--mr-radius) !important;
    border: 1px solid rgba(97,104,50,.18) !important;
    font-family: var(--mr-font-body) !important
}
.elementor-field-group .elementor-field:focus {
    border-color: var(--mr-olive-600) !important;
    box-shadow: 0 0 0 3px rgba(119,125,69,.14) !important
}

.elementor-popup-modal .dialog-widget-content {
    border-radius: var(--mr-radius-xl) !important
}

/* Full-width Elementor template */
body.page-template-template-fullwidth .site-main,
body.page-template-template-fullwidth .mr-content-wrap {
    padding: 0 !important;
    max-width: 100% !important
}

[data-elementor-type="header"], [data-elementor-type="footer"],
[data-elementor-type="single"], [data-elementor-type="archive"] {
    width: 100%
}

body.elementor-page [data-elementor-type="header"] {
    position: sticky;
    top: 0;
    z-index: 200
}

body.elementor-editor-active .mr-site-header,
body.elementor-editor-active .mr-site-footer {
    display: block !important
}

#elementor-navigator {
    z-index: 9998 !important
}
.elementor .wp-block {
    max-width: 100%
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE
   ══════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .mr-site-header__inner {
        gap: 12px;
        min-height: var(--hdr-inner-height, 88px)
    }

    .mr-site-header.is-transparent.is-scrolled {
        --hdr-inner-height: 78px;
    }

    /* En tablet/mobile el grid pasa a: [hamburger+placeholder] [logo] [redes] */
    /* .mr-header-left deja de ser contents y se convierte en la col izquierda */
    .mr-header-left {
        display: flex;
        align-items: center;
        justify-self: start;
    }

    /* Mostrar hamburger */
    .mr-menu-toggle {
        display: flex
    }

    /* El nav se saca del flujo del grid y pasa a overlay */
    .mr-site-nav {
        display: none;
        position: fixed;
        top: var(--hdr-inner-height, 88px);
        left: 0;
        right: 0;
        height: calc(100vh - var(--hdr-inner-height, 88px));
        flex-direction: column;
        align-items: flex-start;
        background: rgba(246,245,238,.99);
        backdrop-filter: blur(20px);
        -webkit-backdrop-filter: blur(20px);
        border-top: 1px solid rgba(97,104,50,.1);
        padding: 48px 40px;
        overflow-y: auto;
        z-index: 9998;
        /* Resetear justify-self del grid desktop */
        justify-self: auto;
    }
    .mr-site-nav.is-open {
        display: flex
    }

    .mr-nav-menu {
        flex-direction: column;
        align-items: flex-start;
        gap: 32px;
        width: 100%;
    }
    .mr-nav-menu a {
        font-size: 28px;
        letter-spacing: .02em;
        font-family: var(--mr-font-heading);
        color: var(--mr-olive-900);
        font-weight: 400;
    }
    .mr-nav-menu a::after {
        display: none
    }

    .mr-brand-script {
        font-size: 40px
    }
    .mr-header-social {
        gap: 4px
    }
    .mr-header-social__link {
        width: 32px;
        height: 32px
    }
    .mr-site-actions .mr-btn {
        min-height: 40px;
        padding-inline: 14px;
        font-size: 10px
    }
    .mr-archive-grid, .mr-grid-4 {
        grid-template-columns: repeat(2, minmax(0,1fr))
    }
    .mr-rubro-main, .mr-rec-main {
        grid-template-columns: 1fr;
        gap: 36px
    }
    .mr-rubro-booking__card {
        position: relative;
        top: 0
    }
    .mr-rec-contact {
        position: relative;
        top: 0
    }
    .mr-rec-contact__card {
        position: relative;
        top: 0
    }
    .mr-rubro-gallery__grid, .mr-rec-gallery__grid {
        grid-template-columns: repeat(2, minmax(0,1fr))
    }
    .mr-site-footer__inner {
        grid-template-columns: 1fr 1fr
    }
    .mr-site-footer__social {
        justify-self: end
    }
    .mr-home-categories__grid, .mr-contact-page__grid, .mr-faq-page__wrap, .mr-home-editorial__inner, .mr-home-section-head.is-between {
        grid-template-columns: 1fr 1fr
    }
    .mr-home-listing__grid {
        grid-auto-columns: calc((100% - 20px) / 2)
    }
    .mr-home-listing__nav.is-prev {
        left: -18px
    }
    .mr-home-listing__nav.is-next {
        right: -18px
    }
    .mr-home-reco-card.card-1 {
        min-height: 0
    }
    .mr-contact-page__aside, .mr-home-editorial__quote {
        position: static
    }
    .mr-home-section-head.is-between {
        display: block;
        text-align: center
    }
}

@media (max-width: 767px) {
    .mr-site-header {
        --hdr-inner-height: 64px;
    }

    .mr-site-header.is-transparent.is-scrolled {
        --hdr-inner-height: 60px;
    }

    body {
        font-size: 17px
    }
    .mr-container {
        width: min(100% - 32px, var(--mr-container))
    }
    .mr-site-header__inner {
        gap: 8px;
        min-height: var(--hdr-inner-height, 64px)
    }
    .mr-site-nav {
        top: var(--hdr-inner-height, 64px);
        height: calc(100vh - var(--hdr-inner-height, 64px));
        padding: 36px 24px
    }
    .mr-nav-menu a {
        font-size: 22px
    }
    .mr-brand-top {
        font-size: 7px
    }
    .mr-brand-script {
        font-size: 26px;
        margin-top: -3px
    }
    .mr-header-social {
        gap: 2px
    }
    .mr-header-social__link {
        width: 28px;
        height: 28px
    }
    .mr-header-social__link svg {
        width: 16px;
        height: 16px
    }
    .mr-site-actions .mr-btn {
        font-size: 9px;
        min-height: 32px;
        padding: 5px 8px
    }
    .mr-content-wrap {
        padding-block: 48px
    }
    .entry-title, .page-title {
        font-size: 40px
    }
    .mr-archive-grid, .mr-grid-3, .mr-grid-4 {
        grid-template-columns: 1fr
    }
    .mr-card__title {
        font-size: 30px
    }
    .mr-rubro-hero__overlay .mr-container, .mr-rec-hero__overlay .mr-container {
        padding-bottom: 32px
    }
    .mr-rec-hero__overlay.has-logo .mr-container {
        width: min(100% - 28px, 420px);
        padding-bottom: 0
    }
    .mr-rec-hero__logo {
        padding: 14px 12px
    }
    .mr-rec-hero__logo img {
        max-height: 110px
    }
    .mr-rubro-main, .mr-rec-main {
        padding-block: 48px 36px
    }
    .mr-rubro-main__entry, .mr-rec-main__entry {
        font-size: 19px
    }
    .mr-rec-main__title {
        font-size: clamp(34px, 8vw, 52px)
    }
    .mr-rec-main__meta {
        font-size: 17px
    }
    .mr-rec-rating {
        gap: 12px;
        margin-bottom: 28px
    }
    .mr-rec-rating__stars {
        font-size: 17px
    }
    .mr-rec-rating__text {
        font-size: 15px
    }
    .mr-rec-proposals__panel {
        padding: 20px
    }
    .mr-rec-proposals__title {
        font-size: clamp(28px, 7vw, 40px)
    }
    .mr-rec-proposals__content {
        font-size: 18px
    }
    .mr-rec-proposals__tabs {
        overflow: auto;
        flex-wrap: nowrap;
        padding-bottom: 4px
    }
    .mr-rec-proposals__tab {
        flex: 0 0 auto;
        white-space: nowrap
    }
    .mr-rubro-gallery__grid, .mr-rec-gallery__grid {
        grid-template-columns: 1fr
    }
    .mr-site-footer__inner {
        grid-template-columns: 1fr
    }
    .mr-site-footer__social {
        justify-self: start;
        text-align: left
    }
    .mr-page-hero.has-image {
        min-height: 290px
    }
    .mr-home-hero {
        min-height: 540px
    }
    .mr-home-hero__title {
        font-size: 46px
    }
    .mr-home-hero__text, .mr-page-hero__text {
        font-size: 17px
    }
    .mr-home-categories, .mr-home-editorial, .mr-home-listing, .mr-page-section {
        padding: 56px 0
    }
    .mr-home-categories__grid, .mr-contact-page__grid, .mr-faq-page__wrap, .mr-home-editorial__inner, .mr-contact-form__grid {
        grid-template-columns: 1fr
    }
    .mr-home-listing__grid {
        grid-auto-columns: 100%;
        gap: 16px
    }
    .mr-home-listing__nav {
        display: none
    }
    .mr-home-reco-card.card-1 {
        min-height: 0
    }
    .mr-home-reco-card__body {
        padding: 22px 20px 24px
    }
    .mr-home-reco-card__body strong {
        font-size: 30px
    }
    .mr-home-category-card__body strong {
        font-size: 28px
    }
    .mr-contact-form-card h2, .mr-contact-info-card h2, .mr-faq-cta h2 {
        font-size: 32px
    }
    .mr-faq-item__trigger {
        font-size: 21px;
        padding: 20px 22px
    }
    .mr-faq-item__content {
        padding: 0 22px 22px;
        font-size: 17px
    }
    .mr-home-editorial__quote-text {
        font-size: 30px
    }
    .mr-home-cta-strip__inner {
        padding: 26px;
        align-items: flex-start;
        flex-direction: column
    }
    body.single-meli_recomendacion {
        padding-bottom: 86px
    }
    .mr-rec-contact--desktop {
        display: none
    }
    .mr-rec-mobile-cta {
        display: block;
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 999;
        padding: 10px 14px max(10px, env(safe-area-inset-bottom));
        background: rgba(246,245,238,.94);
        backdrop-filter: blur(12px);
        border-top: 1px solid rgba(97,104,50,.14)
    }
    .mr-rec-mobile-cta__button {
        width: 100%;
        min-height: 52px;
        border: 0;
        border-radius: var(--mr-radius);
        background: linear-gradient(135deg, var(--mr-olive-700) 0%, var(--mr-olive-600) 100%);
        color: var(--mr-white);
        font-family: var(--mr-font-ui);
        font-size: 13px;
        font-weight: 600;
        letter-spacing: .1em;
        text-transform: uppercase;
        box-shadow: 0 4px 18px rgba(97,104,50,.28)
    }
    .mr-rec-mobile-drawer {
        display: block;
        position: fixed;
        inset: 0;
        z-index: 1000;
        pointer-events: none;
        opacity: 0;
        transition: opacity .25s var(--mr-ease)
    }
    .mr-rec-mobile-drawer.is-open {
        opacity: 1;
        pointer-events: auto
    }
    .mr-rec-mobile-drawer__backdrop {
        position: absolute;
        inset: 0;
        background: rgba(0,0,0,.42)
    }
    .mr-rec-mobile-drawer__panel {
        position: absolute;
        left: 0;
        right: 0;
        bottom: 0;
        max-height: 88vh;
        background: var(--mr-cream-100);
        border-radius: 22px 22px 0 0;
        overflow: hidden;
        transform: translateY(100%);
        transition: transform .3s var(--mr-ease)
    }
    .mr-rec-mobile-drawer.is-open .mr-rec-mobile-drawer__panel {
        transform: translateY(0)
    }
    .mr-rec-mobile-drawer__header {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding: 18px 20px;
        background: var(--mr-cream-200);
        border-bottom: 1px solid rgba(97,104,50,.12);
        color: var(--mr-olive-700)
    }
    .mr-rec-mobile-drawer__close {
        width: 40px;
        height: 40px;
        border: 0;
        border-radius: 999px;
        background: var(--mr-white);
        color: var(--mr-olive-700);
        font-size: 26px;
        line-height: 1
    }
    .mr-rec-mobile-drawer__body {
        overflow: auto;
        max-height: calc(88vh - 73px);
        padding: 0
    }
    .mr-rec-mobile-drawer__body .mr-rec-contact__card {
        position: relative;
        top: 0;
        border-radius: 0;
        border: 0;
        box-shadow: none;
        padding-bottom: calc(24px + env(safe-area-inset-bottom))
    }
    .mr-lightbox__dialog {
        width: min(100vw - 16px, 1000px);
        margin: 8px auto;
        max-height: calc(100vh - 16px);
        border-radius: 18px
    }
    .mr-lightbox__topbar {
        padding: 18px 68px 10px 16px
    }
    .mr-lightbox__caption {
        font-size: 14px
    }
    .mr-lightbox__stage {
        gap: 8px;
        padding: 0 10px
    }
    .mr-lightbox__nav {
        flex: 0 0 40px;
        width: 40px;
        height: 40px;
        font-size: 26px
    }
    .mr-lightbox__content, .mr-lightbox__content img, .mr-lightbox__content video, .mr-lightbox__media {
        min-height: auto;
        max-height: 58vh
    }
    .mr-lightbox__thumbs {
        gap: 10px;
        padding: 12px 10px 14px
    }
    .mr-lightbox__thumb {
        flex-basis: 82px;
        width: 82px
    }
}

@media print {
    .mr-site-header, .mr-site-footer, .mr-rec-mobile-cta,
    .mr-rec-mobile-drawer, .mr-lightbox, .mr-menu-toggle {
        display: none !important
    }
    body {
        background: #fff;
        color: #000
    }
}

/* ══════════════════════════════════════════════════════════
   EXTRAS v1.8.0 — templates additions
   ══════════════════════════════════════════════════════════ */

/* ── Skip to content ─────────────────────────────────────── */
.mr-skip-link {
    position: absolute;
    top: -100%;
    left: 0;
    z-index: 9999;
    padding: 12px 20px;
    background: var(--mr-olive-700);
    color: var(--mr-white);
    font-family: var(--mr-font-ui);
    font-size: 13px;
    font-weight: 600;
    text-decoration: none;
    transition: top .2s;
}
.mr-skip-link:focus {
    top: 0
}

/* ── 404 enhanced ────────────────────────────────────────── */
.mr-404 {
    text-align: center;
    padding-block: 100px 80px
}
.mr-404__code {
    display: block;
    font-family: var(--mr-font-script);
    font-size: clamp(80px, 16vw, 180px);
    line-height: 1;
    color: var(--mr-olive-200);
    margin-bottom: -24px;
}
.mr-404 .entry-title {
    color: var(--mr-olive-700)
}
.mr-404__desc {
    max-width: 40ch;
    margin: 0 auto 28px;
    font-size: 19px;
    color: var(--mr-text-muted)
}
.mr-404__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: center;
    margin-bottom: 32px
}
.mr-404__search {
    max-width: 480px;
    margin: 0 auto
}

/* ── Post navigation ─────────────────────────────────────── */
.mr-post-navigation {
    padding-block: 32px 0;
    border-top: 1px solid var(--mr-color-border);
    margin-top: 48px
}
.mr-post-navigation .nav-links {
    display: flex;
    justify-content: space-between;
    gap: 24px
}
.mr-post-navigation a {
    color: var(--mr-olive-700);
    font-size: 16px
}
.mr-post-navigation a:hover {
    color: var(--mr-text)
}
.mr-post-navigation .nav-subtitle {
    display: block;
    margin-top: 4px;
    font-size: 19px;
    line-height: 1.2
}

/* ── Page links (multi-page posts) ──────────────────────── */
.page-links {
    margin-block: 32px 0;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center
}
.page-links > .post-page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 38px;
    padding: 4px 10px;
    border: 1px solid var(--mr-color-border);
    border-radius: var(--mr-radius);
    font-family: var(--mr-font-ui);
    font-size: 14px;
    color: var(--mr-olive-700);
    transition: var(--mr-trans-fast);
}
.page-links > .post-page-numbers.current,
.page-links > .post-page-numbers:hover {
    background: var(--mr-olive-700);
    border-color: var(--mr-olive-700);
    color: var(--mr-white);
}

/* ── Posts pagination ────────────────────────────────────── */
.navigation.pagination {
    margin-top: 48px
}
.navigation.pagination .nav-links {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    align-items: center
}
.navigation.pagination .page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    height: 44px;
    padding: 6px 14px;
    border: 1px solid var(--mr-color-border);
    border-radius: var(--mr-radius);
    font-family: var(--mr-font-ui);
    font-size: 14px;
    font-weight: 500;
    color: var(--mr-olive-700);
    transition: var(--mr-trans-fast);
}
.navigation.pagination .page-numbers.current,
.navigation.pagination .page-numbers:hover {
    background: var(--mr-olive-700);
    border-color: var(--mr-olive-700);
    color: var(--mr-white);
    box-shadow: 0 4px 14px rgba(97,104,50,.22);
}
.navigation.pagination .page-numbers.dots {
    border: 0;
    background: transparent;
    cursor: default
}

/* ── Location icon in meta ───────────────────────────────── */
.mr-rec-main__address {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}
.mr-rec-main__address svg {
    flex-shrink: 0;
    color: var(--mr-olive-400);
}

/* ── Footer logo variant ─────────────────────────────────── */
.mr-logo--footer img {
    max-height: 48px;
    width: auto;
    filter: brightness(10)
}

/* ── Blockquote in editorial ─────────────────────────────── */
.mr-home-editorial__quote blockquote {
    margin: 0;
    padding: 0;
    border: 0
}


/* ── Logo light/dark swap ──────────────────────────────────
 * Por defecto: logo oscuro (header sólido)
 * Con header transparente: logo claro siempre
 * ───────────────────────────────────────────────────────── */
.mr-logo--light {
    display: none
}
.mr-logo--dark  {
    display: block
}
.mr-site-header.is-transparent .mr-logo--light {
    display: block
}
.mr-site-header.is-transparent .mr-logo--dark  {
    display: none
}
.mr-site-header.is-transparent.is-scrolled .mr-logo--light {
    display: none
}
.mr-site-header.is-transparent.is-scrolled .mr-logo--dark  {
    display: block
}

/* Tamaño del logo */
.mr-logo__img, .mr-logo img {
    max-height: 52px;
    width: auto;
    display: block
}

/* Brand text light fallback (sin imagen de logo) */
.mr-brand-text--light .mr-brand-top   {
    color: rgba(255,255,255,.5)
}
.mr-brand-text--light .mr-brand-script {
    color: #fff
}
.mr-site-header.is-transparent.is-scrolled .mr-brand-text--light .mr-brand-top {
    color: var(--mr-olive-400)
}
.mr-site-header.is-transparent.is-scrolled .mr-brand-text--light .mr-brand-script {
    color: var(--mr-olive-700)
}

/* ── Header social icons ─────────────────────────────────── */
.mr-header-social {
    display: flex;
    align-items: center;
    gap: 6px;
}
.mr-header-social__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    color: var(--hdr-social-color, var(--mr-olive-600));
    transition: color .2s, background .2s, transform .2s;
}
.mr-header-social__link:hover {
    background: rgba(97,104,50,.08);
    transform: translateY(-1px);
}
.mr-site-header.is-transparent .mr-header-social__link:hover {
    background: rgba(255,255,255,.12);
}
.mr-site-header.is-transparent.is-scrolled .mr-header-social__link:hover {
    background: rgba(97,104,50,.08);
}

/* Botón outline-white en header transparente */
.mr-btn--outline-white {
    background: transparent !important;
    border-color: rgba(255,255,255,.7) !important;
    color: #fff !important;
}
.mr-btn--outline-white:hover {
    background: rgba(255,255,255,.12) !important;
    border-color: rgba(255,255,255,1) !important;
}
.mr-site-header.is-transparent.is-scrolled .mr-btn--outline-white {
    background: transparent !important;
    border-color: rgba(97,104,50,.32) !important;
    color: var(--mr-olive-700) !important;
}
.mr-site-header.is-transparent.is-scrolled .mr-btn--outline-white:hover {
    background: rgba(97,104,50,.08) !important;
    border-color: rgba(97,104,50,.48) !important;
    color: var(--mr-olive-700) !important;
}

/* Compensar header fixed: hero empieza desde 0, resto tiene offset */
body.mr-has-transparent-header .site-main > *:first-child:not(.mr-home-hero):not(.mr-rubro-hero):not(.mr-rec-hero):not(.mr-page-hero) {
    padding-top: 88px;
}

/* ══════════════════════════════════════════════════════════
   FOOTER 4-COLUMNAS — v1.8.0
   ══════════════════════════════════════════════════════════ */
.mr-site-footer {
    margin-top: 0
} /* reset: el margin lo pone el main */

.mr-site-footer__top {
    background: var(--mr-olive-900);
    position: relative;
    overflow: hidden;
}
.mr-site-footer__top::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 8% 40%, rgba(200,169,110,.07) 0%, transparent 55%),
        radial-gradient(ellipse at 92% 15%, rgba(172,176,129,.06) 0%, transparent 50%);
    pointer-events: none;
}

.mr-site-footer__inner {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: 1.6fr 1fr 1fr .9fr;
    gap: 48px;
    align-items: start;
    padding: 80px 0 64px;
}

/* Col titles */
.mr-site-footer__col-title {
    margin: 0 0 20px;
    font-family: var(--mr-font-ui);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: rgba(255,255,255,.38);
}

/* Brand col */
.mr-site-footer .mr-brand-script {
    color: var(--mr-white);
    font-size: 48px
}
.mr-site-footer .mr-brand-top    {
    color: rgba(255,255,255,.38)
}
.mr-site-footer__tagline {
    margin: 14px 0 0;
    font-size: 15px;
    line-height: 1.6;
    color: rgba(255,255,255,.48);
    max-width: 26ch;
}

.mr-site-footer__brand-head {
    display: inline-flex;
    align-items: center;
    gap: 16px;
}
.mr-brand-emblem {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    flex-shrink: 0;
    background-color: currentColor;
    -webkit-mask: url('../icons/brand-star.svg') center / contain no-repeat;
    mask: url('../icons/brand-star.svg') center / contain no-repeat;
}

/* Footer nav */
.mr-site-footer .mr-footer-menu {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
}
.mr-site-footer .mr-footer-menu a {
    font-family: var(--mr-font-ui);
    font-size: 13px;
    font-weight: 400;
    letter-spacing: .04em;
    text-transform: none;
    color: rgba(255,255,255,.62);
    transition: color .2s;
}
.mr-site-footer .mr-footer-menu a:hover {
    color: var(--mr-white)
}

/* Contact col */
.mr-site-footer__contact-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 10px;
}
.mr-site-footer__contact-list li {
    font-size: 14px;
    line-height: 1.5;
    color: rgba(255,255,255,.62)
}
.mr-site-footer__contact-list a {
    color: rgba(255,255,255,.62);
    transition: color .2s
}
.mr-site-footer__contact-list a:hover {
    color: var(--mr-white)
}

/* Social col */
.mr-site-footer__social {
    display: flex;
    flex-direction: column;
    gap: 14px;
    text-align: left;
    justify-self: auto;
}
.mr-site-footer__social a {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    font-family: var(--mr-font-ui);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: rgba(255,255,255,.55);
    transition: color .2s;
}
.mr-site-footer__social a:hover {
    color: var(--mr-gold-light)
}
.mr-site-footer__social svg {
    flex-shrink: 0
}

/* Bottom bar */
.mr-site-footer__bottom {
    background: rgba(0,0,0,.25);
    padding: 18px 0;
}
.mr-site-footer__bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
}
.mr-site-footer__bottom p {
    margin: 0;
    font-family: var(--mr-font-ui);
    font-size: 12px;
    color: rgba(255,255,255,.3);
    letter-spacing: .04em;
}
.mr-footer-legal-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 24px;
}
.mr-footer-legal-menu a {
    font-family: var(--mr-font-ui);
    font-size: 12px;
    color: rgba(255,255,255,.3);
    transition: color .2s;
}
.mr-footer-legal-menu a:hover {
    color: rgba(255,255,255,.7)
}

/* ── Responsive footer ───────────────────────────────────── */
@media (max-width: 1100px) {
    .mr-site-footer__inner {
        grid-template-columns: 1fr 1fr;
        gap: 36px;
        padding: 60px 0 48px;
    }
}
@media (max-width: 767px) {
    .mr-brand-emblem {
        width: 36px;
        height: 36px;
    }
    .mr-site-footer__brand-head {
        gap: 12px;
    }
    .mr-site-footer__inner {
        grid-template-columns: 1fr;
        gap: 28px;
        padding: 48px 0 36px;
    }
    .mr-site-footer__bottom-inner {
        flex-direction: column;
        text-align: center;
        gap: 12px;
    }
    .mr-footer-legal-menu {
        justify-content: center;
        flex-wrap: wrap;
        gap: 16px
    }
    .mr-site-footer .mr-brand-script {
        font-size: 40px
    }
}

/* ══════════════════════════════════════════════════════════
   HERO OFFSET para header fixed transparente
   El site-main necesita padding-top = 0 porque los heros
   ya son full-screen. Las páginas sin hero necesitan el offset.
   ══════════════════════════════════════════════════════════ */
body.mr-has-transparent-header .site-main:not(.mr-has-hero) {
    padding-top: 88px;
}

/* ══════════════════════════════════════════════════════════
   WILDER-INSPIRED REFINEMENTS
   Más aire, serif más grande, líneas más finas
   ══════════════════════════════════════════════════════════ */

/* Títulos con más peso visual como en Wilder */
.mr-home-hero__title {
    font-size: clamp(52px, 8vw, 110px);
    letter-spacing: -.03em;
    line-height: .9;
}

/* Eyebrow con línea lateral */
.mr-home-hero__eyebrow {
    font-size: 10px;
    letter-spacing: .32em;
}

/* Section titles más ligeros */
.mr-section-title {
    font-size: clamp(32px, 4.5vw, 58px);
    letter-spacing: -.02em;
}

/* Cards con aspecto más editorial: sin border, solo sombra */
.mr-card {
    border: none;
    box-shadow: 0 2px 20px rgba(30,32,16,.06);
}
.mr-card:hover {
    box-shadow: 0 20px 60px rgba(30,32,16,.13)
}

/* Reco cards en home: títulos más grandes */
.mr-home-reco-card__body strong {
    font-family: var(--mr-font-heading);
    font-size: 36px;
    font-weight: 400;
    letter-spacing: -.01em;
}

/* Category cards body */
.mr-home-category-card__body strong {
    font-size: 28px
}

/* Editorial quote: más grande y centrado */
.mr-home-editorial__quote-text {
    font-size: 36px;
    letter-spacing: -.01em;
}

/* Rubro/Rec hero title: más impacto */
.mr-rubro-hero__title, .mr-rec-hero__title {
    font-size: clamp(48px, 8vw, 106px);
    letter-spacing: -.03em;
    line-height: .9;
}

/* FAQ: pregunta más grande */
.mr-faq-item__trigger {
    font-size: 25px
}

/* Buttons más altos, más aire */
.mr-btn {
    min-height: 50px;
    padding: 12px 28px;
    letter-spacing: .2em
}



/* ===== v2.0.0 Enhancements ===== */
.mr-section-shell {
    position: relative;
    overflow: hidden;
    padding-top: var(--mr-block-padding-top, 72px);
    padding-bottom: var(--mr-block-padding-bottom, 72px);
}
.mr-section-shell.has-bg-media::before,
.mr-section-shell.has-bg-media::after {
    content: "";
    position: absolute;
    inset: 0;
    pointer-events: none;
}
.mr-section-shell.has-bg-media::before {
    background-image: var(--mr-block-bg-image);
    background-position: center;
    background-size: cover;
    transform: scale(1.02);
}
.mr-section-shell.has-bg-media::after {
    background: var(--mr-block-overlay-color, #000);
    opacity: var(--mr-block-overlay-opacity, 0);
}
.mr-section-shell > .mr-container,
.mr-section-shell > .mr-home-hero__overlay,
.mr-section-shell > .mr-home-hero__inner,
.mr-section-shell > .mr-container.mr-home-hero__inner {
    position: relative;
    z-index: 1;
}
.mr-section-shell.is-tone-dark,
.mr-section-shell.is-tone-dark .mr-section-title,
.mr-section-shell.is-tone-dark .mr-home-section-head__kicker,
.mr-section-shell.is-tone-dark p,
.mr-section-shell.is-tone-dark .entry-content,
.mr-section-shell.is-tone-dark .mr-home-editorial__quote-author,
.mr-section-shell.is-tone-dark h2 {
    color: #f7f2e8;
}
.mr-section-shell.is-tone-dark .mr-btn--ghost {
    border-color: rgba(247,242,232,.35);
    color: #f7f2e8;
}
.mr-section-shell.is-align-center .mr-home-section-head,
.mr-section-shell.is-align-center .mr-home-editorial__copy,
.mr-section-shell.is-align-center .mr-home-cta-strip__inner,
.mr-section-shell.is-align-center .mr-home-hero__content {
    text-align: center;
    margin-inline: auto;
    justify-content: center;
}
.mr-home-listing,
.mr-home-categories,
.mr-home-editorial,
.mr-home-cta-strip { padding-top: var(--mr-block-padding-top, 72px); padding-bottom: var(--mr-block-padding-bottom, 72px); }
.mr-home-listing__slider {
    position: relative;
    user-select: none;
}
.mr-home-listing__slider.is-dragging { cursor: grabbing; }
.mr-home-listing__grid {
    gap: 24px;
    scroll-snap-type: x mandatory;
    cursor: grab;
    padding-bottom: 8px;
}
.mr-home-listing__grid > * { scroll-snap-align: start; }
.mr-home-listing__dots {
    display: flex;
    justify-content: center;
    gap: 10px;
    margin-top: 22px;
}
.mr-home-listing__dot {
    width: 10px;
    height: 10px;
    border-radius: 999px;
    border: 0;
    background: rgba(60,65,32,.18);
    cursor: pointer;
    transition: transform .2s ease, background .2s ease;
}
.mr-home-listing__dot.is-active { background: #3c4120; transform: scale(1.15); }
.mr-home-reco-card,
.mr-rec-related__grid .mr-home-reco-card,
.mr-home-category-card {
    min-height: var(--mr-card-min-height, 420px);
}
.mr-home-reco-card__media,
.mr-home-category-card__media {
    aspect-ratio: var(--mr-card-ratio, 16/9);
}
.mr-home-reco-card__media img,
.mr-home-category-card__media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.mr-home-reco-card__body strong,
.mr-home-category-card__body strong {
    display: -webkit-box;
    -webkit-line-clamp: var(--mr-card-title-lines, 2);
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mr-home-reco-card__body small,
.mr-home-category-card__body small {
    display: -webkit-box;
    -webkit-line-clamp: var(--mr-card-text-lines, 3);
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.mr-home-reco-card__body,
.mr-home-category-card__body {
    gap: 10px;
}
.mr-home-reco-card__button,
.mr-home-category-card__button {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: auto;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .12em;
    color: #616832;
}
.mr-home-reco-card__button::after,
.mr-home-category-card__button::after {
    content: '→';
}
.mr-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.mr-badge {
    display: inline-flex;
    align-items: center;
    padding: 6px 10px;
    border-radius: 999px;
    font-size: 11px;
    line-height: 1;
    letter-spacing: .08em;
    text-transform: uppercase;
    background: rgba(60,65,32,.08);
    color: #3c4120;
}
.mr-home-reco-card__badges { margin-top: 2px; }
.mr-rec-main__badges { margin: 18px 0 0; }
.mr-rec-facts {
    margin: 28px 0 18px;
}
.mr-rec-facts__grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}
.mr-rec-facts__item {
    padding: 18px 18px 16px;
    border-radius: 14px;
    background: #f6f5ee;
    border: 1px solid rgba(60,65,32,.08);
}
.mr-rec-facts__item small {
    display: block;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 11px;
    color: #7c8461;
}
.mr-rec-facts__item strong {
    font-size: 16px;
    color: #2e3118;
}
.mr-rec-related {
    padding-top: 12px;
    padding-bottom: 78px;
}
.mr-rec-related__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}
.mr-site-footer {
    position: relative;
    background-image: var(--mr-footer-bg-image, none);
    background-size: cover;
    background-position: center;
}
.mr-site-footer::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(31,34,15,.0) 0%, rgba(31,34,15,.4) 100%);
    pointer-events: none;
}
.mr-site-footer__top,
.mr-site-footer__bottom {
    position: relative;
    z-index: 1;
}
.mr-site-footer__inner {
    grid-template-columns: 1.1fr .9fr .9fr .9fr .9fr;
}
.mr-site-footer__signature {
    margin: 12px 0 0;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: rgba(255,255,255,.55);
}
.mr-site-footer__extra-text {
    margin: 0 0 18px;
    color: rgba(255,255,255,.74);
    max-width: 32ch;
}
.mr-faq-cats {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 22px;
}
.mr-faq-cats__link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 9px 14px;
    border-radius: 999px;
    background: #f0eee5;
    color: #3c4120;
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.mr-faq-group-title {
    margin: 34px 0 14px;
    font-size: 24px;
    color: #3c4120;
}
@media (max-width: 1024px) {
    .mr-rec-facts__grid,
    .mr-rec-related__grid,
    .mr-site-footer__inner {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 767px) {
    .mr-home-listing__nav { display: none; }
    .mr-rec-facts__grid,
    .mr-rec-related__grid,
    .mr-site-footer__inner {
        grid-template-columns: 1fr;
    }
    .mr-home-reco-card,
    .mr-home-category-card { min-height: auto; }
}
