@font-face {
  font-family: "Geomanist";
  src: url("../fonts/Geomanist/Geomanist-Regular.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Geomanist";
  src: url("../fonts/Geomanist/Geomanist-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato/lato-regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Lato";
  src: url("../fonts/Lato/lato-bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --color-bg: #212222;
  --color-text: #ffffff;
  --color-accent: #ebffa5;
  --color-ink: #212222;
  --color-surface: rgba(255, 255, 255, 0);
  --color-border: rgba(235, 255, 165, 0.2);
  --radius-m: 16px;
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 32px;
  --space-5: 48px;
  --space-6: 56px;
  --gov-header-height: 64px;
  --font-scale: 1;
  --destination-cip-bg: #235c4e;
  --destination-cip-title-margin-top: 0;
  --destination-road-bg: none;
  --destination-road-bg-color: transparent;
}

#huatulco-main {
  --destination-cip-bg: #cacbf7;
  --destination-cip-title-margin-top: var(--space-2);
  --destination-road-bg: url("./png/huatulco/road-mobile.png");
  --destination-road-bg-color: #212222;
}

#ixtapa-main {
  --destination-cip-bg: #ff5c3b;
}

#cozumel-main {
  --destination-cip-bg: #efe7da;
}

#litibu-main {
  --destination-cip-bg: #953012;
}

/* Base */
*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text);
  text-align: left;
}

/* Layout */
.site-main {
  padding: calc(var(--gov-header-height) + var(--space-1)) var(--space-3)
    var(--space-5);
  font-family: "Lato", Arial, sans-serif;
}

.page-main {
  width: 100%;
}

.section {
  width: 100%;
}

.grid {
  display: grid;
  gap: var(--space-3);
}

.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-m);
  padding: var(--space-1);
}

.divisor-horizontal {
  height: 2px;
  width: 100%;
  background: #fff;
}

/* CIP */
.cip-grid {
  grid-template-columns: 1.2fr 2.8fr;
  gap: 0;
  border: 2px solid #ffffff;
}

.cip-grid > .card {
  display: flex;
  align-items: center;
  border-radius: 0;
}

.cip-grid > .card:last-child {
  justify-content: center;
  padding: 1px var(--space-2);
}

.cip-grid > .card:first-child {
  border-right: 2px solid #ffffff;
}

.cip-detail {
  background: var(--destination-cip-bg);
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: var(--space-2);
  padding-bottom: var(--space-2);
}

.cip-detail-grid {
  grid-template-columns: 1fr;
  gap: 0;
}

.cip-media-card {
  padding: 0;
  border: 0;
  border-radius: 0;
}

.cip-detail.card {
  padding: 0;
  border: 0;
  border-radius: 0;
}

.cip-detail-title {
  margin-top: var(--destination-cip-title-margin-top);
}

.cip-detail-text {
  font-size: calc(1.25rem * var(--font-scale));
  margin-top: var(--space-1);
  margin-left: var(--space-3);
  margin-right: var(--space-3);
}

.market-title {
  text-align: center;
  margin-left: var(--space-3);
  margin-right: var(--space-3);
}

.market-section {
  margin-left: var(--space-2);
  margin-right: var(--space-2);
  width: calc(100% - (var(--space-2) * 2));
}

.market-section .card {
  border: none;
  border-radius: 0;
}

.market-item {
  grid-template-columns: 1fr 4fr;
  gap: var(--space-2);
}

.market-item > .card {
  margin: 0;
  padding: 0;
}

.market-icon {
  display: flex;
  align-items: center;
  height: 100%;
}

.market-vector {
  display: block;
  margin-top: auto;
  margin-bottom: auto;
}

.market-connectivity {
  grid-template-columns: 1fr 1fr;
  gap: var(--space-1);
  margin-top: var(--space-2);
}

.market-feature--road {
  background-image: var(--destination-road-bg);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  background-color: var(--destination-road-bg-color);
}

.market-connectivity > .card {
  border: 2px solid #ffffff;
  display: flex;
  flex-direction: column;
}

.market-feature {
  display: grid;
  grid-template-columns: 1fr 4fr;
  gap: var(--space-1);
  justify-content: stretch;
  align-content: stretch;
  align-items: start;
}

.market-feature > .card {
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
}

.market-feature-text {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

.market-feature-media {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.market-feature-media img {
  display: block;
  max-width: 100%;
  height: auto;
  max-height: 100%;
}

.market-infra {
  border: 2px solid #ffffff;
  grid-template-columns: 1fr 4fr;
  gap: var(--space-2);
  margin-top: var(--space-1);
  margin-bottom: var(--space-4);
}

.market-infra > .card {
  margin: 0;
  padding: 0;
}

.market-horizontal-cards-finales {
  margin-right: var(--space-1) !important;
}

.market-infra > .market-infra-icon {
  margin-left: var(--space-1);
}

.market-marina,
.marina-infra,
.connectividad-infra,
.market-entorno {
  border: 2px solid #ffffff;
  grid-template-columns: 1fr 4fr;
  gap: var(--space-2);
  margin-top: var(--space-1);
}

.market-marina > .card,
.marina-infra > .card,
.connectividad-infra > .card,
.market-entorno > .card {
  margin: 0;
  padding: 0;
}

.market-marina > .market-infra-icon,
.marina-infra > .marina-infra-icon,
.connectividad-infra > .connectividad-infra-icon,
.market-entorno > .market-entorno-icon {
  margin-left: var(--space-1);
}

.market-infra-icon,
.marina-infra-icon,
.connectividad-infra-icon,
.market-entorno-icon {
  display: flex;
  align-items: center;
  justify-content: center;
}

.market-infra-icon img,
.marina-infra-icon img,
.connectividad-infra-icon img,
.market-entorno-icon img {
  display: block;
  max-width: 100%;
  height: auto;
  max-height: 100%;
}

.market-infra-title,
.marina-infra-title,
.connectividad-infra-title,
.market-entorno-title {
  margin-top: var(--space-1);
  margin-bottom: var(--space-1);
}

/* Navigation */
.site-nav {
  gap: var(--space-2);
}

.site-nav .nav-link {
  color: var(--color-text);
  font-weight: 600;
}

.site-nav .nav-link[aria-current="page"] {
  color: var(--color-accent);
}

.lang {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
}

.lang button {
  appearance: none;
  border: 1px solid rgba(255, 255, 255, 0.4);
  background: transparent;
  color: var(--color-text);
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
}

.lang button[aria-pressed="true"] {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-ink);
}

/* Media */
.hero-media,
.cip-media {
  display: block;
  width: 100%;
}

.hero-media-img,
.cip-media-img {
  width: 100%;
  height: auto;
  object-fit: cover;
  display: block;
}

.hero-banner-cta {
  align-self: flex-start;
  display: inline-flex;
  border: none;
  border-radius: 999px;
  padding: 8px 16px;
  background: var(--color-accent);
  cursor: pointer;
  text-decoration: none;
  color: inherit;
}

.hero-banner-cta .subtitulo-strong-obscuro {
  margin: 0;
}

/* Typography */
.titulo-strong {
  color: #fff;
  font-family: "Geomanist";
  font-size: calc(3rem * var(--font-scale));
  font-style: normal;
  font-weight: 700;
}

.subtitulo {
  color: #fff;
  font-family: "Geomanist";
  font-size: calc(2rem * var(--font-scale));
  font-style: normal;
  font-weight: 400;
}

.subtitulo-strong {
  color: #fff;
  font-family: "Geomanist";
  font-size: calc(2rem * var(--font-scale));
  font-style: normal;
  font-weight: 700;
}

.subtitulo-strong-obscuro {
  color: #212222;
  font-family: "Geomanist";
  font-size: calc(2rem * var(--font-scale));
  font-style: normal;
  font-weight: 700;
}

.subtitulo-obscuro {
  color: #212222;
  font-family: "Geomanist";
  font-size: calc(2rem * var(--font-scale));
  font-style: normal;
  font-weight: 400;
}

.t-body-geomanist-strong {
  color: #fff;
  font-family: "Geomanist";
  font-size: calc(1.125rem * var(--font-scale));
  font-style: normal;
  font-weight: 700;
}

.t-body-geomanist-obscuro {
  color: #212222;
  font-family: "Geomanist";
  font-size: calc(1.125rem * var(--font-scale));
  font-style: normal;
  font-weight: 700;
}

.t-body-geomanist {
  color: #fff;
  font-family: "Geomanist";
  font-size: calc(1.125rem * var(--font-scale));
  font-style: normal;
  font-weight: 400;
}

/* Cierre */
.cierre {
  background-image: none;
}

.closing-section {
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  aspect-ratio: 576 / 215;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding-bottom: var(--space-2);
}

.closing-text {
  text-align: center;
  padding-left: 12.5vw;
  padding-right: 12.5vw;
}

.map-section {
  margin-top: var(--space-4);
  margin-bottom: var(--space-4);
  margin-left: var(--space-2);
}

.map-section .card {
  border: 0;
}

.map-grid {
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: start;
}

.map-text {
  align-self: center;
}

.media-card,
.map-media {
  padding: 0;
  display: flex;
  align-items: center;
  align-self: center;
}

/* Responsive */
@media (min-width: 768px) {
  .site-nav {
    width: 100%;
    align-items: center;
  }
}

@media (max-width: 768px) {
  .site-main {
    padding: 0;
  }

  .market-feature {
    background-size: 100% 100%;
  }

  .cip-intro {
    margin-top: var(--space-1);
  }
}

@media (min-width: 769px) {
  .site-main {
    padding-left: 0;
    padding-right: 0;
    padding-top: var(--space-2);
    --font-scale: 2;
  }

  .cip-detail-grid {
    grid-template-columns: 1fr 1fr;
  }

  .market-connectivity {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-1);
    margin-top: var(--space-6);
  }

  .map-section {
    margin-left: var(--space-6);
  }
  /* Para la altura de la hambuguesa con guia de inversion en desk */
  .navbar-expand-md .navbar-nav .nav-link {
    height: 75px;
  }
}
