@import url("https://fonts.googleapis.com/css2?family=Work+Sans:wght@300;400;500;600;700;800&display=swap");

:root {
  --primary-color: #9062c1;
  --primary-color-dark: #6632a3;
  --text-dark: #1e293b;
  --text-light: #64748b;
  --extra-light: #fafafacf;
  --white: #ffffff;
  --max-width: 1200px;
  --card-margin: 10px;
}

* {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

.section__container {
  max-width: var(--max-width);
  margin: auto;
  padding: 5rem 1rem;
}

.section__header {
  font-size: 3rem;
  font-weight: 300;
  text-align: center;
  color: var(--text-dark);
}

.section__subheader {
  font-size: 1rem;
  font-weight: 300;
  text-align: center;
  color: var(--text-light);
  letter-spacing: 2px;
}

.btn {
  padding: 1rem 1.5rem;
  outline: none;
  border: none;
  font-size: 1rem;
  color: var(--white);
  background-color: var(--primary-color);
  border-radius: 5rem;
  cursor: pointer;
  display: inline-flex;          /* clave */
  align-items: center;           /* centra vertical */
  justify-content: center;       /* centra horizontal */
  text-align: center;
}

img {
  width: 100%;
  display: flex;
}

a {
  text-decoration: none;
}

html,
body {
  scroll-behavior: smooth;
}

body {
  font-family: "Work Sans", sans-serif;
}

nav {
  max-width: auto;
  margin: auto;
  padding: 1rem 0.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background-color: #EADFFD;
  position: -webkit-sticky; /* Soporte para Safari */
  position: sticky;
  top: 0; /* Esto hace que la barra de navegación se pegue a la parte superior de la ventana gráfica */
  z-index: 1000; /* Asegúrate de que la navbar se muestre sobre otros contenidos */
}

.nav__logo {
  display: flex;
  align-items: center;
  gap: 5px;
}

.nav__logo img {
  max-width: 75px;
}

.nav__logo span {
  font-size: 1.25rem;
  color: var(--text-dark);
}

.nav__links {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 2rem;
}

.link a {
  padding: 5px;
  color: var(--text-light);
}

.link a:hover {
  color: var(--primary-color);
}

header {
  position: relative;
}

header::before {
  position: absolute;
  content: "";
  bottom: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(to top, var(--primary-color), transparent);
  opacity: 0.2;
}

.header__container {
  padding: 0 1rem;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
}

.header__content {
  z-index: 1;
}

.header__content h1 {
  margin-bottom: 1rem;
  font-size: 4rem;
  font-weight: 300;
  color: var(--text-dark);
}

.header__content h2 {
  margin-bottom: 2rem;
  font-size: 2rem;
  font-weight: 300;
  color: var(--text-light);
}

.header__image {
  z-index: -1;
}

.header__image img {
  padding-top: 5px;
  max-width: 475px;
  margin: auto;
}

.why__container {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: center;
}

.why__image img {
  max-width: 600px;
  margin: auto;
}

.why__content .section__header {
  margin-bottom: 1rem;
  text-align: justify;
}

.why__content p {
  margin-bottom: 2rem;
  line-height: 1.5rem;
  color: var(--text-light);
}

.why__content ul {
  list-style: none;
}

.why__content li {
  margin-bottom: 1.5rem;
  font-size: 1.2rem;
  color: var(--primary-color);
}

.hero {
  background-color: var(--extra-light);
}

.hero__container {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}

.hero__card span {
  margin-bottom: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 75px;
  aspect-ratio: 1;
  background-color: #dcd0e6;
  border-radius: 100%;
}

.hero__card span img {
  max-width: 40px;
}

.hero__card h4 {
  margin-bottom: 10px;
  font-size: 1.2rem;
  font-weight: 500;
  color: var(--text-dark);
}

.hero__card p {
  line-height: 1.5rem;
  color: var(--text-light);
}

.classes__container{
  background-image: linear-gradient(to bottom, var(--primary-color), transparent);
}

.classes__container .section__subheader{
  color: var(--white)
}

.classes__grid {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  grid-gap: 2rem; /* Añadimos espacio entre las tarjetas */
  justify-content: center; /* Centramos las tarjetas en el grid */
  align-items: start; /* Alineamos las tarjetas al principio de cada celda del grid */
  padding: 0 2rem;
}

.stories__grid {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}

.stories__card {
  padding: 1rem;
  background-color: #EADFFD;
}

.stories__content {
  position: relative;
  isolation: isolate;
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.stories__content span {
  padding: 7px 10px;
  font-size: 2rem;
  color: var(--white);
  background-color: var(--primary-color);
  border-radius: 100%;
}

.stories__content::after {
  position: absolute;
  content: "";
  height: 100%;
  width: 2px;
  top: 0;
  left: 24px;
  background-color: var(--text-light);
  opacity: 0.1;
  z-index: -1;
}

.stories__content p {
  line-height: 1.5rem;
  color: var(--text-light);
}

.stories__author {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.stories__author img {
  max-width: 100px;
  border-radius: 100%;
}

.stories__author__details h4 {
  margin-bottom: 5px;
  font-size: 1.1rem;
  font-weight: 500;
  color: var(--text-dark);
}

.stories__author__details h6 {
  font-size: 1rem;
  font-weight: 500;
  color: var(--text-light);
}

.banner {
  padding: 5rem 0;
  background: linear-gradient(to right, var(--primary-color-dark), var(--primary-color));
  background-position: center center;
  background-size: cover;
  background-repeat: no-repeat;
}

.banner__container {
  max-width: 1200px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  text-align: center;
}

.banner__card{
  background: rgba(255, 255, 255, 0.1);
  border-radius: 10px;
  padding: 2rem;
  transition: transform 0.3s ease-in-out, background-color 0.3s;
}

.banner__card:hover {
  transform: scale(1.05);
  background: rgba(255, 255, 255, 0.2);
}

.banner__card h4 {
  margin-bottom: 1rem;
  font-size: 2rem;
  font-weight: 500;
  color: var(--white);
}

.banner__card p {
  color: var(--white);
}


.photos__grid {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
}

.footer {
  background-color: var(--primary-color); /* Use the darker purple for better contrast */
  color: var(--white); /* This ensures all text in the footer is white unless specified otherwise */
  padding: 2rem 0; /* Add some padding to give content inside the footer some space */
}

.footer__container {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center; /* Align items vertically */
  max-width: 1200px; /* Set a max-width to constrain the footer's width */
  margin: 0 auto; /* Center the footer container */
  padding: 0 1rem; /* Add padding on the sides */
}

.footer__logo a {
  font-size: 1.5rem;
  font-weight: 400;
}

.footer__col p {
  font-size: 1rem; /* Slightly reduce font size for more space and better readability */
  margin: 0; /* Remove any default margins */
}

.footer__socials {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1rem;
}

.footer__socials a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  aspect-ratio: 1;
  font-size: 1.5rem;
  color: var(--white);
  background-color: #f7ebf330;
  border-radius: 100%;
}

.footer__bar {
  font-size: 0.75rem; /* Reduce the font size for the copyright bar to be subtler */
  padding: 1rem 0; /* Add some padding to give it its own space */
  border-top: 1px solid rgba(255, 255, 255, 0.2); /* Add a subtle border on top for visual separation */
  width: 100%; /* Ensure it spans the full width */
}

@media (width < 900px) {
  .nav__links {
    gap: 1rem;
  }

  header::before {
    left: 0;
  }

  .header__container {
    grid-template-columns: repeat(1, 1fr);
  }

  .header__image {
    grid-area: 1/1/2/2;
  }

  .header__content {
    padding: 5rem 0;
    text-align: center;
  }

  .why__container p{
    text-align: justify;
  }

  .why__container {
    grid-template-columns: repeat(1, 1fr);
  }

  .why__content :is(.section__header, p) {
    text-align: justify;
  }

  .hero__container {
    grid-template-columns: repeat(2, 1fr);
  }

  .membership__grid {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 4rem;
    column-gap: 1rem;
  }

  .stories__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }

  .banner__container {
    grid-template-columns: repeat(2, 1fr);
  }

  .posts__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
  }

  .photos__grid {
    gap: 1rem;
  }

  .footer__container {
    grid-template-columns: 1fr;
    text-align: center;
  }

  .footer__socials {
    justify-content: center;
  }
}

/* Styles for screens smaller than 750px */
@media (max-width: 768px) {
  .classes__grid,
  .photos__grid {
    grid-template-columns: repeat(1, 1fr);
  }

  .nav__links {
    gap: 0.5rem;
  }

  .pilates__types__grid {
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  }
}

/* Styles for screens smaller than 600px */
@media (max-width: 480px) {
  .nav__links {
    display: none;
  }

  .hero__container,
  .membership__grid,
  .stories__grid,
  .posts__grid {
    grid-template-columns: repeat(1, 1fr);
  }

  .banner__container,
  .photos__grid,
  .footer__container {
    grid-template-columns: 1fr;
  }

  .footer__socials {
    justify-content: center;
  }

  .header__container,
  .why__container,
  .hero__container,
  .classes__grid,
  .stories__grid,
  .banner__container,
  .posts__grid,
  .photos__grid {
    grid-template-columns: 1fr;
  }

  .pilates__type__card img {
    height: 150px; /* Adjust for smaller screens */
  }
}

@media (max-width: 768px) {
  .hero__container,
  .membership__grid,
  .stories__grid,
  .banner__container,
  .posts__grid,
  .photos__grid,
  .classes__grid {
    grid-template-columns: 1fr;
  }
  
  .pilates__type__card img {
    height: auto; /* Cambiado para mantener la proporción */
  }

  .nav__logo img {
    max-width: 60px; /* Un poco más pequeño para pantallas reducidas */
  }
}

@media (max-width: 480px) {
  /* Contenedores que no se ajustaron previamente a 1fr para móviles */
  .header__container,
  .why__container,
  .hero__container {
    grid-template-columns: 1fr;
  }
}


.sing_up-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 15px 30px;
  border: 0;
  position: relative;
  overflow: hidden;
  border-radius: 10rem;
  transition: all 0.02s;
  font-weight: bold;
  color: rgb(37, 37, 37);
  z-index: 0;
  box-shadow: 0 0px 7px -5px rgba(0, 0, 0, 0.5);
  cursor: pointer;
  
}

.sing_up-button:hover {
  background: rgb(193, 228, 248);
  color: rgb(33, 0, 85);
}

.sing_up-button:active {
  transform: scale(0.97);
}

.sing_up-hoverEffect {
  position: absolute;
  bottom: 0;
  top: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}

.sing_up-hoverEffect div {
  background: rgb(222,0,75);
  background: linear-gradient(90deg, rgba(222,0,75,1) 0%, rgba(191,70,255,1) 49%, rgba(0,212,255,1) 100%);
  border-radius: 40rem;
  width: 10rem;
  height: 10rem;
  transition: 0.4s;
  filter: blur(20px);
  animation: effect infinite 3s linear;
  opacity: 0.5;
}

.sing_up-button:hover .sing_up-hoverEffect div {
  width: 8rem;
  height: 8rem;
}

@keyframes effect {

  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.flip-card {
  background-color: transparent;
  width: 300px;
  height: 420px;
  perspective: 1000px;
  font-family: sans-serif;
}

.title-card {
  font-size: 1.58em;
  font-weight: bold;
  color: #562f97;
  background-color: rgba(255, 255, 255, 0.8);
  padding: 0.3em;
  border-radius: 0 0 10px 10px;
  text-align: center;
  margin: 0;
}

.flip-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  text-align: center;
  transition: transform 0.8s;
  transform-style: preserve-3d;
}

.flip-card:hover .flip-card-inner {
  transform: rotateY(180deg);
}

.flip-card-front, .flip-card-back {
  box-shadow: 0 8px 14px 0 rgba(0,0,0,0.2);
  position: absolute;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 100%;
  height: 100%;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  border: 1px solid #6632a3;
  border-radius: 1rem;
}

.flip-card-front {
  background: linear-gradient(
    120deg, 
    #9062c1 60%, 
    #7a56ac 88%, 
    #6632a3 40%, 
    rgba(102, 50, 163, 0.6) 48%
  );
  color: white; /* Esto garantiza que el texto sea legible */
  cursor: pointer;
}

.flip-card-back {
  background: linear-gradient(
    120deg, 
    #6632a3 30%, 
    #7a56ac 88%, 
    #9062c1 40%, 
    rgba(144, 98, 193, 0.6) 78%
  );
  color: white; /* Para mantener la legibilidad del texto */
  transform: rotateY(180deg);
  text-align: justify;
  padding: 1rem;
  overflow: hidden;
}

/* Asegúrate de que .flip-card-front y .flip-card-back también se ajusten al 100% del tamaño de .flip-card */
.flip-card-front, .flip-card-back {
  width: 100%;
  height: 100%;
}


.pilates__type__card img {
  width: 100%;
  height: 200px; /* Adjust based on your preference */
  object-fit: cover;
}

.pilates__types {
  background-image: linear-gradient(to bottom, var(--primary-color), transparent);
  color: var(--white); /* Color de texto principal */
  padding: 3rem 0; /* Espacio superior e inferior para la sección */
  width: 100vw;
}

.pilates__types__grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around; /* Esto distribuirá las tarjetas uniformemente */
  gap: 2rem;
  max-width: var(--max-width);
  margin: auto;
}

.pilates__type__card {
  background-color: rgba(255, 255, 255, 0.2); /* Tarjetas semitransparentes para que se vea el fondo */
  border-radius: 10px;
  box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.2);
  flex-basis: calc(33.333% - 2rem); /* Ajusta este valor para cambiar el ancho inicial de las tarjetas */
  margin-bottom: 2rem; /* Espacio debajo de cada tarjeta */
  padding: 1rem; /* Relleno dentro de las tarjetas */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}

.pilates__type__card h3 {
  background-color: var(--primary-color-dark); /* Fondo del título con el color primario */
  color: var(--white); /* Título en color blanco para contraste */
  padding: 0.5rem 1rem; /* Espaciado dentro del título */
  margin: 0; /* Remover cualquier margen por defecto */
}

.pilates__type__card p {
  padding: 1rem; /* Espaciado dentro del párrafo */
  flex-grow: 1; /* El párrafo crece para ocupar el espacio disponible */
  background-color: var(--white); /* Fondo blanco para el texto */
  color: var(--text-light); /* Color de texto más suave */
  border-top: 1px solid var(--primary-color-dark); /* Borde superior para separar del título */
  text-align: justify; /* Alineación del texto justificada */
}

.pilates__types button{
  margin-top: 0.5rem;
  right: 100%;
  background-color: var(--primary-color-dark);
}

.pilates__types .section__subheader,
.classes__container .section__subheader{
  color: var(--white); /* Un púrpura más oscuro para el subheader */
  text-shadow: 1px 1px 2px rgba(46, 31, 73, 0.5); /* Sutil sombra de texto para mejorar la legibilidad */
}

.pilates__types .section__header,
.classes__container .section__header{
  color: var(--extra-light);
  text-shadow: 2px 2px 4px rgba(46, 31, 73, 0.8);
}

.button-container {
  text-align: center; /* Centra el contenido del contenedor */
  padding-top: 1rem; /* Añade espacio encima del botón */
}

.btn-center {
  display: inline-block; /* Hace que el enlace se comporte como un bloque para permitir centrarlo */
  margin-top: 1rem; /* Añade espacio arriba del botón si es necesario */
}

.map-container {
  text-align: center;
  padding: 2rem 0;
}

.map-container iframe {
  width: 90%;
  max-width: 1000px; /* Ajusta esto según el ancho máximo deseado para el mapa en pantallas grandes */
  height: 450px;
  border: none;
  margin-bottom: 1rem; /* Para añadir un poco de espacio debajo del mapa */
  /* Si se requiere centrar verticalmente dentro de su contenedor */
  display: block;
  margin-left: auto;
  margin-right: auto;
}

/* Responsividad */
@media (max-width: 768px) {
  .map-container iframe {
    width: 95%;
    height: 300px; /* Puedes ajustar la altura para pantallas más pequeñas si es necesario */
  }
}

@media (max-width: 480px) {
  .map-container iframe {
    width: 100%;
    height: 250px; /* Puedes disminuir la altura aún más para pantallas muy pequeñas */
  }
}

/* Horarios (iframe BoxMagic) responsivo */
.posts__container iframe,
.schedule__iframe {
  width: 100%;
  max-width: 1000px;
  height: 700px;
  border: none;
  display: block;
  margin: 1rem auto 0;
}
@media (max-width: 768px) {
  .posts__container iframe,
  .schedule__iframe {
    height: 600px;
  }
}
@media (max-width: 480px) {
  .posts__container iframe,
  .schedule__iframe {
    height: 520px;
  }
}

.nav__hamburger {
  display: none;
  cursor: pointer;
}

.nav__hamburger i {
  font-size: 1.5rem;
  color: var(--text-dark);
}


@media (max-width: 768px) {
  .nav__links {
    position: absolute;
    right: 0;
    top: 60px;
    background-color: #EADFFD;
    flex-direction: column;
    width: 100%;
    display: none; /* Oculto por defecto */
    border-top: 1px solid var(--primary-color);
  }

  .nav__links.active {
    display: flex; /* Muestra el menú cuando está activo */
  }

  .nav__hamburger {
    display: block; /* Muestra el botón de hamburguesa */
  }
}

@media (max-width: 768px) {
  .footer__socials a {
    font-size: 1.25rem; /* Reducir el tamaño de los íconos en pantallas más pequeñas */
    width: 40px; /* Ajustar el tamaño del contenedor de los íconos */
    height: 40px; /* Mantener la proporción del contenedor de los íconos */
  }
}

@media (max-width: 390px) {
  .section__container {
    padding: 3rem 1rem; /* Reduce el padding general para dar más espacio */
  }

  .section__header {
    font-size: 2.5rem; /* Reduce el tamaño de la fuente para los títulos de sección */
  }

  .section__subheader {
    font-size: 0.9rem; /* Reduce el tamaño de la fuente para los subtítulos */
  }

  .btn {
    padding: 0.8rem 1.2rem; /* Reduce el tamaño del botón */
    font-size: 0.9rem; /* Reduce el tamaño de la fuente del botón */
  }

  nav .nav__logo img {
    max-width: 50px; /* Reduce aún más el logo */
  }

  .nav__links {
    flex-direction: column;
    width: 100%; /* Asegúrate de que los enlaces ocupen todo el ancho */
    padding: 1rem; /* Agrega algo de espacio dentro del menú de navegación */
  }

  .nav__links a {
    font-size: 1rem; /* Ajusta el tamaño de la fuente de los enlaces */
    padding: 0.5rem 0; /* Espacio vertical para cada enlace */
  }

  /* Ajustes para el contenido de las tarjetas y otros componentes que puedan necesitar cambios */
  .flip-card {
    width: 100%; /* Ocupa todo el ancho disponible */
    /*height: auto;*/ /* Ajusta la altura automáticamente */
  }

  .flip-card-front, .flip-card-back {
    padding: 1rem; /* Añade relleno a las tarjetas para evitar que el texto se amontone */
  }

  /* Asegúrate de que los íconos y otros elementos gráficos también se escalen adecuadamente */
  .footer__socials a {
    font-size: 1.2rem; /* Reduce ligeramente el tamaño de los íconos */
    width: 35px; /* Ajusta el tamaño del contenedor de los íconos */
    height: 35px; /* Ajusta la altura para mantener la proporción */
  }

  /* Si tienes una barra de navegación pegajosa, asegúrate de que su tamaño y posición también se ajusten correctamente */
  nav {
    padding: 1rem 0.5rem; /* Reduce el relleno */
  }

  /* Para el mapa y otros iframes o elementos incrustados, asegúrate de que sean responsivos */
  .map-container iframe {
    width: 100%; /* Ocupa todo el ancho */
    height: auto; /* Altura automática para mantener la proporción */
  }
}

@media only screen and (min-width: 375px) and (max-height: 667px) {
  /* Reducir los márgenes y el padding general */
  .section__container {
    padding: 2rem 0.5rem;
  }

  /* Ajustar el tamaño de los títulos y los subtítulos */
  .section__header {
    font-size: 2.2rem;
    line-height: 1.2;
    margin-bottom: 1rem;
  }

  .section__subheader {
    font-size: 0.9rem;
    margin-bottom: 0.5rem;
  }

  /* Asegurarse de que el texto del botón sea legible y el botón sea fácil de tocar */
  .btn {
    padding: 0.8rem 1.2rem;
    font-size: 0.9rem;
  }

  /* Ajustar la barra de navegación para dispositivos más pequeños */
  nav .nav__logo img {
    width: 50px; /* Ajustar el tamaño del logo */
  }

  /* Reducir el tamaño de fuente y espaciado de los enlaces de navegación */
  .nav__links a {
    font-size: 0.8rem;
    padding: 0.5rem;
  }

  /* Ajustar el tamaño y el espaciado de las tarjetas y otros elementos gráficos */
  .flip-card, .hero__card, .stories__card, .banner__card {
    padding: 0.5rem;
  }

  /* Ajustar el grid de las secciones que usen grid layout */
  .hero__container, .stories__grid, .classes__grid, .photos__grid {
    grid-template-columns: 1fr;
  }

  /* Modificar el tamaño de los íconos sociales y otros elementos interactivos para que sean fáciles de tocar */
  .footer__socials a {
    font-size: 1.5rem;
    width: 40px;
    height: 40px;
  }

  /* Ajustar las imágenes para que sean responsivas */
  .header__image img, .why__image img {
    width: 100%;
    height: auto;
  }

  /* Asegurarse de que los iframes y otros elementos incrustados como mapas sean responsivos */
  .map-container iframe {
    width: 100%;
    height: 200px;
  }

  /* Para menús desplegables o navegación tipo hamburguesa */
  .nav__hamburger {
    display: block;
  }
  
  /* Esconder el menú de navegación horizontal si está presente cuando se muestra el menú tipo hamburguesa */
  .nav__links--horizontal {
    display: none;
  }
  
  /* Ajustar la visibilidad de los elementos según sea necesario */
  .some-section-specific-class {
    display: none; /* Esconder elementos que no se deben mostrar en dispositivos móviles */
  }
  
  /* Ajustar las fuentes y otros elementos de texto para mejorar la legibilidad */
  .text-element {
    font-size: 0.8rem;
  }
}

.pricing-table {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  padding: 20px;
  max-width: var(--max-width);
  margin: 0 auto;
}

.pricing-card {
  flex: 0 1 calc(33% - var(--card-margin) * 2); /* Empieza con 3 tarjetas por fila y margen en los lados */
  margin: var(--card-margin);
  width: 100%;
  max-width: 300px;
  border: 1px solid var(--extra-light);
  border-radius: 10px;
  text-align: center;
  padding: 20px;
  background-color: var(--white);
  color: var(--text-dark);
  margin: 10px;
  box-shadow: 0 4px 8px 0 rgba(0,0,0,0.2);
  position: relative;
  min-height: 450px;
  box-sizing: border-box; /* Incluye padding y bordes en el cálculo del ancho */
  flex: 0 0 20%;
}

.pricing-card:hover {
  transform: translateY(-5px); /* Efecto de elevación al pasar el mouse */
}

.pricing-title {
  color: var(--primary-color);
  font-size: 24px;
  margin-bottom: 10px;
}

.price {
  font-size: 32px;
  color: var(--primary-color);
  margin-bottom: 20px;
}

.features {
  list-style: none; /* Elimina los bullets de la lista */
  padding: 0;
  margin: 20px 0; /* Da un poco más de espacio antes y después de la lista */
  text-align: left; /* Alinea el texto a la izquierda */
}

.features li {
  margin-bottom: 10px; /* Espaciado entre características */
  padding-left: 15px; /* Espaciado a la izquierda para compensar la ausencia de bullet */
  position: relative; /* Posiciona relativamente para poder colocar un pseudo-elemento */
}

.features li::before {
  content: ''; /* El pseudo-elemento, como un 'bullet' personalizado */
  width: 5px;
  height: 5px;
  background-color: var(--primary-color); /* Color del 'bullet' */
  border-radius: 50%; /* Hace que el 'bullet' sea un círculo */
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%); /* Centra el 'bullet' verticalmente */
}

.btn-container {
  position: absolute; /* Posicionamiento absoluto respecto a su contenedor más cercano con posición relativa */
  bottom: -0; /* Alinea el contenedor del botón en la parte inferior */
  left: 0; /* Alinea el contenedor del botón a la izquierda */
  width: 100%; /* Asegura que el contenedor del botón se extienda por toda la tarjeta */
  padding: 10px 0; /* Añade un poco de espacio por encima y debajo del botón */
}

.pricing-card .btn {
  text-decoration: none;
  background-color: var(--primary-color);
  color: var(--white);
  padding: 10px 20px;
  border-radius: 5px;
  transition: background-color 0.3s ease;
  display: block;
  width: 80%;
  margin: 0 auto;
  justify-content: center;
}

.pricing-card .btn:hover {
  background-color: var(--primary-color-dark);
}

@media (max-width: 1200px) {
  .pricing-card {
    flex: 0 0 25%; /* 4 tarjetas por fila */
    /* ... otros estilos ... */
  }
}

@media (max-width: 992px) {
  .pricing-card {
    flex: 0 0 33.3333%; /* 3 tarjetas por fila */
    /* ... otros estilos ... */
  }
}

@media (max-width: 768px) {
  .pricing-card {
    flex: 0 0 50%; /* 2 tarjetas por fila */
    /* ... otros estilos ... */
  }
}

@media (max-width: 576px) {
  .pricing-card {
    flex: 0 0 100%; /* 1 tarjeta por fila */
    /* ... otros estilos ... */
  }
}

.flip-card-image{
  width: 100%;
  height: 350px;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
  object-fit: cover;
}

.partner-banner {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
}

.partner-banner__card {
  background-size: cover;
  background-position: center;
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
  text-align: center;
  margin: 10px;
  width: 170px;
  height: 170px;
  transition: transform 0.3s, box-shadow 0.3s;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.partner-banner__card--text {
  background: white;
}

.partner-banner__card--text h4{
  color: var(--primary-color);
}

.partner-banner__card--logo::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.5); /* Oscurece el fondo para mejorar la legibilidad del texto */
  z-index: 1;
}

.partner-banner__card:hover {
  transform: translateY(-10px);
  box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
}

.partner-banner__card h4,
.partner-banner__card p {
  z-index: 2;
  margin: 0;
}

.partner-banner__card h4 {
  font-size: 1.5em;
  margin-bottom: 10px;
}

.partner-banner__card p {
  font-size: 1em;
  margin-top: 0;
}

#navBar {
  display: flex;
}

/* ================================
   PLANES: 3 GRUPOS + LISTA (cards fila)
   ================================ */

.pricing-groups{
  display: grid;
  gap: 2rem;
  margin-top: 2rem;
}

/* 3 columnas en desktop, 1 en mobile */
@media (min-width: 980px){
  .pricing-groups{
    grid-template-columns: repeat(3, 1fr);
    align-items: start;
  }
}

/* Contenedor por tipo de plan */
.pricing-group{
  --plan-accent: var(--primary-color);
  border: 1px solid var(--extra-light);
  border-radius: 16px;
  padding: 1.25rem;
  background: rgba(255,255,255,0.7);
  box-shadow: 0 10px 30px rgba(0,0,0,0.06);
}

/* “colores” por tipo */
.pricing-group--barre   { --plan-accent: #b48dd3; }
.pricing-group--reformer{ --plan-accent: #7a56ac; }
.pricing-group--total   { --plan-accent: #563297; }

.pricing-group__header h3{
  margin: 0;
  font-size: 1.35rem;
  color: var(--plan-accent);
}

.pricing-group__header p{
  margin: .25rem 0 1rem;
  opacity: .85;
}

/* Lista dentro del grupo (en vez de grid gigante) */
.pricing-table--list{
  display: flex;
  flex-direction: column;
  gap: .75rem;
  padding: 0;
}

/* Card tipo “fila” */
.pricing-card--row{
  display: grid;
  grid-template-columns: 1fr auto 1fr; /* nombre / # / precio */
  column-gap: 1.25rem;
  align-items: center;

  max-width: none;
  min-height: auto;
  padding: .9rem 1rem;
  margin: 0;

  border: 1px solid rgba(0,0,0,0.06);
  border-radius: 12px;
  box-shadow: none;
}

.pricing-row__name{
  font-weight: 700;
  letter-spacing: .02em;
}

.pricing-row__count{
  text-align: center;
  font-weight: 700;
  min-width: 60px;
  opacity: .9;
}

.pricing-row__price{
  text-align: right;
  font-weight: 800;
  color: var(--plan-accent);
  font-variant-numeric: tabular-nums;
}

/* CTA por grupo */
.pricing-group__cta{
  margin-top: 1rem;
  display: flex;
  justify-content: center;
}
.pricing-group__cta .btn{
  width: 100%;
  max-width: 240px;
}

/* Ajuste para mobile (que quepa bonito) */
@media (max-width: 480px) {
  .pricing-card--row{
    grid-template-columns: 1fr 70px 110px;
    padding: .85rem .85rem;
  }
  .pricing-row__count{ min-width: 46px; }
  .pricing-card--row{ column-gap: .9rem; }

}

.pricing-group--total {
  transform: translateY(-6px);
  border-width: 3px;
}

.slider-container-classes {
  position: relative;
  height: 100%;
  width: 100%;
  overflow: hidden;
}

.slider-wraper-classes .slider-item-classes {
  position: relative;
  width: 100%;
  height: 100vh;
  display: flex;
  align-items: center;
}

.slider-wraper-classes .slider-item-classes::before {
  position: absolute;
  content: "";
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  filter: grayscale(20%);
  background-image: url("assets/Pilates_clases.png");
  background-size: cover;
  background-position: center;
}

.slider-wraper-classes .slider-item-classes:nth-child(2):before {
  background-image: url("assets/Barre_classes.png");
}

.slider-wraper-classes .slider-item-classes:nth-child(3):before {
  background-image: url("assets/Dance-Fit_clases.png");
}

.slider-wraper-classes .slider-item-classes:nth-child(4):before {
  background-image: url("assets/Cardio-Dance_clases.png");
}

.slider-wraper-classes .slider-item-classes:nth-child(5):before {
  background-image: url("assets/K-pop_clases.webp");
}

.slider-wraper-classes .slider-item-classes .slide-content-classes {
  color: #fff;
  z-index: 20;
  width: 100%;
  margin: 0 auto;
  padding: 0 20px 10px;
  max-width: 1400px;
  position: relative;
}

.slider-wraper-classes .slider-item-classes .slide-content-classes > * {
  max-width: 35%;
}

.slider-item-classes .slide-content-classes .slide-subtitle-classes {
  font-size: 1rem;
  font-weight: normal;
}

.slider-item-classes .slide-content-classes .slide-title-classes {
  font-size: 1.5rem;
  font-weight: 700;
  margin-top: 5px;
  text-transform: uppercase;
}

.slider-item-classes .slide-content-classes .slide-description-classes {
  margin-top: 15px;
  line-height: 25px;
  margin-bottom: 25px;
}

.slider-container-classes .slider-controls {
  position: absolute;
  bottom: 45px;
  z-index: 20;
  width: 100%;
  overflow-x: auto;
  scrollbar-width: none;
}

.slider-controls .slider-pagination {
  position: relative;
  display: flex;
  margin: 0 auto;
  padding: 0 20px;
  max-width: 1400px;
  list-style: none;
  justify-content: space-between;
}

.slider-pagination .slider-tab {
  color: #fff;
  font-size: 0.85rem;
  text-align: center;
  cursor: pointer;
  padding: 20px 30px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.5);
}

.slider-pagination .slider-indicator {
  position: absolute;
  bottom: 0;
  border-bottom: 5px solid #fff;
  transition: 0.4s ease-in-out;
}

.slider-navigations button {
  position: absolute;
  top: unset;
  height: 40px;
  width: 40px;
  cursor: pointer;
  z-index: 20;
  color: #fff;
  border: none;
  background: none;
  transform: translateY(-50%);
  transition: 0.4s ease;
  bottom: -15px;
}

.slider-navigations button.swiper-button-disabled {
  display: none;
}

.slider-navigations button:hover {
  background: none;
}

.slider-navigations button#slide-prev {
  left: 20px;
}

.slider-navigations button#slide-next {
  right: 20px;
}