/* --- Global & Base Styles --- */
body {
    font-family: 'Open Sans', sans-serif;
    color: rgba(33, 33, 33, 1); /* Dark Gray for text */
    background-color: rgba(255, 255, 255, 1); /* White background (based on .ImnMyf) */
    margin: 0;
    padding: 0;
}

#handyman-service-site {
    min-width: 320px; /* Ensures responsiveness starting small */
}

/* Base styles for all primary text elements */
.content-sections p {
    font-size: 13pt; /* based on .zfr3Q */
    line-height: 1.6;
    margin-top: 15px;
}

/* Base styles for major headings (Oswald font) */
.content-sections h2 {
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    color: rgba(31, 31, 31, 1); /* Dark Gray */
    text-transform: uppercase;
    margin-top: 20px;
}

/* Style for medium headings (h3) */
.content-sections h3 {
    font-family: 'Open Sans', sans-serif;
    font-size: 18pt; /* based on .OmQG5e */
    line-height: 1.3;
    font-weight: 400;
    color: rgba(17, 54, 126, 1); /* Primary Blue */
    margin-top: 20px;
}


/* --- Header & Navigation Styles --- */
#site-header {
    background-color: rgba(247, 247, 247, 1); /* Light Gray background for header */
    display: none;
}

.navigation-menu {
    /* Styles mimicking the layout/spacing of nav links */
    padding: 10px 20px;
}

.logo-link {
    text-decoration: none;
    display: flex;
    align-items: center;
}

.company-name {
    font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 20pt; /* based on .Zjiec */
    color: rgba(17, 54, 126, 1); /* Primary Blue */
    margin-left: 10px;
}

.nav-list {
    list-style: none;
    display: flex;
    padding: 0;
}

.nav-item a {
    font-family: 'Open Sans', sans-serif;
    font-size: 12pt;
    font-weight: 400;
    color: rgba(31, 31, 31, 1); /* Dark Gray */
    text-decoration: none;
    padding: 0 6px;
}

/* --- Section 1: Hero Banner Styles --- */
#hero-banner {
    height: 340px; /* Based on .O13XJf */
    padding-top: 56px;
    padding-bottom: 56px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

.background-image-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center center;
    z-index: -2;
}

/* Overlay color for the background image */
.background-image-container::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(33, 33, 33, 1); /* Dark Gray overlay */
    opacity: 0.6; /* Reduced opacity based on 'section[id="h.4a9d518ede350020_0"] .IFuOkc:before' */
    display: block;
    z-index: -1;
}

.content-overlay {
    text-align: center;
    z-index: 1;
}

#company-title {
    font-size: 60pt; /* Based on .LB7kq .duRjpb */
    line-height: 1.2;
    color: rgba(255, 255, 255, 1); /* White text */
}

/* Call to Action Button */
.call-to-action-button a {
    /* Styles based on .O13XJf .QmpIrf */
    display: inline-block;
    background-color: rgba(255, 255, 255, 1); /* White BG */
    border: 1px solid rgba(17, 54, 126, 1); /* Blue Border */
    color: rgba(17, 54, 126, 1); /* Blue Text */
    font-size: 13pt;
    line-height: 22px;
    padding: 8px 16px;
    text-decoration: none;
    margin-top: 20px;
}

.tagline-container p span {
    color: rgba(255, 255, 255, 1); /* White text for taglines */
    font-style: italic;
}


/* --- Section 2 & 9 (lQAHbd sections) --- */
#mission-statement,
#final-contact-block {
    padding: 60px 20px;
    position: relative;
    background-color: rgba(17, 54, 126, 1); /* Primary Blue BG */
}

/* Background overlay (for section separation) */
#mission-statement::before,
#final-contact-block::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(17, 54, 126, 1); /* Based on .lQAHbd:before */
    display: block;
    z-index: -1;
}

#mission-statement h2,
#final-contact-block h2,
#final-contact-block p span,
#final-contact-block a span {
    color: rgba(255, 255, 255, 1) !important; /* White text for blue sections */
}

/* Button style inversion for blue sections (based on .lQAHbd .QmpIrf) */
.email-button-container a {
    display: inline-block;
    background-color: rgba(255, 255, 255, 1); /* White BG */
    border: 1px solid rgba(17, 54, 126, 1); /* Blue Border */
    color: rgba(17, 54, 126, 1); /* Blue Text */
    font-size: 13pt;
    line-height: 22px;
    padding: 8px 16px;
    text-decoration: none;
    margin-top: 20px;
}

/* --- Section 3 & 8 (qeLZfd sections) --- */
#legal-status,
#detailed-services-list {
    padding: 60px 20px;
    position: relative;
    background-color: rgba(239, 239, 239, 1); /* Light Gray BG */
}

/* Text color for light gray sections (based on .qeLZfd) */
#legal-status h3,
#detailed-services-list h3 {
    color: rgba(17, 54, 126, 1); /* Primary Blue */
}


/* --- Spotlight Section Styles (Image/Text Blocks) --- */
.service-spotlight {
    padding: 32px 20px; /* Based on .gk8rDe media query */
    background-color: rgba(255, 255, 255, 1); /* White background (based on .gk8rDe) */
}

.content-with-image {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
}

.content-with-image img {
    /* Assuming images are round based on common Google Sites layouts */
    border-radius: 50%;
    width: 150px;
    height: 150px;
    object-fit: cover;
    margin-bottom: 20px;
}

.service-spotlight h3 {
    color: rgba(31, 31, 31, 1); /* Dark Gray for the h3 in these sections (based on .gk8rDe) */
}


/* --- Detailed Services List --- */
.service-list {
    list-style-type: square;
    padding-left: 20px;
}

.service-list p {
    margin: 5px 0;
}


/* --- Footer Styles --- */
footer {
    padding: 20px 20px;
    background-color: rgba(244, 244, 244, 1); /* Light Gray (based on .Vs12Bd) */
    text-align: center;
}

.footer-contact, .copyright {
    color: rgba(17, 54, 126, 1); /* Primary Blue (based on .Vs12Bd) */
    font-size: 13pt;
    margin: 5px 0;
}

.footer-contact a {
    color: inherit;
}