/* Estilos base */
@font-face {
    font-family: 'Dolcissimo Regular';
    src: url('includes/img/fonts/dolcissimo-regular.otf') format('truetype');
}

@font-face {
    font-family: 'Graphite Heavitas';
    src: url('includes/img/fonts/Graphite-Heavitas-Neue-Black.otf') format('opentype');
}

body {
    font-family: 'Gotham', 'Helvetica Neue', Arial, sans-serif;
    background-size: cover;
    margin: 0;
    padding: 0;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
}

/* Header */
header {
    background-color: white;
    padding: 4px 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
}

header img {
    height: 50px;
}

.menu-icon {
    width: 30px;
    height: 30px;
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    cursor: pointer;
}

.menu-icon div {
    height: 3px;
    background-color: var(--color-principal);
    border-radius: 2px;
}

/* Contenido principal */
.main-content {
    flex: 1;
    padding: 80px 20px 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    min-height: calc(100vh - 200px);
}

.container {
    max-width: 500px;
    width: 100%;
    margin: 0 auto;
}

h1 {
    font-family: 'Graphite Heavitas';
    color: white;
    text-align: center;
    font-size: 28px;
    margin: 6px  20px;
    text-transform: uppercase;
    letter-spacing: 8px;
}

/* Formulario */
.form-section {
    max-width: 600px;
    margin: 0 auto;
}

.card {
    background-color: #ffffffc7;
    border-radius: 20px;
    padding: 14px;
    margin-bottom: 12px;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);

}

/* Select y wrapper */
.select-wrapper {
    position: relative;
    width: 100%;
    margin-top: 5px;
}

select {
    width: 100%;
    padding: 8px 30px 8px 10px;
    appearance: none;
    background: white;
    font-size: 14px;
    cursor: pointer;
    color: #000000;
    border: 1px solid var(--color-principal);
    background-image: url("includes/img/icono reservas new-05.png"), 
                     linear-gradient(to left, var(--color-principal) 1.5em, white 1em);
    background-position: calc(100% - 0.3em) center, 100%;
    background-repeat: no-repeat;
    background-size: 0.8em auto, auto;
}

/* Añadir estos estilos para el select cuando está seleccionado */
select option:checked {
    background-color: var(--color-principal);
    color: white;
}

select option:hover {
    background-color: var(--color-principal);
    color: white;
}

.select-wrapper::after {
    display: none;
}

/* Calendario */
.calendar-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    margin: 0px 0;
    position: relative;
    padding: 0 30px; /* Espacio para las flechas */
}

.calendar-icon {
    width: 24px;
    height: 24px;
}

.separator {
    width: 1px;
    height: 24px;
    background-color: rgba(0, 0, 0, 0.2);
}

.number {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 5px;
    background-color: lightgray;
    cursor: pointer;
    flex-direction: column;
}

/* Estilo para el número activo */
.number.active {
    background-color: var(--color-principal);
    color: white;
}

/* Estilo para los números inactivos */
.number.desactive {
    background-color: #f0f0f0;
    color: #666;
}

/* Formularios y campos */
.form-row {
    display: flex;
    flex-direction: column;
    margin-bottom: 1rem;
}

.form-group {
    position: relative;
    margin-bottom: 15px;
}

.form-group .floating-label {
    position: absolute;
    left: 10px;
    top: -7px;
    font-size: 10px;
    background: white;
    padding: 0 5px;
    color: #666;
    z-index: 1;
    font-weight: normal;
    border-radius: 3px;
}

/* Ajustar el padding superior de los inputs para evitar superposición */
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group select,
.form-group textarea {
    padding: 8px 10px;
    width: 95%;
    border: 1px solid var(--color-principal) !important;
    border-radius: 5px;
    font-size: 14px;
    background-color: #fff;
}

/* Mantener los placeholders */
.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #999;
    opacity: 1;
}

/* Ajuste específico para el grupo de documento */
.form-group[style*="display: flex"] {
    gap: 10px;
}

.form-group[style*="display: flex"] select,
.form-group[style*="display: flex"] input {
    flex: 1;
}

/* Etiquetas */
.form-group label {
    display: block;
    color: #000;
    font-size: 14px;
    margin-bottom: 5px;
    font-weight: bold;
}

input#numero-documento {
    width: 90%;
    height: 11px;
}
/* Estilos para los inputs y textarea */
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
    width: 95%; /* Asegúrate de que ocupen el ancho completo */
    padding: 10px; /* Espaciado interno */
    border: 1px solid var(--color-principal) !important;
    border-radius: 5px; /* Bordes redondeados */
    font-size: 14px; /* Tamaño de fuente */
    background-color: #fff; /* Fondo blanco */
    outline: none; /* Sin contorno al seleccionar */
    transition: border-color 0.3s; /* Transición suave para el borde */
}

/* Efecto al enfocar */
.form-group input:focus,
.form-group textarea:focus {
    border-color: var(--color-secundario);
}

/* Estilo para el textarea */
.form-group.full-width textarea {
    resize: vertical; /* Permitir redimensionar solo verticalmente */
    min-height: -120px !important; /* Altura mínima */
}

/* Espaciado entre los grupos */
.form-row {
    margin-bottom: 15px; /* Espaciado entre filas */
}

/* Estilo para los placeholders */
.form-group input::placeholder,
.form-group textarea::placeholder {
    color: #999; /* Color del placeholder */
    font-style: italic; /* Estilo en cursiva */
}

/* Estilo específico para el campo de comentario */
.form-group.full-width textarea {
    width: 96.9%;
    padding: 6px;
    border: 1px solid var(--color-principal);
    resize: none;
    min-height: 30px;
    font-size: 14px;
    background-color: white;
    outline: none;
}

/* Checkboxes */
.checkbox {
    margin: 5px 0;
}

.checkbox div {
    align-items: baseline;
    margin-bottom: 10px;
}

.checkbox input[type="checkbox"] {
    width: 20px;
    height: 20px;
    margin-right: 10px;
    accent-color: var(--color-principal);
    border: 1px solid var(--color-principal);
    flex-shrink: 0;
    margin-left: 20px;
}

.checkbox label {
    color: white;
    font-size: 8.3px;
    line-height: 1.3;
    text-transform: uppercase;
    flex: 1;
    padding-top: 2px;
}

/* Botón */
.btn {
    font-family: 'Graphite Heavitas';
    background-color: var(--color-principal);
    color: white;
    padding: 5px;
    border: none;
    cursor: pointer;
    width: 30%;
    height: 35px;
    font-size: 16px;
    text-transform: uppercase;
    letter-spacing: 1px;
   margin-left: 150px;
       margin-bottom: 15px;
}

.btn:hover {
    background-color: var(--color-secundario);
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.3);
}

/* Footer */
footer {
    background-color: #f8f9fa;
    padding: 0px 0;
    width: 100%;
    
}

.footer-content {
    max-width: 1500px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 20px;
    font-size: 13px;
    font-weight: bold;
}

/* Grupo izquierdo */
.left-group {
    display: flex;
    align-items: center;
    gap: 20px;
    flex-direction: row-reverse;
}

/* Trinetsoft y contact-info (izquierda) */
.trinetsoft {
    display: flex;
    align-items: center;
    padding: 0;
    background-color: transparent;
}

.contact-info {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* Social icons (derecha) */
.social-icons {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: auto;
}

/* Ajustes responsive */
@media (max-width: 768px) {
    .footer-content {
        flex-direction: column;
        align-items: center;
        gap: 15px;
    }

    .left-group {
        flex-direction: column;
        align-items: center;
    }

    .social-icons {
        margin-left: 0;
    }
}

/* Contacto footer */
.contact-info {
    display: flex;
    align-items: center;
    gap: 10px;
    order: 2;
}

.location, .phone, .email {
    display: flex;
    align-items: center;
    gap: 4px;
}

.location img, .phone img, .email img {
    width: 16px;
    height: 16px;
    object-fit: contain;
    margin-right: 2px;
}

.location span, .phone span, .email span {
    color: #333;
    font-size: 11px;
}

.separator {
    color: #666;
    margin: 0 5px;
}

/* Redes sociales footer */
.social-icons {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-left: 0;
    order: 1;
}

.social-icons span {
    background-color: var(--color-secundario) !important;
    color: white;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.social-icons img {
    width: 24px;
    height: 24px;
    transition: transform 0.2s ease;
}

.social-icons a:hover img {
    transform: scale(1.1);
}

/* Estilo para el contenedor de "Escoge local" */
.local-row {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-bottom: 12px;
    justify-content: center;
}

.local-row label {
    font-family: 'Dolcissimo Regular';
    color: #333;
    font-size: 14px;
    white-space: nowrap;
    margin: 0;
}

/* Select específico para local */
.local-row .select-wrapper {
    width: 150px;
}

.local-row select {
    width: 100%;
    border: 1px solid var(--color-principal);
    padding: 0px 20px 1px 10px;
    font-size: 14px;
    color: #333;
    background-color: white;
}

.local-row .select-wrapper::after {
    right: 10px;
    border-top-color: var(--color-principal);
}

/* Añadir estos estilos para el separador */
.calendar-strip .separator {
    width: 1px;
    height: 20px;
    background-color: #666;  /* o el color que prefieras */
    margin: 0 10px;
}

/* Estilos específicos para los selectores de Personas y Hora */
.select-personas,
.select-hora {
    position: relative;
    width: 100%;
}

.select-personas select,
.select-hora select {
    width: 100%;
    padding: 2px 40px 1px 10px;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-color: white;
    border: 1px solid var(--color-principal);
    font-size: 14px;
    cursor: pointer;
    color: #000;
}

/* Contenedor de la flecha roja */
.select-arrow {
    position: absolute;
    right: 0;
    top: 0;
    bottom: 0;
    width: 35px;
    background-color: var(--color-principal);
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Triángulo blanco para la flecha */
.select-arrow::after {
    content: '';
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid white;
}

/* Contenedor para la fila de selectores */
.reserva-row {
    display: flex;
    gap: 15px;
    
}

.reserva-group {
    flex: 1;
}

.reserva-group label {
    display: block;
    color: #333;
    font-size: 14px;
    margin-bottom: 8px;
    font-family: 'Dolcissimo Regular';
}

/* Trinetsoft */
.trinetsoft {
    display: flex;
    align-items: center;
    padding: 0;
    background-color: transparent;
    order: 3;
}

.trinetsoft img {
    height: 20px;
    object-fit: contain;
}

/* Barra superior */
.top-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-color: rgba(0, 0, 0, 0.8); /* Fondo negro semi-transparente */
    padding: 8px 20px;
    position: relative;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

/* Información de contacto */
.contact-info-top {
    display: flex;
    align-items: center;
    gap: 20px;
}

.contact-info-top a {
    color: #fff;
    text-decoration: none;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Sección derecha */
.right-section {
    display: flex;
    align-items: center;
    gap: 15px;
}

.social-button {
    background-color: var(--color-principal);
    color: white;
    padding: 5px 15px;
    border-radius: 4px;
    text-decoration: none;
    font-size: 14px;
}

.social-icons {
    display: flex;
    gap: 10px;
   
}

.social-icons a img {
    width: 20px;
    height: 20px;

}

.trinetsoft img {
    height: 40px;
}

/* Estilos para el input y select */
.form-group select {
    width: 100%; /* Asegúrate de que ocupe el ancho completo */
    padding: 10px; /* Espaciado interno */
    border: 1px solid var(--color-principal);
    border-radius: 5px; /* Bordes redondeados */
    font-size: 14px; /* Tamaño de fuente */
    background-color: #fff; /* Fondo blanco */
    outline: none; /* Sin contorno al seleccionar */
    background-image: url('includes/img/icono reservas new-05.png'); /* Imagen de la flecha */
    background-repeat: no-repeat; /* No repetir la imagen */
    background-position: right 10px center; /* Posición de la imagen */
    background-size: 12px; /* Tamaño de la imagen */
    appearance: none; /* Ocultar la flecha predeterminada */
    transition: border-color 0.3s; /* Transición suave para el borde */
}

/* Efecto al enfocar */
.form-group select:focus {
    border-color: var(--color-secundario);
}

/* Estilos generales para responsividad */
@media (max-width: 768px) {
   
   .social-icons {
    display: flex;
    gap: 10px;
    margin-left: 0px;
}
    /* Header */
    header {
        padding: 10px 15px; /* Ajusta el padding para pantallas pequeñas */
    }

    /* Contenido principal */
    .main-content {
        padding: 80px 15px 0; /* Ajusta el padding para pantallas pequeñas */
    }

    /* Contenedor */
    .container {
        max-width: 100%; /* Asegura que el contenedor ocupe el 100% del ancho */
        padding: 0 4px; /* Añade padding para pantallas pequeñas */
    }

    /* Títulos */
    h1 {
        font-size: 24px; /* Reduce el tamaño de la fuente en pantallas pequeñas */
        letter-spacing: 4px; /* Reduce el espaciado de letras */
    }

    /* Formulario */
    .form-section {
        max-width: 100%; /* Asegura que el formulario ocupe el 100% del ancho */
        padding: 0 15px; /* Añade padding para pantallas pequeñas */
    }

    /* Inputs y Textareas */
    .form-group input[type="text"],
    .form-group input[type="email"],
    .form-group input[type="tel"],
    .form-group textarea,
    .form-group select {
        width: 92%; /* Asegura que los inputs y selects ocupen el 100% del ancho */
        padding: 10px; /* Espaciado interno */
    }

    /* Botón */
    .btn {
        width: 60%; /* Asegura que el botón ocupe el 100% del ancho */
        margin: 0 auto;
        margin-left: 70px; /* Centra el botón */
    }

    /* Footer */
    .footer-content {
        padding: 0 15px; /* Añade padding para pantallas pequeñas */
    }

    /* Redes sociales */
    .social-icons {
        flex-direction: column; /* Cambia la dirección a columna en pantallas pequeñas */
        align-items: center; /* Centra los iconos */
    }

    /* Local Row */
    .local-row {
        flex-direction: column; /* Cambia la dirección a columna en pantallas pequeñas */
        align-items: stretch; /* Alinea los elementos para ocupar el ancho completo */
    }

    .local-row .select-wrapper {
        width: 100%; /* Asegura que el select ocupe el 100% del ancho */
    }
}

/* Estilos específicos para el footer en móviles */
@media (max-width: 768px) {
    .trinetsoft img {
        margin-top: 0px;
    }
    /* Footer */
    footer {
        background-color: #f8f9fa;
        padding: 0px 10px; /* Aumenta el padding para pantallas pequeñas */
        width: 95%;
        display: flex;
        flex-direction: column; /* Cambia a columna para mejor disposición en móviles */
        align-items: center; /* Centra el contenido */
    }

    /* Contenido del footer */
    .footer-content {
        max-width: 100%; /* Asegura que el contenido ocupe el 100% del ancho */
        display: flex;
        flex-direction: column; /* Cambia a columna para mejor disposición en móviles */
        align-items: center; /* Centra el contenido */
        padding: 8px 10px; /* Añade padding para pantallas pequeñas */
        font-size: 13px;
        font-weight: bold;
    }

    /* Información de contacto */
    .contact-info {
       display: flex;
        flex-direction: row-reverse;
        align-items: baseline;
        gap: 2px;
        flex-wrap: wrap;
        justify-content: center;
        align-content: stretch;
    }
}


    

    .location, .phone, .email {
        display: flex;
        align-items: center;
        gap: 4px;
    }

    /* Redes sociales */
    .social-icons {
        display: flex;
        justify-content: center;
        gap: 10px;
        margin-top: 0px;
        flex-direction: row;

    .social-icons span {
        background-color: var(--color-secundario);
        color: white;
        padding: 6px 12px;
        border-radius: 20px; /* Bordes redondeados */
        font-size: 11px;
        text-transform: uppercase;
        letter-spacing: 0.5px;
    }

    /* Ajustes para los iconos de redes sociales */
    .social-icons img {
        width: 24px;
        height: 24px;
        transition: transform 0.2s ease;
    }

    .social-icons a:hover img {
        transform: scale(1.1);
    }
}

.mobile-break {
    display: inline; /* Por defecto, sin salto de línea */
}

@media (max-width: 768px) { /* Ajusta el ancho según tus necesidades */
    .mobile-break {
        display: block; /* Salto de línea solo en móviles */
    }
}





.footer-desktop {
    display: none; /* Ocultar por defecto */
}
@media (max-width: 768px) {
    
    .footer-mobile {
        display: block; /* Mostrar en móviles */
    }
    .footer-desktop {
        display: none; /* Ocultar en móviles */
    }
}
@media (min-width: 769px) {
    .footer-mobile {
        display: none; /* Ocultar en tabletas y ordenadores */
    }
    .footer-desktop {
        display: block; /* Mostrar en tabletas y ordenadores */
    }
}
.calendar-strip {
    display: flex;
    align-items: center;
}
.number {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 5px;
    background-color: lightgray; /* Color por defecto */
    cursor: pointer;
    flex-direction: column; /* Para apilar el número y la abreviatura */
}
.number.active .day-abbreviation {
    color: white;
}
.number.desactive {
    background-color: lightgray; /* Color para los días inactivos */
    color: black;
}
#days-container {
    display: flex; /* Mostrar los días en fila horizontal */
    justify-content: center; /* Centrar los días */
    transition: all 0.3s ease;
}
.arrow {
    cursor: pointer;
    font-size: 24px;
    margin: 0 0px;
}
.day-abbreviation {
    font-size: 12px; /* Tamaño de la abreviatura */
    color: black; /* Color de la abreviatura */
}
#date-selector {
    display: none; /* Ocultar por defecto */
    position: absolute; /* Asegurarse de que se superponga correctamente */
    background: white; /* Fondo blanco para la ventana emergente */
    border: 1px solid #ccc; /* Borde para la ventana emergente */
    padding: 10px; /* Espaciado interno */
    z-index: 1000; /* Asegurarse de que esté por encima de otros elementos */
}
#date-selector select{
    margin: 5px;
}

#close-selector{
    background-color: var(--color-principal);
    color: #ffffff;
    font-family: 'Dolcissimo Regular';
    border: 0;
    margin-left: 5px;
}

/* Ajustes para mantener la estructura centrada en pantallas grandes */
.container {
    max-width: 500px;
    width: 100%;
    margin: 0 auto;
}

.form-section {
    max-width: 600px;
    margin: 0 auto;
}

/* Mantener los inputs y textareas con el ancho específico */
.form-group input[type="text"],
.form-group input[type="email"],
.form-group input[type="tel"],
.form-group textarea {
    width: 95%;
}

/* Ajuste para la fila de reserva */
.reserva-row {
    display: flex;
    gap: 15px;
}

.reserva-group {
    flex: 1;
}

/* Solo modificar para móvil manteniendo tu estructura actual */
@media (max-width: 768px) {

    .form-group.full-width textarea {
        width: 91.8%;
    }

    .form-group input[type="text"],
    .form-group input[type="email"],
    .form-group input[type="tel"],
    .form-group textarea {
        width: 92%;
    }
    
    .btn {
        width: 60%;
        margin-left: 70px;
    }
    
    .reserva-row {
        flex-direction: column;
    }
}

/* Media query para móvil */
@media (max-width: 768px) {
    .calendar-strip {
        justify-content: center;
        padding: 0 25px;
    }
    
    /* Mostrar solo 4 días */
    .number:nth-child(n+7) {
        display: none;
    }
    
    .number {
        width: 35px;
        height: 35px;
        margin: 0 2px;
        font-size: 14px;
    }

    .day-abbreviation {
        font-size: 10px;
    }

    /* Ajustes específicos para las flechas en móvil */
    .arrow {
        padding: 10px;
        font-size: 20px;
    }

    .arrow.left {
        left: -5px;
    }

    .arrow.right {
        right: -5px;
    }
}

.number {
    transition: transform 0.3s ease;
}










.modal {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0,0,0,0.5);
}

.modal-content {
    background-color: #fefefe;
    margin: 15% auto;
    padding: 15px;
    border: 1px solid #ccc;
    border-radius: 5px;
    width: 200px;
    position: relative;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}

.close {
    position: absolute;
    right: 8px;
    top: 2px;
    color: #aaa;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
}

.close:hover {
    color: #000;
}

.modal-content h3 {
    margin-top: 0;
    margin-bottom: 10px;
    color: #333;
    font-size: 14px;
    text-align: center;
}

#otros-personas-input {
    width: 100%;
    padding: 6px;
    margin: 5px 0;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-sizing: border-box;
    font-size: 13px;
}

.modal-content button {
    background-color: var(--color-principal);
    color: white;
    padding: 6px 12px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    width: 100%;
    margin-top: 8px;
    font-size: 13px;
}

.modal-content button:hover {
    background-color: var(--color-secundario);
}

.select-personas {
    position: relative;
}

.popup {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    margin-top: 5px;
    background-color: #fff;
    border: 1px solid #ccc;
    border-radius: 5px;
    box-shadow: 0 2px 5px rgba(0,0,0,0.2);
    width: 200px;
    padding: 15px;
    z-index: 1000;
}

.popup h3 {
    margin-top: 0;
    margin-bottom: 10px;
    color: #333;
    font-size: 14px;
    text-align: center;
}

#otros-personas-input {
    width: 100%;
    padding: 6px;
    margin: 5px 0;
    border: 1px solid #ddd;
    border-radius: 4px;
    box-sizing: border-box;
    font-size: 13px;
}

.popup button {
    background-color: var(--color-principal);
    color: white;
    padding: 6px 12px;
    border: none;
    border-radius: 4px;
    cursor: pointer;
    width: 100%;
    margin-top: 8px;
    font-size: 13px;
}

.popup button:hover {
    background-color: var(--color-secundario);
}

.close {
    position: absolute;
    right: 8px;
    top: 2px;
    color: #aaa;
    font-size: 16px;
    font-weight: bold;
    cursor: pointer;
}

.close:hover {
    color: #000;
}

/* Estilos específicos para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
     
    .footer-content {
        display: grid;
        grid-template-columns: 1fr;
        gap: 15px;
        padding: 15px;
        max-width: 100%;
    }

    .contact-info {
        display: flex;
        justify-content: center;
        flex-wrap: wrap;
        gap: 20px;
        width: 100%;
    }

    .location, 
    .phone, 
    .email {
        display: flex;
        align-items: center;
        gap: 8px;
        margin: 0 10px;
    }

    .location img, 
    .phone img, 
    .email img {
        width: 18px;
        height: 18px;
    }

    .location span, 
    .phone span, 
    .email span {
        font-size: 12px;
        white-space: nowrap;
    }

    .social-icons {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 15px;
        margin: 10px 0;
        margin-left: 0;
    }

    .social-icons span {
        background-color: var(--color-principal);
        padding: 8px 15px;
        border-radius: 20px;
        font-size: 12px;
    }

    .social-icons a {
        background-color: transparent !important; /* Elimina cualquier fondo */
        display: flex;
        align-items: center;
            background-color: #ffffff !important;
    }

    .social-icons img {
        width: 25px;
        height: 25px;
    }

    .trinetsoft {
        display: flex;
        justify-content: center;
        padding: 10px 0;
        margin-top: 10px;
    }

    .trinetsoft img {
        height: 30px;
    }

    /* Eliminar márgenes y paddings innecesarios */
    footer {
        padding: 0;
        margin: 0;
        width: 100%;
    }

    /* Ajustar separadores */
    .separator {
        display: none;
    }
}

/* Estilos específicos para tablets en footer-desktop */
@media (min-width: 769px) and (max-width: 1024px) {
    
    .footer-desktop .footer-content {
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
        padding: 10px 20px;
        gap: 15px;
        flex-wrap: wrap;
    }

    .footer-desktop .contact-info {
        order: 1;
        flex: 2;
        display: flex;
        justify-content: center;
        gap: 10px;
        flex-wrap: wrap;
    }

    .footer-desktop .social-icons {
        order: 2;
        flex: 1;
        margin-left: 0;
        display: flex;
        justify-content: flex-end;
        align-items: center;
        gap: 10px;
    }

    .footer-desktop .trinetsoft {
        order: 3;
        flex: 0 0 100%;
        justify-content: center;
        padding: 10px 0;
    }

    /* Ajustes específicos para los elementos internos */
    .footer-desktop .location span, 
    .footer-desktop .phone span, 
    .footer-desktop .email span {
        font-size: 12px;
    }

    .footer-desktop .social-icons span {
        font-size: 11px;
        padding: 6px 12px;
    }

    .footer-desktop .social-icons img {
        width: 22px;
        height: 22px;
    }

    /* Ajustar separadores */
    .footer-desktop .contact-info span:not([class]) {
        display: none;
    }
}

/* Desactivar el margen-left para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
    .footer-desktop .footer-content .social-icons {
        margin-left: 0 !important;
    }
    
    /* También anular directamente la clase .social-icons */
    .social-icons {
        margin-left: 0 !important;
    }
}

/* Solución 2: Agregar regla específica para sobrescribir */
@media (min-width: 769px) and (max-width: 1024px) {
    footer .footer-desktop .footer-content .social-icons,
    footer .social-icons {
        margin-left: auto !important;
        margin-right: auto !important;
    }
}

/* Regla específica para tablets */
@media (min-width: 769px) and (max-width: 1024px) {
    /* Resetear todos los márgenes de social-icons */
    .social-icons,
    .footer-content .social-icons,
    .footer-desktop .social-icons,
    .footer-desktop .footer-content .social-icons,
    footer .social-icons,
    footer .footer-desktop .footer-content .social-icons {
        margin: 0 !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        justify-content: center !important;
        width: 100% !important;
    }

    /* Ajustar el contenedor del footer para mejor distribución */
    .footer-desktop .footer-content {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 20px;
    }

    /* Asegurar que el contact-info tome el ancho completo */
    .footer-desktop .contact-info {
        width: 100%;
        justify-content: center;
    }
}

/* Estilos por defecto para desktop */
.social-icons {
    display: flex;
    gap: 10px;
}



/* Tablets */
@media (min-width: 769px) and (max-width: 1024px) {
    .footer-content {
        display: flex;
        flex-direction: row;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        width: 100%;
    }

    .contact-info {
        flex: 1;
        justify-content: center;
        order: 1;
    }

    .social-icons {
        flex: 1;
        justify-content: center;
        margin-left: 0;
        margin-right: 0;
        order: 2;
    }

    .trinetsoft {
        width: 100%;
        justify-content: center;
        order: 3;
    }
}

/* Móvil */
@media (max-width: 768px) {
    .social-icons {
        margin-left: 0;
    }
}

/* Estilo específico para el select de locales */
#tipo-documento, #tipo-evento, #salon-select, #fuente-select{
    width: 100%;
    padding: 8px 30px 8px 10px;
    appearance: none;
    background: rgb(255, 255, 255);
    font-size: 14px;
    cursor: pointer;
    color: #000000;
    border: 1px solid var(--color-principal);
    background-image: url("includes/img/icono reservas new-05.png"), linear-gradient(to left, var(--color-principal) 1.5em, white 1em);
    background-position: calc(100% - 0.3em) center, 100%;
    background-repeat: no-repeat;
    background-size: 0.8em auto, auto;
}

#tipo-documento:focus, #tipo-evento:focus, #salon-select:focus, #fuente-select:focus {
    outline: none;
    border-color: var(--color-secundario);
    box-shadow: 0 0 0 2px rgba(231, 76, 60, 0.2);
}

#tipo-documento:hover, #tipo-evento:hover, #salon-select:hover, #fuente-select:hover {
    border-color: var(--color-secundario);
}

#tipo-documento option, #tipo-evento option, #salon-select option, #fuente-select option {
    padding: 12px;
    font-size: 14px;
}

/* Contenedor del select para mejor control del diseño */
.select-wrapper {
    position: relative;
    width: 100%;
}

/* Estilo para el texto del local seleccionado */
#tipo-documento option:checked, #tipo-evento option:checked, #salon-select option:checked {
    background-color: #f8f9fa;
    font-weight: 500;
}

.popup {
    position: absolute;
    background: white;
    padding: 20px;
    border-radius: 5px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    z-index: 1000;
}

.popup .close {
    position: absolute;
    right: 10px;
    top: 5px;
    cursor: pointer;
    font-size: 20px;
}

.popup input {
    margin: 10px 0;
    padding: 5px;
    width: 100%;
}

.popup button {
    background: var(--color-principal);
    color: white;
    border: none;
    padding: 5px 10px;
    border-radius: 3px;
    cursor: pointer;
}

#otros-evento-modal.popup {
    position: absolute;
    background: white;
    padding: 15px;
    border-radius: 5px;
    box-shadow: 0 2px 10px rgba(0,0,0,0.1);
    z-index: 1000;
    top: 100%;
    left: 30%;
    transform: translateX(-50%);
    width: 250px;
    margin-top: 5px;
}

#otros-evento-modal h3 {
    font-size: 14px;
    margin: 0 0 10px 0;
    text-align: center;
}

#otros-evento-modal input {
    margin: 5px 0;
    padding: 5px;
    width: calc(100% - 10px);
    font-size: 13px;
}

#otros-evento-modal button {
    width: 100%;
    margin-top: 5px;
    padding: 5px;
    font-size: 13px;
}

.form-group {
    position: relative;
}

/* Agregar estos estilos */
input:disabled {
    background-color: #f5f5f5;
    cursor: not-allowed;
    opacity: 0.7;
    border: 1px solid #ddd;
}

select option {
    padding: 10px;
    background-color: white;
}

select option:hover,
select option:focus,
select option:active,
select option:checked {
    background-color: var(--color-secundario) !important;
    color: white !important;
}

/* Estilos específicos para el contenedor del select */
.select-wrapper {
    position: relative;
    width: 50%;
}

/* Estilos para el campo de teléfono */
.iti {
    width: 100%;
}

.iti__flag {
    background-image: url("https://cdn.jsdelivr.net/npm/intl-tel-input@18.2.1/build/img/flags.png");
}

@media (-webkit-min-device-pixel-ratio: 2), (min-resolution: 192dpi) {
    .iti__flag {
        background-image: url("https://cdn.jsdelivr.net/npm/intl-tel-input@18.2.1/build/img/flags@2x.png");
    }
}

input[type="telefono"] {
    padding-left: 150px !important;
}

.error {
    border-color: var(--color-secundario);
}

/* Ajustes responsive */
@media (min-width: 769px) and (max-width: 1024px) {
    .footer-desktop .footer-content {
        justify-content: space-between;
        padding: 10px 20px;
    }

    .footer-desktop .social-icons {
        margin-left: 0;
        order: 1;
    }

    .footer-desktop .contact-info {
        order: 2;
    }

    .footer-desktop .trinetsoft {
        order: 3;
    }
}

@media (max-width: 768px) {
    .footer-content {
        flex-direction: column;
        align-items: center;
        gap: 15px;
    }

    .social-icons,
    .contact-info,
    .trinetsoft {
        margin: 0;
        order: unset;
    }
}

.popup1 {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.7);
    z-index: 1000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.popup1 > div {
    max-width: 450px;
    width: 90%;
    animation: modalFadeIn 0.3s ease-out;
}

@keyframes modalFadeIn {
    from {
        opacity: 0;
        transform: translateY(-20px);
    }
    to {
        opacity: 1;
        transform: translateY(0);
    }
}

.popup1 button:hover {
    background-color: var(--color-secundario) !important;
}

/* Agregar estos estilos para las etiquetas flotantes */
.form-group {
    position: relative;
    margin-bottom: 15px;
}

.form-group input,
.form-group select {
    width: 100%;
    padding: 10px;
    border: 1px solid var(--color-principal);
    border-radius: 5px;
    font-size: 14px;
    background-color: #fff;
}

.form-group .floating-label {
    position: absolute;
    left: 10px;
    top: -8px;
    font-size: 11px;
    padding: 0 4px;
    background: white;
    color: #666;
    transition: all 0.2s;
    pointer-events: none;
    z-index: 1;
}

/* Mantener los estilos existentes de los placeholders */
.form-group input::placeholder {
    opacity: 1;
    transition: opacity 0.2s;
}

/* Ocultar el placeholder cuando el campo está enfocado */
.form-group input:focus::placeholder {
    opacity: 0;
}