/* Hero image: moved from inline style for performance and consistency */
.hero-img {
    width: 100%;
    height: 315px;
    object-fit: cover;
    background: #f4f4f4;
    display: block;
}
/* Header and Footer logo: preserve aspect ratio, prevent distortion */
.footer-logo, .header-logo {
    max-width: 140px;
    height: auto;
    width: auto;
    display: block;
    margin-bottom: 15px;
}
/* removed stray closing brace */
.container.breadcrumb {
    margin: 20px auto 10px auto;
    padding: 0 20px;
    min-height: 1.5em;
    font-size: 1em;
    color: #888;
    background: none;
    border: none;
    box-shadow: none;
}
/* Footer menu link styles */
.footer-list.footer-menu a { color: #fff; text-decoration: none; transition: color 0.2s; }
.footer-list.footer-menu a:hover { color: #1e6d9a; }
body { font-family: Arial, sans-serif; margin: 0; padding: 0; }
header { background: #222; color: #fff; padding: 20px 0; }
nav { display: flex; justify-content: center; gap: 38px; align-items: center; }
nav a, .desktop-nav > a, .desktop-nav .menu-dropdown > a { color: #fff !important; text-decoration: none !important; background: none; }
nav a:hover, .desktop-nav > a:hover, .desktop-nav .menu-dropdown > a:hover { text-decoration: none !important; color: #ffd700; }
/* Menu Dropdown */
.menu-dropdown { position: relative; display: inline-block; padding-bottom: 0; padding-top: 0; }
.menu-dropdown::after { content: ''; display: block; position: absolute; left: 0; right: 0; top: 100%; height: 18px; background: transparent; }
.menu-dropdown > a { cursor: pointer; }
.dropdown-content { display: none; position: absolute; background: #222; min-width: 160px; box-shadow: 0 8px 16px rgba(0,0,0,0.15); z-index: 2000; flex-direction: column; padding: 0; margin-top: 8px; opacity: 0; pointer-events: none; transition: opacity 0.18s; }
.dropdown-content a { color: #fff; padding: 10px 18px; text-decoration: none; display: block; border-bottom: 1px solid #333; font-weight: normal; font-size: 1em; }
.dropdown-content a:last-child { border-bottom: none; }
.menu-dropdown:hover .dropdown-content, .menu-dropdown:focus-within .dropdown-content, .menu-dropdown:hover .dropdown-content, .dropdown-content:hover, .menu-dropdown:has(.dropdown-content:hover) .dropdown-content { display: flex; opacity: 1; pointer-events: auto; }
.container { max-width: 1000px; margin: 20px auto 10px auto; padding: 0 20px; }
h1 { color: #222; }
.cta { background: #f4f4f4; padding: 30px; border-radius: 8px; margin-top: 30px; }
footer {
    background: #222;
    color: #fff;
    text-align: center;
    padding: 15px 0 10px 0;
    font-size: 0.95em;
    border-top: 1px solid #333;
}
.footer-main {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 40px;
    max-width: 1200px;
    margin: 0 auto;
    padding: 40px 20px 20px 20px;
    background: #222;
    color: #fff;
    text-align: left;
}
.footer-col {
    flex: 1 1 200px;
    min-width: 200px;
    margin-bottom: 20px;
}
.logo-col {
    max-width: 260px;
}
.footer-list {
    list-style: none;
    padding: 0;
    margin: 15px 0 0 0;
}
.footer-list li {
    margin-bottom: 8px;
}
.footer-address > div {
    margin-bottom: 18px;
}
.footer-social a {
    display: inline-block;
    margin-right: 10px;
}
.footer-social img {
    width: 24px;
    height: 24px;
    filter: brightness(0) invert(1);
}
.hero {
    background: #f4f4f4;
    padding: 40px 0 30px 0;
}
.hero-flex {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 40px;
}
.hero-video {
    flex: 1 1 380px;
    min-width: 300px;
    max-width: 540px;
}
.hero-content {
    flex: 1 1 320px;
    min-width: 260px;
}
.hero-content h2 {
    color: #222;
    margin-top: 0;
}
.hero-buttons {
    margin-top: 25px;
    display: flex;
    gap: 18px;
}
.hero-btn {
    display: inline-block;
    padding: 12px 28px;
    border-radius: 6px;
    font-size: 1.1em;
    font-weight: bold;
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.call-btn {
    background: #222;
    color: #fff;
}
.call-btn:hover {
    background: #444;
}
.book-btn {
    background: #fff;
    color: #222;
    border: 2px solid #222;
}
.book-btn:hover {
    background: #222;
    color: #fff;
}
/* Header styles */
.header-flex {
    display: flex;
    align-items: center;
    gap: 24px;
    position: relative;
}
.mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    flex-shrink: 0;
    margin-left: auto;
    cursor: pointer;
    z-index: 1101;
    position: fixed;
    top: 20px;
    right: 32px;
    width: 44px;
    height: 44px;
    justify-content: center;
    align-items: center;
}
.mobile-menu-btn span {
    display: block;
    position: absolute;
    left: 8px;
    right: 8px;
    height: 4px;
    background: #fff;
    border-radius: 2px;
    transition: all 0.3s;
}
.mobile-menu-btn span:nth-child(1) {
    top: 12px;
}
.mobile-menu-btn span:nth-child(2) {
    top: 20px;
}
.mobile-menu-btn span:nth-child(3) {
    top: 28px;
}
.mobile-menu-overlay {
    display: none;
}
.mobile-menu {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    position: fixed;
    top: 0;
    right: -260px;
    width: 220px;
    height: 100vh;
    background: #222;
    box-shadow: -2px 0 12px rgba(0,0,0,0.15);
    padding: 80px 24px 24px 24px;
    z-index: 1100;
    transition: right 0.3s;
    gap: 8px;
    overflow-y: auto;
}
body.menu-open .mobile-menu {
    right: 0;
}
@media (max-width: 1200px) {
    nav {
        gap: 28px; /* Slightly less gap for smaller screens, but still more than default */
    }
}
@media (max-width: 900px) {
    .header-flex {
        flex-direction: row;
        gap: 12px;
    }
    nav {
        display: none;
    }
    .mobile-menu-btn {
        display: flex;
        position: fixed;
        top: 20px;
        right: 32px;
        background: none;
        border: none;
        z-index: 1101;
    }
    .mobile-menu {
        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        position: fixed;
        top: 0;
        right: -260px;
        width: 220px;
        height: 100vh;
        background: #222;
        box-shadow: -2px 0 12px rgba(0,0,0,0.15);
        /* Padding top leaves space for the hamburger icon */
        padding: 80px 24px 24px 24px;
        z-index: 1100;
        transition: right 0.3s;
        gap: 8px;
    }
    .mobile-menu a {
        color: #fff;
        text-decoration: none;
        font-size: 1.1em;
        font-weight: bold;
        padding: 10px 0;
        border-bottom: 1px solid #333;
        width: 100%;
    }
    .mobile-menu .menu-dropdown {
        width: 100%;
    }
    .mobile-menu .menu-dropdown > a {
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px 0;
        color: #fff;
        font-size: 1.1em;
        font-weight: bold;
        border-bottom: 1px solid #333;
        text-decoration: none;
    }
    .mobile-menu .menu-dropdown > a::after {
        content: '\203A'; /* Unicode for single right-pointing angle quotation mark (›) */
        font-size: 1.2em;
        margin-left: 8px;
        display: inline-block;
        vertical-align: middle;
    }
    .mobile-menu .dropdown-content {
        display: none;
        position: static;
        background: none;
        box-shadow: none;
        min-width: 0;
        padding: 0 0 0 16px;
        margin: 0;
    }
    .mobile-menu .dropdown-content a {
        color: #fff;
        padding: 8px 0;
        border: none;
        font-size: 1em;
        font-weight: normal;
    }
    .mobile-menu .menu-dropdown.menu-open .dropdown-content {
        display: flex;
        flex-direction: column;
    }
    body.menu-open .mobile-menu {
        right: 0;
    }
    .mobile-menu-overlay {
        display: none;
        position: fixed;
        top: 0; left: 0; right: 0; bottom: 0;
        background: rgba(0,0,0,0.4);
        z-index: 1000;
        transition: opacity 0.3s;
        opacity: 0;
        pointer-events: none;
    }
    body.menu-open .mobile-menu-overlay {
        display: block;
        opacity: 1;
        pointer-events: auto;
    }
    body.menu-open {
        overflow: hidden;
    }
}
