@media screen and (max-width: 768px) {
    /* Reset HTML and Body for Mobile */
    html {
        width: 100%;
        margin: 0;
        padding: 0;
        box-sizing: border-box;
    }

    body {
        margin: 0;
        padding: 0 env(safe-area-inset-right) 0 env(safe-area-inset-left);
        width: 100%;
        overflow-x: hidden;
        box-sizing: border-box;
    }

    body.modal-open {
        overflow: hidden; /* Evitar scroll cuando el modal está abierto */
    }

    /* Header Adjustments */
    header {
        width: 100%;
        margin: 0;
        padding: 0;
        box-sizing: border-box;
    }

    /* Top Bar */
    .top-bar {
        width: 100%;
        padding: 10px 15px;
        display: flex;
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        gap: 10px;
        background-color: var(--header-bg);
        box-shadow: 0 2px 5px var(--card-shadow);
        box-sizing: border-box;
        margin: 0;
        position: sticky;
        top: 0;
        left: 0;
        z-index: 30;
        flex-wrap: nowrap;
    }

    .menu-toggle {
        display: flex;
        padding: 5px;
        order: -1;
    }

    .menu-toggle:hover {
        background-color: var(--nav-hover-bg);
        color: var(--border-color);
    }

    .menu-icon {
        font-size: 20px;
        color: var(--text-color);
    }

    .nombre-local {
        font-size: 16px;
        white-space: nowrap;
        flex: 0;
        margin: 0;
    }

    .nombre-local a {
        color: var(--text-color);
        text-decoration: none;
    }

    .nombre-local a:hover {
        color: var(--border-color);
    }

    .barra-busqueda {
        flex: 1;
        padding: 0;
        display: flex;
        justify-content: center;
    }

    .search-bar {
        max-width: 100%;
        width: 100%;
        padding: 5px;
        font-size: 14px;
        background: var(--search-bar-bg);
        color: var(--text-color);
        border: 1px solid var(--card-shadow);
        border-radius: 5px;
        font-family: 'Roboto', sans-serif;
    }

    .search-bar:focus {
        outline: none;
        border-color: var(--border-color);
    }

    .iconos-contacto {
        display: flex;
        align-items: center;
        gap: 10px;
        flex: 0;
        flex-shrink: 0;
    }

    .icono-ws,
    .icono-ubicacion {
        font-size: 0;
    }

    .icono-ubicacion {
        display: none;
    }

    .icono-ws i {
        font-size: 20px;
        color: var(--icon-color);
    }

    .theme-toggle {
        background: none;
        border: none;
        cursor: pointer;
        padding: 5px;
    }

    .theme-icon {
        font-size: 18px;
        color: var(--text-color);
    }

    .theme-icon:hover {
        color: var(--border-color);
    }

    /* Menú de Navegación */
    .nav-container {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        width: 40%;
        background-color: var(--nav-bg);
        box-shadow: 0 4px 8px var(--card-shadow);
        z-index: 20;
        transition: background-color 0.3s ease;
        overflow: hidden;
    }

    .nav-container.active {
        display: block;
    }

    .nav-bar {
        padding: clamp(10px, 2vw, 15px);
        width: 100%;
        box-sizing: border-box;
        background: none;
    }

    .nav-bar ul {
        flex-direction: column;
        gap: 10px;
        padding: 0;
        align-items: flex-start;
        width: 100%;
        background: none;
        list-style: none;
        margin: 0;
    }

    .nav-bar a {
        padding: clamp(8px, 2vw, 10px) clamp(10px, 2vw, 15px);
        font-size: 14px;
        text-align: left;
        color: var(--text-color);
        background-color: rgba(255, 255, 255, 0.05);
        border-radius: 5px;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1);
        transition: background-color 0.3s ease, color 0.3s ease, transform 0.2s ease;
        width: 100%;
        box-sizing: border-box;
        text-decoration: none;
    }

    .nav-bar a:hover,
    .nav-bar a:focus {
        background-color: var(--nav-hover-bg);
        color: var(--nav-hover-text);
        transform: translateX(5px);
    }

    /* Ubicación Section */
    .ubicacion-contacto {
        width: 100%;
        padding: 20px;
        margin: 20px 0;
        box-sizing: border-box;
    }

    .ubicacion-contacto h2 {
        font-size: 24px;
    }

    .ubicacion-contacto h2::after {
        width: 80px;
        height: 3px;
    }

    .subtitulo {
        font-size: 16px;
    }

    .contenedor-principal {
        flex-direction: column;
        gap: 20px;
        width: 100%;
    }

    .columna-izquierda {
        width: 100%;
    }

    .mapa {
        height: 300px;
        width: 100%;
        box-sizing: border-box;
    }

    .mapa iframe {
        width: 100%;
        height: 100%;
    }

    .mapa-btn {
        padding: 8px 16px;
        font-size: 14px;
        margin-top: 10px;
        width: fit-content;
        align-self: center;
    }

    .foto-item {
        width: 100%;
    }

    .foto-item .gallery-img {
        max-height: 250px;
        width: 100%;
    }

    .modal-content {
        width: 90%;
        max-width: 90%;
        margin: 0 auto;
        padding: 10px;
        position: relative;
        top: 50%;
        transform: translateY(-50%);
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }

    .modal-image {
        max-height: 60vh;
        width: auto;
        max-width: 100%;
        object-fit: contain;
        display: block;
        margin: 0 auto;
        touch-action: pinch-zoom;
    }

    .modal-prev,
    .modal-next {
        display: flex;
        align-items: center;
        justify-content: center;
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        background-color: rgba(0, 0, 0, 0.6);
        color: #fff;
        border: none;
        border-radius: 50%;
        width: 40px;
        height: 40px;
        font-size: 20px;
        cursor: pointer;
        transition: background-color 0.3s ease;
        z-index: 10;
        font-family: 'Arial', sans-serif; /* Asegura fuente estándar */
        text-align: center; /* Centra el texto del HTML si existe */
    }

    /* Si el HTML tiene texto (< o >), desactivamos ::before para evitar duplicados */
    .modal-prev:not(:empty)::before,
    .modal-next:not(:empty)::before {
        content: none; /* No usamos ::before si el botón tiene texto */
    }

    .modal-prev::before {
        content: '<'; /* Chevron simple para botones vacíos */
    }

    .modal-next::before {
        content: '>'; /* Chevron simple para botones vacíos */
    }

    .modal-prev:hover,
    .modal-next:hover {
        background-color: rgba(0, 0, 0, 0.8);
    }

    .modal-prev {
        left: 10px;
    }

    .modal-next {
        right: 10px;
    }

    .modal-close {
        font-size: 30px;
        top: -35px;
        right: 0;
        color: #fff;
        background: none;
        border: none;
        cursor: pointer;
        position: absolute;
    }

    .detalles-contacto {
        width: 100%;
        padding: 20px;
    }

    .contacto-item {
        font-size: 16px;
        gap: 10px;
    }

    .contacto-item i {
        font-size: 24px;
    }

    .whatsapp-btn {
        padding: 8px 16px;
        font-size: 16px;
    }

    .horario-tabla {
        font-size: 14px;
        width: 100%;
    }

    .horario-tabla td {
        padding: 10px;
    }

    /* Footer */
    .footer {
        padding: 20px 10px;
        width: 100%;
        background-color: var(--header-bg);
        color: var(--text-color);
    }

    .footer-content {
        flex-direction: column;
        gap: 15px;
        width: 100%;
    }

    .footer-section {
        width: 100%;
    }

    /* Dark Mode Overrides */
    body.dark-mode .top-bar {
        background-color: var(--header-bg);
        color: var(--text-color);
        box-shadow: 0 2px 5px var(--card-shadow);
    }

    body.dark-mode .search-bar {
        background: var(--search-bar-bg);
        color: var(--text-color);
        border: 1px solid var(--card-shadow);
    }

    body.dark-mode .menu-toggle:hover,
    body.dark-mode .nav-bar a:hover {
        background-color: var(--nav-hover-bg);
        color: var(--nav-hover-text);
    }

    body.dark-mode .footer {
        background-color: var(--header-bg);
        color: var(--text-color);
    }

    body.dark-mode .nombre-local a,
    body.dark-mode .icono-ws a {
        color: var(--text-color);
    }

    body.dark-mode .nombre-local a:hover,
    body.dark-mode .nombre-local a:active,
    body.dark-mode .nombre-local a:visited,
    body.dark-mode .icono-ws a:hover,
    body.dark-mode .icono-ws a:active,
    body.dark-mode .icono-ws a:visited {
        color: var(--text-color);
    }

    body.dark-mode .modal-prev,
    body.dark-mode .modal-next {
        background-color: rgba(255, 255, 255, 0.2);
        color: #fff;
    }

    body.dark-mode .modal-prev:hover,
    body.dark-mode .modal-next:hover {
        background-color: rgba(255, 255, 255, 0.4);
    }
}