/* ============================= */
/* PAGINA MANIFIESTO */
/* ============================= */

.page-manifiesto{
  background: #F4F4F5;
}

body.page-template-page-manifiesto,
body.page-template-page-manifiesto-php{
  margin: 0;
  padding: 0;
  background: #18181B;
}

/* ============================= */
/* HEADER — MANIFIESTO */
/* ============================= */

body.page-template-page-manifiesto .site-header,
body.page-template-page-manifiesto-php .site-header{
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 0;
  background: #18181B;
  z-index: 300;
  box-shadow: none;
}

body.page-template-page-manifiesto .header-inner,
body.page-template-page-manifiesto-php .header-inner{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  min-height: 80px;
  background: transparent;
}

body.page-template-page-manifiesto .brand,
body.page-template-page-manifiesto .brand--light,
body.page-template-page-manifiesto .nav a,
body.page-template-page-manifiesto-php .brand,
body.page-template-page-manifiesto-php .brand--light,
body.page-template-page-manifiesto-php .nav a{
  color: #ffffff;
}

body.page-template-page-manifiesto .nav a,
body.page-template-page-manifiesto-php .nav a{
  transition: color 0.22s ease, opacity 0.22s ease;
}

body.page-template-page-manifiesto .nav a:hover,
body.page-template-page-manifiesto-php .nav a:hover,
body.page-template-page-manifiesto .nav .current-menu-item > a:hover,
body.page-template-page-manifiesto-php .nav .current-menu-item > a:hover,
body.page-template-page-manifiesto .nav a:focus,
body.page-template-page-manifiesto-php .nav a:focus{
  color: #2F54F1;
}

body.page-template-page-manifiesto .btn-primary,
body.page-template-page-manifiesto-php .btn-primary{
  background: #2F54F1;
  color: #ffffff;
}

body.page-template-page-manifiesto .site-header::after,
body.page-template-page-manifiesto-php .site-header::after{
  content: none;
}

/* ============================= */
/* FOOTER BACKGROUND */
/* ============================= */

body.page-template-page-manifiesto .site-footer,
body.page-template-page-manifiesto-php .site-footer{
  background: #18181B;
}

/* ============================= */
/* HERO */
/* ============================= */

.manifiesto-hero{
  background: #F4F4F5;
  padding-top: 0;
}

.manifiesto-hero__grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 820px;
  border-bottom: 1px solid #D4D4D8;
  align-items: stretch;
}

.manifiesto-hero__media{
  position: relative;
  min-height: 820px;
  overflow: hidden;
}

.manifiesto-hero__media img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.manifiesto-hero__content{
  position: relative;
  min-height: 820px;
  padding: 0 104px 0 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
}

.manifiesto-hero__copy{
  max-width: 532px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.manifiesto-hero__content h1{
  margin: 0;
  max-width: 532px;
  font-family: "PP Neue Montreal";
  font-size: 26px;
  font-weight: 500;
  line-height: 130%;
  color: #171717;
}

.manifiesto-hero__content p{
  margin: 0;
  max-width: 532px;
  font-family: "PP Neue Montreal";
  font-size: 18px;
  font-weight: 500;
  line-height: 150%;
  letter-spacing: 0.36px;
  color: #404040;
}

/* ============================= */
/* LISTA */
/* ============================= */

.manifiesto-lista{
  position: relative;
  background: #F4F4F5;
  padding: 42px 0 140px;
}

.manifiesto-lista__inner{
  position: relative;
  max-width: 1240px;
  margin: 0 auto;
  padding-left: 64px;
  padding-right: 320px;
}

.manifiesto-item{
  display: grid;
  grid-template-columns: 90px minmax(0, 640px);
  gap: 0;
  align-items: start;
  padding: 28px 0;
}

.manifiesto-item__num{
  font-size: 46px;
  line-height: 1;
  letter-spacing: -0.03em;
  font-weight: 300;
  color: #71717A;
}

.manifiesto-item__content h2{
  margin: 0 0 8px;
  font-size: 30px;
  line-height: 1.22;
  letter-spacing: -0.02em;
  font-weight: 400;
  color: #27272A;
}

.manifiesto-item__content p{
  margin: 0;
  font-size: 16px;
  line-height: 1.5;
  color: #71717A;
  max-width: 620px;
}

/* ============================= */
/* CTA */
/* ============================= */

.manifiesto-cta{
  background: #18181B;
  padding: 82px 0 42px;
  position: relative;
  z-index: 2;
}

.manifiesto-cta__inner{
  min-height: 420px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
}

.manifiesto-cta__intro{
  margin: 0 0 12px;
  max-width: 600px;
  font-size: 32px;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: #F4F4F5;
}

.manifiesto-cta__title{
  margin: 0 0 32px;
  max-width: 760px;
  font-size: 32px;
  line-height: 1.08;
  letter-spacing: -0.03em;
  color: #F4F4F5;
}

.manifiesto-cta__title .is-bold{
  font-weight: 500;
}

.manifiesto-cta__button{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 6px;
  background: #2F54F1;
  color: #ffffff;
  text-decoration: none;
  font-size: 14px;
  line-height: 1;
  transition: opacity 0.2s ease;
}

.manifiesto-cta__button:hover{
  opacity: 0.9;
}

/* ============================= */
/* LOGO TOGGLE */
/* ============================= */

.manifiesto-toggle-wrap{
  position: absolute;
  right: 72px;
  bottom: 40px;
  width: 140px;
  height: auto;
  pointer-events: none;
}

.manifiesto-toggle{
  display: block;
  width: 100%;
  height: auto;
  overflow: visible;
}

.toggle-track{
  fill: transparent;
  stroke: rgba(23,23,23,0.18);
  stroke-width: 1.2;
}

.toggle-knob{
  transform-box: fill-box;
  transform-origin: center;
}

.toggle-knob--top{
  fill: transparent;
  stroke: #171717;
  stroke-width: 1.2;
  animation: knobTopMove 4s cubic-bezier(0.65, 0, 0.35, 1) infinite;
}

.toggle-knob--bottom{
  fill: #2F54F1;
  stroke: #2F54F1;
  stroke-width: 1.2;
  animation: knobBottomMove 4s cubic-bezier(0.65, 0, 0.35, 1) infinite;
}

@keyframes knobTopMove{
  0%, 1%, 99%, 100%{
    transform: translateX(0);
    fill: transparent;
    stroke: #171717;
  }

  49%, 50%{
    transform: translateX(116px);
    fill: #2F54F1;
    stroke: none;
  }
}

@keyframes knobBottomMove{
  0%, 1%, 99%, 100%{
    transform: translateX(0);
    fill: #2F54F1;
    stroke: none;
  }

  49%, 50%{
    transform: translateX(-116px);
    fill: transparent;
    stroke: #171717;
  }
}

/* ============================= */
/* FOOTER VISUAL */
/* ============================= */

.contacto-visual--footer-only{
  position: relative;
  overflow: hidden;
  padding: 120px 0 48px;
  background: #18181B;
}

.contacto-visual--footer-only .contacto-visual__bg,
.contacto-visual--footer-only .contacto-visual__overlay{
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: none;
}

.contacto-visual--footer-only .site-footer--integrated{
  width: 100%;
  background: transparent;
  padding-bottom: 0;
}

.contacto-visual--footer-only .footer-inner{
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding-left: var(--gutter);
  padding-right: var(--gutter);
}

.site-footer--integrated{
  background: #18181B;
  position: relative;
  z-index: 3;
}

/* ============================= */
/* HOVERS — MANIFIESTO PREMIUM */
/* ============================= */

body.page-template-page-manifiesto a,
body.page-template-page-manifiesto button,
body.page-template-page-manifiesto .manifiesto-hero__media img,
body.page-template-page-manifiesto .manifiesto-bloque,
body.page-template-page-manifiesto .manifiesto-cta__inner,
body.page-template-page-manifiesto .site-footer a,
body.page-template-page-manifiesto-php a,
body.page-template-page-manifiesto-php button,
body.page-template-page-manifiesto-php .manifiesto-hero__media img,
body.page-template-page-manifiesto-php .manifiesto-bloque,
body.page-template-page-manifiesto-php .manifiesto-cta__inner,
body.page-template-page-manifiesto-php .site-footer a{
  transition:
    color 0.24s ease,
    opacity 0.24s ease,
    transform 0.32s ease,
    border-color 0.24s ease,
    background-color 0.24s ease,
    box-shadow 0.32s ease;
}

body.page-template-page-manifiesto .nav a:hover,
body.page-template-page-manifiesto .site-footer a:hover,
body.page-template-page-manifiesto-php .nav a:hover,
body.page-template-page-manifiesto-php .site-footer a:hover{
  color: #2F54F1;
}

body.page-template-page-manifiesto .manifiesto-hero__media:hover img,
body.page-template-page-manifiesto-php .manifiesto-hero__media:hover img{
  transform: scale(1.015);
}

body.page-template-page-manifiesto .reveal:hover,
body.page-template-page-manifiesto-php .reveal:hover{
  transform: translateY(-4px);
}

body.page-template-page-manifiesto .manifiesto-cta.reveal:hover,
body.page-template-page-manifiesto-php .manifiesto-cta.reveal:hover{
  transform: none;
}

body.page-template-page-manifiesto .site-footer.reveal:hover,
body.page-template-page-manifiesto-php .site-footer.reveal:hover{
  transform: none;
}

body.page-template-page-manifiesto .manifiesto-cta__button,
body.page-template-page-manifiesto-php .manifiesto-cta__button,
body.page-template-page-manifiesto .btn-primary,
body.page-template-page-manifiesto-php .btn-primary{
  transition:
    background-color 0.24s ease,
    color 0.24s ease,
    transform 0.28s ease,
    box-shadow 0.28s ease;
}

body.page-template-page-manifiesto .manifiesto-cta__button:hover,
body.page-template-page-manifiesto .manifiesto-cta__button:focus,
body.page-template-page-manifiesto .btn-primary:hover,
body.page-template-page-manifiesto .btn-primary:focus,
body.page-template-page-manifiesto-php .manifiesto-cta__button:hover,
body.page-template-page-manifiesto-php .manifiesto-cta__button:focus,
body.page-template-page-manifiesto-php .btn-primary:hover,
body.page-template-page-manifiesto-php .btn-primary:focus{
  color: #ffffff;
}

/* ============================= */
/* FIX TIPOGRAFÍA — MANIFIESTO */
/* ============================= */

.page-manifiesto .manifiesto-hero__content,
.page-manifiesto .manifiesto-hero__content h1,
.page-manifiesto .manifiesto-hero__content p,
.page-manifiesto .manifiesto-lista,
.page-manifiesto .manifiesto-lista h2,
.page-manifiesto .manifiesto-lista p,
.page-manifiesto .manifiesto-cta,
.page-manifiesto .manifiesto-cta h2,
.page-manifiesto .manifiesto-cta p{
  font-family: "PP Neue Montreal", sans-serif;
}