/* Utility Systems theme for base3-bones. Source: docs/assets/utility-systems-v1/utility-systems-v1-imagegen-reference.png. */

:root {
    --text-xs: 0.74rem;
    --text-sm: 0.86rem;
    --text-base: 1rem;
    --text-lg: 1.12rem;
    --text-xl: 1.32rem;
    --text-2xl: clamp(1.45rem, 2.2vw, 1.9rem);
    --text-3xl: clamp(2rem, 3.8vw, 3rem);
    --text-4xl: clamp(2.5rem, 5vw, 4rem);
    --text-hero: clamp(2.8rem, 6vw, 5.55rem);
    --container-max: 1220px;
    --container-pad: clamp(1rem, 4vw, 2.5rem);
    --section-pad: clamp(4rem, 8.5vw, 7rem);
    --grid-gap: clamp(1rem, 2vw, 1.5rem);
    --radius-sm: 0.35rem;
    --radius: 0.45rem;
    --radius-lg: 0.65rem;
    --button-radius: 0.22rem;
    --button-shadow: none;
    --button-shadow-hover: 0 1rem 2.2rem -1.7rem color-mix(in srgb, var(--ocf-accent) 44%, transparent);
    --button-transform-hover: translateY(-1px);
    --button-letter-spacing: 0;
    --button-text-transform: none;
    --card-radius: 0.45rem;
    --card-radius-lg: 0.65rem;
    --card-border-color: color-mix(in srgb, var(--ocf-border) 88%, transparent);
    --card-border-color-subtle: color-mix(in srgb, var(--ocf-border-light) 82%, transparent);
    --card-shadow: 0 1.4rem 3.5rem -3rem color-mix(in srgb, var(--ocf-bg-dark) 38%, transparent);
    --card-shadow-hover: 0 1.8rem 4rem -3rem color-mix(in srgb, var(--ocf-bg-dark) 46%, transparent);
    --card-transform-hover: translateY(-2px);
    --image-radius: 0.55rem;
    --media-overlay-opacity: 0.18;
    --duration: 190ms;
    --ease: cubic-bezier(0.16, 1, 0.3, 1);
    --utility-line: color-mix(in srgb, var(--ocf-border-light) 72%, transparent);
    --utility-surface: color-mix(in srgb, #ffffff 82%, var(--ocf-bg));
    --utility-amber-soft: color-mix(in srgb, var(--ocf-secondary) 14%, var(--ocf-bg));
}

body {
    background:
        linear-gradient(90deg, var(--utility-line) 1px, transparent 1px),
        linear-gradient(var(--utility-line) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in srgb, var(--ocf-bg-alt) 52%, transparent), transparent 36rem),
        var(--ocf-bg);
    background-size: 96px 96px, 96px 96px, 100% 100%, 100% 100%;
}

.ocf-section {
    background: transparent;
}

.eyebrow {
    color: var(--ocf-accent);
    font-size: 0.72rem;
    font-weight: 800;
    letter-spacing: 0.11em;
    text-transform: uppercase;
}

.heading-section {
    color: var(--ocf-heading);
    font-weight: 820;
    line-height: 1.01;
}

.text-body,
.prose,
.page-content-body {
    color: var(--ocf-body);
}

.btn-primary,
.btn-secondary,
.nav-cta {
    min-height: 2.95rem;
    padding: 0.78rem 1.1rem;
    font-weight: 800;
}

.btn-primary,
.nav-cta,
.ocf-simple-form .btn-primary,
.hero-form-card .form-submit-btn,
.booking-submit,
.bw-button-primary {
    background: var(--ocf-accent);
    border-color: 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 {
    background: var(--ocf-accent-hover);
    border-color: var(--ocf-accent-hover);
    box-shadow: var(--button-shadow-hover);
}

.btn-secondary {
    background: color-mix(in srgb, #ffffff 72%, transparent);
    border-color: color-mix(in srgb, var(--ocf-accent) 28%, var(--ocf-border));
    color: var(--ocf-accent);
}

.nav-bar {
    background: color-mix(in srgb, var(--ocf-bg) 92%, transparent);
    border-bottom-color: var(--ocf-border-light);
    box-shadow: 0 1rem 2.2rem -2rem color-mix(in srgb, var(--ocf-bg-dark) 32%, transparent);
    backdrop-filter: blur(16px) saturate(1.05);
}

.nav-logo {
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.nav-links {
    gap: 1.1rem;
    color: color-mix(in srgb, var(--ocf-heading) 82%, var(--ocf-body));
    font-size: 0.78rem;
    font-weight: 750;
}

.nav-phone {
    color: var(--ocf-heading);
    font-size: 0.84rem;
    font-weight: 850;
}

.dropdown-menu,
.mobile-menu {
    background: color-mix(in srgb, var(--ocf-bg) 96%, transparent);
    box-shadow: var(--card-shadow);
}

.ocf-hero {
    min-height: min(790px, calc(100dvh - 4.5rem));
    background:
        linear-gradient(90deg, var(--ocf-bg) 0%, var(--ocf-bg) 47%, color-mix(in srgb, var(--ocf-bg-alt) 86%, var(--ocf-bg)) 47%, color-mix(in srgb, var(--ocf-bg-alt) 86%, var(--ocf-bg)) 100%);
}

.ocf-hero__media {
    left: 48%;
    right: 0;
    width: 52%;
    overflow: hidden;
}

.ocf-hero__media::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, var(--ocf-bg) 0%, color-mix(in srgb, var(--ocf-bg) 70%, transparent) 10%, transparent 32%),
        linear-gradient(0deg, color-mix(in srgb, var(--ocf-bg-dark) 18%, transparent), transparent 46%);
}

.ocf-hero__shade {
    background:
        linear-gradient(90deg, var(--ocf-bg) 0%, var(--ocf-bg) 46%, color-mix(in srgb, var(--ocf-bg) 26%, transparent) 64%, transparent 100%);
    opacity: 1;
}

.ocf-hero__grid {
    grid-template-columns: minmax(0, 590px);
    min-height: inherit;
    align-items: center;
    padding-block: clamp(4.5rem, 9vw, 7rem);
}

.ocf-hero__rating {
    width: fit-content;
    margin-bottom: 1.15rem;
    border: 1px solid color-mix(in srgb, var(--ocf-accent) 20%, transparent);
    border-radius: var(--radius-full);
    background: color-mix(in srgb, #ffffff 78%, transparent);
    color: var(--ocf-accent);
    padding: 0.48rem 0.7rem;
    font-size: 0.8rem;
    font-weight: 800;
}

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

.ocf-hero__title {
    color: var(--ocf-heading);
    letter-spacing: 0;
    max-width: 11.8ch;
}

.ocf-hero__text {
    max-width: 46ch;
    color: var(--ocf-body);
    font-size: clamp(1.02rem, 1.35vw, 1.25rem);
}

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

.ocf-services,
.ocf-service-areas {
    background: color-mix(in srgb, var(--ocf-bg-alt) 78%, var(--ocf-bg));
    border-block: 1px solid var(--ocf-border-light);
}

.ocf-services-header,
.ocf-testimonials-header,
.ocf-testimonials__header {
    text-align: center;
    justify-content: center;
}

.ocf-services-heading,
.ocf-testimonials-heading {
    max-width: 760px;
    margin-inline: auto;
}

.ocf-services-footer {
    display: flex;
    justify-content: center;
}

.ocf-svc-card,
.ocf-testimonial-card,
.ocf-testimonial,
.ocf-area-card,
.ocf-service-area-card,
.ocf-faq__item,
.ocf-faq-item,
.ocf-contact__panel,
.hero-form-card,
.ocf-simple-form,
.booking-wizard {
    background: var(--utility-surface);
    border-color: var(--card-border-color);
    box-shadow: var(--card-shadow);
}

.ocf-svc-card {
    overflow: hidden;
}

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

.ocf-svc-card-img {
    display: none;
}

.ocf-svc-card-body {
    min-height: 11.25rem;
    gap: 0.72rem;
    padding: clamp(1.15rem, 2vw, 1.45rem);
}

.ocf-svc-card-body::before {
    content: "";
    width: 2.6rem;
    height: 0.2rem;
    border-radius: var(--radius-full);
    background: var(--ocf-accent);
}

.ocf-svc-card-body h3 {
    font-size: var(--text-xl);
    font-weight: 820;
}

.ocf-svc-card-body p {
    color: var(--ocf-body);
}

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

.about-grid,
.ocf-commitments-grid {
    align-items: center;
}

.about-image,
.ocf-commitments-image,
.ocf-cta__media {
    border-radius: var(--image-radius);
    box-shadow: var(--card-shadow);
    overflow: hidden;
}

.about-body ul {
    display: grid;
    gap: 0.65rem;
    margin: 1.25rem 0 0;
    padding: 0;
    list-style: none;
}

.about-body li {
    position: relative;
    padding-left: 1.65rem;
    color: var(--ocf-heading);
    font-weight: 700;
}

.about-body li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.25rem;
    width: 0.9rem;
    height: 0.9rem;
    border-radius: 50%;
    background: var(--ocf-accent);
    box-shadow: inset 0 0 0 0.25rem var(--ocf-bg);
}

.ocf-commitments {
    background: color-mix(in srgb, var(--ocf-bg) 88%, var(--ocf-bg-alt));
}

.ocf-commitments-list {
    gap: 0;
    border-top: 1px solid var(--ocf-border-light);
}

.ocf-commitment {
    border-bottom: 1px solid var(--ocf-border-light);
    padding-block: 1.05rem;
}

.ocf-commitment-num {
    color: var(--ocf-secondary);
    font-weight: 900;
}

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

.ocf-testimonial-card,
.ocf-testimonial {
    padding: clamp(1rem, 2vw, 1.25rem);
}

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

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

.ocf-service-areas__grid,
.ocf-area-grid {
    align-items: start;
}

.ocf-service-areas__map {
    border-color: var(--ocf-border);
    box-shadow: var(--card-shadow);
    background:
        radial-gradient(circle at 24% 30%, var(--ocf-accent) 0 0.28rem, transparent 0.31rem),
        radial-gradient(circle at 58% 42%, var(--ocf-accent) 0 0.25rem, transparent 0.28rem),
        radial-gradient(circle at 70% 68%, var(--ocf-accent) 0 0.24rem, transparent 0.27rem),
        radial-gradient(circle at 38% 72%, var(--ocf-accent) 0 0.22rem, transparent 0.25rem),
        linear-gradient(90deg, color-mix(in srgb, var(--ocf-border-light) 64%, transparent) 1px, transparent 1px),
        linear-gradient(color-mix(in srgb, var(--ocf-border-light) 64%, transparent) 1px, transparent 1px),
        color-mix(in srgb, var(--ocf-accent) 7%, var(--ocf-bg));
    background-size: 100% 100%, 100% 100%, 100% 100%, 100% 100%, 2.4rem 2.4rem, 2.4rem 2.4rem, 100% 100%;
}

.ocf-service-areas__map::before {
    content: "";
    position: absolute;
    inset: 16% 18%;
    border: 1px solid color-mix(in srgb, var(--ocf-accent) 26%, transparent);
    border-radius: 50% 43% 46% 54%;
    background: color-mix(in srgb, var(--ocf-accent) 10%, transparent);
}

.ocf-service-areas__map::after {
    content: "";
    position: absolute;
    left: 14%;
    right: 14%;
    top: 52%;
    height: 1px;
    background: color-mix(in srgb, var(--ocf-accent) 28%, transparent);
    transform: rotate(-8deg);
}

.ocf-service-areas--map_left_places_right .ocf-service-areas__links {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.75rem 1.25rem;
}

.ocf-service-areas--map_left_places_right .ocf-service-areas__link {
    justify-content: flex-start;
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
    color: var(--ocf-heading);
    font-weight: 750;
}

.ocf-service-areas__link:hover {
    color: var(--ocf-accent);
}

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

.ocf-faq-header {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    max-width: none;
}

.ocf-faq__item,
.ocf-faq-item {
    box-shadow: none;
}

.ocf-faq__question,
.ocf-faq-question,
.ocf-faq-trigger {
    min-height: 3.3rem;
    padding: 0.85rem 1rem;
}

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

.ocf-cta--contrast_action_strip .ocf-cta__panel {
    background: transparent;
    border: 0;
    box-shadow: none;
}

.ocf-cta--contrast_action_strip .ocf-cta__inner {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: clamp(1rem, 3vw, 2rem);
}

.ocf-cta--contrast_action_strip .heading-section,
.ocf-cta--contrast_action_strip .ocf-cta__title,
.ocf-cta--contrast_action_strip .ocf-cta__text,
.ocf-cta--contrast_action_strip .ocf-cta__eyebrow {
    color: var(--ocf-heading-alt);
}

.ocf-cta--contrast_action_strip .ocf-cta__actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: end;
}

.ocf-cta--contrast_action_strip .btn-primary {
    background: #cf2f26;
    border-color: #cf2f26;
}

.ocf-cta--contrast_action_strip .ocf-cta__phone {
    color: var(--ocf-heading-alt);
}

.site-footer {
    background: radial-gradient(circle at 0 0, color-mix(in srgb, var(--ocf-accent) 22%, transparent), transparent 34rem), var(--ocf-bg-dark);
    border-top-color: var(--ocf-border-alt);
    color: var(--ocf-body-alt);
}

.site-footer .footer-brand-name,
.site-footer .footer-heading {
    color: var(--ocf-heading-alt);
}

.site-footer .footer-brand-desc,
.site-footer .footer-link-list,
.site-footer .footer-hours,
.site-footer .footer-contact-links,
.site-footer .footer-address {
    color: var(--ocf-body-alt);
}

.site-footer a:hover {
    color: var(--ocf-heading-alt);
}

.site-footer .footer-bottom {
    border-top-color: var(--ocf-border-alt);
    color: var(--ocf-label-alt);
}

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

    .ocf-hero__media {
        position: relative;
        inset: auto;
        left: auto;
        right: auto;
        width: 100%;
        min-height: 18rem;
        order: 2;
        border-top: 1px solid var(--ocf-border-light);
    }

    .ocf-hero__shade {
        background: linear-gradient(180deg, var(--ocf-bg), color-mix(in srgb, var(--ocf-bg) 80%, transparent));
    }

    .ocf-hero__grid {
        padding-block: clamp(3rem, 10vw, 5rem);
    }
}

@media (max-width: 760px) {
    .ocf-cta--contrast_action_strip .ocf-cta__inner {
        grid-template-columns: 1fr;
    }

    .ocf-cta--contrast_action_strip .ocf-cta__actions {
        justify-content: start;
    }

    .ocf-service-areas--map_left_places_right .ocf-service-areas__links {
        grid-template-columns: 1fr;
    }
}
