/* 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,
.hero-form-card .form-submit-btn,
.booking-submit,
.bw-button-primary {
    border-color: var(--ocf-accent);
    background: var(--ocf-accent);
    color: var(--ocf-heading-alt);
}

.btn-primary:hover,
.nav-cta:hover,
.hero-form-card .form-submit-btn:hover,
.booking-submit:hover,
.bw-button-primary: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(780px, calc(100vh - 4.5rem));
    background: var(--ocf-bg);
}

.ocf-hero__media {
    inset: 0;
    width: 100%;
    border-radius: 0;
    opacity: 1;
    overflow: hidden;
    box-shadow: none;
}

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

.ocf-hero__shade {
    display: block;
    background: linear-gradient(90deg, rgba(251, 250, 245, 0.2), rgba(251, 250, 245, 0.02));
    opacity: 1;
}

.ocf-hero__grid {
    grid-template-columns: minmax(0, 0.55fr) minmax(0, 0.45fr);
    min-height: min(780px, calc(100vh - 4.5rem));
    padding-block: clamp(4rem, 7vw, 6.5rem);
}

.ocf-hero__content {
    max-width: 620px;
    align-self: center;
    border: 1px solid rgba(216, 211, 196, 0.62);
    background: rgba(251, 250, 245, 0.94);
    padding: clamp(2.5rem, 5vw, 4.2rem);
    box-shadow: 0 20px 60px rgba(38, 56, 41, 0.1);
}

.ocf-hero__rating {
    gap: 0.55rem;
    width: fit-content;
    margin-bottom: 1.35rem;
    border: 1px solid var(--ocf-border-light);
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
    color: var(--ocf-label);
}

.ocf-hero__title {
    font-size: clamp(3.15rem, 5vw, 5.05rem);
    letter-spacing: 0;
}

.ocf-hero__actions {
    align-items: center;
    gap: 1.5rem;
}

.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-card {
    border-color: var(--card-border-color-subtle);
    background: rgba(255, 250, 240, 0.9);
    box-shadow: none;
    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: 1 / 1.08;
    border-radius: var(--card-radius) var(--card-radius) 0 0;
}

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

.ocf-svc-card-body {
    align-items: center;
    gap: 0.7rem;
    min-height: 10.75rem;
    padding: 1.25rem 1rem;
    text-align: center;
}

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

.ocf-svc-card-body p {
    font-size: 0.84rem;
    line-height: 1.55;
}

.ocf-svc-arrow {
    display: inline-flex;
    width: auto;
    height: auto;
    gap: 0.45rem;
    place-items: center;
    margin-top: 0.25rem;
    border: 0;
    border-radius: 0;
    color: var(--ocf-accent);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.ocf-svc-arrow::before {
    content: "Learn More";
}

@media (min-width: 1100px) {
    .ocf-svc-track .ocf-svc-card {
        flex-basis: calc((100% - (var(--grid-gap) * 5)) / 6);
    }
}

@media (min-width: 900px) and (max-width: 1099px) {
    .ocf-svc-track .ocf-svc-card {
        flex-basis: calc((100% - (var(--grid-gap) * 3)) / 4);
    }
}

.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 {
    position: relative;
    min-height: 0;
    border-color: var(--card-border-color-subtle);
    border-radius: var(--card-radius-lg);
    background:
        radial-gradient(circle at 49% 48%, rgba(63, 90, 66, 0.2) 0 8rem, transparent 8.1rem),
        linear-gradient(35deg, transparent 0 43%, rgba(63, 90, 66, 0.16) 43% 45%, transparent 45% 100%),
        linear-gradient(122deg, transparent 0 36%, rgba(63, 90, 66, 0.12) 36% 38%, transparent 38% 100%),
        linear-gradient(90deg, rgba(216, 211, 196, 0.46) 1px, transparent 1px),
        linear-gradient(0deg, rgba(216, 211, 196, 0.46) 1px, transparent 1px),
        #f6f4ec;
    background-size: auto, auto, auto, 4rem 4rem, 4rem 4rem, auto;
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.ocf-service-areas__map::before {
    content: "";
    position: absolute;
    inset: 17% 24%;
    border: 1px solid rgba(63, 90, 66, 0.22);
    border-radius: 999px;
    background: rgba(63, 90, 66, 0.08);
    pointer-events: none;
}

.ocf-service-areas__map::after {
    content: "Irvine";
    position: absolute;
    left: 50%;
    top: 50%;
    width: 0.82rem;
    height: 0.82rem;
    border-radius: 999px;
    background: var(--ocf-accent);
    box-shadow: 0 0 0 0.75rem rgba(63, 90, 66, 0.12);
    color: var(--ocf-heading);
    font-size: 0.76rem;
    font-weight: 700;
    line-height: 1;
    text-indent: 1.25rem;
    transform: translate(-50%, -50%);
    pointer-events: none;
}

.ocf-service-areas__map iframe {
    min-height: clamp(22rem, 38vw, 32rem);
    opacity: 0.08;
    filter: grayscale(1) contrast(0.86) brightness(1.12);
}

.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);
}

.hero-form-card,
.ocf-simple-form,
.booking-wizard {
    border-color: var(--ocf-border-light);
    border-radius: var(--card-radius-lg);
    background: rgba(255, 250, 240, 0.86);
    box-shadow: var(--card-shadow);
}

.ocf-field input,
.ocf-field textarea,
.hero-form-card input,
.hero-form-card textarea,
.ocf-phone-combo,
.booking-wizard input,
.booking-wizard textarea,
.booking-wizard select,
.bw-phone-combo,
.bw-service-option {
    border-color: var(--ocf-border-light);
    border-radius: var(--radius);
    background: rgba(255, 250, 240, 0.82);
}

.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__shade {
        display: none;
    }

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

    .ocf-hero__content {
        max-width: none;
        border: 0;
        background: transparent;
        padding: 0;
        box-shadow: none;
    }
}

@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;
    }

    .container-global,
    .ocf-hero__grid,
    .ocf-hero__content,
    .ocf-hero__form {
        width: calc(100vw - 2rem);
        max-width: calc(100vw - 2rem);
    }

    .heading-section.size-xl {
        font-size: clamp(2.4rem, 12vw, 3.4rem);
    }

    .ocf-hero__title {
        max-width: 100%;
        overflow-wrap: break-word;
    }

    .ocf-hero__title span {
        display: inline;
    }

    .ocf-hero__title span:not(:last-child)::after {
        content: " ";
    }

    .hero-form-card,
    .ocf-simple-form,
    .booking-wizard {
        width: 100%;
        max-width: 100%;
        overflow: hidden;
    }

    .ocf-phone-combo,
    .bw-phone-combo {
        display: grid;
        grid-template-columns: minmax(0, 7rem) minmax(0, 1fr);
    }

    .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);
    }
}
