/* Fonts Definitios*/
/*TITULOS*/
@font-face {
  font-family: Bashield;
  src: url(../fonts/Bashield.otf) format(opentype);
}
/*TITULOS*/
@font-face {
  font-family: Bashield;
  font-style: italic;
  src: url(../fonts/Bashield\ Italic.otf) format(opentype);
}
/*TIPOGRAFICA DE MARCA (LOGO)*/
@font-face {
  font-family: Hastina;
  src: url(../fonts/Hastina.otf) format(opentype);
}
/*TEXTOS*/
@font-face {
  font-family: Minerva;
  src: url(../fonts/Minerva_Modern_Regular.otf) format(opentype);
}
/*TEXTOS*/
@font-face {
  font-family: Minerva;
  font-weight: bold;
  src: url(../fonts/Minerva_Modern_Bold.otf) format(opentype);
}
/*TEXTOS*/
@font-face {
  font-family: Minerva;
  font-style: italic;
  src: url(../fonts/Minerva_Modern_Italic.otf) format(opentype);
}
/*TEXTOS*/
@font-face {
  font-family: Minerva_Black;
  src: url(../fonts/Minerva_Modern_Black.otf) format(opentype);
}
/*TEXTOS*/
@font-face {
  font-family: Minerva_Black;
  font-style: italic;   
  src: url(../fonts/Minerva_Modern_Black_Italic.otf) format(opentype);
}
/*FIRMA*/
@font-face {
  font-family: DancingScript;
  src: url(../fonts/DancingScript-Regular.ttf) format(truetype);
}
/*FIRMA*/
@font-face {
  font-family: DancingScript;
  font-weight: bold;
  src: url(../fonts/DancingScript-Bold.ttf) format(truetype);
}
/*FIRMA*/
@font-face {
  font-family: DancingScript;
  font-weight:600;
  src: url(../fonts/DancingScript-Medium.ttf) format(truetype);
}
body {
  font-family: Minerva, sans-serif;
  text-align: center;
}
h1 {
  font-family: Bashield, serif;
  font-weight: 700;
  font-size: 2.5em;
}
h2,
h3,
h4,
h5,
h6 {
  font-family: Bashield, serif;
  font-weight: 700;
}
p {
  color: #2B1936;
  text-align: justify;
  font-weight: 500;
  font-size:x-large;
}
li {
  color: #2B1936;
  text-align: justify;
  font-weight: 500;
}
hr {
  border-color: transparent;
  border-style: none;
  border-width: 0px;
  border-bottom: none;
  width: 5%;
  margin: 10px auto;
  clear: both;
  visibility: hidden;
}
.hr-violet {
  border-top:2px solid #52366C;
  visibility: visible;
  width: 100%;

}
.accordion {
  box-shadow: 10px 10px 5px #914267;
  font-size: x-large;
}
.accordion-body li {
  transform: translate3d(-10px, 0, 0);
}
.accordion-body li.show {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition: all 0.3s ease-in-out;
}
footer {
  padding-top: 3%;
}
/* Sections */
.violet-section {
  background-color: #AC74AC;
  color: #52366C;
  }
.dark-violet-section{
    background-color: #52366C;
  }
.pink-section {
  background-color: #AC74AC;
  color: #52366C;
  }
.violet-section-no-gradiet {
  background-color: #AC74AC;
  color: #52366C;
}
.pink-section-no-gradiet {
  background-color: #AC74AC;
  color: #52366C;
}
.titulo {
  padding: 5% 0 2% 0;
}
.titulo-presentacion{
  padding: 1% 0 0 0;
  margin: 0;
}
.p-format {
  padding: 0 5% 0 5%;
  /* margin: 5% 0 0 5%; */
  color: #2B1936;
}
.orange-box{
  background-color: #DE907F;
  margin: 0px 30px 30px 0px;
  padding: 2%;
  margin-left: 3%;
  margin-right: 3%;
}

.white-box{
  background-color: #FBF1DE;
  margin: 0px 30px 30px 0px;
  border-radius: 2%;
  margin: 3%;
}
.violet-box{
  background-color: #AC74AC;
  margin: 0px 30px 30px 0px;
  border-radius: 2%;
  margin: 3%;
}

.quien-soy{
  padding: 7% 1%;
}

.dark-violet-box{
  background-color: #2B1936;
  padding: 2%;
  margin-left: 3%;
  margin-right: 3%;
}
.free-text-left{
  margin:30px 0px 30px 0px;
}
.orange-box-text{
  color:#FBF1DE;
  font-family: "Minerva",sans-serif;
  font-size: 24px;
  font-weight: 500;
  margin: 2%;
  /* padding-left: 1%; */
  padding-right: 3%;
}
.p-center {
  margin: auto;
  width: 100%;
  padding: 0px 30px 0px 30px;
}
.titulo-servicios{
  margin-top: 5%;
  color: #2B1936;
  text-align: center;
  line-height: normal;
  font-weight: bold;
}
.titulo-servicios-blanco{
  margin-top: 5%;
  color: #FBF1DE;
  text-align: center;
  line-height: normal;
  font-weight: bold;
}
.titulo-barras {
  padding: 50px 0 0 0;
  height: 350px;
}
.white-section {
  background-color: #FBF1DE;
  color: #2B1936;
  padding: 8% 0% 8% 0%;
}
.white-section-taller {
  background-color: #FBF1DE;
  color: #2B1936;
  padding: 2% 0% 2% 0%;
}
.white-accordion {
  background-color: #FBF1DE;
  color: #2B1936;
}
.white-text{
  color: #FBF1DE;
  padding: 0% 3%;
}
.green-section {
  background-image: linear-gradient(#adeaee, #24a9b3);
}
.green-section-flat {
  background-color: #DE907F;
  color: #DE907F;
}
.green-section-flat-dark {
  background-color: #52366C;
  color: #52366C;
  text-align: center;
  padding-top: 0%;
  padding-bottom: 0%;
}
/* Botones */
#btn-back-to-top {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: none;
}
#btn-float-whatsapp {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: block;
}
.listas {
  color: #2B1936;
  text-align: justify;
}
.btn-cta {
  padding-top: 2%;
}
.btn-rounded {
  border-radius: 100%;
  z-index: 999;
  text-decoration: none;
}
.btn-primary {
  background-color: #52366C;
  border-color: #52366C;
}
.btn-primary:hover {
  background-color: #AC74AC;
  border-color: #AC74AC;
  color: #52366C;
}
.btn-secondary {
  background-color: #DE907F;
  border-color: #DE907F;
  margin: 0 auto 1rem auto;
}
.btn-secondary:hover {
  background-color: #F0A78E 3px 3px;
  border-color: #F0A78E 3px 3px;
  color: #DE907F;
}
/* Acordeon */
.accordion-button {
  background-color: #F0A78E;
  color: #FBF1DE;
  font-size: x-large;
}
.collapsed {
  background-color: #F0A78E;
  color: #FBF1DE;
}
.accordion-button:not(.collapsed) {
  background-color: #AC74AC;
  color: #52366C;
}
.accordion-button:focus {
  border-color: #AC74AC;
}
.accordion-body {
  text-align: justify;
}
/* Barra de Navegación y Titulos */
.navbar {
  background-color: #52366C;
  padding: 0 0 0.1rem;
}
.marca {
  font-family: Bashield;
  color: #FBF1DE;
}
.lema {
  color: #24a9b3;
}
.navbar-brand {
  padding-left:1% ;
}
.navbar-dark .navbar-nav .nav-link {
  color: #FBF1DE;
  font-size:large;
}
.navbar-dark .navbar-nav .dropdown-item {
  color: #FBF1DE;
}
.header-unpin {
  position: fixed;
  opacity: 0;
  transform: translate3d(0, -100%, 0);
  transition: all 0.3s ease-in-out;
}
.header-pin {
  position: fixed;
  background: #fff;
  opacity: 1;
  border-bottom: 1px solid #cecece;
  transform: translate3d(0, 0%, 0);
  transition: all 0.6s ease-in-out;
}
.nav-item {
  padding: 0 18px;
}
.texto-titulo {
  font-family: Bashield, sans-serif;
  color: #52366C;
}
.ocultar{
  visibility: hidden;
}
.texto-titulo-color2 {
  font-family: Bashield, sans-serif;
  color: #DE907F;
}
.texto-titulo-color3 {
  font-family: Bashield, sans-serif;
  color: #52366C;
}
.texto-titulo-color1 {
  font-family: Bashield, sans-serif;
  color: #52366C;
  text-align: center;
  font-weight: 600;
  text-shadow: #AC74AC 3px 3px;
}
.texto-titulo-naranja{
  font-family: Bashield, sans-serif;
  color: #DE907F;
  text-align: center;
  font-weight: 600;
}
.texto-titulo-blanco{
  font-family: Bashield, sans-serif;
  color: #FBF1DE;
  text-align: center;
  font-weight: 600;
}
.texto-titulo-white {
  font-family: Bashield, sans-serif;
  color: #52366C;
  text-align: center;
  font-weight: 400;
}
.img-intro{
  width: calc(70%);
  max-width: calc(70%);
}
.img-intro-taller{
  width: calc(100%);
  max-width: calc(100%);
  padding: 0;
}
.texto-titulo-green {
  font-family: Bashield, sans-serif;
  color: #DE907F;
  text-align: center;
  font-weight: 400;
  text-shadow: #F0A78E 3px 3px;
}
.texto-titulo-orange {
  font-family: Bashield, sans-serif;
  color: #DE907F;
  text-align: center;
  font-weight: 400;
}
.texto-subtitulo {
  font-family: Bashield, sans-serif;
  color: #52366C;
  padding: 3% 0;
  font-size:56px;
}
.texto-centrado-violeta{
  text-align: center;
  align-items: center;
  color: #52366C;
  font-family: Bashield, sans-serif;
  padding: 3%;
}
.texto-left-violeta{
  text-align: left;
  align-items: center;
  color: #52366C;
  font-family: Bashield, sans-serif;
  padding: 3%;
}
.texto-right-violeta{
  text-align: right;
  align-items: right;
  color: #52366C;
  font-family: Bashield, sans-serif;
}
.texto-left-white{
  text-align: left;
  align-items: center;
  color: #FBF1DE;
  font-family: Bashield, sans-serif;
  padding-left: 3%;
}
.texto-right-white{
  text-align: right;
  align-items: center;
  color: #FBF1DE;
  font-family: Bashield, sans-serif;
  padding-right: 3%;
}
.texto-centrado-white{
  text-align: center;
  align-items: center;
  color: #FBF1DE;
  font-family: Bashield, sans-serif;
}

.texto-alineado-naranja{
  text-align: left;
  align-items: center;
  color: #DE907F;
  font-family: Bashield, sans-serif;
  padding: 3%;
}
.texto-alineado-violeta{
  text-align: left;
  align-items: center;
  color:#52366C ;
  font-family: Bashield, sans-serif;
  padding: 3%;
}

.texto-centrado {
  text-align: center;
  align-items: center;
  padding: 5%;
}
.texto-subtitulo-blanco {
  font-family: Bashield, sans-serif;
  color: #FBF1DE;
  padding: 3% 0; 
  font-size:56px;
}
.texto-subtitulo2 {
  font-family: Bashield, sans-serif;
  font-size: xx-large;
  color: #52366C;
  text-shadow: #AC74AC  2px 2px;
  padding: 3% 0;
  font-size:56px;
}
.texto-presentacion {
  padding: 15px 0 0 0;
  color: #52366C;
}
.texto-welcome{
  font-family: Bashield, sans-serif;
  font-size:x-large;
  font-weight: 800;
  color: #52366C;
}
.texto-resaltado{
  font-family: Bashield, sans-serif;
  font-size:x-large;
  font-weight: 800;
  color: #DE907F;
}
.texto-firma {
  font-family: DancingScript, cursive;
  color: #52366C;
  margin-bottom: 5%;
}
.lista-inicio{
  text-align: justify;
  padding-left: 10%;
  padding-right: 6%;
  font-size:x-large;
}
.main-image {
  width: 28%;
  transform: rotate(0deg);
  position: absolute;
  top: 26%;
  right: -1%;
  z-index: 2;
}
.main-image-barras {
  width: 28%;
  transform: rotateY(180deg);
  position: absolute;
  top: 12%;
  right: -1%;
  z-index: 2;
}
.modal-title {
  color: #52366C;
  font-size: x-large;
}
.title-image {
  width: 50%;
  border-radius: 5%;
  opacity: 1;
  box-shadow: 10px 10px 5px #F0A78E;
}
.halfsize-image{
  width: calc(80%);
  max-width: calc(80%);
  padding: 10%;
}
.contenedor{
  position: relative;
}
.halfsize-image-transparent{
  display: block;
  width: calc(45%);
  max-width: calc(45%);
 margin-left: 30%;
}
.halfsize-image-transparent-taller{
  display: block;
  width: calc(100%);
  max-width: calc(100%);
 margin-left: 5%;
}
.halfsize-image-transparent-barras{
  display: block;
  width: calc(60%);
  max-width: calc(60%);
 margin-left: 5%;
}
.box-vert-center{
  vertical-align: bottom;
}
.halfsize-image-transparent-barras-2{
  display: block;
  width: calc(95%);
  max-width: calc(95%);
 margin-left: 5%;
 margin-right: 20%;
 padding-bottom: 0;
 margin-bottom: 0;
}
.halfsize-image-transparent-taller-2{
  display: block;
  width: calc(70%);
  max-width: calc(70%);
 margin-left: 10%;
}
#intro {
  position: relative;
  z-index: 1;
}
/* Sobre Mi */
.card {
  text-align: center;
  border-radius: 2%;
}
.card-selfie {
  width: 100%;
  border-radius: 5%;
  align-self: center;
  padding: 3%;
  box-shadow: 10px 10px 5px #AC74AC;
}
.card-selfie-barras {
  width: 60%;
  background-color: #fff;
  align-self: center;
}
.card-body {
  border-radius: 25%;
}
.card-consultorio {
  width: 60%;
  border-radius: 100%;
  align-self: center;
}
.card-text {
  text-align: justify;
}
.card-title {
  color: #52366C;
}
.list-group-item {
  text-align: justify;
  color: #52366C;
  padding: 0 3rem;
}
.text-primary {
  color: #52366C !important;
}
/* Footer */
.list-inline-item {
  color: #FBF1DE ;
}
.footer{
  background-color: #52366C;
}
.footer-text {
  color: #FBF1DE;
  font-weight: bold;
  text-align: center;
}
.footer-icons {
  text-align: center;
  padding: 0;
}
.iconos {
  text-decoration: none;
  color: #FBF1DE;
}
.iconos:hover {
  color: #FFF;
}
.image-box img {
    width: 100%;
    height: 100%;
    /* object-fit: cover; */
    padding: 5%;
}
.image-zoom img {
  width: 125%;
}
.image-box {
  display: block;
  max-height: 350px;
  /* width:33.3%; */
  overflow: hidden;
  height: 100%;
  margin: 5% 0;
  padding: 10% 0;
}
.box-container {
  display: inline-block;
  margin: 0;
  padding: 0;
  margin-top: 1.4em;
  width: 100%;
}
.box {
  list-style-type: none;
  float: left;
  opacity: 0;
  transform: translate3d(0, 40px, 0);
  transition: opacity 0.2s, transform 0.35s;
}
.box.show {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  transition: opacity 0.4s, transform 0.35s;
}
.box .inner {
  padding: 10px;
  position: relative;
}
.box a {
  display: block;
  width: 100%;
  height: auto;
  position: relative;
  overflow: hidden;
}
.box img {
  width: calc(100%);
  max-width: calc(100%);
  border-radius: 10%;
}
.box a::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: #000;
  z-index: 99;
  opacity: 0;
  transition: opacity 0.4s;
}
.three-cols .box {
  width: 100%;
}
.four-cols .box {
  width: 25%;
}
.four-cols .box:nth-child(4n+0) {
  margin-right: 0;
}
.four-cols .box:nth-child(4n+1) {
  clear: both;
  margin-left: 0;
}


 /* Estilos para el slider de scroll continuo */
.scrolling-wrapper {
    overflow: hidden; /* Oculta las imágenes que se salen del contenedor */
    white-space: nowrap; /* Evita que las imágenes salten de línea */
    position: relative; /* Necesario para posicionar las imágenes si es necesario */
    padding: 20px 0; /* Espaciado vertical opcional */
    box-shadow: 0 4px 8px rgba(129, 75, 165, 0.1); /* Sombra suave para destacar */
}

.scrolling-wrapper .image-container {
    display: inline-block; /* Permite que los divs estén en la misma línea */
    animation: scroll-left 180s linear infinite; /* Animación: nombre, duración, tipo, repetición */
    /* Duplicamos el ancho para asegurarnos de que haya espacio para el bucle */
    width: fit-content; /* Se ajusta al contenido para que la animación funcione mejor */
}

.scrolling-wrapper .image-container img {
    height: 500px; /* Altura fija para las imágenes */
    width: auto; /* Ancho automático para mantener la proporción */
    margin: 0 15px; /* Espacio entre imágenes */
    vertical-align: middle; /* Alineación vertical para imágenes pequeñas */
    filter: grayscale(0%); /* Opcional: Desaturar Images */
    transition: filter 0.3s ease; /* Transición suave para el hover */
    border-radius: 10%;
}

.scrolling-wrapper .image-container img:hover {
    filter: grayscale(80%); /* Opcional: Color al pasar el ratón */
}

  /* Definición de la animación */
  @keyframes scroll-left {
      0% {
          transform: translateX(0%); /* Empieza en la posición original */
      }
      100% {
          transform: translateX(-50%); /* Se mueve el 50% de su propio ancho hacia la izquierda */
      }
  }

  /* Si quieres que vaya a la derecha, cambia el keyframes a: */
  
  @keyframes scroll-right {
      0% {
          transform: translateX(-50%);
      }
      100% {
          transform: translateX(0%);
      }
  }
  

  /* Pausar animación al pasar el ratón (opcional) */
  .scrolling-wrapper:hover .image-container {
      animation-play-state: paused;
  }



/* Media Querys */
@media (min-width: 390px) {
  .three-cols .box {
    width: 100%;
  }

  .four-cols .box{
    width: 100%;
  }

   .texto-subtitulo{
    font-size: 36px;
    text-align: center;
  }

   .halfsize-image{
  width: calc(95%);
  max-width: calc(95%);
  padding: 10%;
}

.img-intro-taller{
  width: calc(100%);
  max-width: calc(100%);
}
.scrolling-wrapper .image-container img {
                height: 500px; /* Un poco más pequeñas en móviles */
                margin: 0 10px;
            }


@media (max-with: 500) {
  .marca {
    text-indent: -9999;
    white-space: nowrap;
    overflow: hidden;
    visibility: hidden;
    display: none;
  }
}

}


@media (min-width: 576px) {
  .three-cols .box {
    width: 33.3%;
  }

  .three-cols .box:nth-child(3n+0) {
    margin-right: 0;
  }

  .three-cols .box:nth-child(3n+1) {
    margin-left: 0;
  }

  .four-cols .box {
    width: 25%;
  }



}



@media (min-width: 768px) {
  .modal-xl {
    width: 90%;
    max-width: 1200px;
  }
 .halfsize-image{
  width: calc(80%);
  max-width: calc(80%);
  padding: 10%;
   
}
.img-intro-taller{
  width: calc(100%);
  max-width: calc(100%);
}


}


@media (min-width: 992px) {
  h1 {
    font-size: 3.8em;
  }


 .texto-subtitulo{
    font-size: 56px;
    text-align: center;
  }

  .box:hover img {
    transform: translate3d(0, 0, 0);
    transition: opacity 0.35s, transform 0.35s;
  }

  .box:hover a::before {
    opacity: 0.3;
    transition: opacity 0.5s;
  }
}

@media (max-width: 1280px) {

  
  .main-image {
    position: static;
    width: 55%;
    /* top:40%; */
    right: 20%;
    transform: rotate(0);
  }

  .main-image-barras {
    position: static;
    width: 55%;
    /* top:40%; */
    right: 20%;
    transform: rotate(0);
  }

  .titulo {
    padding: 5% 0 2% 0;
    /* height: 400px; */
  }

  .titulo-barras {
    padding: 15px 0 0 0;
    height: 320px;
  }

  .card-selfie-barras {
    margin-bottom: 5%;
  }
}