:root{
  --bg: #0c1210;
  --surface: #0f1613;
  --surface-2: #121c18;
  --card: rgba(255,255,255,.06);
  --card-2: rgba(255,255,255,.08);
  --stroke: rgba(255,255,255,.12);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.72);

  --sage: #8fa78b;
  --olive: #566b45;
  --sand: #d8c3a5;
  --terracotta: #b46a4a;
  --deep-blue: #1e4a66;

  --shadow: 0 18px 50px rgba(0,0,0,.35);
  --shadow-soft: 0 10px 30px rgba(0,0,0,.25);
  --r-xl: 22px;
  --r-lg: 16px;
  --r-md: 12px;
  --r-sm: 10px;

  --serif: "Playfair Display", ui-serif, Georgia, serif;
  --sans: "Montserrat", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{ box-sizing: border-box; }
html{ scroll-behavior: smooth; }
body{
  margin: 0;
  font-family: var(--sans);
  color: var(--text);
  background:
    radial-gradient(900px 520px at 20% -10%, rgba(143,167,139,.22), transparent 70%),
    radial-gradient(900px 520px at 90% 10%, rgba(30,74,102,.18), transparent 70%),
    linear-gradient(180deg, #0b100e 0%, #070a09 60%, #050606 100%);
}

img{ max-width: 100%; display: block; }
a{ color: inherit; text-decoration: none; }
strong{ color: rgba(255,255,255,.98); font-weight: 700; }

.container{
  width: min(1120px, calc(100% - 48px));
  margin-inline: auto;
}

.skip-link{
  position: absolute;
  left: -999px;
  top: 10px;
  background: #fff;
  color: #000;
  padding: 10px 12px;
  border-radius: 10px;
  z-index: 9999;
}
.skip-link:focus{ left: 16px; }

.header{
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(10,14,12,.75);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.header__inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 0;
  gap: 14px;
}
.brand{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 220px;
}
.brand__mark{
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(143,167,139,.22), rgba(180,106,74,.16));
  border: 1px solid rgba(255,255,255,.10);
}
.brand__text{ display: grid; line-height: 1.05; }
.brand__title{
  margin-top: 1.5em; /* Adds 1.5 times the current font size of space below each paragraph */
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: .2px;
}
.brand__subtitle{ font-size: 12px; color: var(--muted); }

.nav{
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
}
.nav__link{
  font-size: 13px;
  color: rgba(255,255,255,.82);
  padding: 8px 10px;
  border-radius: 999px;
  transition: background .2s ease, color .2s ease;
}
.nav__link:hover{
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.95);
}

.header__actions{ display: flex; gap: 10px; align-items: center; }

.btn{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  border-radius: 999px;
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.92);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: .2px;
  box-shadow: 0 0 0 rgba(0,0,0,0);
  transition: transform .15s ease, background .2s ease, border-color .2s ease, box-shadow .2s ease;
  cursor: pointer;
}
.btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.07);
  border-color: rgba(255,255,255,.16);
  box-shadow: var(--shadow-soft);
}
.btn--primary{
  background: linear-gradient(135deg, rgba(143,167,139,.90), rgba(86,107,69,.92));
  border-color: rgba(255,255,255,.14);
  color: #07100c;
}
.btn--primary:hover{
  background: linear-gradient(135deg, rgba(143,167,139,1), rgba(180,106,74,.92));
}
.btn--ghost{
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.10);
}
.btn--lg{ padding: 13px 18px; font-size: 14px; }

.hero{
  position: relative;
  min-height: 78vh;
  display: grid;
  align-items: center;
  padding: 64px 0 46px;
  overflow: clip;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.hero__bg{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(120deg, rgba(30,74,102,.22), rgba(180,106,74,.18)),
    radial-gradient(1000px 650px at 20% 20%, rgba(143,167,139,.25), transparent 55%),
    url(/imgs/IMG_7888.jpg);
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.02);
  transform: scale(1.03);
}
.hero__shade{
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(5,7,6,.50) 0%, rgba(5,7,6,.78) 52%, rgba(5,7,6,.92) 100%),
    radial-gradient(900px 600px at 30% 20%, rgba(0,0,0,.22), transparent 60%);
}
.hero__content{
  position: relative;
  z-index: 2;
  padding: 10px 0;
}
.pill{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  color: rgba(255,255,255,.86);
  font-size: 13px;
  margin-bottom: 18px;
}
.pill__dot{
  width: 10px; height: 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--sage), var(--terracotta));
  box-shadow: 0 0 0 4px rgba(143,167,139,.18);
}
.hero__title{
  font-family: var(--serif);
  font-weight: 700;
  letter-spacing: .2px;
  font-size: clamp(38px, 5vw, 56px);
  line-height: 1.02;
  margin: 0 0 14px;
  max-width: 18ch;
}
.hero__subtitle{
  margin: 0 0 22px;
  max-width: 62ch;
  font-size: 16px;
  line-height: 1.6;
  color: rgba(255,255,255,.84);
}
.hero__cta{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 26px;
}
.trust{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  width: min(640px, 100%);
}
.trust__item{
  border-radius: var(--r-lg);
  padding: 14px 14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
}
.trust__kpi{
  font-weight: 800;
  letter-spacing: .2px;
  font-size: 16px;
  color: rgba(255,255,255,.96);
}
.trust__label{
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: rgba(255,255,255,.72);
}

.section{
  padding: 66px 0;
}
.section--sand{
  background:
    radial-gradient(900px 520px at 15% 0%, rgba(216,195,165,.10), transparent 55%),
    radial-gradient(900px 520px at 85% 15%, rgba(30,74,102,.10), transparent 58%),
    rgba(255,255,255,.02);
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.section--olive{
  background:
    radial-gradient(900px 520px at 10% 10%, rgba(143,167,139,.16), transparent 56%),
    radial-gradient(900px 520px at 90% 30%, rgba(180,106,74,.12), transparent 60%),
    linear-gradient(180deg, rgba(10,14,12,.92) 0%, rgba(7,9,8,.98) 100%);
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.section__head{
  display: grid;
  gap: 10px;
  margin-bottom: 22px;
}
.section__head--center{ text-align: center; justify-items: center; }
.section__title{
  margin: 0;
  font-family: var(--serif);
  letter-spacing: .2px;
  font-size: clamp(28px, 3.2vw, 40px);
  line-height: 1.1;
}
.section__title--light{ color: rgba(255,255,255,.96); }
.section__lead{
  margin: 0;
  max-width: 78ch;
  color: rgba(255,255,255,.80);
  line-height: 1.7;
}
.section__lead--light{ color: rgba(255,255,255,.78); }

.grid{ display: grid; gap: 16px; align-items: start; }
.grid--2{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid--3{ grid-template-columns: repeat(3, minmax(0, 1fr)); }

.card{
  border-radius: var(--r-xl);
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  padding: 18px 18px;
  box-shadow: 0 0 0 rgba(0,0,0,0);
}
.card--soft{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.08);
}
.card--path{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  box-shadow: var(--shadow-soft);
}
.card__title{
  margin: 0 0 10px;
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: .2px;
}
.card__text{ margin: 0; color: rgba(255,255,255,.80); line-height: 1.65; }

.muted{ color: rgba(255,255,255,.70); line-height: 1.65; }

.icon-list{
  list-style: none;
  padding: 0;
  margin: 0 0 12px;
  display: grid;
  gap: 10px;
}
.icon-list__item{
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: rgba(255,255,255,.84);
  line-height: 1.45;
}
.icon{
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.15);
  flex: 0 0 auto;
  position: relative;
  overflow: hidden;
}
.icon::before{
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(143,167,139,.35), rgba(30,74,102,.22));
  opacity: .85;
}
.icon--kite::after,
.icon--horse::after,
.icon--bike::after{
  content: "";
  position: absolute;
  inset: 5px;
  /*background: rgba(7,16,12,.85);*/
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
}
.icon--kite::after{
  background-image: url("/imgs/family_link_16dp_000000_FILL0_wght400_GRAD0_opsz20.svg");
}
.icon--horse::after{
  background-image: url("/imgs/horse-solid-full.svg");
}
.icon--bike::after{
  background-image: url("/imgs/person-hiking-solid-full.svg");
}

.carousel{
  border-radius: var(--r-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  overflow: hidden;
  position: relative;
  min-height: 320px;
}
.carousel__track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 86%;
  gap: 14px;
  padding: 16px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,.18) transparent;
}
.carousel__track::-webkit-scrollbar{ height: 10px; }
.carousel__track::-webkit-scrollbar-thumb{
  background: rgba(255,255,255,.18);
  border-radius: 999px;
}
.slide{
  margin: 0;
  scroll-snap-align: start;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  box-shadow: var(--shadow-soft);
}
.slide__img{
  height: 240px;
  background-size: cover;
  background-position: center;
  filter: saturate(1.06) contrast(1.02);
}
.slide__img--1{
  background-image:
    linear-gradient(120deg, rgba(30,74,102,.18), rgba(180,106,74,.12)),
    url("/imgs/Papalote.webp");
}
.slide__img--2{
  background-image:
    linear-gradient(120deg, rgba(143,167,139,.18), rgba(180,106,74,.12)),
    url("/imgs/Actividades_3.webp");
}
.slide__img--3{
  background-image:
    linear-gradient(120deg, rgba(30,74,102,.18), rgba(143,167,139,.12)),
    url("/imgs/Cima del Coronel.webp");
}
.slide__cap{
  padding: 12px 12px;
  font-size: 13px;
  color: rgba(255,255,255,.80);
}
.carousel__hint{
  position: absolute;
  right: 12px;
  top: 12px;
  font-size: 12px;
  color: rgba(255,255,255,.74);
  background: rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.12);
  padding: 6px 10px;
  border-radius: 999px;
}

.map{
  margin-top: 18px;
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: stretch;
  border-radius: var(--r-xl);
  border: 1px solid rgba(255,255,255,.10);
  overflow: hidden;
  background: rgba(255,255,255,.03);
}
.map__media{
  min-height: 320px;
  background:
    linear-gradient(135deg, rgba(216,195,165,.10), rgba(30,74,102,.10)),
    repeating-linear-gradient(45deg, rgba(255,255,255,.06) 0 12px, rgba(255,255,255,.03) 12px 24px);
  position: relative;
}
.map__media::after{
  content: "VISTA AEREA";
  position: absolute;
  left: 18px;
  bottom: 18px;
  font-size: 12px;
  letter-spacing: .24px;
  color: rgba(255,255,255,.70);
  padding: 8px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
}
.map__content{
  padding: 18px 18px;
  display: grid;
  gap: 10px;
  align-content: start;
}
.map__title{
  margin: 0;
  font-family: var(--serif);
  font-size: 22px;
}
.map__text{ margin: 0; color: rgba(255,255,255,.80); line-height: 1.65; }
.map__legend{ display: flex; gap: 8px; flex-wrap: wrap; }
.tag{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.82);
}
.tag::before{
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.22);
}
.tag--ok::before{ background: rgba(143,167,139,.95); }
.tag--hold::before{ background: rgba(216,195,165,.95); }
.tag--sold::before{ background: rgba(180,106,74,.95); }

.pricing{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: start;
}
.pricing__table{
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
}
.pricing__row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.08);
}
.pricing__row--head{
  border-top: none;
  background: rgba(143,167,139,.14);
}
.pricing__cell{
  padding: 14px 14px;
  font-size: 14px;
  color: rgba(255,255,255,.84);
  line-height: 1.45;
}
.pricing__row--head .pricing__cell{
  font-weight: 700;
  color: rgba(255,255,255,.92);
}
.pricing__row .pricing__cell:first-child{
  border-right: 1px solid rgba(255,255,255,.08);
}

.note{
  border-radius: var(--r-xl);
  background:
    radial-gradient(700px 420px at 20% 10%, rgba(216,195,165,.12), transparent 60%),
    rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
  padding: 18px 18px;
  box-shadow: var(--shadow-soft);
  display: grid;
  gap: 10px;
}
.note__title{ margin: 0; font-family: var(--serif); font-size: 22px; }
.note__text{ margin: 0; color: rgba(255,255,255,.80); line-height: 1.65; }
.note__fine{ margin: 0; color: rgba(255,255,255,.68); font-size: 12px; line-height: 1.5; }

.check{
  list-style: none;
  padding: 0;
  margin: 12px 0 16px;
  display: grid;
  gap: 10px;
  color: rgba(255,255,255,.82);
}
.check li{
  display: flex;
  gap: 10px;
  align-items: flex-start;
  line-height: 1.45;
}
.check li::before{
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 7px;
  margin-top: 2px;
  background: linear-gradient(135deg, rgba(143,167,139,.95), rgba(30,74,102,.45));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.22);
}

.contact{
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 16px;
  align-items: start;
}
.form{
  border-radius: var(--r-xl);
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.10);
  padding: 18px 18px;
}
.form__row{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.field{ display: grid; gap: 8px; margin-bottom: 12px; }
.field__label{ font-size: 13px; color: rgba(255,255,255,.78); font-weight: 600; }
.field__input{
  width: 100%;
  border-radius: 14px;
  padding: 12px 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.20);
  color: rgba(255,255,255,.92);
  outline: none;
  font-family: var(--sans);
}
.field__input::placeholder{ color: rgba(255,255,255,.48); }
.field__input:focus{
  border-color: rgba(143,167,139,.55);
  box-shadow: 0 0 0 4px rgba(143,167,139,.18);
}
.field__input--textarea{ resize: vertical; min-height: 118px; }
.form__actions{
  display: grid;
  gap: 10px;
  align-items: start;
}

.divider{
  height: 1px;
  background: rgba(255,255,255,.10);
  margin: 10px 0;
}

.footer{
  padding: 40px 0 70px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: rgba(0,0,0,.18);
}
.footer__inner{
  display: grid;
  grid-template-columns: 1.2fr .6fr .9fr;
  gap: 16px;
  align-items: start;
}
.brand--footer .brand__subtitle{ color: rgba(255,255,255,.66); }
.footer__link{
  display: inline-flex;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.80);
  margin-bottom: 10px;
}
.footer__link:hover{ background: rgba(255,255,255,.05); color: rgba(255,255,255,.92); }
.footer__fine{
  margin: 10px 0 0;
  color: rgba(255,255,255,.66);
  font-size: 12px;
  line-height: 1.6;
}

.wa-float{
  position: fixed;
  right: 16px;
  bottom: 16px;
  z-index: 60;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(143,167,139,.96), rgba(30,74,102,.60));
  color: #06100c;
  border: 1px solid rgba(255,255,255,.16);
  box-shadow: var(--shadow);
}
.wa-float:hover{ transform: translateY(-1px); }
.wa-float__icon{
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: rgba(0,0,0,.20);
  position: relative;
}
.wa-float__icon::after{
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 4px;
  background: rgba(255,255,255,.78);
  opacity: .9;
}
.wa-float__text{ font-weight: 800; letter-spacing: .2px; font-size: 13px; }

@media (max-width: 980px){
  .grid--3{ grid-template-columns: 1fr; }
  .map{ grid-template-columns: 1fr; }
  .pricing{ grid-template-columns: 1fr; }
  .contact{ grid-template-columns: 1fr; }
  .footer__inner{ grid-template-columns: 1fr; }
  .nav{ display: none; }
}

@media (max-width: 640px){
  .container{ width: min(1120px, calc(100% - 32px)); }
  .header__inner{ padding: 12px 0; }
  .brand{ min-width: unset; }
  .header__actions .btn--ghost{ display: none; }
  .trust{ grid-template-columns: 1fr; }
  .form__row{ grid-template-columns: 1fr; }
  .carousel__track{ grid-auto-columns: 92%; }
  .hero{ padding: 56px 0 40px; }
}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
  .btn, .wa-float{ transition: none; }
  .btn:hover, .wa-float:hover{ transform: none; }
}
