
:root {

    /**
     * colors
     */
  
    --iteazul: #072D70;
    --iteverde: #A4C639;
    --itefondo: #E1E1E1;
    --dark: #000;
    --violet-blue-crayola: hsla(234, 50%, 64%, 1);
    --dark-cornflower-blue_a7: hsla(214, 88%, 27%, 0.07);
    --white: hsla(0, 0%, 100%, 1);
    --white_a3: hsla(0, 0%, 100%, 0.03);
    --white_a8: hsla(0, 0%, 100%, 0.08);
    --white_a12: hsla(0, 0%, 100%, 0.12);
    --white_a70: hsla(0, 0%, 100%, 0.7);
    --cultured: hsla(220, 20%, 97%, 1);
    --lavender-web: hsla(233, 52%, 94%, 1);
    --cadet-blue-crayola: hsla(220, 12%, 70%, 1);
    --cadet-blue-crayola_a20: hsla(222, 23%, 71%, 0.2);
    --charcoal: hsla(218, 22%, 26%, 1);
    --raisin-black: hsla(216, 14%, 14%, 1);
    --light-gray: hsla(0, 0%, 79%, 1);
    --black-coral: hsla(220, 12%, 43%, 1);
  
    /**
     * typography
     */
  
    --ff-manrope: 'Poppins', sans-serif;
  
    --fs-1: calc(2.7rem + 1.38vw);
    --fs-2: calc(2.6rem + .66vw);
    --fs-3: 2.2rem;
    --fs-4: 1.9rem;
    --fs-5: 1.8rem;
    --fs-6: 1.7rem;
    --fs-7: 1.5rem;
    --fs-8: 1.4rem;
    
    --fw-700: 700;
  
    /** 
     * spacing
     */
  
    --section-padding: 90px;
  
    /**
     * box shadow
     */
  
    --shadow-1: 0 0 20px hsla(216, 14%, 14%, 0.05);
    --shadow-2: 0 0 0 0.05rem hsla(214, 88%, 27%, 0.08), 0 0 1.25rem hsla(216, 14%, 14%, 0.06);
    --shadow-3: 0 0 1.25rem hsla(216, 14%, 14%, 0.04);
  
    /**
     * border radius
     */
  
    --radius-circle: 50%;
    --radius-pill: 100px;
    --radius-10: 10px;
    --radius-8: 8px;
    --radius-6: 6px;
  
    /**
     * transition
     */
  
    --transition-1: 0.25s ease;
    --transition-2: 0.5s ease;
    --transition-3: 0.3s ease-in-out;
  
  }
  
  /*-----------------------------------*\
    #ETIQUETAS
  \*-----------------------------------*/
  
  *,
  *::before,
  *::after {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
  
  li { list-style: none; }
  
  a,
  img,
  span,
  input,
  button,
  ion-icon { display: block; }
  
  a {
    color: inherit;
    text-decoration: none;
  }
  
  img { height: auto; }
  
  input,
  button {
    background: none;
    border: none;
    font: inherit;
  }
  
  input { width: 100%; }
  
  button { cursor: pointer; }
  
  ion-icon { pointer-events: none; }
  
  address { font-style: normal; }
  
  html {
    font-family: var(--ff-manrope);
    font-size: 10px;
    scroll-behavior: smooth;
  }
  
  main{
    margin-top: 7em;
  }
  
  body {
    background-color: var(--white);
    color: var(--black-coral);
    font-size: 1.6rem;
    line-height: 1.7;
  }

/*-----------------------------------*\
  # SERVICIOS
\*-----------------------------------*/

 /*
    +++++++
    # CONSULTORIA AUDITORIA
    ++++++++
    */

    .consults {
      background-color: #f3f7f9; 
      padding: 40px 0;
    }
    
    .consults .container {
      max-width: 1200px;
      width: 80%;
      margin: 0 auto;
      padding: 0 20px;
    }
    
    .content-consultoria {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
    }
    
    .colum-o {
      flex: 1;
    }
    
    .colum-o:first-child {
      margin-right: 20px;
    }
    
    .icono-h2 {
      width: 100px;
      height: auto;
      margin-right: 10px;
      vertical-align: middle;
      display: inline-block;
    }
    
    .colum-o h2 {
      font-size: 30px;
      color: var(--iteazul); 
      margin-bottom: 20px;
      display: inline-block;
      vertical-align: middle; 
      margin-top: 10px; 
      margin-left: 0; 
    }
    

    .colum-o ul li {
      list-style: none; 
      position: relative;
      padding-left: 20px;
    }
    
    .colum-o ul li::before {
      content: '•'; 
      position: absolute;
      left: 0;
      font-size: 18px;
      line-height: 1.6;
    }

    .colum-o ul {
      padding-left: 20px;
      font-size: 18px;
      line-height: 1.6;
      text-align: justify;
      max-width: 450px;
    }
    
    .colum-o ul li {
      margin-bottom: 15px;
    }
    
    .colum-o .img-colum {
      width: 450px;
      margin: 0 auto;
    }

     
    .container-btn {
      display: flex;
      justify-content: center;
      align-items: center;
      height: 100%;
      width: 100%; 
      margin-bottom: 10px;
    }
    
    .btn_servis {
      display: inline-block;
      padding: 10px 20px;
      font-weight: bold;
      font-size: 16px;
      color: white;
      text-align: center;
      text-decoration: none;
      background: linear-gradient(90deg, var(--iteazul), var(--iteverde));
      border-radius: 15px;
      box-shadow: 0 0 10px rgba(2, 188, 255, 0.658);
      transition: transform 0.2s ease-in-out;

    }
    
    .btn_servis:hover {
      transform: scale(1.05);
    }
    
    .btn_servis:active {
      transform: scale(0.98);
    }
    
    @media (max-width: 768px) {

      .consults .container {
        width: 95%;
      }
    
      .consults {
        margin-top: -40px;
      }
    
      .icono-h2 {
        width: 45px;
        height: auto;
        margin-right: 10px;
        display: inline-block;
      }
    
      .colum-o h2 {
        font-size: 20px;
        display: inline-block;
        margin-top: 15px; 
      }
    
      .content-consultoria {
        flex-direction: column;
        align-items: center;
        text-align: center;
        margin-top: -20px;
      }
    
      .colum-o:first-child {
        margin-right: 0;
        margin-bottom: 20px;
      }
    
      .colum-o ul {
        padding-left: 0;
        font-size: 13px;
      }

      .colum-o .img-colum {
        width: 300px;
        margin: 0 auto;
        border-radius: 10px;
      }

      .btn_servis {
        margin-top: 20px;
      }
    }
    

    .title-informativo {
      max-width: 60%;
      font-size: 28px;
      font-weight: bold;
      color: var(--iteazul);
      text-align: center;
      line-height: 1.2;
      margin: 20px auto;
    }

    @media (max-width: 768px) {

      .title-informativo {
        max-width: 95%;
        font-size:20px;
      }
    }
    
    /*
    +++++++
    # SUPERVISION
    ++++++++
    */

    .supervision {
      padding: 40px 0; 
    }
    
    .supervision .container {
      max-width: 1200px;
      margin: 0 auto;
      padding: 0 20px;
    }
    
    .supervision-content {
      display: flex;
      justify-content: space-between;
      align-items: flex-start;
    }
    
    .supervi-column {
      flex: 1;
    }
    
    .supervi-column:first-child {
      margin-right: 20px;
    }

    .supervi-header {
      display: flex;
      align-items: center; 
      margin-bottom: 20px;
      padding-left: 20px;
    }
    
    .icon-image {
      width: 100px;
      height: auto;
      margin-right: 10px;
    }
    
    .supervi-header h2 {
      font-size: 30px;
      color: var(--iteazul); 
      margin: 0;
      line-height: 1.2; 
    }
    
    .supervi-column ul li {
      list-style: none; 
      position: relative;
      padding-left: 20px;
    }
    
    .supervi-column ul li::before {
      content: '•'; 
      position: absolute;
      left: 0;
      font-size: 18px;
      line-height: 1.6;
    }
    
    .supervi-column p {
      font-size: 16px;
      color: var(--iteazul);
      line-height: 1.6;
      margin-bottom: 20px;
      text-align: justify;
      padding-left: 40px;
    }
    
    .supervi-column ul {
      list-style-type: disc;
      padding-left: 20px;
      font-size: 16px;
      line-height: 1.6;
      text-align: justify;
    }
    
    .supervi-column ul li {
      margin-bottom: 15px;
    }

    .image-column {
      max-width: 100%;
      height: auto;
      display: block;
      margin: 0 auto;
      margin-top: 60px;
    }
    
    @media (max-width: 768px) {
      .supervision .container {
        margin-top: -10px;
        width: 95%;
      }
    
      .supervi-header {
        padding-left: 0px;
      }

      .supervi-header h2 {
        font-size: 20px;
      }
      
      .supervision-content {
        flex-direction: column;
        align-items: center;
        text-align: center;
      }
    
      .supervi-column:first-child {
        margin-right: 0;
        margin-bottom: 20px;
      }
    
      .icon-image {
        width: 50px;
      }

      .supervi-column p {
        font-size: 16px;
        padding-left: 0px;
      }
      
      .supervi-column ul {
        padding-left: 0;
        font-size: 14px;
      }

      .image-column {
        width: 300px;
        margin: 0 auto;
        border-radius: 10px;
      }
    }
    
    /*
    +++++++
    # MONITOREO
    ++++++++
    */

    .colum-o p {
      font-size: 16px;
      color: var(--iteazul);
      line-height: 1.6;
      margin-bottom: 20px;
      text-align: justify;
      padding-left: 40px;
    }

    .colum-o p span{
      font-size: 16px;
      color: var(--iteparrafos);
      font-weight: bold;
    }

    .img-colum-ll {
      margin-top: 100px;
      width: 500px;
      margin: 0 auto;
    }

    @media (max-width: 768px) {
      .colum-o p {
        padding-left: 0px;
      }

      .colum-o .img-colum-ll{
        width: 300px;
        margin: 0 auto;
        border-radius: 10px;
      }

    }

  /*-----------------------------------*\
    # MypeSegura-Psicosocial
  \*-----------------------------------*/

    /*
    +++++++
    # Inicial
    ++++++++
    */

  .inspecciones-sst-section {
    padding: 20px 0px;
  }
  
  .inspecciones-sst-section .container {
    max-width: 75%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  
  .content-wrapper {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 40px;
    width: 100%;
  }
  
  .text-content {
    flex: 0 1 45%;
  }
  
  .text-content .title-icon {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  
  .text-content h2 {
    font-size: 35px;
    color: var(--iteazul);
    font-weight: 700;
    line-height: 1.1;
  }
  
  .text-content p {
    font-size: 20px;
    color: var(--iteparrafos);
    font-weight: 400;
    margin-top: 15px;
    line-height: 1.6;
    text-align: justify;
  }
  
  .text-content .text-psicosocial {
    font-size: 17px;
    color: var(--iteparrafos);
    font-weight: 400;
    margin-top: 15px;
    line-height: 1.6;
    text-align: justify;
  }

  .carrusel-content {
    flex: 0 1 45%;
  }
  
  .carrusel-content .slide-container {
    position: relative;
    width: 100%;
    overflow: hidden;
    border-radius: 10px;
  }
  
  .carrusel-content .swiper-wrapper {
    display: flex;
    transition: transform 0.5s ease-in-out;
  }
  
  .carrusel-content .card {
    flex: 0 0 100%;
  }
  
  .carrusel-content .card-image {
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
  }
  
  .carrusel-content .card-image img {
    width: 100%;
    height: auto;
    display: block;
    margin: 0 auto;
  }
  
  
  .card-image-software img {
    width: 100%;
    height: auto;
    margin: 0 auto;
  }
  
  /* Botones de navegación */
  .carrusel-content .swiper-button-next,
  .carrusel-content .swiper-button-prev {
    background-color: var(--iteverde);
    top: 60%;
    width: 30px;
    height: 30px;
    border-radius: 50%;
    transform: translateY(-100%);
  }
  
  .carrusel-content .swiper-button-next {
    right: 0px;
  }
  
  .carrusel-content .swiper-button-prev {
    left: 0px;
  }
  
  .carrusel-content .swiper-button-next::after,
  .carrusel-content .swiper-button-prev::after {
    font-size: 14px;
    font-weight: 700;
    color: #fff;
  }
  
  .carrusel-content .swiper-button-next:hover,
  .carrusel-content .swiper-button-prev:hover {
    background-color: var(--iteazul);
  }
  
  @media (max-width: 768px) {
    .inspecciones-sst-section .container {
      max-width: 80%;
    }
  
    .inspecciones-sst-section .container {
      flex-direction: column;
      align-items: center;
    
    }
  
    .content-wrapper {
      flex-direction: column;
      align-items: center;
      gap: 20px;
    }
  
    .text-content {
      text-align: center;
    }
  
    .text-content h2 {
      font-size: 22px;
    }
  
    .text-content p {
      font-size: 18px;
      text-align: justify;
    }
    .carrusel-content .card-image img {
      width: 90%;
    }
  
    .carrusel-content .card-image-software img {
      width: 100%;
  
    }
  
    .carrusel-content .swiper-button-next,
    .carrusel-content .swiper-button-prev {
      top: 60%;
    }
  
    .carrusel-content .swiper-button-next {
      right: 5px;
    }
    
    .carrusel-content .swiper-button-prev {
      left: 5px;
    }
  }
  
  .btns-infos {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin-top: 20px;
  }
  
  .btn-contactos {
    width: 250px;
    height: auto;
    display: block;
  }
  
  /* Vista mobile */
  @media (max-width: 768px) {
    .btns-infos {
      flex-direction: column; 
    }
  
    .btn-contactos {
      width: 250px;
    }
  }
  
  .title-simple{
    max-width: 55%;
    font-size: 35px;
    text-align: center;
    color: var(--iteazul);
    margin: 0 auto;
  }

  @media (max-width: 768px) {
    .title-simple{
      max-width: 95%;
      font-size: 25px;
    }
  }

    /*
    +++++++
    # REGLAMENTOS
    ++++++++
    */

  .accordion{
  background-color: #F0F6F7;
  }

  .accordion .container{
    padding: 20px 0px;
    width: 100%;
    max-width: 55%;
    margin: 0 auto; 
  }

  .accordion-item {
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
    margin: 10px 0;
    border-radius: 8px;
    overflow: hidden;
    height: auto;
    background-color: #fff;
  }


  .accordion-header {
    background-color: var(--iteverde);
    padding: 15px;
    color: white;
    font-weight: bold; 
    cursor: pointer;
    text-align: center;
    outline: none;
    font-size: 18px;
    transition: background-color 0.3s ease;
    border: none;
    width: 100%;
  }

  .accordion-header::after {
    content: "▼";
    font-size: 20px; 
    float: right; 
    color: white; 
    transition: transform 0.3s ease; 
  }

  .accordion-header.active::after {
    content: "▲"; 
  }

  .accordion-header:hover, .accordion-header.active {
    background-color: #072D70;
  }

  .accordion-content {
    padding: 0 15px;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s ease-out;
    background-color: white;
    color: black;
    text-align: center;
  }


  .accordion-content p {
    margin: 15px 0;
    text-align: justify;
    color: var(--iteparrafos);
  }


  @media (max-width: 1590px) {
    .accordion .container{
      width: 100%;
      max-width: 65%;
      margin: 0 auto; 
    }
  }

  @media (max-width: 1220px) {
    .accordion .container{
      width: 100%;
      max-width: 75%;
      margin: 0 auto; 
    }
  }

  @media (max-width: 706px) {
    .accordion .container{
      width: 100%;
      max-width: 90%;
      margin: 0 auto; 
    }
  }

    /*
    +++++++
    # VISTAS
    ++++++++
    */

  .boton-container {
    display: flex;
    justify-content: space-between;
    width:65%;
    margin: 0 auto 20px auto;
    flex-wrap: wrap;
  }

  .boton-descripcion-container {
    display: flex;
    flex-direction: column;
    align-items: center; 
    width: 25%;
  }

  .boton {
    padding: 10px 5px;
    font-size: 2rem;
    font-weight: bold;
    border: none;
    cursor: pointer;
    transition: background-color 0.3s, transform 0.3s ease; 
    width: 100%; 
    text-align: center;
    border-radius: 10px;
    margin-bottom: 10px; 
  }

  .boton.activo {
      transform: scale(1.3);
  }


  .descripcion {
    display: none;
    font-size: 1.8rem;
    color: var(--iteparrafos);
    list-style: none;
    padding: 0;
    margin-top: 10px;
    text-align: left;
    width: 500px;
    margin-left: 150px;
  }

  .descripcion.activo {
    display: block;
  }

  .descripcion li {
    margin-bottom: 10px;
  }

  .descripcion li::before {
    content: "▪ ";
    color: var(--iteazul);
    font-weight: bold;
  }


  .descripcion-img {
    display: none;
    list-style: none;
    padding: 0;
    margin-top: 10px;
    width: 100%;
    margin-right: 1550px;
  }

  .descripcion-img img{
    width: 1000px;
  }

  .descripcion-img.activo {
    display: block;
  }

  @media (max-width: 768px) {
    .boton-container {
        flex-direction: column; 
        width: 90%; 
    }

    .boton-descripcion-container {
        width: 100%;
    }

    .boton {
        width: 85%; 
    }
  }

  @media (max-width: 480px) {
    .boton {
        font-size: 1.5rem; 

    }

    .descripcion {
      display: none;
      font-size: 1.8rem;
      color: var(--iteparrafos);
      list-style: none;
      padding: 0;
      margin-top: 10px;
      text-align: left;
      width: 320px;
      font-size: 1.8rem; 
      margin-left: 0px;
    }

    .descripcion-img {
      display: none;
      list-style: none;
      padding: 0;
      margin-top: 10px;
      width: 320px;
      margin-right: 30px;
    }
  
    .descripcion-img img{
      width: 350px;
    }

  }

  /*
  +++++++++++++++++++++++
  #  OVERLAY - IMAGENES
  +++++++++++++++++++++++
  */

  .image-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.8);
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1000;
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s, opacity 0.3s ease;
  }

  /* Estilo de la imagen dentro del overlay */
  .overlay-image {
    max-width: 90%;
    max-height: 90%;
    border-radius: 10px;
    box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.5);
  }

  /* Botón para cerrar el overlay */
  .close-overlay {
    position: absolute;
    top: 20px;
    right: 30px;
    color: #fff;
    font-size: 40px;
    font-weight: bold;
    cursor: pointer;
  }

  /* Cuando el overlay está activo */
  .image-overlay.active {
    visibility: visible;
    opacity: 1;
  }

  /*
  +++++++++++++++++++++++
  #  PRECIOS A TU MEDIDA
  +++++++++++++++++++++++
  */

  .precios-medida{
    background-color: #F0F6F7;
    padding: 20px 0px;
  }

  .title-medium{
    max-width: 55%;
    font-size: 35px;
    text-align: center;
    color: var(--iteazul);
    margin: 0 auto;
  }

  @media (max-width: 768px) {
    .title-medium{
      max-width: 95%;
      font-size: 28px;
    }
  }

  .title-celeste{
    max-width: 55%;
    font-size: 35px;
    text-align: center;
    color: var(--iteverde);
    margin: 0 auto;
  }

  @media (max-width: 768px) {
    .title-celeste{
      max-width: 95%;
      font-size: 25px;
    }
  }

  .img-precios-web {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 100%;
    padding: 20px;
  }

  .img-precios-web img {
    width: 100%;
    max-width: 1200px;
    height: auto;
  }

  .img-precios-mobile {
    display: flex;
    justify-content: center;
    align-items: center;
    max-width: 100%;
    padding: 20px;
  }

  .img-precios-mobile img {
    width: 100%;
    max-width: 1200px;
    height: auto;
  }

  .logo-mype{
    margin: 0 auto;
    width: 200px;
  }

  @media (min-width: 768px) {
    .img-precios-mobile {
        display: none; 
    }
  }

  @media (max-width: 767px) {
    .img-precios-web {
        display: none; 
    }
  }

  /*
  +++++++++++++++++++++++
  #  CUALIDADES
  +++++++++++++++++++++++
  */

  .cualidades {
    width: 100%;
    padding: 20px 0;
  }
  
  .cualidades .container {
    max-width: 75%;
    margin: 0 auto;
  }
  
  .imgs-block {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 20px;
  }
  
  .block-img {
    flex: 1;
    text-align: center;
  }
  
  .block-img img {
    width: 100%;
    max-width: 400px;
    height: auto;
    margin: 0 auto;
  }
  
  .block-img p {
    max-width: 50%;
    margin-top: 10px;
    font-size: 1.5rem;
    color: var(--iteparrafos);
    line-height: 1.5;
    margin: 0 auto;
  }
  
  /* Estilos Responsivos */
  @media (max-width: 1024px) {
    .imgs-block {
      flex-direction: column;
      align-items: center;
      gap: 10px;
    }

    .cualidades .container {
      max-width: 90%;
    }
  
    .block-img {
      margin-bottom: 10px;
    }

    .block-img p {
      max-width: 100%;
      margin-top: 15px;
      font-size: 1.5rem;
      margin: 0 auto;
    }

  }
  

  /*
  +++++++++++++++++++++++
  #  VISTAS - PSICOSOCIAL
  +++++++++++++++++++++++
  */


/* Contenedor principal de los botones */
.contenedor-botones {
  display: flex;
  justify-content: space-between;
  width: 65%;
  margin: 0 auto 20px auto;
  flex-wrap: wrap;
}

.contenedor-boton-imagen {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 25%;
}

.boton-imagen {
  padding: 10px 5px;
  font-size: 2rem;
  font-weight: bold;
  border: none;
  cursor: pointer;
  transition: background-color 0.3s, transform 0.3s ease;
  width: 100%;
  text-align: center;
  border-radius: 10px;
  margin-bottom: 10px;
}

.activo-boton {
  transform: scale(1.3);
}

.imagen-contenido {
  display: none;
  text-align: center;
}

.imagen-contenido img {
  width: 900px;  
  height: auto;
  margin: 0 auto;
}

.activo-imagen {
  display: block;
}

.imagen-contenido .imagen-centrada-left {
  margin-left: 700px;
}

.imagen-contenido .imagen-centrada-rigth{
  margin-right: 700px;
}

@media (max-width: 768px) {
  .contenedor-botones {
    flex-direction: column;
    width: 90%;
  }

  .contenedor-boton-imagen {
    width: 100%;
  }

  .boton-imagen {
    width: 85%;
  }

  .imagen-contenido img {
    width: 80%; /* Ajuste para pantallas más pequeñas */
  }

  .imagen-contenido .imagen-centrada-left {
    margin-left: 0px;
    margin: 0 auto;
  }
  
  .imagen-contenido .imagen-centrada-rigth{
    margin-left: 0px;
    margin: 0 auto;
  }
}

@media (max-width: 480px) {
  .boton-imagen {
    font-size: 1.5rem;
  }

  .imagen-contenido img {
    font-size: 1.8rem;
  }
}


/* boton-reunion */

.container-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
  width: 100%; 
}

.btn_servis {
  display: inline-block;
  padding: 10px 20px;
  font-weight: bold;
  font-size: 16px;
  color: white;
  text-align: center;
  text-decoration: none;
  background: linear-gradient(90deg, var(--iteazul), var(--iteverde));
  border-radius: 15px;
  box-shadow: 0 0 10px rgba(2, 188, 255, 0.658);
  transition: transform 0.2s ease-in-out;
  margin-top: 20px;
}

.btn_servis:hover {
  transform: scale(1.05);
}

.btn_servis:active {
  transform: scale(0.98);
}

  /*
  +++++++++++++++++++++++
  #  PLANES
  +++++++++++++++++++++++
  */


  .img-tabla-costos {
    display: block;
    margin: 0 auto;
    max-width: 75%;
    height: auto;
  }
  
  .img-tabla-costos-mobile {
    display: none;
  }
  
  @media (min-width: 768px) {
    .img-tabla-costos {
      display: block;
    }
  
    .img-tabla-costos-mobile {
      display: none;
    }
  }
  
  @media (max-width: 768px) {
    .img-tabla-costos {
      display: none;
    }
  
    .img-tabla-costos-mobile {
      display: block;
      margin: 0 auto;
      max-width: 95%;
      height: auto;
    }
  }
  
  
  /*
  +++++++++++++++++++++++
  #  EXPERIENCIA
  +++++++++++++++++++++++
  */

.experience {
  background-color: #F5F8FA; 
  padding: 50px 0;
}

.experience .container {
  max-width: 1200px;
  margin: 0 auto;
}

.components-experience {
  display: flex;
  justify-content: space-around;
  align-items: center;
  gap: 20px;
}

.section-experience {
  text-align: center;
  flex: 1;
}

.section-experience h3 {
  font-size: 50px;
  color: var(--iteazul); 
  font-weight: bold;
}

.section-experience p {
  font-size: 21px;
  color: var(--iteparrafos);
  margin-top: 10px;
}

.separator {
  width: 5px;
  height: 250px;
  background-color: var(--iteazul); 
}

@media (max-width: 768px) {
  .components-experience {
      flex-direction: column; 
  }
  .separator {
      display: none;
  }
  .section-experience {
      margin-bottom: 20px;
  } 
}

/****** Animaciones *********/

/*+++++ h2 y p +++++*/

.efect-left {
  opacity: 0;
  transform: translateX(-10%);
  transition: opacity 2s ease-out, transform 2s ease-out;
}

.efect-left-visible {
  opacity: 1;
  transform: translateX(0); 
}

/*+++++ boton-accion +++++*/

.efect-rigth-salto {
  opacity: 0;
  transform: translateX(20px); 
  transition: opacity 1.5s ease-out, transform 1.5s ease-out;
}

.efect-rigth-salto-visible {
  opacity: 1;
  transform: translateX(0) scale(1.02);
  animation: bounce 0.8s ease forwards 1.5s;
}

@keyframes bounce {
  0%, 100% {
    transform: translateX(0) scale(1);
  }
  50% {
    transform: translateX(0) scale(1.03);
  }
}

/*+++++ aparicion +++++*/

.efect-aparicion {
  opacity: 0;
  transform: scale(0.9); 
  transition: opacity 1.5s ease-out, transform 1.5s ease-out; 
}

.efect-aparicion-visible {
  opacity: 1;
  transform: scale(1);
}

/*+++++ arriba-abajo +++++*/

.efect-arriba {
  opacity: 0;
  transform: translateY(-20px); 
  transition: opacity 2.5s ease-out, transform 2.5s ease-out; 
}

.efect-arriba-visible {
  opacity: 1;
  transform: translateY(0);
}

/*+++++ derecha +++++*/

.efect-rigth {
  opacity: 0;
  transform: translateX(10%); /* Reducir el desplazamiento inicial */
  transition: opacity 2s ease-out, transform 2s ease-out;
}

.efect-rigth-visible {
  opacity: 1;
  transform: translateX(0); 
}

/*+++++ pequeño-grande +++++*/

.efect-pequeño-grande {
  opacity: 0;
  transform: scale(0.8);
  transition: opacity 1.5s ease-out, transform 1.5s ease-out;
}

.efect-pequeño-grande-visible {
  opacity: 1;
  transform: scale(1); 
}

@media (max-width: 768px) { 
  .efect-pequeño-grande {
    transition: opacity 3s ease-out, transform 2s ease-out; 
     
  }
}

/*+++++ abajo-arriba +++++*/

.efect-abajo {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 1.5s ease-out, transform 1.5s ease-out;
}

.efect-abajo-visible {
  opacity: 1;
  transform: translateY(0);
}

/*+++++ grande-pequeño +++++*/

.efect-grande-pequeño {
  opacity: 0;
  transform: scale(2); 
  transition: opacity 1.5s ease-out, transform 2s ease-out; 
  transition-delay: 1s; 
}

.efect-grande-pequeño-visible {
  opacity: 1;
  transform: scale(1); 
}

/*+++++ izquierda-rapido +++++*/

.efect-left-run {
  opacity: 0;
  transform: translateX(-100%);
  transition: opacity 1.5s ease-out, transform 1.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.efect-left-run-visible {
  opacity: 1;
  transform: translateX(0);
}

@media (max-width: 768px) { 
  .efect-left-run {
  transform: translateX(-0%);
  }
}

/*+++++ cabecera +++++*/

.efect-cabecer {
  opacity: 0;
  transform: translateX(-100%);
  transition: opacity 1s ease-out, transform 1.5s cubic-bezier(0.25, 1, 0.5, 1);
}

.efect-cabecer-visible {
  opacity: 1;
  animation: slide-bounce 1.5s ease forwards;
}

@keyframes slide-bounce {
  0% {
    transform: translateX(-100%);
  }
  70% {
    transform: translateX(50%);
  }
  100% {
    transform: translateX(0);
  }
}
