:root {
    --text-xs: 0.76rem;
    --text-sm: 0.9rem;
    --text-lg: 1.15rem;
    --text-xl: 1.45rem;
    --text-2xl: 2rem;
    --text-3xl: clamp(2.15rem, 3.2vw, 3.35rem);
    --text-4xl: clamp(2.65rem, 4.4vw, 4.45rem);
    --text-hero: clamp(3rem, 5.35vw, 5.85rem);

    --container-max: 1216px;
    --container-pad: clamp(1.125rem, 4vw, 2.5rem);
    --section-pad: clamp(4.25rem, 8vw, 7.75rem);
    --grid-gap: clamp(1rem, 2vw, 1.5rem);

    --radius-sm: 6px;
    --radius: 8px;
    --radius-lg: 8px;
    --button-radius: 999px;
    --button-border-color: var(--ocf-heading);
    --button-shadow: 0 14px 34px rgba(20, 19, 15, 0.08);
    --button-shadow-hover: 0 18px 42px rgba(20, 19, 15, 0.12);
    --button-transform-hover: translateY(-1px);
    --card-radius: 8px;
    --card-radius-lg: 8px;
    --card-border-color: color-mix(in srgb, var(--ocf-border) 72%, transparent);
    --card-border-color-subtle: color-mix(in srgb, var(--ocf-border-light) 78%, transparent);
    --card-shadow: 0 20px 70px rgba(20, 19, 15, 0.07);
    --card-shadow-hover: 0 24px 80px rgba(20, 19, 15, 0.1);
    --card-transform-hover: translateY(-2px);
    --image-radius: 8px;
    --media-overlay-opacity: 0.18;
}

body {
    background:
        linear-gradient(90deg, rgba(20, 19, 15, 0.035) 1px, transparent 1px) 0 0 / 5.5rem 5.5rem,
        var(--ocf-bg);
    color: var(--ocf-body);
}

.ocf-section {
    overflow: clip;
}

.eyebrow {
    align-items: center;
    gap: 0.5rem;
    color: var(--ocf-accent);
    font-size: var(--text-xs);
    font-weight: 800;
    text-transform: uppercase;
}

.eyebrow::before {
    content: "";
    width: 1.65rem;
    height: 1px;
    background: currentColor;
}

.heading-section {
    max-width: min(100%, 20ch);
    font-weight: 600;
}

.heading-section.size-lg,
.heading-section.size-md {
    max-width: min(100%, 19ch);
}

.text-body,
.ocf-hero__text,
.ocf-about__text,
.about-body,
.ocf-service-areas__text,
.ocf-cta__text {
    font-size: var(--text-lg);
    line-height: 1.65;
}

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

.btn-primary:hover,
.nav-cta:hover,
.form-submit-btn:hover:not(:disabled) {
    background: var(--ocf-accent);
    box-shadow: var(--button-shadow-hover);
}

.btn-secondary {
    border-color: color-mix(in srgb, var(--ocf-heading) 22%, transparent);
    background: color-mix(in srgb, var(--ocf-bg) 72%, white);
}

.btn-secondary:hover {
    border-color: var(--ocf-accent);
    color: var(--ocf-accent);
}

.nav-bar {
    border-bottom-color: color-mix(in srgb, var(--ocf-border) 68%, transparent);
    background: color-mix(in srgb, var(--ocf-bg) 90%, transparent);
    backdrop-filter: blur(18px);
}

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

.nav-links {
    gap: 1.2rem;
}

.nav-link,
.nav-phone,
.dropdown-item,
.mobile-link,
.mobile-accordion-trigger {
    font-weight: 650;
}

.dropdown-menu,
.mobile-menu {
    border-color: color-mix(in srgb, var(--ocf-border) 75%, transparent);
    border-radius: var(--radius);
    box-shadow: 0 24px 70px rgba(20, 19, 15, 0.12);
}

.ocf-hero {
    min-height: min(820px, calc(100vh - 4.5rem));
    background:
        radial-gradient(circle at 78% 18%, rgba(216, 58, 49, 0.12), transparent 28rem),
        linear-gradient(135deg, var(--ocf-bg) 0%, #f4efe4 58%, #e9e0d1 100%);
}

.ocf-hero::after {
    content: "";
    position: absolute;
    right: max(2rem, calc((100vw - var(--container-max)) / 2));
    bottom: clamp(3rem, 7vw, 6rem);
    width: min(33vw, 25rem);
    aspect-ratio: 4 / 5;
    border: 1px solid color-mix(in srgb, var(--ocf-heading) 14%, transparent);
    border-radius: var(--image-radius);
    background:
        linear-gradient(135deg, rgba(20, 19, 15, 0.72), rgba(20, 19, 15, 0.18)),
        url("../hero-placeholder.jpg") center / cover no-repeat;
    box-shadow: 0 32px 90px rgba(20, 19, 15, 0.18);
    pointer-events: none;
}

.ocf-hero__media {
    opacity: 0.1;
    filter: grayscale(1) contrast(1.08);
    mix-blend-mode: multiply;
}

.ocf-hero__grid {
    z-index: 1;
    min-height: inherit;
    align-items: center;
}

.ocf-hero--split_no_form .ocf-hero__grid,
.ocf-hero--single_column .ocf-hero__grid,
.ocf-hero--centered_band .ocf-hero__grid,
.ocf-hero--compact_emergency .ocf-hero__grid {
    grid-template-columns: minmax(0, 0.82fr) minmax(14rem, 0.45fr);
}

.ocf-hero__content {
    max-width: min(100%, 900px);
}

.ocf-hero__rating {
    width: fit-content;
    border: 1px solid color-mix(in srgb, var(--ocf-heading) 16%, transparent);
    border-radius: var(--radius-full);
    background: rgba(255, 250, 240, 0.72);
    padding: 0.55rem 0.85rem;
    color: var(--ocf-heading);
    backdrop-filter: blur(12px);
}

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

.ocf-hero__title {
    max-width: min(100%, 14.8ch);
}

.ocf-hero__text {
    max-width: 49ch;
    color: color-mix(in srgb, var(--ocf-body) 92%, var(--ocf-heading));
}

.ocf-hero__actions {
    margin-top: 2rem;
}

.ocf-services {
    background: var(--ocf-bg-dark);
    color: var(--ocf-body-alt);
}

.ocf-services .heading-section {
    color: var(--ocf-heading-alt);
}

.ocf-services .eyebrow {
    color: var(--ocf-label-alt);
}

.ocf-services-header {
    align-items: end;
}

.ocf-services-heading {
    width: 100%;
    max-width: min(100%, 1040px);
}

.ocf-services .heading-section {
    max-width: min(100%, 29ch);
    font-size: clamp(2.45rem, 3.45vw, 4rem);
    line-height: 1.02;
}

.ocf-services--slider .ocf-svc-viewport {
    overflow: hidden;
}

.ocf-services--slider .ocf-svc-track {
    align-items: stretch;
}

.ocf-services--slider .ocf-svc-track .ocf-svc-card {
    flex-basis: calc((100% - (var(--grid-gap) * 2)) / 3);
    min-height: clamp(27rem, 34vw, 33rem);
}

.ocf-svc-card {
    height: 100%;
    border-color: var(--ocf-border-alt);
    background:
        linear-gradient(180deg, rgba(255, 250, 240, 0.07), rgba(255, 250, 240, 0.025)),
        #1c1a15;
    color: var(--ocf-body-alt);
}

.ocf-svc-card:hover {
    border-color: color-mix(in srgb, var(--ocf-accent) 62%, var(--ocf-border-alt));
    transform: var(--card-transform-hover);
}

.ocf-svc-card-img {
    display: block;
    aspect-ratio: 16 / 11;
    border-bottom: 1px solid var(--ocf-border-alt);
    background: #15130f;
}

.ocf-svc-card-img img {
    filter: grayscale(0.2) contrast(1.04);
}

.ocf-svc-card-body {
    flex: 1;
    min-height: 14rem;
    align-content: space-between;
    padding: clamp(1.25rem, 3vw, 1.8rem);
}

.ocf-svc-card-body::before {
    content: "0" counter(service-card);
    color: var(--ocf-accent);
    font-size: var(--text-xs);
    font-weight: 800;
}

.ocf-svc-grid,
.ocf-svc-track {
    counter-reset: service-card;
}

.ocf-svc-card {
    counter-increment: service-card;
}

.ocf-svc-card-body p {
    color: var(--ocf-body-alt);
    font-size: var(--text-base);
}

.ocf-svc-card-body h3 {
    color: var(--ocf-heading-alt);
}

.ocf-svc-arrow {
    display: inline-flex;
    color: var(--ocf-accent);
}

.ocf-svc-nav button,
.ocf-testimonial-nav button {
    border-radius: var(--radius-full);
}

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

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

.about-image-wrap,
.ocf-about__media,
.ocf-about__image,
.ocf-commitments-image,
.ocf-commitments__media {
    border-color: color-mix(in srgb, var(--ocf-heading) 13%, transparent);
    border-radius: var(--image-radius);
    box-shadow: 0 30px 80px rgba(20, 19, 15, 0.12);
}

.about-image img,
.ocf-about__media img,
.ocf-about__image img {
    aspect-ratio: auto;
    min-height: clamp(30rem, 46vw, 40rem);
}

.ocf-commitments-image img,
.ocf-commitments__media img {
    aspect-ratio: auto;
    min-height: clamp(32rem, 44vw, 39rem);
}

.about-image img,
.ocf-about__media img,
.ocf-about__image img,
.ocf-commitments-image img,
.ocf-commitments__media img {
    filter: grayscale(0.3) contrast(1.02);
}

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

.ocf-commitments-grid,
.ocf-commitments__grid {
    grid-template-columns: minmax(0, 0.95fr) minmax(280px, 0.72fr);
    align-items: center;
}

.ocf-commitment {
    border-top: 1px solid color-mix(in srgb, var(--ocf-border) 78%, transparent);
    padding-top: 1.1rem;
}

.ocf-commitment-num {
    color: var(--ocf-accent);
    font-weight: 800;
}

.ocf-testimonials {
    background:
        linear-gradient(180deg, var(--ocf-bg) 0%, #f7f1e6 100%);
}

.ocf-testimonials-header,
.ocf-testimonials__header {
    max-width: 860px;
}

.ocf-testimonial-card,
.ocf-testimonial {
    min-height: 18rem;
    border-color: color-mix(in srgb, var(--ocf-border) 75%, transparent);
    border-radius: var(--card-radius);
    background: color-mix(in srgb, var(--ocf-bg) 86%, white);
    padding: clamp(1.15rem, 2.5vw, 1.6rem);
    box-shadow: var(--card-shadow);
}

.testimonial-quote-mark {
    color: var(--ocf-accent);
}

.testimonial-avatar {
    border-radius: var(--radius-full);
    background: var(--ocf-heading);
    color: var(--ocf-heading-alt);
}

.ocf-service-areas {
    background: var(--ocf-bg-dark);
    color: var(--ocf-body-alt);
}

.ocf-service-areas .heading-section,
.ocf-service-areas__link,
.ocf-service-areas .btn-secondary {
    color: var(--ocf-heading-alt);
}

.ocf-service-areas .eyebrow {
    color: var(--ocf-label-alt);
}

.ocf-service-areas__grid,
.ocf-area-grid {
    grid-template-columns: minmax(280px, 0.86fr) minmax(0, 1fr);
}

.ocf-service-areas__map {
    min-height: 0;
    border-color: var(--ocf-border-alt);
    border-radius: var(--image-radius);
    background: transparent;
}

.ocf-service-areas__map-visual {
    height: clamp(20rem, 35vw, 28rem);
    background:
        linear-gradient(135deg, rgba(216, 58, 49, 0.78), transparent 42%),
        linear-gradient(315deg, rgba(47, 95, 143, 0.5), transparent 46%),
        #211f19;
}

.ocf-map-pin {
    width: 7rem;
    height: 7rem;
    border: 1px solid rgba(255, 250, 240, 0.28);
    background: rgba(255, 250, 240, 0.08);
}

.ocf-service-areas__text {
    color: var(--ocf-body-alt);
}

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

.ocf-service-areas__link {
    border-color: var(--ocf-border-alt);
    border-radius: var(--radius-full);
    background: rgba(255, 250, 240, 0.08);
}

.ocf-service-areas .btn-secondary {
    border-color: var(--ocf-border-alt);
    background: transparent;
}

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

.ocf-faq__item,
.ocf-faq-item {
    border-color: color-mix(in srgb, var(--ocf-border) 76%, transparent);
    background: color-mix(in srgb, var(--ocf-bg) 86%, white);
}

.ocf-faq__question,
.ocf-faq-question,
.ocf-faq-trigger {
    padding: 1.15rem 1.25rem;
}

.ocf-faq__answer,
.ocf-faq-answer {
    padding-inline: 1.25rem;
    padding-bottom: 1.2rem;
}

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

.ocf-cta__panel,
.ocf-cta__grid {
    min-height: clamp(24rem, 40vw, 34rem);
    border: 0;
    border-radius: var(--card-radius);
    background:
        linear-gradient(135deg, rgba(20, 19, 15, 0.92), rgba(20, 19, 15, 0.7)),
        var(--ocf-bg-dark);
    box-shadow: 0 34px 100px rgba(20, 19, 15, 0.18);
}

.ocf-cta__inner {
    padding: clamp(1.5rem, 6vw, 4rem);
}

.ocf-cta__image {
    opacity: 0.18;
    filter: grayscale(0.35) contrast(1.1);
}

.site-footer {
    border-top-color: color-mix(in srgb, var(--ocf-border) 70%, transparent);
    background: #f3ede1;
}

.footer-grid {
    grid-template-columns: minmax(220px, 1.25fr) repeat(4, minmax(0, 0.8fr));
}

.footer-heading {
    color: var(--ocf-heading);
    font-size: var(--text-xs);
    text-transform: uppercase;
}

.footer-link-list a:hover,
.footer-contact-links a:hover,
.footer-bottom-links a:hover {
    color: var(--ocf-accent);
}

.footer-bottom {
    border-top-color: color-mix(in srgb, var(--ocf-border) 72%, transparent);
}

@media (max-width: 980px) {
    .ocf-hero::after {
        display: none;
    }

    .ocf-hero--split_no_form .ocf-hero__grid,
    .ocf-hero--single_column .ocf-hero__grid,
    .ocf-hero--centered_band .ocf-hero__grid,
    .ocf-hero--compact_emergency .ocf-hero__grid {
        grid-template-columns: 1fr;
    }

    .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

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

@media (max-width: 760px) {
    .heading-section,
    .heading-section.size-lg,
    .heading-section.size-md,
    .ocf-hero__title {
        max-width: 100%;
    }

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

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

    .ocf-svc-card-body,
    .ocf-testimonial-card {
        min-height: 0;
    }

    .ocf-services--slider .ocf-svc-track .ocf-svc-card {
        flex-basis: 100%;
        min-height: 0;
    }

    .about-image img,
    .ocf-about__media img,
    .ocf-about__image img,
    .ocf-commitments-image img,
    .ocf-commitments__media img {
        min-height: 18rem;
    }

    .ocf-service-areas__map-visual {
        height: 16rem;
    }
}
