/*
Theme Name:   Casa Rambla Serra Child
Theme URI:    https://casaramblaserra.com
Description:  Child theme de Blocksy para Casa Rambla Serra — Boutique Stays en Cali, Cartagena y Barcelona.
Author:       Casa Rambla Serra
Author URI:   https://casaramblaserra.com
Template:     blocksy
Version:      6.13.0
Text Domain:  crs-child
License:      GPL-2.0-or-later
*/

/* ── Fuentes cargadas via functions.php con preconnect (mejor performance) ── */

/* ══════════════════════════════════════════
   TOKENS
══════════════════════════════════════════ */
:root {
  --navy:   #1B2B4B;
  --navy2:  #0F1C38;
  --gold:   #C9A96E;
  --gold2:  #E8C98A;
  --cream:  #F8F5F0;
  --white:  #FFFFFF;
  --mid:    #6B7A99;
  --mid-on-dark: #9AA8C7; /* texto secundario legible sobre fondo navy (footer) */
  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Montserrat', sans-serif;
  --ease:   cubic-bezier(.16,1,.3,1);
  --shadow: 0 8px 40px rgba(15,28,56,.18);
}

/* ══════════════════════════════════════════
   RESET / BASE
══════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; overflow-x: hidden; max-width: 100%; }
body.crs-home {
  font-family: var(--sans);
  background: var(--navy2);
  color: var(--white);
  overflow-x: hidden;
  max-width: 100%;
  position: relative;
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* ══════════════════════════════════════════
   HIDE BLOCKSY HEADER/FOOTER ON HOME
══════════════════════════════════════════ */
.ct-header, [data-id="header"], .site-header,
.ct-footer, [data-id="footer"], .site-footer { display: none !important; }
.ct-main-content, .entry-content, .site-main,
#primary, #content, .wp-site-blocks {
  padding: 0 !important; margin: 0 !important; max-width: 100% !important;
}
body.crs-home { padding: 0 !important; }

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
#crs-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 9999;
  display: flex; align-items: center;
  padding: 16px 48px;
  background: linear-gradient(to bottom, rgba(11,17,33,.88) 0%, transparent 100%);
  transition: background .4s var(--ease), padding .4s var(--ease);
}
#crs-nav.scrolled {
  background: rgba(11,17,33,.97);
  padding: 10px 48px;
  box-shadow: 0 2px 24px rgba(0,0,0,.4);
  /* Mantener mismo layout que estado normal */
  display: flex;
  align-items: center;
}

/* ── Logo ── */
.crs-logo {
  display: flex; align-items: center;
  flex-shrink: 0;
  min-width: 200px;
  transition: opacity .25s;
  text-decoration: none;
}
.crs-logo:hover { opacity: .82; }

/* Logo PNG landscape 441x76 — icono + wordmark integrados */
.crs-logo-img {
  display: block;
  height: 38px;
  width: auto;
  /* El logo es blanco sobre transparente — perfecto para nav oscuro */
}

/* Footer logo */
.crs-footer-logo-wrap {
  display: flex; align-items: center;
  margin-bottom: 16px;
}
.crs-footer-logo-img {
  display: block;
  height: 32px;
  width: auto;
  opacity: .85;
}

/* Links centrados — flex: 1 en ambos lados empuja al centro */
.crs-nav-links {
  display: flex; gap: 36px; list-style: none;
  flex: 1; justify-content: center; align-items: center;
  /* Bajar levemente para alinear con el centro optico del logo */
  margin: 0; padding-top: 4px;
}
.crs-nav-links a {
  font-family: var(--sans); font-size: .62rem; font-weight: 500;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(255,255,255,.85);
  transition: color .25s;
}
.crs-nav-links a:hover { color: var(--gold); }

/* CTA derecha */
.crs-nav-cta {
  flex-shrink: 0;
  flex-basis: 200px;         /* igual al logo: .crs-nav-links queda centrado de verdad */
  display: flex;
  align-items: center;
  justify-content: center;
  margin-left: auto;         /* se ancla a la derecha sin desbordar el nav */
  text-align: center;
  white-space: nowrap;
  font-family: var(--sans); font-size: .6rem; font-weight: 600;
  letter-spacing: .18em; text-transform: uppercase;
  padding: 10px 22px; border: 1px solid var(--gold);
  color: var(--gold); transition: background .25s, color .25s;
  box-sizing: border-box;
}
.crs-nav-cta:hover { background: var(--gold); color: var(--navy2); }

/* ── Hamburguesa (oculta en desktop) ── */
.crs-nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 32px; height: 32px;
  background: none; border: none; cursor: pointer;
  flex-shrink: 0; padding: 0;
  z-index: 10001;
}
.crs-nav-toggle span {
  display: block; height: 2px; width: 24px;
  background: var(--gold);
  transition: transform .3s, opacity .3s;
}
.crs-nav-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.crs-nav-toggle.open span:nth-child(2) { opacity: 0; }
.crs-nav-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── Menu movil desplegable ── */
.crs-mobile-menu {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 78%; max-width: 320px;
  background: rgba(11,17,33,.98);
  backdrop-filter: blur(10px);
  z-index: 10000;
  display: flex; flex-direction: column;
  justify-content: center;
  align-items: center; gap: 8px;
  padding: 40px;
  transform: translateX(100%);
  transition: transform .35s var(--ease);
  box-shadow: -8px 0 40px rgba(0,0,0,.4);
  visibility: hidden;
}
.crs-mobile-menu.open { transform: translateX(0); visibility: visible; }
/* Boton cerrar (X) dentro del menu */
.crs-mobile-close {
  position: absolute; top: 24px; right: 24px;
  width: 36px; height: 36px;
  background: none; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  padding: 0;
}
.crs-mobile-close::before,
.crs-mobile-close::after {
  content: ''; position: absolute;
  width: 22px; height: 2px; background: var(--gold);
}
.crs-mobile-close::before { transform: rotate(45deg); }
.crs-mobile-close::after  { transform: rotate(-45deg); }
.crs-mobile-link {
  font-family: var(--sans); font-size: .8rem; font-weight: 500;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.9);
  padding: 16px 0; width: 100%; text-align: center;
  border-bottom: 1px solid rgba(201,169,110,.12);
  transition: color .2s;
}
.crs-mobile-link:hover { color: var(--gold); }
.crs-mobile-cta {
  margin-top: 16px; border: 1px solid var(--gold);
  color: var(--gold); border-bottom: 1px solid var(--gold);
}
.crs-mobile-cta:hover { background: var(--gold); color: var(--navy2); }
/* Backdrop oscuro detras del menu */
.crs-mobile-backdrop {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.5);
  opacity: 0; visibility: hidden;
  transition: opacity .3s, visibility .3s;
}
.crs-mobile-backdrop.open { opacity: 1; visibility: visible; }

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
#crs-hero {
  position: relative; min-height: 100vh;
  display: flex; align-items: center; justify-content: center;
  background: var(--hero-img, linear-gradient(135deg, #1B2B4B 0%, #0F1C38 100%))
              center/cover no-repeat;
  /* Fijar posicion para que la imagen no se pixele en mobile */
  background-attachment: scroll;
}

/* Overlay doble: base oscura + gradiente direccional para legibilidad */
#crs-hero::before {
  content: '';
  position: absolute; inset: 0;
  background:
    linear-gradient(
      to bottom,
      rgba(11,17,33,.4) 0%,
      rgba(11,17,33,.5) 50%,
      rgba(11,17,33,.62) 100%
    );
  z-index: 1;
}
/* Segundo overlay separado en el div .crs-hero-overlay para mayor control */
.crs-hero-overlay {
  position: absolute; inset: 0; z-index: 1;
  background: radial-gradient(
    ellipse at center,
    rgba(27,43,75,.12) 0%,
    rgba(11,17,33,.28) 100%
  );
}

/* Todo el contenido centrado */
.crs-hero-content {
  position: relative; z-index: 2;
  width: 100%; max-width: 900px;
  padding: 120px 48px 80px;
  text-align: center;
  display: flex; flex-direction: column; align-items: center;
}

/* Eyebrow — legibilidad mejorada */
.crs-hero-eyebrow {
  display: none; /* Quitado por peticion del cliente */
}

/* Titulo principal — sombra de texto para legibilidad total */
.crs-hero-title {
  font-family: var(--serif); font-size: clamp(2.8rem, 5.5vw, 5rem);
  font-weight: 300; line-height: 1.08; letter-spacing: -.01em;
  color: var(--white); margin-bottom: 20px;
  text-shadow: 0 2px 24px rgba(0,0,0,.8), 0 1px 4px rgba(0,0,0,.6);
}
.crs-hero-title em { font-style: italic; color: var(--gold); }

/* Ciudades */
.crs-hero-cities {
  font-family: var(--sans); font-size: .68rem; font-weight: 400;
  letter-spacing: .25em; text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-bottom: 10px;
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
}

/* Nombre propiedad */
.crs-hero-sub {
  font-family: var(--sans); font-size: 1.15rem; font-weight: 700;
  letter-spacing: .34em; text-transform: uppercase;
  color: rgba(255,255,255,.92);
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
  margin-bottom: 6px;
}
.crs-hero-tagline {
  font-family: var(--serif); font-size: .9rem; font-style: italic;
  letter-spacing: .04em;
  color: rgba(201,169,110,.9);
  text-shadow: 0 1px 8px rgba(0,0,0,.5);
  margin-bottom: 44px;
}
@media (max-width: 560px) {
  .crs-hero-sub { font-size: 1rem; letter-spacing: .28em; }
  .crs-hero-tagline { font-size: .82rem; margin-bottom: 32px; }
}

/* ── Label "Seleccionar ciudad" sobre el buscador ── */
.crs-hero-search-label {
  font-family: var(--sans); font-size: .62rem; font-weight: 600;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 10px;
  text-shadow: 0 1px 6px rgba(0,0,0,.5);
  align-self: flex-start; /* alinea con los botones */
}

/* ── SEARCHBAR hero ── */
.crs-searchbar {
  display: flex; background: rgba(255,255,255,.06);
  border: 1px solid rgba(201,169,110,.25); backdrop-filter: blur(12px);
  max-width: 760px;
}
.crs-sb-field {
  flex: 1; padding: 18px 20px;
  border-right: 1px solid rgba(201,169,110,.15);
  cursor: pointer; transition: background .2s;
}
.crs-sb-field:hover { background: rgba(255,255,255,.04); }
.crs-sb-label {
  display: block; font-family: var(--sans); font-size: .5rem;
  font-weight: 600; letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold); margin-bottom: 5px;
}
.crs-sb-val {
  font-family: var(--sans); font-size: .75rem; font-weight: 300;
  color: rgba(255,255,255,.7);
}
.crs-sb-btn {
  padding: 0 28px; background: var(--gold); border: none; cursor: pointer;
  font-family: var(--sans); font-size: .6rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase; color: var(--navy2);
  transition: background .2s;
}
.crs-sb-btn:hover { background: var(--gold2); }

/* ══════════════════════════════════════════
   SECTIONS SHARED
══════════════════════════════════════════ */
.crs-section { padding: 100px 48px; }
.crs-section--white { background: var(--cream); color: var(--navy2); }
.crs-section--navy2 { background: var(--navy2); color: var(--white); }

.crs-section-header { text-align: center; margin-bottom: 64px; }
.crs-eyebrow {
  display: inline-block;
  font-family: var(--sans); font-size: .55rem; font-weight: 600;
  letter-spacing: .28em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 16px;
}
.crs-title {
  font-family: var(--serif); font-size: clamp(2rem, 4vw, 3.2rem);
  font-weight: 300; line-height: 1.1; color: inherit; margin-bottom: 20px;
}
.crs-title--light { color: var(--white); }
.crs-divider {
  width: 48px; height: 1px; background: var(--gold);
  margin: 0 auto 24px;
}
.crs-subtitle {
  font-family: var(--sans); font-size: .8rem; font-weight: 300;
  line-height: 1.8; color: var(--mid); max-width: 520px; margin: 0 auto;
}

/* Fade-in on scroll */
.crs-fade { opacity: 0; transform: translateY(28px); transition: opacity .7s var(--ease), transform .7s var(--ease); }
.crs-fade.visible { opacity: 1; transform: none; }

/* ══════════════════════════════════════════
   DESTINATIONS
══════════════════════════════════════════ */
.crs-countries {
  display: grid; grid-template-columns: repeat(2,1fr); gap: 16px;
  max-width: 1200px; margin: 0 auto;
}
.crs-country {
  position: relative; overflow: hidden;
  aspect-ratio: 4/3; cursor: pointer;
  text-decoration: none; display: block;
}
.crs-country-img {
  width: 100%; height: 100%; background-size: cover; background-position: center;
  transition: transform .7s var(--ease);
}
.ci-colombia { background-image: var(--colombia-img, linear-gradient(180deg,#1B2B4B,#0F1C38)); }
.ci-espana   { background-image: var(--espana-img,   linear-gradient(180deg,#2B1B4B,#1C0F38)); }
.crs-country:hover .crs-country-img { transform: scale(1.06); }
.crs-country-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11,17,33,.88) 0%, rgba(11,17,33,.15) 55%);
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 40px; transition: background .4s;
}
.crs-country:hover .crs-country-overlay { background: linear-gradient(to top, rgba(11,17,33,.94) 0%, rgba(11,17,33,.3) 60%); }
.crs-country-label {
  font-family: var(--sans); font-size: .58rem; font-weight: 600;
  letter-spacing: .24em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 10px;
}
.crs-country-name {
  font-family: var(--serif); font-size: 2.6rem; font-weight: 300;
  color: var(--white); line-height: 1; margin-bottom: 8px;
}
.crs-country-cities {
  font-family: var(--sans); font-size: .72rem; font-weight: 400;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.7); margin-bottom: 22px;
}
.crs-country-btn {
  display: inline-block; width: fit-content;
  font-family: var(--sans); font-size: .58rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  padding: 12px 24px; border: 1px solid var(--gold); color: var(--gold);
  opacity: 0; transform: translateY(8px);
  transition: opacity .3s, transform .3s, background .2s, color .2s;
}
.crs-country:hover .crs-country-btn { opacity: 1; transform: none; }
.crs-country-btn:hover { background: var(--gold); color: var(--navy2); }

/* ══════════════════════════════════════════
   FEATURED
══════════════════════════════════════════ */
.crs-featured {
  display: grid; grid-template-columns: 1fr 1fr; gap: 0;
  max-width: 1200px; margin: 0 auto 0;
}
.crs-feat-gallery {
  position: relative;
  display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 1fr 1fr;
  gap: 2px; min-height: 520px;
}
.crs-feat-badge {
  position: absolute; top: 24px; left: 24px; z-index: 10;
  font-family: var(--sans); font-size: .5rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  background: var(--gold); color: var(--navy2); padding: 6px 14px;
}
.crs-feat-photo {
  background: var(--navy) center/cover no-repeat;
  grid-column: span 2;
}
.crs-feat-photo:not(.crs-feat-main-photo) { grid-column: span 1; }
.crs-feat-main-photo { background-image: var(--cali-img, linear-gradient(135deg,#1B2B4B,#0F1C38)); }
.crs-feat-photo:nth-child(3) { background-image: var(--cart-img, linear-gradient(135deg,#2B1B4B,#1C0F38)); }
.crs-feat-photo:nth-child(4) { background-image: var(--bcn-img, linear-gradient(135deg,#1B4B2B,#0F3818)); }
.crs-feat-photo:nth-child(5) { background: linear-gradient(135deg,#4B1B2B,#381C0F); }

.crs-feat-info {
  background: var(--navy2); padding: 64px 56px;
  display: flex; flex-direction: column; justify-content: center;
}
.crs-feat-loc {
  font-family: var(--sans); font-size: .55rem; font-weight: 600;
  letter-spacing: .22em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 14px;
}
.crs-feat-name {
  font-family: var(--serif); font-size: 2.4rem; font-weight: 300;
  color: var(--white); line-height: 1.1; margin-bottom: 20px;
}
.crs-feat-desc {
  font-family: var(--sans); font-size: .78rem; font-weight: 300;
  line-height: 1.85; color: var(--mid); margin-bottom: 36px;
}
.crs-feat-stats {
  display: flex; gap: 40px; margin-bottom: 40px;
  padding-top: 28px; border-top: 1px solid rgba(201,169,110,.2);
}
.crs-feat-stat-num {
  font-family: var(--serif); font-size: 2rem; font-weight: 300;
  color: var(--gold); line-height: 1;
}
.crs-feat-stat-lbl {
  font-family: var(--sans); font-size: .55rem; font-weight: 500;
  letter-spacing: .14em; text-transform: uppercase; color: var(--mid);
  margin-top: 6px;
}

/* Strip */
.crs-feat-strip {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
  max-width: 1200px; margin: 2px auto 0;
}
.crs-feat-strip > div {
  height: 200px; position: relative; overflow: hidden; cursor: pointer;
}
.crs-feat-strip > div::after {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(11,17,33,.7) 0%, transparent 60%);
  transition: background .4s;
}
.crs-feat-strip > div:hover::after { background: linear-gradient(to top, rgba(11,17,33,.5) 0%, transparent 60%); }
.crs-feat-strip span {
  position: absolute; bottom: 20px; left: 20px; z-index: 2;
  font-family: var(--serif); font-size: 1.4rem; font-weight: 300;
  color: var(--white);
}

/* ══════════════════════════════════════════
   STEPS
══════════════════════════════════════════ */
.crs-steps-section {
  background: var(--navy);
  padding: 80px 48px;
}
.crs-steps-header {
  text-align: center;
  margin-bottom: 56px;
}
.crs-steps {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 48px;
  max-width: 1100px; margin: 0 auto;
}
.crs-step {
  padding: 0; text-align: center;
  display: flex; flex-direction: column; align-items: center;
}
/* Numero circular grande */
.crs-step-num {
  width: 72px; height: 72px;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--gold);
  border-radius: 50%;
  font-family: var(--serif); font-size: 2rem; font-weight: 400;
  color: var(--gold);
  margin-bottom: 28px;
  flex-shrink: 0;
}
.crs-step-title {
  font-family: var(--serif); font-size: 1.6rem; font-weight: 300;
  color: var(--white); line-height: 1.2; margin-bottom: 14px;
}
.crs-step-text {
  font-family: var(--sans); font-size: .82rem; font-weight: 300;
  line-height: 1.8; color: var(--mid);
  max-width: 280px;
}

/* ══════════════════════════════════════════
   CATALOG
══════════════════════════════════════════ */
.crs-catalog-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px;
  max-width: 1200px; margin: 0 auto;
}
.crs-prop {
  background: var(--white); overflow: hidden;
  border: 1px solid rgba(201,169,110,.18);
  display: flex; flex-direction: column;
  transition: box-shadow .3s, transform .3s;
}
.crs-prop:hover {
  box-shadow: 0 12px 40px rgba(27,43,75,.12);
  transform: translateY(-4px);
}
.crs-prop-img-real {
  height: 230px; position: relative; overflow: hidden;
  background: var(--navy) center/cover no-repeat;
}
.crs-prop-badge {
  position: absolute; top: 16px; left: 16px;
  font-family: var(--sans); font-size: .5rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  background: var(--gold); color: var(--navy2); padding: 5px 12px;
}
.crs-prop-country {
  position: absolute; top: 16px; right: 16px;
  font-family: var(--sans); font-size: .5rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  background: rgba(11,17,33,.78); color: var(--gold); padding: 5px 12px;
  backdrop-filter: blur(4px);
}
.crs-prop-body {
  padding: 24px 26px 26px;
  display: flex; flex-direction: column; flex: 1;
}
.crs-prop-name {
  font-family: var(--serif); font-size: 1.3rem; font-weight: 400;
  color: var(--navy2); margin-bottom: 14px; line-height: 1.25;
}
/* Specs con iconos */
.crs-prop-specs {
  display: flex; flex-wrap: wrap; gap: 16px;
  padding-bottom: 16px; margin-bottom: 16px;
  border-bottom: 1px solid rgba(201,169,110,.18);
}
.crs-prop-spec {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--sans); font-size: .68rem; font-weight: 500;
  color: #5a6478;
}
.crs-prop-spec svg { color: var(--gold); flex-shrink: 0; }
.crs-prop-desc {
  font-family: var(--sans); font-size: .72rem; font-weight: 300;
  line-height: 1.7; color: #7a8496; margin-bottom: 20px; flex: 1;
}
.crs-prop-footer {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px; margin-top: auto;
}
.crs-prop-price {
  font-family: var(--serif); font-size: 1.45rem; font-weight: 600; color: var(--navy2);
}
.crs-prop-price small,
.crs-prop-price-unit {
  font-family: var(--sans); font-size: .6rem; font-weight: 400;
  color: var(--mid); margin-left: 4px;
}
.crs-prop-price-val {
  font-family: var(--serif); font-size: 1.45rem; font-weight: 600; color: var(--navy2);
}
.crs-prop-consult {
  font-family: var(--serif); font-size: 1rem; font-style: italic; color: var(--mid);
}
.crs-prop-btns { display: flex; gap: 8px; }
.crs-prop-link {
  font-family: var(--sans); font-size: .55rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase;
  padding: 9px 15px; border: 1px solid rgba(27,43,75,.25); color: var(--navy2);
  transition: border-color .2s, background .2s, color .2s;
  white-space: nowrap;
}
.crs-prop-link:hover { border-color: var(--navy2); background: var(--navy2); color: #fff; }
.crs-prop-link--gold { border-color: var(--gold); color: var(--gold); }
.crs-prop-link--gold:hover { background: var(--gold); color: var(--navy2); border-color: var(--gold); }

.crs-catalog-cta { text-align: center; margin-top: 48px; }

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.crs-btn {
  display: inline-block;
  font-family: var(--sans); font-size: .6rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; padding: 16px 36px;
  transition: all .25s;
}
.crs-btn--gold { background: var(--gold); color: var(--navy2); }
.crs-btn--gold:hover { background: var(--gold2); }
.crs-btn--outline-n { border: 1px solid var(--navy2); color: var(--navy2); }
.crs-btn--outline-n:hover { background: var(--navy2); color: var(--white); }
.crs-btn--outline-w { border: 1px solid rgba(255,255,255,.4); color: var(--white); }
.crs-btn--outline-w:hover { border-color: var(--gold); color: var(--gold); }

/* ══════════════════════════════════════════
   BANNER
══════════════════════════════════════════ */
.crs-banner {
  background: var(--gold);
  padding: 80px 48px; text-align: center;
}
.crs-banner-label {
  display: block;
  font-family: var(--sans); font-size: .55rem; font-weight: 700;
  letter-spacing: .28em; text-transform: uppercase; color: var(--navy2);
  opacity: .6; margin-bottom: 18px;
}
.crs-banner-title { font-family: var(--serif); font-size: clamp(1.8rem, 3.5vw, 2.8rem);
  font-weight: 300; color: var(--navy2); line-height: 1.2;
}
.crs-banner-title em { font-style: italic; }
/* Copy explicativo del video */
.crs-banner-copy {
  max-width: 760px; margin: 24px auto 0;
  font-family: var(--sans); font-size: .92rem; font-weight: 300;
  line-height: 1.8; color: var(--navy2);
}
.crs-banner-copy strong { font-weight: 600; }
/* Video responsivo 16:9 */
.crs-banner-video {
  max-width: 880px; margin: 44px auto 0;
}
.crs-video-frame {
  position: relative; width: 100%;
  padding-bottom: 56.25%; /* 16:9 */
  height: 0; overflow: hidden;
  background: var(--navy2);
  box-shadow: 0 20px 60px rgba(11,17,33,.3);
}
.crs-video-frame iframe {
  position: absolute; inset: 0;
  width: 100%; height: 100%; border: 0;
}

/* ══════════════════════════════════════════
   FEATURES
══════════════════════════════════════════ */
/* ── Subtitle claro para fondos oscuros ── */
.crs-subtitle--light { color: rgba(255,255,255,.7); }

/* ── Tarjetas de actividades por ciudad ── */
.crs-activities {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px;
  max-width: 1200px; margin: 0 auto;
}
.crs-activity {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(201,169,110,.14);
  overflow: hidden;
  display: flex; flex-direction: column;
  transition: transform .3s, box-shadow .3s, border-color .3s;
}
.crs-activity:hover {
  transform: translateY(-4px);
  border-color: rgba(201,169,110,.4);
  box-shadow: 0 16px 44px rgba(0,0,0,.35);
}
.crs-activity-img {
  height: 230px;
  background: var(--navy) center/cover no-repeat;
  transition: transform .6s var(--ease);
}
.crs-activity:hover .crs-activity-img { transform: scale(1.05); }
.crs-activity-body {
  padding: 28px 28px 30px;
  display: flex; flex-direction: column; flex: 1;
}
.crs-activity-tag {
  display: inline-block; width: fit-content;
  font-family: var(--sans); font-size: .5rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; color: var(--gold);
  border: 1px solid rgba(201,169,110,.35); padding: 4px 10px;
  margin-bottom: 14px;
}
.crs-activity-title {
  font-family: var(--serif); font-size: 1.6rem; font-weight: 400;
  color: var(--white); margin-bottom: 12px; line-height: 1.15;
}
.crs-activity-text {
  font-family: var(--sans); font-size: .78rem; font-weight: 300;
  line-height: 1.8; color: var(--mid); margin-bottom: 22px; flex: 1;
}
.crs-activity-link {
  font-family: var(--sans); font-size: .58rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; color: var(--gold);
  border-bottom: 1px solid rgba(201,169,110,.3); padding-bottom: 4px;
  width: fit-content;
  transition: border-color .2s, color .2s;
}
.crs-activity-link:hover { border-color: var(--gold); color: #d8bd8a; }
.crs-features-cta { text-align: center; margin-top: 56px; }

/* ══════════════════════════════════════════
   TESTIMONIALS
══════════════════════════════════════════ */
.crs-testimonials {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
  max-width: 1200px; margin: 0 auto;
}
.crs-testi {
  background: rgba(255,255,255,.03); padding: 48px 40px;
  border-top: 1px solid rgba(201,169,110,.15);
}
.crs-testi-stars { color: var(--gold); font-size: 1rem; margin-bottom: 20px; }
.crs-testi-text {
  font-family: var(--serif); font-size: 1.05rem; font-style: italic;
  font-weight: 300; line-height: 1.65; color: rgba(255,255,255,.8);
  margin-bottom: 24px;
}
.crs-testi-author {
  font-family: var(--sans); font-size: .65rem; font-weight: 600;
  letter-spacing: .14em; text-transform: uppercase; color: var(--white);
}
.crs-testi-city {
  font-family: var(--sans); font-size: .6rem; font-weight: 400;
  color: var(--mid); margin-top: 4px;
}
.crs-reviews-cta { text-align: center; margin-top: 48px; }
.crs-ta-widget { max-width: 1100px; margin: 0 auto 40px; }
.crs-ta-widget:empty { display: none; margin: 0; }

/* ══════════════════════════════════════════
   BOOKING
══════════════════════════════════════════ */
.crs-booking-outer { max-width: 900px; margin: 0 auto; }
.crs-booking-tabs {
  display: flex; border-bottom: 1px solid rgba(27,43,75,.15);
  margin-bottom: 40px;
}
.crs-booking-tab {
  padding: 14px 28px; border: none; background: none; cursor: pointer;
  font-family: var(--sans); font-size: .6rem; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase; color: var(--mid);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color .2s, border-color .2s;
}
.crs-booking-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.crs-booking-tab:hover { color: var(--navy2); }
.crs-booking-form {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
  margin-bottom: 24px;
}
.crs-bf-field { padding: 20px; background: var(--cream); }
.crs-bf-label {
  display: block; font-family: var(--sans); font-size: .5rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 8px;
}
.crs-bf-input {
  width: 100%; border: none; background: none; outline: none;
  font-family: var(--sans); font-size: .8rem; font-weight: 300;
  color: var(--navy2); padding: 0;
}
.crs-bf-submit {
  display: block; width: 100%;
  padding: 18px; background: var(--navy2); border: none; cursor: pointer;
  font-family: var(--sans); font-size: .65rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase; color: var(--white);
  transition: background .2s;
}
.crs-bf-submit:hover { background: var(--navy); }
.crs-mybooking { padding: 40px; background: var(--cream); text-align: center; }
.crs-mybooking h3 {
  font-family: var(--serif); font-size: 1.6rem; font-weight: 300;
  color: var(--navy2); margin-bottom: 10px;
}
.crs-mybooking p {
  font-family: var(--sans); font-size: .75rem; color: var(--mid);
  margin-bottom: 28px;
}
.crs-mybooking-form { display: flex; max-width: 440px; margin: 0 auto; }
.crs-mybooking-input {
  flex: 1; padding: 14px 18px; border: 1px solid rgba(27,43,75,.2);
  font-family: var(--sans); font-size: .8rem; outline: none; color: var(--navy2);
}
.crs-mybooking-btn {
  padding: 14px 24px; background: var(--navy2); border: none; cursor: pointer;
  font-family: var(--sans); font-size: .6rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; color: var(--white);
}

/* ══════════════════════════════════════════
   FOOTER
══════════════════════════════════════════ */
#crs-footer {
  background: #070D1A; padding: 80px 48px 0;
  border-top: 1px solid rgba(201,169,110,.12);
}
.crs-footer-grid {
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px;
  max-width: 1200px; margin: 0 auto; padding-bottom: 64px;
}
.crs-footer-logo {
  display: flex; align-items: center; gap: 10px;
  font-family: var(--serif); font-size: 1.1rem; font-weight: 300;
  color: var(--white); margin-bottom: 18px;
}
.crs-footer-tagline {
  font-family: var(--sans); font-size: .72rem; font-weight: 300;
  line-height: 1.8; color: var(--mid-on-dark); margin-bottom: 28px;
}
.crs-footer-social { display: flex; gap: 14px; }
.crs-footer-social a {
  width: 36px; height: 36px; border: 1px solid rgba(201,169,110,.25);
  display: flex; align-items: center; justify-content: center;
  transition: border-color .2s;
}
.crs-footer-social a:hover { border-color: var(--gold); }
.crs-footer-social svg {
  width: 14px; height: 14px; stroke: var(--mid-on-dark); fill: none; stroke-width: 1.5;
  transition: stroke .2s;
}
.crs-footer-social a:hover svg { stroke: var(--gold); }
.crs-footer-heading {
  font-family: var(--sans); font-size: .55rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase; color: var(--gold);
  margin-bottom: 24px;
}
.crs-footer-links { list-style: none; }
.crs-footer-links li { margin-bottom: 12px; }
.crs-footer-links a {
  font-family: var(--sans); font-size: .72rem; font-weight: 300;
  color: var(--mid-on-dark); transition: color .2s;
}
.crs-footer-links a:hover { color: var(--white); }
.crs-footer-bottom {
  max-width: 1200px; margin: 0 auto;
  display: flex; flex-wrap: wrap; justify-content: space-between; align-items: center;
  padding: 24px 0; border-top: 1px solid rgba(255,255,255,.06);
}
.crs-footer-copy {
  font-family: var(--sans); font-size: .65rem; font-weight: 300; color: var(--mid-on-dark);
}
.crs-footer-legal { display: flex; gap: 28px; }
.crs-footer-legal a {
  font-family: var(--sans); font-size: .6rem; font-weight: 400;
  color: var(--mid-on-dark); transition: color .2s;
}
.crs-footer-legal a:hover { color: var(--white); }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width: 1024px) {
  .crs-catalog-grid,
  .crs-activities, .crs-testimonials { grid-template-columns: 1fr 1fr; }
  .crs-featured { grid-template-columns: 1fr; }
  .crs-feat-gallery { min-height: 340px; }
  .crs-feat-info { padding: 48px 36px; }
  .crs-feat-strip { grid-template-columns: repeat(3,1fr); }
  .crs-steps { gap: 32px; }
  .crs-footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 768px) {
  #crs-nav {
    padding: 12px 20px;
    justify-content: space-between;
  }
  /* Ocultar links y CTA inline en movil */
  .crs-nav-links, .crs-nav-cta { display: none; }
  /* Logo centrado: empujarlo al centro con el toggle a la derecha */
  .crs-logo { min-width: 0; flex: 1; justify-content: center; padding-left: 36px; }
  .crs-logo-img { height: 32px; }
  /* Mostrar boton hamburguesa con margen del logo */
  .crs-nav-toggle { display: flex; margin-left: 12px; }
  .crs-hero-content { padding: 100px 20px 60px; text-align: center; align-items: center; }
  .crs-hero-search-label { align-self: center; }
  /* Tablet: 2 columnas */
  .crs-hero-search .rf-sgrid { grid-template-columns: 1fr 1fr !important; gap: 14px !important; }
  .crs-hero-search .rf-scard { padding: 20px 18px; }
  .crs-hero-search .rf-label { font-size: .6rem !important; }
  .crs-hero-search .rf-input,
  .crs-hero-search .rf-guests-trigger { font-size: 16px !important; padding: 12px 14px !important; }
  .crs-searchbar { flex-direction: column; }
  .crs-sb-field { border-right: none; border-bottom: 1px solid rgba(201,169,110,.15); }
  .crs-section { padding: 64px 24px; }
  .crs-countries { grid-template-columns: 1fr; gap: 14px; }
  /* Cards de pais en movil: texto centrado, boton siempre visible */
  .crs-country { aspect-ratio: 16/10; }
  .crs-country-overlay {
    padding: 28px 24px; align-items: center; text-align: center;
    background: linear-gradient(to top, rgba(11,17,33,.9) 0%, rgba(11,17,33,.35) 70%);
  }
  .crs-country-name { font-size: 2.1rem; }
  .crs-country-btn { opacity: 1; transform: none; }
  .crs-catalog-grid,
  .crs-activities, .crs-testimonials { grid-template-columns: 1fr; }
  .crs-feat-strip { grid-template-columns: 1fr; }
  .crs-footer-grid { grid-template-columns: 1fr; gap: 32px; }
  .crs-footer-bottom { flex-direction: column; gap: 16px; text-align: center; }
  .crs-booking-form { grid-template-columns: 1fr; }
  #crs-footer { padding: 56px 24px 0; }
  /* Banner + video en movil */
  .crs-banner { padding: 56px 24px; }
  .crs-banner-copy { font-size: .85rem; }
  .crs-banner-video { margin-top: 32px; }
  /* Proceso: vertical (1 columna) y centrado en movil */
  .crs-steps { grid-template-columns: 1fr !important; gap: 40px; }
  .crs-steps-section { padding: 56px 24px; }
  .crs-step { text-align: center; align-items: center; }
  .crs-step-text { max-width: 320px; }
  /* Cards de hospedaje: footer apilado para que quepan los botones */
  .crs-prop-footer { flex-direction: column; align-items: flex-start; gap: 14px; }
  .crs-prop-btns { width: 100%; }
  .crs-prop-link { flex: 1; text-align: center; }
}
/* Telefonos pequenos: una sola columna, todo apilado */
@media (max-width: 560px) {
  .crs-hero-content { padding: 90px 16px 48px; }
  .crs-hero-title { font-size: clamp(2rem, 9vw, 2.8rem) !important; }
  .crs-hero-search .rf-sgrid { grid-template-columns: 1fr !important; gap: 12px !important; }
  .crs-hero-search .rf-scard { padding: 18px 16px; }
  .crs-hero-search .rf-pais-row { flex-direction: column; }
  .crs-hero-search .rf-pais-btn { border-right: none !important; border-bottom: 1px solid rgba(201,169,110,.2); }
  .crs-hero-search .rf-pais-btn:last-child { border-bottom: none; }
  /* Inputs full width, texto legible (16px evita zoom en iOS) */
  .crs-hero-search .rf-input,
  .crs-hero-search .rf-guests-trigger { font-size: 16px !important; }
  .crs-hero-search .rf-label { font-size: .62rem !important; letter-spacing: .12em !important; }
  .crs-hero-search .rf-btn-g { font-size: .72rem !important; letter-spacing: .12em !important; }
}

/* ══════════════════════════════════════════
   PAGINAS INTERNAS (hospedajes, alojamiento, reservar)
══════════════════════════════════════════ */
body.crs-inner {
  background: var(--navy2, #0F1C38);  /* mismo color que el hero, evita franja crema */
  color: var(--navy2, #0F1C38);
  padding-top: 64px;   /* = altura real del nav en inner pages */
  overflow-x: hidden;
}
/* inner-wrap transparente: cada seccion define su fondo. Evita franja crema bajo el nav */
body.crs-inner .crs-inner-wrap { background: transparent; }
/* Nav siempre oscuro y mas compacto en internas */
body.crs-inner #crs-nav {
  background: rgba(11,17,33,.97) !important;
  padding: 12px 48px !important;
}
/* Limpiar todos los wrappers de Blocksy */
body.crs-inner .ct-container,
body.crs-inner .ct-main-content,
body.crs-inner .entry-content,
body.crs-inner .site-main,
body.crs-inner #primary,
body.crs-inner #content,
body.crs-inner .wp-site-blocks {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  background: var(--cream, #F8F5F0) !important;
  width: 100% !important;
}
/* Nav link activo */
.crs-nav-active {
  color: var(--gold, #C9A96E) !important;
  border-bottom: 1px solid rgba(201,169,110,.5);
  padding-bottom: 2px;
}
@media (max-width: 768px) {
  body.crs-inner { padding-top: 56px !important; overflow-x: hidden; }
  body.crs-inner #crs-nav {
    height: 56px !important;
    padding: 0 16px !important;
  }
  /* Ensure all Blocksy wrappers don't add space on mobile */
  body.crs-inner .ct-container,
  body.crs-inner .ct-main-content,
  body.crs-inner #primary,
  body.crs-inner main {
    padding: 0 !important;
    margin: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
  }
}

/* ══════════════════════════════════════════════════════════
   PAGINA NOSOTROS
══════════════════════════════════════════════════════════ */
.crs-eyebrow--gold { color: var(--gold, #C9A96E); }
.crs-divider--center { margin-left: auto; margin-right: auto; }

/* ── Hero ── */
.crs-nos-hero {
  background: var(--navy2, #0F1C38);
  padding: 72px 40px 72px;
  text-align: center;
}
.crs-nos-hero-inner { max-width: 760px; margin: 0 auto; }
.crs-nos-hero-title {
  font-family: var(--serif);
  font-size: clamp(2.4rem, 5vw, 3.6rem);
  font-weight: 300;
  color: #fff;
  line-height: 1.1;
  margin: 16px 0 0;
}
.crs-nos-hero-sub {
  font-family: var(--sans);
  font-size: .95rem;
  font-weight: 300;
  line-height: 1.8;
  color: rgba(255,255,255,.7);
  max-width: 560px;
  margin: 22px auto 0;
}

/* ── Historia ── */
.crs-nos-historia {
  max-width: 1140px;
  margin: 0 auto;
  padding: 80px 40px;
}
.crs-nos-historia-head {
  text-align: center;
  margin-bottom: 56px;
}
.crs-nos-h2 {
  font-family: var(--serif);
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 300;
  color: var(--navy2, #0F1C38);
  line-height: 1.15;
  margin-top: 12px;
}
.crs-nos-h2 strong { font-weight: 600; color: var(--gold, #C9A96E); }
.crs-nos-historia-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 56px;
  align-items: start;
}
.crs-nos-historia-img {
  position: sticky;
  top: 90px;
}
.crs-nos-historia-img img {
  width: 100%;
  height: auto;
  display: block;
  box-shadow: 0 16px 50px rgba(15,28,56,.18);
}
.crs-nos-img-fallback {
  aspect-ratio: 4/5;
  background: linear-gradient(135deg, var(--navy), var(--navy2));
}
.crs-nos-h3 {
  font-family: var(--sans);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold, #C9A96E);
  margin-bottom: 18px;
}
.crs-nos-historia-text p {
  font-family: var(--sans);
  font-size: .92rem;
  font-weight: 300;
  line-height: 1.9;
  color: #4a5468;
  margin-bottom: 18px;
}

/* ── Que ofrecemos ── */
.crs-nos-ofrecemos {
  background: var(--cream, #F8F5F0);
  padding: 80px 40px;
  border-top: 1px solid rgba(201,169,110,.15);
}
.crs-nos-ofrecemos-grid {
  max-width: 1140px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.crs-nos-h2-gold {
  font-family: var(--serif);
  font-size: clamp(2rem, 4.5vw, 3rem);
  font-weight: 300;
  color: var(--navy2, #0F1C38);
  line-height: 1.05;
  margin-bottom: 24px;
}
.crs-nos-ofrecemos-text p {
  font-family: var(--sans);
  font-size: .92rem;
  font-weight: 300;
  line-height: 1.9;
  color: #4a5468;
  margin-bottom: 18px;
}
.crs-nos-ofrecemos-imgs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.crs-nos-oimg {
  aspect-ratio: 1;
  background: var(--navy) center/cover no-repeat;
}

/* ── Video aereo ── */
.crs-nos-video {
  max-width: 1000px;
  margin: 0 auto;
  padding: 80px 40px;
  text-align: center;
}
.crs-nos-video-eyebrow {
  font-family: var(--sans);
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--navy2, #0F1C38);
  margin-bottom: 6px;
}
.crs-nos-video-loc {
  font-family: var(--sans);
  font-size: .68rem;
  font-weight: 400;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gold, #C9A96E);
  margin-bottom: 32px;
}
.crs-nos-video-frame {
  position: relative;
  width: 100%;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  background: var(--navy2);
  box-shadow: 0 20px 60px rgba(15,28,56,.25);
}
.crs-nos-video-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

/* ── Descubre coleccion ── */
.crs-nos-coleccion {
  background: var(--cream, #F8F5F0);
  padding: 80px 40px 90px;
}
.crs-nos-ciudades {
  max-width: 1200px;
  margin: 48px auto 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.crs-nos-ciudad {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  display: block;
}
.crs-nos-ciudad-img {
  position: absolute;
  inset: 0;
  background: var(--navy) center/cover no-repeat;
  transition: transform .6s var(--ease);
}
.crs-nos-ciudad:hover .crs-nos-ciudad-img { transform: scale(1.06); }
.crs-nos-ciudad-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 32px;
  text-align: center;
  background: linear-gradient(to top, rgba(11,17,33,.85) 0%, rgba(11,17,33,.1) 60%);
}
.crs-nos-ciudad-name {
  font-family: var(--serif);
  font-size: 2rem;
  font-weight: 300;
  color: #fff;
  margin-bottom: 6px;
}
.crs-nos-ciudad-count {
  font-family: var(--sans);
  font-size: .62rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--gold, #C9A96E);
}

/* Boton navy */
.crs-btn--navy {
  display: inline-block;
  font-family: var(--sans);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: 14px 32px;
  background: var(--navy2, #0F1C38);
  color: #fff;
  transition: background .2s;
}
.crs-btn--navy:hover { background: var(--gold, #C9A96E); color: var(--navy2, #0F1C38); }

/* ── Responsive Nosotros ── */
@media (max-width: 900px) {
  .crs-nos-historia-grid,
  .crs-nos-ofrecemos-grid { grid-template-columns: 1fr; gap: 40px; }
  .crs-nos-historia-img { position: static; max-width: 440px; margin: 0 auto; }
  .crs-nos-ciudades { grid-template-columns: 1fr; max-width: 440px; }
}
@media (max-width: 768px) {
  .crs-nos-hero { padding: 64px 20px 56px; }
  .crs-nos-historia,
  .crs-nos-ofrecemos,
  .crs-nos-video,
  .crs-nos-coleccion { padding: 56px 20px; }
  .crs-nos-ciudad { aspect-ratio: 16/10; }
}

/* ══════════════════════════════════════════════════════════
   BARRA DE RECONOCIMIENTOS (home, bajo el hero)
══════════════════════════════════════════════════════════ */
.crs-awards-bar {
  background: var(--navy2, #0F1C38);
  border-top: 1px solid rgba(201,169,110,.15);
  padding: 0;
}
.crs-awards-bar-inner {
  max-width: 1200px; margin: 0 auto;
  padding: 0 40px;
  display: flex; align-items: stretch;
  justify-content: center;
}
.crs-award-item {
  display: flex; align-items: center; gap: 12px;
  padding: 22px 32px;
  color: inherit; text-decoration: none;
  transition: background .2s;
  flex: 1; justify-content: center;
}
a.crs-award-item:hover { background: rgba(201,169,110,.06); }
.crs-award-star {
  font-size: 1.1rem; color: var(--gold, #C9A96E);
  flex-shrink: 0; line-height: 1;
}
.crs-award-item div {
  display: flex; flex-direction: column; gap: 2px;
}
.crs-award-item strong {
  font-family: var(--sans); font-size: .72rem; font-weight: 700;
  letter-spacing: .08em; color: #fff;
}
.crs-award-item span {
  font-family: var(--sans); font-size: .62rem; font-weight: 300;
  color: rgba(255,255,255,.55);
}
.crs-award-sep {
  width: 1px; background: rgba(201,169,110,.15);
  margin: 12px 0; flex-shrink: 0;
}
@media (max-width: 900px) {
  .crs-awards-bar-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    padding: 8px 16px;
    gap: 0;
  }
  .crs-award-item {
    padding: 16px 10px;
    flex: none;
    justify-content: center;
    text-align: left;
  }
  .crs-award-item div { align-items: flex-start; }
  .crs-award-sep { display: none; }
}
@media (max-width: 480px) {
  .crs-awards-bar-inner { grid-template-columns: 1fr; }
  .crs-award-item {
    border-bottom: 1px solid rgba(201,169,110,.1);
    justify-content: center;
  }
  .crs-award-item:last-child { border-bottom: none; }
}

/* ══════════════════════════════════════════════════════════
   NOSOTROS — secciones adicionales
══════════════════════════════════════════════════════════ */
.crs-title--dark { color: var(--navy2, #0F1C38); }

/* Awards en nosotros */
.crs-nos-awards {
  background: var(--navy2, #0F1C38);
  padding: 0;
}
.crs-nos-awards-inner {
  max-width: 1100px; margin: 0 auto;
  padding: 0 40px;
  display: flex; align-items: stretch; justify-content: center;
}
.crs-nos-award {
  display: flex; align-items: center; gap: 12px;
  padding: 24px 28px; flex: 1; justify-content: center;
}
.crs-nos-award-icon { font-size: 1rem; color: var(--gold, #C9A96E); }
.crs-nos-award-text {
  display: flex; flex-direction: column; gap: 2px;
}
.crs-nos-award-text strong {
  font-family: var(--sans); font-size: .72rem; font-weight: 700;
  color: #fff;
}
.crs-nos-award-text span {
  font-family: var(--sans); font-size: .6rem; color: rgba(255,255,255,.5);
}
.crs-nos-award-sep { width: 1px; background: rgba(201,169,110,.15); margin: 12px 0; }
/* Founders caption */
.crs-nos-founders-caption {
  padding: 16px; text-align: center;
  background: var(--navy2, #0F1C38);
  font-family: var(--sans);
}
.crs-nos-founders-caption {
  display: flex; justify-content: center; align-items: baseline; gap: 8px;
  font-size: .8rem; font-weight: 600; color: #fff; letter-spacing: .1em;
}
.crs-nos-founders-caption span {
  font-size: .6rem; font-weight: 300; color: var(--gold, #C9A96E);
  letter-spacing: .18em; text-transform: uppercase;
}

/* Timeline */
.crs-nos-timeline {
  background: var(--cream, #F8F5F0);
  padding: 80px 40px;
}
.crs-nos-timeline-inner { max-width: 840px; margin: 0 auto; }
.crs-nos-tl-items {
  position: relative; margin-top: 48px;
  padding-left: 48px;
}
.crs-nos-tl-items::before {
  content: '';
  position: absolute; left: 0; top: 8px; bottom: 8px;
  width: 1px; background: rgba(201,169,110,.3);
}
.crs-nos-tl-item {
  position: relative; margin-bottom: 48px;
}
.crs-nos-tl-item:last-child { margin-bottom: 0; }
.crs-nos-tl-year {
  position: absolute; left: -48px;
  width: 40px; text-align: right;
  font-family: var(--sans); font-size: .62rem; font-weight: 700;
  letter-spacing: .08em; color: var(--gold, #C9A96E);
  top: 4px;
}
.crs-nos-tl-dot {
  position: absolute; left: -52px; top: 3px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold, #C9A96E);
  border: 2px solid var(--cream, #F8F5F0);
  box-shadow: 0 0 0 1px var(--gold, #C9A96E);
}
.crs-nos-tl-content h4 {
  font-family: var(--serif); font-size: 1.15rem; font-weight: 400;
  color: var(--navy2, #0F1C38); margin-bottom: 8px;
}
.crs-nos-tl-content p {
  font-family: var(--sans); font-size: .85rem; font-weight: 300;
  line-height: 1.8; color: #5a6478;
}

/* Mundo / ciudades */
.crs-nos-mundo {
  background: var(--navy2, #0F1C38);
  padding: 80px 40px;
  text-align: center;
}
.crs-nos-mundo-inner { max-width: 900px; margin: 0 auto; }
.crs-nos-h2-light {
  font-family: var(--serif); font-size: clamp(1.8rem,4vw,2.6rem);
  font-weight: 300; color: #fff; margin: 14px 0 20px;
}
.crs-nos-mundo-sub {
  font-family: var(--sans); font-size: .88rem; font-weight: 300;
  line-height: 1.8; color: rgba(255,255,255,.6);
  max-width: 560px; margin: 0 auto 36px;
}
.crs-nos-ciudades-globo {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 10px;
  margin-bottom: 40px;
}
.crs-nos-ciudad-tag {
  font-family: var(--sans); font-size: .65rem; font-weight: 500;
  letter-spacing: .12em; text-transform: uppercase;
  color: rgba(255,255,255,.8);
  border: 1px solid rgba(201,169,110,.3);
  padding: 7px 16px;
  transition: border-color .2s, color .2s;
}
.crs-nos-ciudad-tag:hover { border-color: var(--gold,#C9A96E); color: var(--gold,#C9A96E); }
.crs-nos-mundo-cierre {
  font-family: var(--serif); font-size: 1.1rem; font-weight: 300;
  color: rgba(255,255,255,.75); line-height: 1.7; margin-bottom: 12px;
}
.crs-nos-mundo-firma {
  font-family: var(--sans); font-size: .68rem; font-weight: 400;
  letter-spacing: .18em; color: var(--gold,#C9A96E); text-transform: uppercase;
}

/* Ofrecemos pills */
.crs-nos-ofrecemos-pills {
  display: flex; flex-wrap: wrap; gap: 8px; margin-top: 20px;
}
.crs-nos-ofrecemos-pills span {
  font-family: var(--sans); font-size: .6rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--navy2,#0F1C38);
  border: 1px solid rgba(27,43,75,.2);
  padding: 6px 14px;
}

/* ══════════════════════════════════════════════════════════
   PAGINA CONTACTO
══════════════════════════════════════════════════════════ */

/* Hero contacto */
.crs-con-hero {
  background: var(--navy2, #0F1C38);
  padding: 72px 40px 72px; text-align: center;
}
.crs-con-hero-inner { max-width: 680px; margin: 0 auto; }
.crs-con-hero-title {
  font-family: var(--serif);
  font-size: clamp(2.4rem,5vw,3.6rem); font-weight: 300; color: #fff;
  margin: 16px 0 0; line-height: 1.1;
}
.crs-con-hero-sub {
  font-family: var(--sans); font-size: .92rem; font-weight: 300;
  line-height: 1.85; color: rgba(255,255,255,.65);
  max-width: 560px; margin: 20px auto 0;
}

/* Canales */
.crs-con-canales {
  background: var(--cream, #F8F5F0);
  padding: 72px 40px;
}
.crs-con-canales-inner {
  max-width: 1080px; margin: 0 auto;
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
}
.crs-con-destino {
  background: #fff; padding: 40px;
  border: 1px solid rgba(201,169,110,.18);
  box-shadow: 0 2px 16px rgba(27,43,75,.06);
}
.crs-con-destino-header { margin-bottom: 28px; }
.crs-con-destino-tag {
  display: inline-block;
  font-family: var(--sans); font-size: .55rem; font-weight: 700;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--gold,#C9A96E);
  border: 1px solid rgba(201,169,110,.4); padding: 4px 12px;
  margin-bottom: 12px;
}
.crs-con-destino-tag--es { color: #5b7fa6; border-color: rgba(91,127,166,.4); }
.crs-con-destino-name {
  font-family: var(--serif); font-size: 1.4rem; font-weight: 400;
  color: var(--navy2,#0F1C38); margin-bottom: 6px;
}
.crs-con-destino-addr {
  font-family: var(--sans); font-size: .78rem; font-weight: 300;
  line-height: 1.6; color: #6b7a99;
}
.crs-con-items { display: flex; flex-direction: column; gap: 10px; }
.crs-con-item {
  display: flex; align-items: center; gap: 16px;
  padding: 16px 18px;
  border: 1px solid rgba(201,169,110,.18);
  background: var(--cream,#F8F5F0);
  transition: border-color .2s, background .2s, transform .2s;
  text-decoration: none; color: inherit;
}
.crs-con-item:hover {
  border-color: rgba(201,169,110,.5);
  background: #fff; transform: translateX(4px);
}
.crs-con-item--wa { border-color: rgba(37,211,102,.25); }
.crs-con-item--wa:hover { border-color: rgba(37,211,102,.6); }
.crs-con-item--wa .crs-con-item-icon { color: #25D366; }
.crs-con-item-icon {
  width: 40px; height: 40px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(201,169,110,.08);
  color: var(--gold,#C9A96E);
}
.crs-con-item--wa .crs-con-item-icon { background: rgba(37,211,102,.08); }
.crs-con-item-text { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.crs-con-item-label {
  font-family: var(--sans); font-size: .62rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: #8a96aa;
}
.crs-con-item-val {
  font-family: var(--sans); font-size: .9rem; font-weight: 500;
  color: var(--navy2,#0F1C38);
  word-break: break-word;
  overflow-wrap: anywhere;
}
.crs-con-item-arrow {
  font-size: .9rem; color: var(--gold,#C9A96E); flex-shrink: 0;
}

/* Proceso */
.crs-con-proceso { background: var(--navy2,#0F1C38); padding: 80px 40px; }
.crs-con-proceso-inner { max-width: 1080px; margin: 0 auto; }
.crs-con-proceso .crs-title { color: #fff; }
.crs-con-proceso .crs-eyebrow { color: var(--gold,#C9A96E); }
.crs-con-steps {
  display: grid; grid-template-columns: repeat(4,1fr); gap: 32px;
  margin-top: 48px;
}
.crs-con-step { text-align: center; }
.crs-con-step-num {
  width: 60px; height: 60px; border-radius: 50%;
  border: 2px solid var(--gold,#C9A96E);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif); font-size: 1.6rem; font-weight: 400;
  color: var(--gold,#C9A96E); margin: 0 auto 20px;
}
.crs-con-step h3 {
  font-family: var(--serif); font-size: 1.1rem; font-weight: 400;
  color: #fff; margin-bottom: 10px; line-height: 1.3;
}
.crs-con-step p {
  font-family: var(--sans); font-size: .78rem; font-weight: 300;
  line-height: 1.8; color: rgba(255,255,255,.55);
}

/* Info importante */
.crs-con-info { background: var(--cream,#F8F5F0); padding: 80px 40px; }
.crs-con-info-inner { max-width: 1080px; margin: 0 auto; }
.crs-con-info-grid {
  display: grid; grid-template-columns: repeat(3,1fr); gap: 24px;
  margin-top: 48px;
}
.crs-con-info-card {
  background: #fff; padding: 32px 28px;
  border: 1px solid rgba(201,169,110,.15);
  transition: box-shadow .3s, transform .2s;
}
.crs-con-info-card:hover {
  box-shadow: 0 8px 32px rgba(27,43,75,.1);
  transform: translateY(-3px);
}
.crs-con-info-icon { font-size: 1.8rem; margin-bottom: 14px; display: block; }
.crs-con-info-card h3 {
  font-family: var(--serif); font-size: 1.1rem; font-weight: 400;
  color: var(--navy2,#0F1C38); margin-bottom: 10px;
}
.crs-con-info-card p {
  font-family: var(--sans); font-size: .8rem; font-weight: 300;
  line-height: 1.8; color: #6b7a99;
}
.crs-con-info-card strong { font-weight: 600; color: var(--navy2,#0F1C38); }

/* CTA final */
.crs-con-cta {
  background: var(--gold,#C9A96E);
  padding: 80px 40px; text-align: center;
}
.crs-con-cta-inner { max-width: 680px; margin: 0 auto; }
.crs-con-cta-title {
  font-family: var(--serif); font-size: clamp(1.6rem,3.5vw,2.4rem);
  font-weight: 300; color: var(--navy2,#0F1C38); margin-bottom: 12px;
}
.crs-con-cta-sub {
  font-family: var(--sans); font-size: .82rem; font-weight: 300;
  color: rgba(15,28,56,.6); margin-bottom: 36px;
}
.crs-con-cta-btns { display: flex; justify-content: center; gap: 16px; flex-wrap: wrap; }
.crs-btn--gold-large {
  font-family: var(--sans); font-size: .65rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  padding: 16px 36px;
  background: var(--navy2,#0F1C38); color: #fff;
  transition: background .2s;
}
.crs-btn--gold-large:hover { background: #0a1225; }
.crs-btn--outline-light {
  font-family: var(--sans); font-size: .65rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  padding: 16px 36px;
  border: 2px solid var(--navy2,#0F1C38); color: var(--navy2,#0F1C38);
  background: transparent; transition: background .2s, color .2s;
}
.crs-btn--outline-light:hover { background: var(--navy2,#0F1C38); color: #fff; }

/* ── Responsive nosotros/contacto ── */
@media (max-width: 900px) {
  .crs-nos-awards-inner { flex-wrap: wrap; padding: 0 20px; }
  .crs-nos-award { flex: 0 0 50%; padding: 20px; }
  .crs-nos-award-sep { display: none; }
  .crs-nos-timeline { padding: 56px 20px; }
  .crs-con-canales-inner { grid-template-columns: 1fr; }
  .crs-con-steps { grid-template-columns: 1fr 1fr; }
  .crs-con-info-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .crs-con-hero, .crs-con-canales, .crs-con-proceso,
  .crs-con-info, .crs-con-cta,
  .crs-nos-timeline, .crs-nos-mundo { padding: 56px 20px; }
  .crs-con-steps { grid-template-columns: 1fr; gap: 32px; }
  .crs-con-info-grid { grid-template-columns: 1fr; }
  .crs-nos-tl-items { padding-left: 40px; }
  /* Contacto: cards y items mas compactos en movil, sin desborde */
  .crs-con-destino { padding: 28px 20px; }
  .crs-con-item { padding: 14px; gap: 12px; }
  .crs-con-item-icon { width: 36px; height: 36px; }
  .crs-con-item-val { font-size: .82rem; }
  .crs-con-item-label { font-size: .56rem; }
  .crs-con-hero-title { font-size: clamp(2rem, 9vw, 2.8rem); }
  .crs-con-cta-btns { flex-direction: column; }
  .crs-con-cta-btns .crs-btn--gold-large,
  .crs-con-cta-btns .crs-btn--outline-light { width: 100%; text-align: center; }
}

/* Fondos explicitos para paginas internas (inner-wrap es transparente) */
body.crs-inner .rf-app,
body.crs-inner .rf-hosp-outer,
body.crs-inner .rf-det-outer { background: var(--cream, #F8F5F0); min-height: 60vh; }

/* ══════════════════════════════════════════════════════════
   PAGINA TERMINOS Y CONDICIONES
══════════════════════════════════════════════════════════ */
.crs-terms {
  background: var(--cream, #F8F5F0);
  padding: 72px 40px 90px;
}
.crs-terms-inner { max-width: 800px; margin: 0 auto; }
.crs-terms-block {
  background: #fff;
  border: 1px solid rgba(201,169,110,.15);
  padding: 36px 40px;
  margin-bottom: 20px;
}
.crs-terms-block h2 {
  font-family: var(--serif);
  font-size: 1.35rem; font-weight: 400;
  color: var(--navy2,#0F1C38);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(201,169,110,.25);
}
.crs-terms-block p, .crs-terms-block li {
  font-family: var(--sans);
  font-size: .86rem; font-weight: 300;
  line-height: 1.85; color: #4a5468;
  margin-bottom: 12px;
}
.crs-terms-block ul { padding-left: 20px; }
.crs-terms-block li { margin-bottom: 10px; }
.crs-terms-block strong { font-weight: 600; color: var(--navy2,#0F1C38); }
.crs-terms-block a { color: var(--gold,#C9A96E); text-decoration: underline; }
.crs-terms-legal {
  background: var(--navy2,#0F1C38);
  border-color: rgba(201,169,110,.3);
}
.crs-terms-legal h2 { color: #fff; }
.crs-terms-legal p { color: rgba(255,255,255,.65); }
.crs-terms-legal strong { color: var(--gold,#C9A96E); }
@media (max-width: 768px) {
  .crs-terms { padding: 48px 20px 64px; }
  .crs-terms-block { padding: 24px 20px; }
}

/* Credito del estudio en el footer */
.crs-footer-credit {
  flex-basis: 100%;
  width: 100%;
  text-align: center;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.05);
  font-family: var(--sans);
  font-size: .62rem;
  font-weight: 300;
  letter-spacing: .08em;
  color: rgba(255,255,255,.5);
}
.crs-footer-credit a {
  color: rgba(201,169,110,.7);
  text-decoration: none;
  transition: color .2s;
}
.crs-footer-credit a:hover { color: var(--gold, #C9A96E); }
