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


#language {
  display: block;     /* Para que se comporte como un bloque y pueda tomar ancho */
  width: 70%;         /* Ocupa el 70% del ancho del contenedor padre */
  margin-left: auto;  /* Empuja el select hacia la derecha */
}



header {
    background-image: url('media/imag_foto2.jpg');
    background-size: cover;
    background-position: top;
    height: 25vh;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    border-radius: 5px;
    gap: 20px;
    margin: 0;
    padding: 0;
  
}


body {
    font-family: 'Segoe UI', Arial, sans-serif;
    overflow-x: hidden;
    margin: 1px;
    padding: 1px;
    width:100%;
    max-width: 100%;


}




.opciones-flex {
    display: flex;
    flex-direction: column;         /* Alinea los hijos en columna (vertical) */
    align-items: flex-end;          /* Alinea los hijos al final (derecha) */
    gap: 8px;                       /* Espacio entre los enlaces */
    padding: 1px 2px 1px ;      /* Padding superior, derecho, inferior, izquierdo */
    min-width: 130px; /* Igual al max-width de .opcion-box */
}

.opciones-flex a,
.opciones-flex a:visited,
.opciones-flex a:hover,
.opciones-flex a:active {
    text-decoration: none;
    color: rgb(255, 255, 255);
    display: block;
}



.opcion-box {
    display: block;
    box-sizing: border-box;
    border: 1px solid #969696;
    background-color: rgba(39, 39, 39, 0.5);
    text-align: center;
    font-family: Arial, sans-serif;
    border-radius: 5px;
    transition: 
        background-color 0.2s, 
        color 0.2s, 
        box-shadow 0.2s, 
        border-color 0.2s;
    cursor: pointer;
    color: #000;
    padding: 3px 5px;              /* Espaciado interno */
    min-width: 100px;               /* Ancho mínimo */
    height: auto;
    margin: 0;                      /* Elimina márgenes externos */
    text-decoration: none;          /* Si son enlaces <a> */
    width: 100%;        /* Ocupa todo el ancho del contenedor */
    max-width: 130px;   /* Pero no más de 200px */
}


/* Efecto al pasar el ratón */
.opcion-box:hover {
    background-color: rgba(39, 39, 39, 0.8); /* Más oscuro */
    color: #000000;                             /* Texto blanco */

    box-shadow: 0 2px 8px rgba(0,0,0,0.15);  /* Sombra suave */
    transform: scale(1.01);                  /* Ligeramente más grande */
}





.opciones1-flex {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 1px 2px;
    min-width: 92px;
}

.opciones1-flex a {
    text-decoration: none;
    color: rgb(31, 31, 31);
    display: block;
}

.opciones1-flex a,
.opciones1-flex a:visited,
.opciones1-flex a:hover,
.opciones1-flex a:active {
    text-decoration: none;
    color: rgb(31, 31, 31);
    display: block;
    font-size: 1.1em;
}

.opcion1-box {
    display: block;
    box-sizing: border-box;
    border: 1px solid #929292;
    background-color: rgba(255, 255, 255, 0.5);
    text-align: center;
    font-family: Arial, sans-serif;
    font-size: 0.9em;
    border-radius: 5px;
    transition: background-color 0.2s, color 0.2s, box-shadow 0.2s, border-color 0.2s;
    cursor: pointer;
    color: #929292;
    padding: 2px 2px;
    height: auto;
    margin: 0;
    text-decoration: none;
    width: 92px;        /* <-- ¡Aquí está la clave! */
    /* O usa flex: 1 1 0; para que todos crezcan igual */
    /* flex: 1 1 0; */
}

.opciones2-flex {
    display: flex;
    flex-direction: column;         /* Alinea los hijos en columna (vertical) */
    align-items: flex-end;          /* Alinea los hijos al final (derecha) */
    gap: 9px;                       /* Espacio entre los enlaces */
    padding: 1px 2px 1px ;      /* Padding superior, derecho, inferior, izquierdo */
    min-width: 130px; /* Igual al max-width de .opcion-box */
}

.opciones2-flex a,
.opciones2-flex a:visited,
.opciones2-flex a:hover,
.opciones2-flex a:active {
    text-decoration: none;
    color: rgb(255, 255, 255);
    display: block;
}



.opcion2-box {
    display: block;
    box-sizing: border-box;
    border: 1px solid #969696;
    background-color: rgba(39, 39, 39, 0.5);
    text-align: center;
    font-family: Arial, sans-serif;
    border-radius: 5px;
    transition: 
        background-color 0.2s, 
        color 0.2s, 
        box-shadow 0.2s, 
        border-color 0.2s;
    cursor: pointer;
    color: #000;
    padding: 3px 5px;              /* Espaciado interno */
    min-width: 250px;               /* Ancho mínimo */
    height: auto;
    margin: 0;                      /* Elimina márgenes externos */
    text-decoration: none;          /* Si son enlaces <a> */
    width: 100%;        /* Ocupa todo el ancho del contenedor */
    max-width: 280px;  
}


/* Efecto al pasar el ratón */
.opcion2-box:hover {
    background-color: rgba(39, 39, 39, 0.8); /* Más oscuro */
    color: #000000;                             /* Texto blanco */

    box-shadow: 0 2px 8px rgba(0,0,0,0.15);  /* Sombra suave */
    transform: scale(1.01);                  /* Ligeramente más grande */
}




.opciones3-flex {
    display: flex;
    flex-direction: column;         /* Alinea los hijos en columna (vertical) */
    align-items: flex-end;          /* Alinea los hijos al final (derecha) */
    gap: 9px;                       /* Espacio entre los enlaces */
    padding: 1px 2px 1px ;      /* Padding superior, derecho, inferior, izquierdo */
    min-width: 130px; /* Igual al max-width de .opcion-box */
}

.opciones3-flex a,
.opciones3-flex a:visited,
.opciones3-flex a:hover,
.opciones3-flex a:active {
    text-decoration: none;
    color: rgb(156, 0, 0);
    display: block;
}



.opcion3-box {
    display: block;
    box-sizing: border-box;
    border: 1px solid #969696;
    background-color: rgba(39, 39, 39, 0.5);
    text-align: center;
    font-family: Arial, sans-serif;
    border-radius: 5px;
    transition: 
        background-color 0.2s, 
        color 0.2s, 
        box-shadow 0.2s, 
        border-color 0.2s;
    cursor: pointer;
    color: #000;
    padding: 3px 5px;              /* Espaciado interno */
    min-width: 250px;               /* Ancho mínimo */
    height: auto;
    margin: 0;                      /* Elimina márgenes externos */
    text-decoration: none;          /* Si son enlaces <a> */
    width: 100%;        /* Ocupa todo el ancho del contenedor */
    max-width: 280px;  
}


/* Efecto al pasar el ratón */
.opcion3-box:hover {
    background-color: rgba(39, 39, 39, 0.8); /* Más oscuro */
    color: #000000;                             /* Texto blanco */

    box-shadow: 0 2px 8px rgba(0,0,0,0.15);  /* Sombra suave */
    transform: scale(1.01);                  /* Ligeramente más grande */
}






main {
    background-color:white;
    display: flex;
    flex-direction: column;
    justify-content:left;
    align-items:flex-start;
    width: 100%;
    box-sizing: border-box;
    margin: 3px;
	  color:rgba(0, 0, 0, 0.726);
    padding: 3px;

  }

main ul li{
    list-style-type: none;
    display: flex;
    flex-direction: column;
    margin: 5px 0;
    color:rgb(48, 48, 48);;
    text-decoration: none;
    font-weight: bold;
}


main h5,
main h4,
main h3,
main h2,
main h1
{
    display: flex;
    flex-direction: column; /* Apila elementos en móvil */
    border-radius: 5px;
    gap: 20px;
    width: 100%;
    box-sizing: border-box;
    padding: 10px;
    background-color:#aaa97817;
    margin: 5px 0 5px 0;
    max-width: 600px;

}

main p {
    text-decoration: none;
    text-align: justify;
    width: 100%;
}
main img {
       width: 100%;
       height: auto;
       margin-top: 30px;
       border-radius: 5px;
    }

main iframe {
        width: 100%;
        height: auto;
        margin-top: 30px;
     }


   
html {
    padding: 0;
    width: 100%;

}






.logo-container {
    height: 100%;
    display: flex;
    align-items: center;
}




.logo {
    height: 50%; /* Reducido de 75% a 50% para dispositivos móviles */
    max-width: 100%;
}



.navigation-bar {
    width: 100%;
    padding: 0px 15px 15px 15px;
    background: white;
}

.nav-row {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px; /* Espacio entre imágenes */
    width: 100%;
    max-width: 600px;
}

.nav-row a {
/*    flex: 1 1 0; /* Cada enlace ocupa el mismo espacio */
    display: flex;
    justify-content: center;
    align-items: center;
    min-width: 0; /* Permite que las imágenes se encojan si es necesario */
}

.nav-row img {
    width: 100%;
    max-width: 130px;
    min-width: 60px;
    height: auto;
    display: block;
    object-fit: contain;
    transition: transform 0.2s; /* Cambia width por transform */
    border-radius: 5px;
    margin: 0 auto;
}

.nav-row img:hover {
    transform: scale(1.07); /* Escala la imagen un 7% más grande */
}






/* Estilo general para el contenedor */
.container {
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin: 2px auto; /* Márgenes automáticos para centrado horizontal */
    max-width: 900px; /* Límite máximo opcional para evitar que se expanda demasiado */
    box-sizing: border-box;
    padding: 4px 1px;
    align-items: letf;
    text-align: left;
    color: black;
    position: relative;

}



.container ul li {
    color: rgb(48, 48, 48);
    text-decoration: none;


}

.container p {
    color: rgb(48, 48, 48);
    text-decoration: none;

}

.texto-inicio {
    display: flex;
    flex-direction: column; /* Apila elementos en móvil */
    border-radius: 5px;
    gap: 20px;
    width: 100%;
    box-sizing: border-box;
    padding: 10px;
    background-color:rgba(255, 255, 255, 0.466);
    margin: 5px 0 5px 0;
    max-width: 600px;

}



/* Estilo para cada fila (image-row) */
/* Contenedor principal */
.image-row {
    display: flex;
    flex-direction: column; /* Apila elementos en móvil */
    border-radius: 5px;
    width: 100%;
    box-sizing: border-box;
    background-color:rgba(194, 194, 194, 0.212);
    border: 1px solid #333;
    margin: 3px;
    padding: 4px;
    height: auto;

}

/* Imagen en móvil */
.image-row img {
    width: 100% !important; /* Fuerza ancho completo */
    flex: none; /* Anula propiedades flex anteriores */
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 5px;
    flex: 0 0 100%; /* Ocupan 100% del contenedor */
}


/* Estilo para los párrafos */
.image-row p {
    margin: 0;

    color: black;
    text-align: justify; /* Alineación a ambos lados */
    text-indent: 0;      /* Elimina sangría inicial */
    width: 100%;         /* Ocupa ancho completo */
    padding: 0;          /* Opcional: elimina rellenos si existen */
}

/* Enlaces dentro de las imágenes */
.image-row a {
    text-decoration: none;
}


.image-row1 {
    display: flex;
    flex-direction: column; /* Apila elementos en móvil */
    border-radius: 12px;
    width: 100%;
    box-sizing: border-box;
    padding: 10px;
    background-color:rgba(255, 255, 255, 0.212);
    border: 1px solid #a3a3a3;
    margin: 1px 2px 0 1px;

    max-width: 600px;
    height:auto;
}

/* Imagen en móvil */
.image-row1 img {
    width: 95%; /*important; /* Fuerza ancho completo */
    flex: none; /* Anula propiedades flex anteriores */
    aspect-ratio: 4/3;
    object-fit: cover;
    border-radius: 5px;
    flex: 0 0 95%; /* Ocupan 100% del contenedor */
}

/* Estilo para los párrafos */
.image-row1 p {
    margin: 0;

    color: black;
    text-align: justify; /* Alineación a ambos lados */
    text-indent: 0;      /* Elimina sangría inicial */
    width: 100%;         /* Ocupa ancho completo */
    padding: 0;          /* Opcional: elimina rellenos si existen */
}

/* Enlaces dentro de las imágenes */
.image-row1 a {
    text-decoration: none;
}

.image-row2 {
    display: flex;
    flex-direction: column; /* Apila elementos en móvil */
    border-radius: 12px;
    width: 100%;
    box-sizing: border-box;
    padding: 5px;
    background-color:rgba(247, 234, 177, 0.26);
    border: 1px solid #770000;
    margin: 3px;

    max-width: 600px;
    height:auto;
}
.image-row2 p {
    margin: 0;
    color: black;
    text-align: center; /* Centra el texto */
    text-indent: 0;
    width: 100%;
    padding: 5px;
}






.idioma {
  display: flex;
  border-radius: 12px;
  width: 200px;
  box-sizing: border-box;
  padding: 10px;
  background-color: rgba(84, 119, 154, 0.534);
  border: 1px solid #a3a3a3;
  margin: 1px 2px 0 1px;
  max-width: 250px;
  height: auto;

  margin-left: auto; /* Esto empuja el div hacia la derecha */
}



.calendar-cell, .calendar-header {
    padding: 2px;
    height: 30px;
    text-align: center;
    vertical-align: middle;
    white-space: nowrap;
    width: 50px;
    min-width: 45px;
    font-size: 70%;
}





















/* Texto en móvil */
.text-content {
    width: 100% !important;
    padding: 10px 10px 10px 10px;
    flex: 0 0 100%; /* Ocupan 100% del contenedor */
}


img {
        max-width: 100%; /* Asegura que la imagen no sobrepase el ancho del contenedor */
        height: auto; /* Ajusta automáticamente la altura */

    }


.image-container {
        width: 100%; /* Asegura que el contenedor ocupe todo el ancho */
    }
   



/* Estilos generales para el formulario */
#mi-formulario {
  max-width: 400px;
  margin: 20px auto;
  padding: 24px 18px;
  background: #fff;
  border-radius: 14px;
  box-shadow: 0 4px 22px rgba(0,0,0,0.08);
  display: flex;
  flex-direction: column;
  gap: 16px;
  font-family: 'Segoe UI', Arial, sans-serif;
}

#mi-formulario label {
  font-weight: 500;
  color: #333;
  letter-spacing: 0.02em;
}

#mi-formulario input[type="text"],
#mi-formulario select {
  width: 100%;
  padding: 10px 12px;
  border: 1.5px solid #d1d5db;
  border-radius: 6px;
  font-size: 1rem;
  margin-bottom: 8px;
  transition: border 0.2s;
  background: #f9fafb;
}

#mi-formulario input[type="text"]:focus,
#mi-formulario select:focus {
  border-color: #746842;
  outline: none;
  background: #fff;
}

#mi-formulario .g-recaptcha {
  margin: 0 auto 50px auto;
}

#mi-formulario button[type="submit"]{
  width: 100%;
  max-width: 250px;
  padding: 12px;
  color: #fff;
  font-weight: 600;
  border: none;
  border-radius: 20px;
  font-size: 1.1rem;
  cursor: pointer;
  transition: background 0.2s;
  margin: 16px auto 0 auto;
  box-shadow: 0 2px 8px rgba(0,123,255,0.09);
  background-color: #aaa978;
}

/* Oscurecer al pasar el mouse */
#mi-formulario button[type="submit"]:hover {
  background-color: #72713d; /* Un tono más oscuro */
}


#mi-formulario #sugerencias {
  height: 160px;            /* Doble altura */
  resize: vertical;         /* Permite redimensionar solo verticalmente */
  padding: 10px;
  font-size: 1rem;
  border-radius: 6px;
  border: 1.5px solid #d1d5db;
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  width: 100%;              /* Que ocupe todo el ancho disponible */
  box-sizing: border-box;   /* Incluye padding y borde en el ancho total */
}




@media (max-width: 480px) {
  #mi-formulario {
    max-width: 260px;
    padding: 5px 2px;
    font-size: 1rem;
  }
  #mi-formulario button[type="submit"] {
    font-size: 1rem;
    padding: 2px;
    width: 100%;         /* Ocupa todo el ancho disponible */
    max-width: 250px;     /* No excede el ancho del contenedor */
    box-sizing: border-box; /* Incluye padding y borde en el ancho */
    margin: 8px 0 0 0;  /* Margen superior para separación */
    padding: 12px;       /* Padding cómodo para toque táctil */
    max-width: 250px;
  }

    #mi-formulario select {
    min-height: 48px;      /* Altura cómoda para el dedo */
    font-size: 1.1rem;     /* Texto más grande y legible */
    padding: 10px 14px;    /* Espacio interno suficiente */
    max-width: 250px;
  }
    #mi-formulario input {
    min-height: 48px;      /* Altura cómoda para el dedo */
    font-size: 1.1rem;     /* Texto más grande y legible */
    padding: 10px 14px;    /* Espacio interno suficiente */
    max-width: 250px;
  }




  .recaptcha-wrapper {
    width: 100%;
    overflow-x: auto;       /* Permite scroll horizontal si es necesario */
    -webkit-overflow-scrolling: touch; /* Suaviza el scroll en iOS */
    display: flex;
    justify-content: flex-start; /* Alinea a la izquierda para scroll natural */
    margin-bottom: 12px;
    height: 68px;           /* Altura estándar del reCAPTCHA */
  }

  .recaptcha-wrapper .g-recaptcha {
    transform: scale(0.75); /* Escala para que quepa mejor */
    transform-origin: 0 0;
    min-width: 302px;       /* Ancho mínimo real del widget */
    height: 68px;
  }


}


.qr-img {
  display: block;
  margin: 0 auto;
  width: 80%;           /* Ocupa hasta el 80% del ancho del contenedor */
  max-width: 365px;     /* No crece más que su ancho original */
  height: auto;         /* Mantiene la proporción original */
  border-radius: 8px;   /* Opcional: bordes redondeados */
  box-shadow: 0 2px 8px rgba(0,0,0,0.08); /* Opcional: sombra suave */
}





.items-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;  /* Alinea todo a la izquierda */
    gap: 10px;  /* Espacio entre elementos */
    width: 100%;  /* Asegura que el contenedor ocupe todo el ancho */
  }
  
  .items {
    text-align: center;
    width: calc(50% - 5px);  /* 50% del ancho menos la mitad del gap (10px/2) */
    box-sizing: border-box;  /* Evita que padding/margin afecten el ancho */
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  
  .items img {
    width: 40px;
    height: auto;
    border: 2px solid #ccc;
    border-radius: 5px;
    margin-bottom: 10px;
  }
  
.items p {
        color: rgb(48, 48, 48);;
        text-decoration: none;

        text-align: justify;
    }
    

footer p {
    text-decoration: none;
 
    text-align: center;
    width: 100%;
    margin: 0; /* Opcional: elimina márgenes por defecto */
}




table.tablalimpia
    {
        border-collapse:collapse;
        text-align:center;
        border:none;
        color: black;
        border-spacing: 0;
        max-width: 98%;
    }

table.tablalimpia th,
table.tablalimpia td {
  border: none;
  border-width: 0;
  border-style: none;
  border-color: transparent;
  width: 20%;

  padding: auto;
}


.MiniCalendar{
        display: flex; 
        justify-content: center; 
        align-items: center; 
        gap: 24px;
        margin-bottom: 12px;
        min-height: 1em;
        width:100%;

}


.table-responsive {
  width: 90%;
  display: flex;
  justify-content: center; /* Centra horizontalmente */
  overflow-x: auto;
  height: auto;
  max-height: none;
  overflow-y: hidden;
}



.disponible {
    background-color:rgba(198, 255, 227, 0.295);
    color: rgb(0, 0, 0);

}
.pasado{
    background-color:rgba(255, 255, 255, 0.418);
    color: rgb(190, 190, 190);
}
.ocupado, .no-venta {
    background-color:rgb(255, 225, 225);
    color: rgb(136, 0, 0);
    text-decoration: line-through;

}

.booking {
    background-color:rgb(173, 199, 255);
    color: rgb(0, 0, 0);

}
.myweb {
    background-color:rgb(125, 172, 115);
    color: rgb(0, 0, 0);

}
.airbnb {
    background-color:rgb(255, 187, 187);
    color: rgb(0, 0, 0);

}
.bloqueado {
    background-color:rgb(179, 179, 179);
    color: rgb(31, 31, 31);

}



.calendario {
  margin: 0 auto;
  width: 45%;
  max-width: 100%;
  border-collapse: separate;
  table-layout: fixed;
  border-spacing: 2px;
}

.calendario th {
  padding: 8px;
  text-align: center;
  vertical-align: middle;
  font-weight: none;
  
  background-clip: padding-box;
}
.calendario td {
  border: 1px solid #c9c9c9;
  border-radius: 8px;
  padding: 8px;
  text-align: center;
  vertical-align: middle;
  font-weight: none;
  
  background-clip: padding-box;
}

.tabla-responsive {
  width: 100%;
  overflow-x: auto;
}

/* Responsive para móviles */
@media (max-width: 650px) {
  .calendario {
    width: 100%;
    min-width: 400px; /* Ajusta según el número de columnas */
    max-width: 100%;
    table-layout: auto;
  }
}






/**************************************************************************************************/


/* 1. Fuente base y tamaño adaptativo usando clamp */
html {
  font-family: 'Segoe UI', 'Roboto', 'Arial', 'Helvetica', sans-serif;
  font-size: clamp(11px, 2vw, 15px); /* Ajuste dinámico entre 14px y 18px según ancho */
  line-height: 1.6;
  color: #222;
  background: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* 2. Encabezados responsivos usando clamp */
h1 { font-size: clamp(1.4em, 4vw, 2.2em); }
h2 { font-size: clamp(0.9em, 2.6vw, 1.8em); }
h3 { font-size: clamp(0.86em, 2vw, 1.4em); }
h4 { font-size: clamp(0.8em, 1.5vw, 1.1em); }
h5 { font-size: clamp(0.7em, 1.2vw, 0.9em); }
h6 { font-size: clamp(0.65em, 1vw, 0.8em); }

h1, h2, h3, h4, h5, h6 {
  font-family: inherit;
  font-weight: 700;
  line-height: 1.2;
  margin-top: 1.2em;
  margin-bottom: 0.5em;
  color: #1a1a1a;
}

/* 3. Texto general */
p, ul, ol, li, td, th, a, label, input, textarea, button, span, div {
  font-family: inherit;
  font-size: 1.02em;
  line-height: 1.6;
  color: black;
  
}

/* 4. Enlaces */
a {
  color: #aaa978;
  text-decoration: none;
  transition: color 0.2s;
}
a:hover, a:focus {
  color: #aaa978;
  text-decoration: underline;
}

/* 5. Tablas */
table {
  border-collapse: collapse;
  width: 100%;
  overflow-x: auto;
  display: block;
}
th, td {
  padding: 0.5em 1em;
  text-align: left;
  font-size: 1em;
}

/* 6. Listas */
ul, ol {
  margin-left: 1.5em;
  margin-bottom: 1em;
}
li {
  margin-bottom: 0.3em;
}

/* 7. Formularios */
input, textarea, button, select {
  font-family: inherit;
  font-size: 1em;
  line-height: 1.4;
}

/* 8. Ajustes responsivos adicionales */
@media (max-width: 900px) {
  html {
    font-size: clamp(13px, 2vw, 16px);
  }
  h1 { font-size: clamp(1.7em, 6vw, 2.5em); }
  h2 { font-size: clamp(1.2em, 5vw, 2em); }
  h3 { font-size: clamp(1em, 4vw, 1.5em); }
}

@media (max-width: 600px) {
  html {
    font-size: clamp(12px, 3vw, 15px);
  }
  h1 { font-size: clamp(1.2em, 7vw, 2em); }
  h2 { font-size: clamp(1em, 6vw, 1.5em); }
  h3 { font-size: clamp(0.9em, 5vw, 1.2em); }
  th, td {
    font-size: 0.95em;
    padding: 0.4em 0.6em;
  }
}

@media (max-width: 400px) {
  html {
    font-size: 12px;
  }
  th, td {
    font-size: 0.9em;
    padding: 0.3em 0.4em;
  }
}

/* 9. Accesibilidad */
:root {
  --focus-outline: 2px solid black;
}
a:focus, button:focus, input:focus, textarea:focus {
  outline: var(--focus-outline);
  outline-offset: 2px;
}





.aviso-cookies {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background: black;
  color: #fff;
  padding: 20px 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 9999;
  font-size: 16px;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.2);
  transition: transform 0.4s;
}
.aviso-cookies.oculto {
  transform: translateY(100%);
}
.aviso-cookies button {
  background: #aaa978;
  color: #fff;
  border: none;
  padding: 10px 20px;
  border-radius: 5px;
  font-size: 16px;
  cursor: pointer;
}
.aviso-cookies a {
  color: #aaa978;
  text-decoration: underline;
}

.info-seguida {
  display: flex;
  flex-direction: column;
  gap: 2px; /* Prueba con un valor menor */
  max-width: 100%;
}



.info-seguida span {
  display: flex;
  align-items: center;
  min-width: 200px;          /* Opcional: ajusta el ancho mínimo de cada bloque */
  max-width: 100%;
            /* Permite que los bloques crezcan y se ajusten */
  box-sizing: border-box;
}

.info-seguida img {
  width: 36px;
  height: 36px;
  object-fit: cover;
  vertical-align: middle;
  margin-right: 16px;
  border-radius: 5px;
  flex-shrink: 0;
}


footer {
    color: #fff;
    width: 100%;
    padding: 10px;
    margin: 5px 0 5px 0;
    max-width: 600px;
}

    