/* ===== Base Modern Theme (Shared) ===== */
:root{
    --bg-overlay: rgba(0,0,0,0.55);
    --surface: rgba(0,0,0,0.65);
    --surface-strong: rgba(0,0,0,0.85);
    --text: #ffffff;
    --muted: rgba(255,255,255,0.8);
    --accent: #2ecc71;
    --accent-2: #3498db;
    --radius: 12px;
    --shadow: 0 10px 25px rgba(0,0,0,0.25);
}

*{
    box-sizing:border-box;
}

body{
    font-family: system-ui, -apple-system, "Segoe UI", sans-serif;
    line-height:1.6;
    color:var(--text);
}

h1, h2, h3{
    letter-spacing:0.4px;
}

a{
    color:var(--text);
    text-decoration:none;
}

a:hover{
    text-decoration:underline;
}

button, input, select, textarea{
    font:inherit;
}

button{
    border-radius:10px;
    transition:transform 0.15s ease, background 0.2s ease, box-shadow 0.2s ease;
    box-shadow:0 6px 16px rgba(0,0,0,0.18);
}

button:hover{
    transform:translateY(-1px);
}

button:focus-visible,
a:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
    outline:2px solid var(--accent);
    outline-offset:2px;
}

section,
.modal-content,
.card,
.zone-card,
.restaurantes,
.taxi-card{
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

/* Subtle overlay for text legibility when needed */
.overlay-surface{
    background:var(--surface);
    border-radius:var(--radius);
    box-shadow:var(--shadow);
}

/* ===== Cookie Banner ===== */
.cookie-banner{
    position:fixed;
    left:16px;
    right:16px;
    bottom:16px;
    background:rgba(20,20,20,0.92);
    color:#fff;
    border:1px solid rgba(255,255,255,0.08);
    border-radius:14px;
    padding:16px 18px;
    display:none;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    z-index:3000;
    box-shadow:0 12px 30px rgba(0,0,0,0.35);
    backdrop-filter: blur(6px);
}
.cookie-banner.active{
    display:flex;
}
.cookie-text{
    font-size:14px;
    color:rgba(255,255,255,0.9);
}
.cookie-actions{
    display:flex;
    gap:10px;
    flex-wrap:wrap;
}
.cookie-btn{
    border:none;
    padding:10px 14px;
    border-radius:10px;
    cursor:pointer;
    font-size:14px;
}
.cookie-essential{
    background:rgba(255,255,255,0.18);
    color:#fff;
}
.cookie-accept{
    background:var(--accent);
    color:#fff;
}
.cookie-config{
    background:rgba(255,255,255,0.12);
    color:#fff;
}
@media (max-width:480px){
    .cookie-banner{
        flex-direction:column;
        align-items:flex-start;
    }
}

/* ===== Cookie Modal ===== */
.cookie-modal{
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.6);
    display:none;
    align-items:center;
    justify-content:center;
    z-index:3200;
    padding:16px;
}
.cookie-modal.active{
    display:flex;
}
.cookie-modal-content{
    background:#ffffff;
    color:#111;
    max-width:520px;
    width:100%;
    border-radius:14px;
    padding:20px;
    box-shadow:0 12px 30px rgba(0,0,0,0.35);
}
.cookie-modal-content h3{
    margin:0 0 8px;
}
.cookie-modal-content p{
    margin:0 0 16px;
    color:#444;
    font-size:14px;
}
.cookie-options{
    display:grid;
    gap:10px;
    margin-bottom:16px;
}
.cookie-option{
    display:flex;
    gap:10px;
    align-items:center;
    background:#f4f4f4;
    padding:10px 12px;
    border-radius:10px;
    font-size:14px;
}
.cookie-modal-actions{
    display:flex;
    justify-content:flex-end;
    gap:10px;
}
.cookie-modal .cookie-config{
    background:#eaeaea;
    color:#111;
    box-shadow:none;
}

/* ===== Language Switcher ===== */
.language-switcher{
    position:fixed;
    top:16px;
    right:16px;
    z-index:4000;
    display:flex;
    align-items:center;
    gap:10px;
    padding:10px 14px;
    border-radius:12px;
    background:rgba(10,10,10,0.92);
    border:1px solid rgba(255,215,0,0.22);
    box-shadow:0 12px 30px rgba(0,0,0,0.22);
    backdrop-filter:blur(8px);
}

.language-switcher-label{
    color:#f9e8c0;
    font-size:14px;
    font-weight:600;
}

.language-switcher select{
    min-width:112px;
    border:none;
    border-radius:8px;
    padding:8px 10px;
    background:#fff8e1;
    color:#111;
    cursor:pointer;
    box-shadow:none;
}

@media (max-width:480px){
    .language-switcher{
        top:14px;
        right:14px;
        padding:8px 10px;
        gap:8px;
    }

    .language-switcher-label{
        font-size:13px;
    }

    .language-switcher select{
        min-width:98px;
        padding:7px 8px;
        font-size:14px;
    }
}

/* ===== Mobile-first hardening across pages ===== */
html{
    width:100%;
    overflow-x:hidden;
    -webkit-text-size-adjust:100%;
}

body{
    width:100%;
    max-width:100%;
    overflow-x:hidden;
}

img,
video,
iframe{
    max-width:100%;
    height:auto;
}

.menu-button,
.language-switcher{
    max-width:calc(100vw - 24px);
}

.menu-button{
    touch-action:manipulation;
}

.modal{
    padding:24px 16px;
}

.modal-content,
.cookie-modal-content,
.menu-content-modal{
    width:min(100%, 720px);
}

.slider,
.slider-track,
.gallery-zone,
.calendar,
.week-days,
#eventList,
#shopList,
#restaurantList,
#monthControls,
.filter-bar{
    max-width:100%;
}

.slider-track img,
.image-modal img,
.modal-content img{
    image-rendering:auto;
}

@media (max-width:768px){
    body{
        background-attachment:scroll !important;
        padding-top:92px !important;
        padding-left:14px !important;
        padding-right:14px !important;
        padding-bottom:18px !important;
    }

    h1{
        width:100%;
        max-width:100%;
        margin:0 0 18px !important;
        padding:16px 18px !important;
        font-size:clamp(1.85rem, 8vw, 2.5rem) !important;
        letter-spacing:0.16em !important;
        line-height:1.05 !important;
        display:block !important;
        word-break:break-word;
    }

    h2{
        font-size:clamp(1.25rem, 5.2vw, 1.75rem) !important;
    }

    .menu-button{
        top:14px !important;
        left:14px !important;
        padding:12px 14px !important;
        font-size:14px !important;
    }

    .language-switcher{
        top:14px !important;
        right:14px !important;
        left:auto !important;
        gap:8px !important;
        padding:10px 12px !important;
        border-radius:16px !important;
    }

    .menu{
        width:min(82vw, 280px) !important;
        left:calc(-1 * min(82vw, 280px)) !important;
        padding:88px 18px 18px !important;
    }

    .menu.active{
        left:0 !important;
    }

    .zones{
        grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
        gap:12px !important;
    }

    .zone-image img{
        height:96px !important;
    }

    .filter-bar{
        display:grid !important;
        grid-template-columns:1fr !important;
        gap:8px !important;
        padding:12px !important;
    }

    .filter-bar label{
        margin:0 !important;
    }

    .filter-bar select{
        width:100% !important;
        min-width:0 !important;
    }

    .modal{
        align-items:flex-start !important;
        padding:88px 12px 12px !important;
    }

    .modal-content,
    .menu-content-modal,
    .cookie-modal-content{
        max-height:calc(100dvh - 104px) !important;
        padding:16px !important;
        border-radius:18px !important;
        overflow-y:auto;
        -webkit-overflow-scrolling:touch;
    }

    #monthControls{
        display:grid !important;
        grid-template-columns:1fr 1fr !important;
        gap:10px !important;
        margin-bottom:18px !important;
    }

    #monthControls span{
        grid-column:1 / -1;
        width:100% !important;
        min-width:0 !important;
        padding:12px 14px !important;
    }

    #monthControls button{
        width:100% !important;
        min-width:0 !important;
    }

    .calendar{
        gap:8px !important;
        padding:12px !important;
        border-radius:20px !important;
    }

    .calendar-weekday{
        padding:8px 0 !important;
        font-size:12px !important;
        letter-spacing:0.04em !important;
        border-radius:12px !important;
    }

    .calendar-day{
        min-height:46px !important;
        font-size:14px !important;
        border-radius:12px !important;
    }

    .event-item{
        gap:12px !important;
    }

    .event-item img{
        width:100% !important;
        max-width:180px;
        height:auto !important;
        margin-right:0 !important;
        object-fit:contain !important;
        border-radius:10px;
    }

    .restaurantes,
    .tienda{
        grid-template-columns:1fr !important;
        gap:14px !important;
        padding:14px !important;
    }

    .restaurantes > img,
    .tienda > img{
        width:100% !important;
        height:auto !important;
        max-height:240px;
        object-fit:contain !important;
        background:rgba(255,255,255,0.04);
    }

    .gallery-zone{
        min-width:0 !important;
        width:100% !important;
    }

    .slider-wrapper{
        gap:10px !important;
        align-items:center !important;
    }

    .slider{
        height:auto !important;
        min-height:112px;
    }

    .slider-track{
        gap:10px !important;
    }

    .slider-track img{
        width:min(46vw, 160px) !important;
        height:min(32vw, 118px) !important;
        object-fit:contain !important;
        background:rgba(255,255,255,0.06);
        padding:6px;
        border:1px solid rgba(255,255,255,0.08);
    }

    .slider-btn{
        width:40px !important;
        height:40px !important;
        font-size:24px !important;
        flex:0 0 40px !important;
    }

    .slide img,
    .featured-section .slide img{
        height:auto !important;
        max-height:62vh !important;
        object-fit:contain !important;
        transform:none !important;
        padding:0 !important;
    }

    .featured-section .slider{
        border-radius:18px !important;
    }

    .slide-info{
        padding:14px !important;
    }

    .image-modal{
        padding:16px !important;
    }

    .image-modal img{
        width:auto;
        max-width:100% !important;
        max-height:82dvh !important;
        object-fit:contain !important;
        background:#111;
    }
}

@media (max-width:480px){
    body{
        padding-top:90px !important;
        padding-left:10px !important;
        padding-right:10px !important;
    }

    h1{
        font-size:clamp(1.65rem, 9vw, 2.2rem) !important;
        letter-spacing:0.12em !important;
        padding:14px 14px !important;
    }

    .zones{
        grid-template-columns:1fr !important;
    }

    .language-switcher{
        max-width:calc(100vw - 132px);
    }

    .language-switcher-label{
        display:none;
    }

    .language-switcher select{
        min-width:120px !important;
    }

    .calendar{
        gap:6px !important;
        padding:10px !important;
    }

    .calendar-day{
        min-height:42px !important;
        font-size:13px !important;
    }

    .slider-track img{
        width:min(58vw, 180px) !important;
        height:min(40vw, 132px) !important;
    }
}
