/* OCF Landscaping Studio - final template overrides. */

:root {
    --text-xs: 0.75rem;
    --text-sm: 0.875rem;
    --text-base: 1rem;
    --text-lg: 1.125rem;
    --text-xl: 1.375rem;
    --text-2xl: clamp(1.75rem, 3vw, 2.25rem);
    --text-3xl: clamp(2.25rem, 4vw, 3.35rem);
    --text-4xl: clamp(3rem, 5vw, 4.5rem);
    --text-hero: clamp(3rem, 7vw, 6.35rem);

    --container-max: 1160px;
    --section-pad: clamp(4.5rem, 9vw, 7.5rem);
    --grid-gap: clamp(1rem, 2vw, 1.5rem);

    --radius-sm: 0.25rem;
    --radius: 0.375rem;
    --radius-lg: 0.5rem;
    --button-radius: 999px;
    --button-border-color: var(--ocf-accent);
    --button-shadow: none;
    --button-shadow-hover: none;
    --button-transform-hover: translateY(-1px);
    --card-radius: 0.5rem;
    --card-radius-lg: 0.5rem;
    --card-border-color: color-mix(in srgb, var(--ocf-border) 78%, transparent);
    --card-border-color-subtle: color-mix(in srgb, var(--ocf-border-light) 72%, transparent);
    --card-shadow: 0 18px 42px rgba(38, 56, 41, 0.08);
    --card-shadow-hover: 0 22px 50px rgba(38, 56, 41, 0.12);
    --card-transform-hover: translateY(-3px);
    --image-radius: 0.5rem;
    --media-overlay-opacity: 0;
}

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

body {
    background:
        radial-gradient(circle at 12% 8%, rgba(185, 130, 100, 0.09), transparent 18rem),
        linear-gradient(180deg, #fbfaf5 0, var(--ocf-bg) 28rem, var(--ocf-bg) 100%);
}

.heading-section {
    font-weight: 600;
    line-height: 0.98;
    overflow-wrap: break-word;
}

.eyebrow {
    color: var(--ocf-secondary);
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.btn-primary,
.nav-cta {
    border-color: var(--ocf-accent);
    background: var(--ocf-accent);
    color: var(--ocf-heading-alt);
}

.btn-primary:hover,
.nav-cta:hover {
    border-color: var(--ocf-accent-hover);
    background: var(--ocf-accent-hover);
}

.btn-secondary {
    border-color: color-mix(in srgb, var(--ocf-accent) 32%, var(--ocf-border));
    background: rgba(255, 250, 240, 0.56);
    color: var(--ocf-accent);
}

.btn-secondary:hover {
    border-color: var(--ocf-accent);
    background: color-mix(in srgb, var(--ocf-accent) 9%, var(--ocf-bg));
    color: var(--ocf-accent-hover);
}

.nav-bar {
    border-bottom-color: rgba(216, 211, 196, 0.78);
    background: rgba(251, 250, 245, 0.88);
    backdrop-filter: blur(18px);
}

.nav-logo {
    font-family: var(--ocf-font-heading), Georgia, serif;
    font-size: 1.25rem;
    font-weight: 600;
}

.nav-links {
    gap: 1.25rem;
}

.nav-link,
.nav-phone {
    color: color-mix(in srgb, var(--ocf-heading) 72%, var(--ocf-body));
}

.dropdown-menu,
.mobile-menu {
    border-color: var(--ocf-border-light);
    background: var(--ocf-bg);
    box-shadow: 0 18px 42px rgba(38, 56, 41, 0.08);
}

.ocf-hero {
    min-height: min(820px, calc(100vh - 4.5rem));
    background:
        linear-gradient(90deg, var(--ocf-bg) 0 62%, rgba(238, 242, 232, 0.72) 62% 100%);
}

.ocf-hero__media {
    inset: clamp(2rem, 5vw, 4.5rem) clamp(1rem, 5vw, 5rem) clamp(2rem, 5vw, 4.5rem) auto;
    width: min(42vw, 540px);
    border-radius: 48% 48% 0.5rem 0.5rem;
    opacity: 1;
    overflow: hidden;
    box-shadow: 0 28px 70px rgba(38, 56, 41, 0.16);
}

.ocf-hero__media img {
    filter: saturate(0.9) contrast(0.98);
}

.ocf-hero__shade {
    display: none;
}

.ocf-hero__grid {
    grid-template-columns: minmax(0, 0.68fr);
    min-height: min(820px, calc(100vh - 4.5rem));
    padding-block: clamp(5rem, 9vw, 8rem);
}

.ocf-hero__content {
    max-width: 690px;
}

.ocf-hero__rating {
    gap: 0.55rem;
    width: fit-content;
    margin-bottom: 1.35rem;
    border: 1px solid var(--ocf-border-light);
    border-radius: 999px;
    background: rgba(255, 250, 240, 0.74);
    padding: 0.45rem 0.75rem;
    color: var(--ocf-label);
}

.ocf-hero__stars {
    color: var(--ocf-secondary);
}

.ocf-hero__text {
    max-width: 52ch;
    color: var(--ocf-body);
}

.ocf-services,
.ocf-commitments,
.ocf-service-areas,
.page-section--alt {
    background:
        linear-gradient(135deg, rgba(255, 250, 240, 0.72), rgba(238, 242, 232, 0.92)),
        var(--ocf-bg-alt);
}

.ocf-services-header {
    align-items: end;
    margin-bottom: clamp(2rem, 4vw, 3rem);
}

.ocf-svc-nav button,
.ocf-testimonial-nav button {
    display: inline-grid;
    place-items: center;
    border-radius: 999px;
    background: var(--ocf-bg);
}

.ocf-svc-nav button:not(:disabled):hover,
.ocf-testimonial-nav button:not(:disabled):hover {
    border-color: var(--ocf-accent);
    color: var(--ocf-accent);
}

.ocf-svc-track .ocf-svc-card {
    flex-basis: calc((100% - (var(--grid-gap) * 2)) / 3);
}

.ocf-svc-card {
    border-color: var(--card-border-color-subtle);
    background: rgba(255, 250, 240, 0.78);
    box-shadow: var(--card-shadow);
    transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}

.ocf-svc-card:hover {
    transform: var(--card-transform-hover);
    box-shadow: var(--card-shadow-hover);
}

.ocf-svc-card-img {
    aspect-ratio: 5 / 4;
    border-radius: var(--card-radius) var(--card-radius) 0 0;
}

.ocf-svc-card-img img {
    filter: saturate(0.9);
}

.ocf-svc-card-body {
    gap: 0.75rem;
    padding: 1.25rem;
}

.ocf-svc-card-body h3 {
    font-family: var(--ocf-font-heading), Georgia, serif;
    font-size: 1.45rem;
    font-weight: 600;
    line-height: 1.05;
}

.ocf-svc-arrow {
    display: inline-grid;
    width: 2rem;
    height: 2rem;
    place-items: center;
    margin-top: 0.25rem;
    border: 1px solid var(--ocf-border-light);
    border-radius: 999px;
    color: var(--ocf-accent);
}

.ocf-about__grid,
.about-grid {
    grid-template-columns: minmax(0, 0.92fr) minmax(280px, 0.86fr);
}

.ocf-about__copy,
.about-content {
    gap: 1.25rem;
}

.ocf-about__media,
.ocf-about__image,
.about-image-wrap {
    border: 0;
    border-radius: 48% 48% var(--image-radius) var(--image-radius);
    box-shadow: 0 20px 54px rgba(38, 56, 41, 0.12);
}

.ocf-about__media img,
.ocf-about__image img,
.about-image img {
    aspect-ratio: 4 / 5;
}

.ocf-commitments-grid,
.ocf-commitments__grid {
    grid-template-columns: minmax(0, 0.78fr) minmax(0, 1fr);
}

.ocf-commitment {
    grid-template-columns: 3rem 1fr;
    border-top: 1px solid var(--ocf-border-light);
    padding-top: 1rem;
}

.ocf-commitment-num {
    color: var(--ocf-secondary);
    font-family: var(--ocf-font-heading), Georgia, serif;
    font-size: 1.45rem;
    font-weight: 600;
}

.ocf-commitment h3 {
    font-family: var(--ocf-font-heading), Georgia, serif;
    font-size: 1.35rem;
    font-weight: 600;
}

.ocf-testimonials {
    background: var(--ocf-bg);
}

.ocf-testimonial-card,
.ocf-testimonial {
    border-color: var(--card-border-color-subtle);
    border-radius: var(--card-radius);
    background: rgba(255, 250, 240, 0.8);
    padding: 1.35rem;
    box-shadow: none;
}

.testimonial-quote-mark {
    color: var(--ocf-secondary);
    font-family: var(--ocf-font-heading), Georgia, serif;
}

.testimonial-avatar {
    border-radius: 999px;
    background: var(--ocf-bg-alt);
    color: var(--ocf-accent);
}

.ocf-service-areas__grid,
.ocf-area-grid {
    grid-template-columns: minmax(0, 1.05fr) minmax(300px, 0.85fr);
}

.ocf-service-areas__map {
    min-height: 0;
    border-color: var(--card-border-color-subtle);
    border-radius: var(--card-radius-lg);
    background: var(--ocf-bg);
    box-shadow: var(--card-shadow);
}

.ocf-service-areas__map-visual {
    height: clamp(22rem, 38vw, 32rem);
    background:
        radial-gradient(circle at 46% 48%, rgba(185, 130, 100, 0.28) 0 0.48rem, transparent 0.52rem),
        linear-gradient(35deg, transparent 0 43%, rgba(63, 90, 66, 0.18) 43% 45%, transparent 45% 100%),
        linear-gradient(122deg, transparent 0 36%, rgba(63, 90, 66, 0.13) 36% 38%, transparent 38% 100%),
        linear-gradient(90deg, rgba(216, 211, 196, 0.38) 1px, transparent 1px),
        linear-gradient(0deg, rgba(216, 211, 196, 0.38) 1px, transparent 1px),
        #f6f4ec;
    background-size: auto, auto, auto, 4rem 4rem, 4rem 4rem, auto;
}

.ocf-map-pin {
    width: 1.2rem;
    height: 1.2rem;
    border-color: var(--ocf-accent);
    box-shadow: 0 0 0 0.75rem rgba(63, 90, 66, 0.11);
}

.ocf-service-areas__links {
    gap: 0.6rem;
}

.ocf-service-areas__link {
    border-color: var(--ocf-border-light);
    border-radius: 999px;
    background: rgba(255, 250, 240, 0.66);
    color: var(--ocf-heading);
    padding: 0.55rem 0.85rem;
}

.ocf-faq {
    background: var(--ocf-bg);
}

.ocf-cta {
    background: var(--ocf-bg);
    color: var(--ocf-body);
}

.ocf-cta__panel,
.ocf-cta__grid {
    min-height: clamp(16rem, 24vw, 20rem);
    border: 0;
    border-radius: var(--card-radius-lg);
    background:
        linear-gradient(135deg, rgba(63, 90, 66, 0.94), rgba(38, 56, 41, 0.96)),
        var(--ocf-bg-dark);
    box-shadow: 0 24px 60px rgba(38, 56, 41, 0.16);
}

.ocf-cta__shade {
    opacity: 0.32;
}

.ocf-cta__image {
    opacity: 0.16;
    filter: saturate(0.8);
}

.site-footer {
    border-top-color: var(--ocf-border-light);
    background: #f6f4ec;
}

.footer-brand-name,
.footer-heading {
    font-family: var(--ocf-font-heading), Georgia, serif;
    font-weight: 600;
}

.footer-grid {
    gap: clamp(1.5rem, 3vw, 2.5rem);
}

@media (max-width: 980px) {
    .ocf-hero {
        min-height: auto;
        background: var(--ocf-bg);
    }

    .ocf-hero__media {
        position: relative;
        inset: auto;
        order: -1;
        width: 100%;
        max-width: none;
        height: clamp(18rem, 50vw, 30rem);
        margin-top: 1.25rem;
        border-radius: var(--image-radius);
    }

    .ocf-hero__grid {
        grid-template-columns: 1fr;
        min-height: 0;
        padding-block: clamp(3rem, 10vw, 5rem);
    }
}

@media (max-width: 900px) {
    .ocf-svc-track .ocf-svc-card {
        flex-basis: calc((100% - var(--grid-gap)) / 2);
    }

    .ocf-commitments-grid,
    .ocf-commitments__grid,
    .ocf-service-areas__grid,
    .ocf-area-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    body {
        padding-top: 4rem;
    }

    .heading-section.size-xl {
        font-size: clamp(2.55rem, 15vw, 4rem);
    }

    .ocf-services-header,
    .ocf-testimonials-header,
    .ocf-testimonials__header {
        display: grid;
    }

    .ocf-svc-track .ocf-svc-card {
        flex-basis: 100%;
    }

    .ocf-hero__rating {
        align-items: flex-start;
        border-radius: var(--radius);
    }
}
