@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700&family=Roboto:wght@300;700&display=swap');
html,body{overflow-x:hidden;}
body{margin: 0;}
    #leaflet { height: 380px; width: 100%; }
    /*NAVBAR*/
    .navbar {
    position: relative;
    z-index: 999999;
    background-color:#003893;
    padding-bottom:1%;
    }
    .navbar-menu {
    list-style-type: none;
    margin: 0;
    padding: 0;
    margin-left: 70%;
    padding-top: 1%;
    display: flex;
    }
    .nav-item {
    display: inline;
    margin-right: 7%;
    font-size: 15px;
    font-weight: 600;
    }
    .nav-item a {
    color: white;
    text-decoration: none;
    }
    .nav-item-provinces a::after {
        content: " ▼";
        font-size: 12px;
    }
    .main-container{
        width: auto;
        margin: 0 18%;
    }
    .background-image{
        background: #003893;
        background-repeat: no-repeat;
        background-size: cover;
        height: 25vw;
    }
    .background-searcher{
        position: absolute;
        left: 20%;
        top: 40%;
        width: 70%;
        position: relative;
        z-index: 999999;
    }
    .background-searcher input{
        width: 70%;
        margin: 0 0 14px;
        padding-top: 1.5%;
        padding-bottom: 1.5%;
        padding-left: 2%;
        padding-right: 5%;
        font-family: inherit;
        font-size: 20px;
        font-weight: inherit;
        line-height: calc(48px - (12px * 2) - 2px);
        color: #8e8e8e;
        border: 2px solid #e6e6e6;
        margin-top: 1%;
        border-top-left-radius: 5px;
        border-bottom-left-radius: 5px;
        outline: 0;
    }
    .background-searcher button{
        padding: 1.8% 3%;
        border-radius: 4px;
        border: 1px solid transparent;
        background: #003893;
        color: white;
        font-size: 20px;
        cursor: pointer;
        outline: 0;
    }
    .search-item{
    margin-right:3%;
    }
    .search-item a{
    cursor:pointer;
    color:white;
    text-decoration:none;
    font-size:18px;
    }
    .search-item a:hover{
    text-decoration:underline;
    }
    .search-items{
    padding: 0 2%
}
.main-container{
    padding: 1% 5%
}
.box-information{
    background: #f3f8ff;
    border-left: 4px solid #003893;
    padding: 20px 24px;
    border-radius: 0 8px 8px 0;
    margin: 20px 0;
}
.box-information p { margin: 6px 0; font-size: 15px; color: #333; line-height: 1.6; }
.box-information a { color: #003893; text-decoration: none; }
.box-information a:hover { text-decoration: underline; }
.buttons-container{
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin: 18px 0;
}
.buttons-container a, .btn-inline {
    display: inline-block;
    background: #003893;
    color: white;
    padding: 10px 20px;
    border-radius: 6px;
    text-decoration: none;
    font-size: 14px;
    font-weight: 600;
    transition: background .2s;
}
.buttons-container a:hover, .btn-inline:hover {
    background: #002370;
}
.timetable-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    gap: 8px;
    margin: 16px 0;
}
.timetable-grid--item {
    background: #f3f8ff;
    border-radius: 8px;
    padding: 10px 6px;
    text-align: center;
    border: 1px solid #e0e7f5;
}
.timetable-grid--item.grid-item-2 { background: #e8f0fb; }
.timetable-grid--item-day p { font-size: 13px; font-weight: 700; margin: 0 0 4px; color: #003893; }
.timetable-grid--item-time p { font-size: 12px; margin: 0; color: #444; }
.open-day { display: inline-block; width: 10px; height: 10px; background: #22c55e; border-radius: 50%; margin-bottom: 3px; }
.close-day { display: inline-block; width: 10px; height: 10px; background: #ef4444; border-radius: 50%; margin-bottom: 3px; }
.item-alert {
    background: #fff8e1;
    border-left: 3px solid #f59e0b;
    padding: 10px 14px;
    border-radius: 0 6px 6px 0;
    font-size: 14px;
    color: #78350f;
    margin: 16px 0;
    line-height: 1.5;
}
.services-list { padding-left: 1.4rem; }
.services-list li { font-size: 15px; color: #333; line-height: 1.7; margin-bottom: 8px; }
.faqs { margin: 30px 0; }
.faq {
    background: #f3f8ff;
    border: 1px solid #d0ddf5;
    border-radius: 6px;
    padding: 14px 16px;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 4px;
}
.faq p { margin: 0; font-size: 15px; font-weight: 600; color: #1a1a1a; }
.faq-descriptions { display: none; padding: 10px 16px 14px; font-size: 15px; color: #444; line-height: 1.7; background: #fff; border: 1px solid #d0ddf5; border-top: none; border-radius: 0 0 6px 6px; margin-bottom: 4px; }
.faq-descriptions p { margin: 0; }
.fixed-btn--container {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 99;
}
.fixed-btn--container button {
    background: #003893;
    color: white;
    border: none;
    padding: 13px 22px;
    border-radius: 30px;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 4px 16px rgba(0,56,147,.35);
    transition: background .2s, transform .15s;
}
.fixed-btn--container button:hover { background: #002370; transform: translateY(-2px); }
.up-arrow {
    position: fixed;
    bottom: 80px;
    right: 22px;
    width: 44px;
    height: 44px;
    background: rgba(0,56,147,.9);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 98;
    cursor: pointer;
}
.up-arrow p { color: white !important; }
.main-title--h1 {
    margin: 24px 0 16px;
}
.main-title--h1 h1 {
    font-size: clamp(22px, 4vw, 34px);
    font-weight: 800;
    color: #1a1a1a;
    line-height: 1.2;
    margin: 0;
    font-family: 'Montserrat', sans-serif;
}
h2 { font-size: clamp(18px, 3vw, 26px); font-weight: 700; color: #1a1a1a; margin: 28px 0 14px; }
h3 { font-size: clamp(15px, 2.5vw, 20px); font-weight: 700; color: #1a1a1a; margin: 20px 0 10px; }
p { font-size: 15px; color: #333; line-height: 1.7; margin: 0 0 12px; }
a { color: #003893; }

@media (max-width: 900px) {
    .navbar-menu { margin-left: 0; justify-content: flex-end; padding-right: 4%; }
    .main-container { padding: 2% 4%; margin: 0; }
    .timetable-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 600px) {
    .navbar-menu { gap: 12px; }
    .timetable-grid { grid-template-columns: repeat(2, 1fr); }
    .buttons-container { flex-direction: column; }
    .buttons-container a, .btn-inline { text-align: center; }
}
