
    :root {
        --primary: #2E5A44; --primary-hover: #244635;
        --secondary: #264533; --secondary-hover: #9f893b;
        --dark: #161219; /* Updated to a deeper, richer dark for the menu */
        --light: #F7F5F0;
        --white: #FFFFFF; --text: #333333; --text-muted: #666666;
        --transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
        --shadow-sm: 0 4px 6px rgba(0,0,0,0.05);
        --shadow-md: 0 10px 15px rgba(0,0,0,0.1);
        --shadow-lg: 0 20px 25px rgba(0,0,0,0.15);
    }
    * { margin: 0; padding: 0; box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body { font-family: 'Inter', system-ui, sans-serif; color: var(--text); background-color: var(--light); line-height: 1.6; }
    h1, h2, h3, h4, h5, h6 { font-weight: 700; line-height: 1.2; color: var(--dark); margin-bottom: 1rem; }
    a { text-decoration: none; color: var(--primary); transition: var(--transition); }
    a:hover { color: var(--primary-hover); }
    .btn { display: inline-block; padding: 1rem 2rem; border-radius: 4px; font-weight: 600; text-align: center; transition: var(--transition); cursor: pointer; border: none; font-size: 1.1rem; }
    .btn-primary { background-color: var(--secondary); color: var(--white); }
    .btn-primary:hover { background-color: var(--secondary-hover); transform: translateY(-2px); box-shadow: var(--shadow-md); color: var(--white); }
    .btn-outline { background-color: transparent; border: 2px solid var(--white); color: var(--white); }
    .btn-outline:hover { background-color: var(--white); color: var(--dark); transform: translateY(-2px); }
    .btn-outline-primary { background-color: transparent; border: 2px solid var(--primary); color: var(--primary); }
    .btn-outline-primary:hover { background-color: var(--primary); color: var(--white); transform: translateY(-2px); }

    /* --- HEADER & NAVIGATION --- */
    header { position: fixed; top: 0; left: 0; width: 100%; background-color: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); z-index: 1000; box-shadow: var(--shadow-sm); padding: 1rem 5%; display: flex; justify-content: space-between; align-items: center; transition: var(--transition); }
    .logo { font-size: 1.5rem; font-weight: 800; color: var(--primary); letter-spacing: -0.5px; display: flex; align-items: center; position: relative; z-index: 1001; }
    #header_logo { height: 4em; margin: auto 1em; }

    .header-actions { display: flex; align-items: center; gap: 1.5rem; position: relative; z-index: 1001; }
    .nav-cta { background-color: var(--primary); color: var(--white); padding: 0.75rem 1.5rem; border-radius: 30px; font-weight: 600; transition: var(--transition); }
    .nav-cta:hover { background-color: var(--primary-hover); color: var(--white); }

    /* Hamburger Menu Button */
    .menu-toggle { background: transparent; border: 1px solid rgba(0,0,0,0.1); border-radius: 50%; width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; cursor: pointer; transition: var(--transition); }
    .hamburger, .hamburger::before, .hamburger::after { width: 20px; height: 2px; background: var(--dark); transition: var(--transition); position: absolute; }
    .hamburger::before { content: ''; transform: translateY(-6px); }
    .hamburger::after { content: ''; transform: translateY(6px); }

    /* Open Menu Overrides */
    body.menu-open header { background-color: var(--secondary); }
    body.menu-open header .logo a { color: var(--white); }
    body.menu-open .nav-cta { background-color: var(--secondary); }
    body.menu-open .nav-cta:hover { background-color: var(--secondary-hover); }
    body.menu-open .menu-toggle { border-color: rgba(255,255,255,0.2); }
    body.menu-open .menu-toggle .hamburger { background: transparent; }
    body.menu-open .menu-toggle .hamburger::before { transform: rotate(45deg); background: var(--white); }
    body.menu-open .menu-toggle .hamburger::after { transform: rotate(-45deg); background: var(--white); }
    body.menu-open .desktop-only { opacity: 0; pointer-events: none; }
    body.menu-open { overflow: hidden; }

    /* Full Screen Overlay */
    .full-screen-menu { position: fixed; top: 0; left: 0; width: 100%; height: 100vh; background-color: var(--primary); color: var(--white); z-index: 999; opacity: 0; visibility: hidden; transition: opacity 0.4s ease, visibility 0.4s ease; overflow-y: auto; display: flex; align-items: center; }
    body.menu-open .full-screen-menu { opacity: 1; visibility: visible; }
    .menu-container { width: 100%; max-width: 1400px; margin: 0 auto; padding: 120px 5% 50px; display: grid; grid-template-columns: 2fr 1fr; gap: 4rem; }

    /* Menu Typography & Layout */
    .primary-nav ul { list-style: none; }
    .primary-nav > ul > li { margin-bottom: 1.5rem; }
    .primary-nav > ul > li > a { font-size: clamp(3rem, 5vw, 5rem); font-weight: 700; color: var(--white); letter-spacing: -2px; line-height: 1.1; }
    .primary-nav > ul > li > a:hover { color: var(--secondary); padding-left: 20px; }

    .sub-nav { margin-top: 1rem; margin-bottom: 2rem; padding-left: 1rem; border-left: 2px solid rgba(255,255,255,0.1); }
    .sub-nav li { margin-bottom: 0.5rem; position: relative; }
    .sub-nav li::before { content: '▪'; color: var(--secondary); position: absolute; left: -1rem; opacity: 0; transition: var(--transition); }
    .sub-nav li:hover::before { opacity: 1; left: -1.5rem; }
    .sub-nav a { font-size: 1.25rem; color: rgba(255,255,255,0.7); font-weight: 500; }
    .sub-nav a:hover { color: var(--white); }

    .menu-contact { padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); }
    .menu-contact h4 { color: var(--white); font-size: 1rem; text-transform: uppercase; letter-spacing: 2px; margin-bottom: 2rem; opacity: 0.5; }
    .contact-block { margin-bottom: 2rem; }
    .contact-block p { font-size: 1.1rem; color: var(--white); }
    .contact-block a { color: rgba(255,255,255,0.7); font-weight: 600; }
    .contact-block a:hover { color: var(--white) }

    /* --- CORE SECTIONS --- */
    .hero { position: relative; min-height: 80vh; display: flex; align-items: center; justify-content: center; text-align: center; padding: 0 5%; margin-top: 70px; background-size: cover; background-position: center; background-attachment: fixed; }
    .hero::before { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(to bottom, rgba(42, 52, 57, 0.6), rgba(42, 52, 57, 0.8)); z-index: 1; }
    .hero-content { position: relative; z-index: 2; max-width: 800px; color: var(--white); animation: fadeInUp 1s ease-out; }
    .hero h1 { color: var(--white); font-size: 3.5rem; margin-bottom: 1.5rem; letter-spacing: -1px; }
    .hero p { font-size: 1.25rem; margin-bottom: 2.5rem; opacity: 0.9; }
    .hero-buttons { display: flex; gap: 1rem; justify-content: center; }
    section { padding: 5rem 5%; }
    .section-header { text-align: center; max-width: 800px; margin: 0 auto 3rem; }
    .section-header h2 { font-size: 2.5rem; color: var(--primary); }
    .grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; max-width: 1200px; margin: 0 auto; }
    .card { background: var(--white); border-radius: 8px; overflow: hidden; box-shadow: var(--shadow-sm); transition: var(--transition); display: flex; flex-direction: column; }
    .card:hover { transform: translateY(-10px); box-shadow: var(--shadow-lg); }
    .card-img { height: 250px; background-color: var(--primary-hover); background-size: cover; background-position: center; }
    .card-content { padding: 2rem; flex-grow: 1; display: flex; flex-direction: column; }
    .card-content h3 { font-size: 1.5rem; margin-bottom: 1rem; }
    .card-content p { color: var(--text-muted); margin-bottom: 1.5rem; flex-grow: 1; }
    .card-link { font-weight: 600; display: flex; align-items: center; gap: 0.5rem; }
    .large-feature-image { width: 100%; max-height: 600px; object-fit: cover; border-radius: 12px; margin: 3rem 0; box-shadow: var(--shadow-md); }
    .photo-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 1rem; max-width: 1200px; margin: 0 auto; }
    .photo-grid img { width: 100%; height: 300px; object-fit: cover; border-radius: 8px; transition: var(--transition); }
    .photo-grid img:hover { transform: scale(1.02); box-shadow: var(--shadow-md); }
    .image-slideshow { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; gap: 1.5rem; padding-bottom: 1.5rem; -webkit-overflow-scrolling: touch; scrollbar-width: none; max-width: 1200px; margin: 0 auto; }
    .image-slideshow::-webkit-scrollbar { display: none; }
    .slideshow-item { flex: 0 0 85%; max-width: 800px; scroll-snap-align: center; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-sm); }
    .slideshow-item img { width: 100%; height: 450px; object-fit: cover; display: block; }
    .social-proof { background-color: var(--primary); color: var(--white); }
    .social-proof h2 { color: var(--white); }
    .reviews-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 2rem; max-width: 1200px; margin: 0 auto; }
    .review-card { background: rgba(255, 255, 255, 0.1); backdrop-filter: blur(5px); box-shadow: var(--shadow-sm); transition: var(--transition); border: 1px solid rgba(255, 255, 255, 0.2); padding: 2rem; border-radius: 8px; }
    .review-card:hover { transform: translateY(-10px); box-shadow: var(--shadow-lg); }
    .google-stars { color: var(--secondary); font-size: 1.5rem; margin-bottom: 1rem; letter-spacing: 2px; }
    .review-text { font-style: italic; margin-bottom: 1rem; font-size: 1.1rem; }
    .reviewer-name { font-weight: 600; display: flex; align-items: center; gap: 0.5rem; }
    .reviewer-name::before { content: 'G'; display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; background: #fff; color: #4285F4; border-radius: 50%; font-weight: bold; font-size: 14px; font-family: sans-serif; }
    .quote-section { background-color: var(--white); max-width: 800px; margin: 0 auto; padding: 4rem; border-radius: 12px; box-shadow: var(--shadow-lg); transform: translateY(-50px); }
    .form-group { margin-bottom: 1.5rem; }
    .form-group label { display: block; font-weight: 600; margin-bottom: 0.5rem; color: var(--dark); }
    .form-control { width: 100%; padding: 1rem; border: 1px solid #ddd; border-radius: 4px; font-family: 'Inter', sans-serif; font-size: 1rem; transition: var(--transition); }
    .form-control:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(46, 90, 68, 0.1); }
    .contact-method-selector { display: flex; gap: 1.5rem; margin-bottom: 1rem; }
    .radio-label { display: flex; align-items: center; gap: 0.5rem; font-weight: 500; cursor: pointer; }
    .conditional-input { display: none; }
    .conditional-input.active { display: block; animation: fadeIn 0.3s ease-out; }
    footer { background-color: var(--primary); color: var(--white); padding: 4rem 5% 2rem; }
    .footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 3rem; max-width: 1200px; margin: 0 auto 3rem; }
    .footer-col h4 { color: var(--white); font-size: 1.25rem; margin-bottom: 1.5rem; }
    .footer-col ul { list-style: none; }
    .footer-col ul li { margin-bottom: 0.75rem; }
    .footer-col ul a { color: rgba(255,255,255,0.7); }
    .footer-col ul a:hover { color: var(--secondary); }
    .footer-bottom { text-align: center; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); color: rgba(255,255,255,0.5); }
    #FSL { color: var(--white); text-decoration: underline; }
    #FSL:hover { color: var(--secondary-hover);}
    #FSL_logo { height: 3.2em; }
    .flex-wrap-center { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; max-width: 1000px; margin: 0 auto; }
    .sitemap-list { list-style: none; padding: 0; max-width: 800px; margin: 0 auto; }
    .sitemap-list li { margin-bottom: 0.5rem; }
    .sitemap-list > li > a { font-size: 1.25rem; font-weight: 600; display: block; padding-bottom: 0.5rem; border-bottom: 1px solid #eaeaea; margin-top: 2rem; margin-bottom: 1rem;}
    .sitemap-list ul { list-style: none; padding-left: 2rem; }
    .sitemap-list ul li a { font-size: 1rem; font-weight: 500; color: var(--dark); }
    .sitemap-list ul li a:hover { color: var(--primary); }
    @keyframes fadeInUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
    @keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }

    @media (max-width: 964px) {
        .menu-container { grid-template-columns: 1fr; gap: 2rem; padding-top: 100px; }
        .primary-nav > ul > li > a { font-size: 3.5rem; }
        .menu-contact { border-top: none; padding-top: 0; }
    }
    @media (max-width: 768px) {
        .hero h1 { font-size: 2.5rem; }
        .hero-buttons { flex-direction: column; }
        .quote-section { padding: 2rem; transform: none; margin-top: 2rem; }
        .desktop-only { display: none; }
        .primary-nav > ul > li > a { font-size: 2.5rem; }
    }
    @media (max-width: 450px) or (max-height: 450px) {
        #header_logo { height: 2em; margin: auto 0.5em auto 0; } .hero-content { margin-top: 2em; } .hero-buttons { margin-bottom: 1.5em; }
        .menu-container { margin-top: 16em; }
    }
    @media (max-width: 400px) and (max-height: 670px) { .menu-container { margin-top: 30em; }  }
    @media (max-height: 445px) { .menu-container { margin-top: 48em; } }
    