:root {
  --morado: #6a2dbd;
  --blanco: #ffffff;
  --aqua: #4ecdc4;
  --gris: #f5f5f5;
  --texto: #333;
  --whats: #25D366;
  --verdin: #e9f9f9;
  --verdemas: #19c6c2;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Segoe UI", sans-serif;
  color: var(--texto);
  background: var(--gris);
  line-height: 1.6;
}

.container {
  width: 90%;
  max-width: 1200px;
  margin: auto;
}

/* HEADER */
.header {
  background: #fff;
  border-bottom: 2px solid #eaeaea;
position:fixed;
z-index:100;
width:100%;
}

.header-content {
	 background: #fff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 0;

}

.logo {
height:80px;
}


.nav a {
  margin-left: 1.2rem;
  text-decoration: none;
  color: var(--texto);
  font-weight: 500;

}

.nav a:hover {
  color: var(--morado);
}

.interruptor {
height:25px;
}
.engclass{
color: var(--aqua);
  font-weight: 500;
}
.espclass{
color: var(--morado);
  font-weight: 500;
}

.interruptor2 {

display:none;
}

/* HERO */
.herosomos {
  /*background: #fff;*/
  padding: 12rem 0 4rem 0;
 background:
        linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)),
        url("../img/somos.jpg")
        center/cover no-repeat;
}

.herocont{
  /*background: #fff;*/
  padding: 12rem 0 4rem 0;

 background:
        linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)),
        url("../img/mapa.jpg")
        center/cover no-repeat;


}
.heroflota {  
  padding: 12rem 0 4rem 0;
 background:
        linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)),
        url("../img/flota.jpg")
        center/cover no-repeat;
}

.hero {
  /*background: #fff;*/
  padding: 12rem 0 4rem 0;

 background:
        linear-gradient(rgba(0,0,0,0.5), rgba(0,0,0,0.5)),
        url("../img/hero.jpg")
        center/cover no-repeat;

/*background-image: url("../img/hero.jpg");
background-repeat: no-repeat; */
}

.hero-grid {
  display: grid;
  gap: 2rem;


}


.hero-text{
color: var(--gris);
}

.hero-text h1 {
  color: var(--aqua);
  font-size: 2rem;
  margin-bottom: 1rem;

	
}

.hero-card {
  background: #fafafa;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: 0 10px 25px rgba(0,0,0,.05);
}

.hero-card h3 {
  margin-bottom: 1rem;
  color: var(--morado);
}

.hero-card input {
  width: 100%;
  padding: .7rem;
  margin-bottom: .8rem;
  border-radius: 6px;
  border: 1px solid #ddd;
}

/* BOTONES */
.btn-primary {
  display: inline-block;
  background: var(--morado);
  color: #fff;
  padding: .8rem 1.5rem;
  border-radius: 30px;
  text-decoration: none;
  margin-top: 1rem;
}

.btn-secondary {
  width: 100%;
  padding: .7rem;
  background: var(--aqua);
  border: none;
  color: #fff;
  border-radius: 6px;
  cursor: pointer;
}

/* TRUST */
.trust {
    background: var(--verdin);
    padding: 25px;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 15px;
    text-align: center;
}

/* SERVICES F2 */
.servicesf2 {
    padding: 60px 25px;
}

.servicesf2 h2 {
    text-align: center;
    margin-bottom: 40px;
	color: var(--morado);
}

.servicesf2-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.servicef2-card {
    border: 1px solid #eee;
    border-radius: 16px;
    padding: 5px;
    background-color: white;
}
.servicef2-card img{
width: 100%;
object-fit: cover;

}

.servicef2-card h3 {
    margin-bottom: 10px;
    color: #6a3dbb;
}

.servicelink {
    color: var(--verdemas);
    text-decoration: none;
    font-weight: 500;
}

.linkservice {
    color: var(--morado);
    text-decoration: none;
    font-weight: 500;
}
.servicelink {
    color: var(--aqua);
    text-decoration: none;
    font-weight: 500;
}
/* PRIVATE */
.private {
    /*background: #efe9fb;*/
    background: var(--blanco);
    padding: 60px 25px;
    text-align: center;

   
}
.private img{   
	width:60%;   
}
/* TOURS */
.tours {
    background: var(--verdin);
    padding: 60px 25px;
    text-align: center;
}
.tours img{   
	width:60%;   
}

/* RESPONSIVE TABLET */
@media (min-width: 768px) {

    .servicesf2-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .trust {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* RESPONSIVE DESKTOP */
@media (min-width: 1024px) {
    .servicesf2-grid {
        grid-template-columns: repeat(4, 1fr);
    }
}


/* SERVICES */
.services {
  padding: 3rem 0;
}

.services-grid {
  display: grid;
  gap: 2rem;
}

.service {
  background: #fff;
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(0,0,0,.05);
}

.service img {
  width: 100%;
  height: 205px;
  object-fit: cover;
}

.service h3 {
  padding: 1rem;
  color: var(--morado);
}

.service p {
  padding: 0 1rem 1.2rem;
}

/*=======BEGINDIVIDUALES ===========*/

.btn-primdiv {
  display: inline-block;
  background: var(--verdemas);
  color: #fff;
  padding: .8rem 1.5rem;
  border-radius: 30px;
  text-decoration: none;
  margin-top: 1rem;
}




/* CONTENIDO */

.containertind{
max-width:1100px;
margin:40px auto;
padding:20px;
display:grid;
grid-template-columns:2fr 1fr;
gap:30px;
}

.contenttind{
background:white;
padding:30px;
border-radius:10px;
box-shadow:0 4px 15px rgba(0,0,0,0.1);
}

.contenttind h2{
margin-top:0;
}

ul{
padding-left:20px;
}

/* SIDEBAR */

.sidebar{
background:white;
padding:25px;
border-radius:10px;
box-shadow:0 4px 15px rgba(0,0,0,0.1);
height:fit-content;
position:sticky;
top:20px;
}

.pricetind{
font-size:28px;
color:var(--morado);
font-weight:bold;
margin:10px 0;
}

.btn{
display:block;
text-align:center;
padding:12px;
margin-top:10px;
border-radius:6px;
text-decoration:none;
font-weight:bold;
}

.btn-whatsapp{
background:#25D366;
color:white;
}

.btn-whatsapp:hover{
background:#1ebe5d;
}

/* RESPONSIVE */

@media(max-width:768px){
.containertind{
grid-template-columns:1fr;
}
.herotind{
height:250px;
}
}
/*============ENDINDIVIDUALES=============*/






/* RESPONSIVE */
@media (min-width: 860px) {
  .hero-grid {
    grid-template-columns: 2fr 1fr;
    align-items: center;
  }

  .services-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.hamburger {
  display: none;
  flex-direction: column;
  cursor: pointer;
}

.hamburger span {
  width: 25px;
  height: 3px;
  background: var(--morado);
  margin: 4px 0;
  transition: all 0.3s ease;
}

/* Animación a X */
.hamburger.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}
.hamburger.active span:nth-child(2) {
  opacity: 0;
}
.hamburger.active span:nth-child(3) {
  transform: rotate(-45deg) translate(6px, -6px);
}

@media (max-width: 1010px) {
  .nav {
/*    position: fixed;
    top: 0;
    right: -100%;
    height: 100vh;
    width: 260px;
    background: #fff;
    flex-direction: column;
    align-items: center;
    padding: 5rem 2rem;
    gap: 1.5rem;
    box-shadow: -10px 0 30px rgba(0,0,0,.1);
    transition: right 0.4s ease;*/


    position: fixed;
    top: 100px;
    right: -100%;
    width: 100%;
    height: calc(100vh - 70px);
    background: white;
    display: flex;
    flex-direction: column;
    align-items: left;
    padding-top: 20px;
    gap: 25px;

  }
  .interruptor {
    display:none;
  }
  .interruptor2 {
    display:flex;
  }
.lang-switch{ 
  margin-left:20px; 
}
  .nav.open {
    right: 0;
  }

  .hamburger {
    display: flex;
  }

  .nav a {
    font-size: 1.1rem;
	/*border: 1px solid #ff0000;*/
  }
}

.whatsapp-float {
  position: fixed;
  bottom: 20px;
  right: 20px;
  background: #25d366;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 8px 20px rgba(0,0,0,.25);
  z-index: 999;
  transition: transform 0.3s ease;
}

.whatsapp-float img {
  width: 32px;
}

.whatsapp-float:hover {
  transform: scale(1.1);
}

/*========CARDS FLOTILA*/
/* TARJETAS */
.containerflo{
    width:90%;
    max-width:1200px;
    margin:60px auto;
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
    gap:30px;
}
.cardflo{
    background:white;
    border-radius:10px;
    overflow:hidden;
    box-shadow:0 4px 12px rgba(0,0,0,0.1);
    transition:0.3s;
}
.cardflo:hover{
    transform:translateY(-5px);
}
.cardflo img{
    width:100%;
    height:200px;
    object-fit:cover;
}
.card-bodyflo{
    padding:20px;
}
.card-bodyflo h3{
    margin-top:0;
}
.infoflo{
    font-size:14px;
    margin:8px 0;
}
.infoflo2{
    font-size:20px;
    margin:8px 0;
	font-weight: bold;
	color:var(--morado);
}

.buttonsflot{
    display:flex;
    gap:10px;
    margin-top:15px;
}

/*=======CARDS FLOTILLA */



/*=========TAV==========*/
table{
    width:100%;
    border-collapse:collapse;
    background:white;
    box-shadow:0 4px 15px rgba(0,0,0,.1);
}

th, td{
    padding:5px;
    padding-top:10px;
    padding-bottom:10px;
    text-align:center;
    border:1px solid #ddd;
}

.tdg{
    background:var(--gris);
    /*color:black;
    font-size:14px;*/
	color:var(--aqua);
}

.tdg2{
   background:var(--morado);
    /*color:black;*/
    font-size:18px;
	color:var(--blanco);
}
.tdg4{
    background:var(--gris);
    /*color:black;*/
    font-size:14px;
	color:var(--morado);
}
.tdg3{
    background:var(--gris);
    /*color:black;*/
    font-size:14px;
	color:var(--morado);
}

th{
    background:var(--gris);
    color:var(--texto);
    font-size:14px;
}

td{
    cursor:pointer;
    transition:.2s;
}

td:hover{
    background:var(--aqua);
}

.parraf{
    font-size:18px;
    text-align:justify;
    max-width:850px;
    margin:0 auto 25px;
}
.parrmor{
    color:var(--morado);
	font-weight: bold;
}
.tdg4 img{
    width:100%;
   /* height:150px;*/
    object-fit:contain;
}


/* MODAL */

.modal{
    display:none;
    position:fixed;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:rgba(0,0,0,.6);
    justify-content:center;
    align-items:center;
    z-index:1000;
}

.modal-content{
    background:white;
    width:90%;
    max-width:500px;
    padding:30px;
    border-radius:10px;
    position:relative;
    animation:fadeIn .3s ease;
}

@keyframes fadeIn{
    from{opacity:0; transform:translateY(-10px);}
    to{opacity:1; transform:translateY(0);}
}

.close{
    position:absolute;
    right:15px;
    top:10px;
    font-size:20px;
    cursor:pointer;
}

.modal-content input{
    width:100%;
    padding:5px;
    margin-top:10px;
}

.btn-group{
    display:flex;
    gap:10px;
    margin-top:20px;
}

button{
    flex:1;
    padding:10px;
    border:none;
    border-radius:6px;
    cursor:pointer;
    font-weight:bold;
}
.btn{
    flex:1;
    padding:10px;
    border:none;
    cursor:pointer;
    border-radius:5px;
    font-weight:bold;
}
.btn-cotizar{
    background:var(--morado);
    color:white;
}

.btn-wsp{
    background:var(--whats);
    color:white;
}


.btn-cotprin{
    background:var(--verdemas);
    color:white;
}

.btn-verif{
    display:flex;
    gap:10px;
    margin-top:10px;
    background: var(--verdin);
}
.btn-verif2{
    display:flex;
    gap:10px;
    margin-top:10px;
    background: var(--blanco);
}
.imgverif{
    display:block;
    margin:auto;
    margin-top:10px;
    margin-bottom:10px;
    
}
.inverif{
    text-align: center;
    
}
/*=========TAV==========*/



/*======FTR================*/
/* FOOTER */
/* BASE */

.footer-pro{
  position:relative;
  background:linear-gradient(135deg,#140a2d,#0d3b66,#1f7a8c);
  color:#fff;
  padding-top:60px;
  overflow:hidden;
}

/* EFECTO GLASS */

.footer-pro::before{
  content:"";
  position:absolute;
  width:300px;
  height:300px;
  background:rgba(168,218,220,0.15);
  filter:blur(120px);
  top:-50px;
  left:-50px;
}

.footer-pro::after{
  content:"";
  position:absolute;
  width:300px;
  height:300px;
  background:rgba(128,0,255,0.2);
  filter:blur(120px);
  bottom:-50px;
  right:-50px;
}

/* CTA */

.footer-cta{
  text-align:center;
  margin-bottom:40px;
}

.footer-cta h2{
  margin:0;
  font-size:28px;
}

.footer-cta p{
  color:#ccc;
}

.btn-cta{
  display:inline-block;
  margin-top:15px;
  padding:12px 25px;
  background:#25D366;
  color:white;
  border-radius:30px;
  text-decoration:none;
  font-weight:bold;
  transition:.3s;
}

.btn-cta:hover{
  transform:translateY(-2px);
}

/* CONTENEDOR */

.footer-container{
  max-width:1200px;
  margin:auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:30px;
  padding:0 20px;
  position:relative;
  z-index:2;
}

/* COLUMNAS */

.footer-col h3,
.footer-col h4{
  margin-bottom:15px;
  color:#a8dadc;
}

.footer-col p{
  color:#ddd;
  font-size:14px;
}

/* MENÚ */

.footer-col ul{
  list-style:none;
  padding:0;
}

.footer-col ul li{
  margin-bottom:8px;
}

.footer-col ul li a{
  color:#ccc;
  text-decoration:none;
  transition:.3s;
}

.footer-col ul li a:hover{
  color:#a8dadc;
}

/* CERTIFICACIONES */

.footer-col.center{
  text-align:center;
}

.certs{
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}

.certs img{
  width:100px;
  background:white;
  padding:5px;
  border-radius:8px;
  transition:.3s;
  margin:3px;	  
}

.certs img:hover{
  transform:scale(1.1);
}

/* REDES */

.socials{
  display:flex;
  justify-content:center;
  gap:10px;
  margin-bottom:10px;
}

.socials a{
  width:38px;
  height:38px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.1);
  border-radius:50%;
  transition:.3s;
}

.socials a:hover{
  background:#25D366;
}

/* BOTON WHATS */

.btn-whatsappfoo{
  display:inline-block;
  margin-top:10px;
  padding:10px 15px;
  background:#25D366;
  color:white;
  border-radius:6px;
  text-decoration:none;
  font-size:14px;
}

/* COPYRIGHT */

.footer-bottom{
  text-align:center;
  margin-top:40px;
  padding:15px;
  border-top:1px solid rgba(255,255,255,0.1);
  font-size:13px;
  color:#bbb;
}

/* RESPONSIVE */

@media(max-width:900px){
  .footer-container{
    grid-template-columns:1fr 1fr;
    text-align:center;
  }
}

@media(max-width:600px){
  .footer-container{
    grid-template-columns:1fr;
  }
}

/*============LANGUAGE00*/

.lang-switch{
  display:flex;
  align-items:center;
  gap:8px;
  font-size:14px;
  color:#fff;
}

/* SWITCH */

.switch{
  position:relative;
  display:inline-block;
  width:46px;
  height:24px;
/*border:1px solid #ff0000;*/
}

.switch input{
  opacity:0;
  width:0;
  height:0;
}

.slider{
  position:absolute;
  cursor:pointer;
  top:0;
  left:0;
  right:0;
  bottom:0;
  background:var(--morado);
  border-radius:30px;
  transition:.4s;
}

.slider:before{
  position:absolute;
  content:"";
  height:18px;
  width:18px;
  left:3px;
  bottom:3px;
  background:white;
  border-radius:50%;
  transition:.4s;
}

/* ACTIVO */

input:checked + .slider{
  background:var(--aqua); /* puedes usar tu morado */
}

input:checked + .slider:before{
  transform:translateX(22px);
}


/* ====icon==== */

.icon{
  width:22px;
  height:22px;
  color:#ffffff;
  transition:.3s;
}

.icon:hover{
  color:var(--verdin); /* aqua */
}

/* Variante morado si quieres alternar */
.icon.morado:hover{
  color:#9b5de5;
}
