/* OCF Luxury
   Premium cosmetic layer on top of Base 3 component structure. */

:root {
    --lux-ink: #111513;
    --lux-ink-soft: #202824;
    --lux-body: #5b655f;
    --lux-muted: #8a938d;
    --lux-paper: #fbfaf7;
    --lux-paper-2: #f3f1eb;
    --lux-panel: rgba(255, 255, 255, 0.78);
    --lux-line: rgba(31, 38, 35, 0.12);
    --lux-line-strong: rgba(31, 38, 35, 0.22);
    --lux-bronze: #8a7356;
    --lux-bronze-dark: #6f5b43;
    --lux-sage: #49625c;
    --lux-shadow: 0 28px 80px -38px rgba(17, 21, 19, 0.38);
    --lux-shadow-soft: 0 16px 48px -32px rgba(17, 21, 19, 0.3);

    --ocf-heading: var(--lux-ink) !important;
    --ocf-body: var(--lux-body) !important;
    --ocf-label: var(--lux-muted) !important;
    --ocf-accent: var(--lux-bronze) !important;
    --ocf-accent-hover: var(--lux-bronze-dark) !important;
    --ocf-secondary: var(--lux-sage) !important;
    --ocf-bg: var(--lux-paper) !important;
    --ocf-bg-alt: var(--lux-paper-2) !important;
    --ocf-bg-dark: var(--lux-ink) !important;
    --ocf-heading-alt: #fffaf1 !important;
    --ocf-body-alt: rgba(255, 250, 241, 0.78) !important;
    --ocf-label-alt: rgba(255, 250, 241, 0.62) !important;
    --ocf-border: var(--lux-line-strong) !important;
    --ocf-border-light: var(--lux-line) !important;
    --ocf-divider: rgba(138, 115, 86, 0.32) !important;
    --ocf-border-alt: rgba(255, 250, 241, 0.16) !important;
    --ocf-font-heading: Outfit !important;
    --ocf-font-body: Outfit !important;

    --radius-sm: 12px !important;
    --radius: 20px !important;
    --radius-lg: 28px !important;
    --shadow-sm: var(--lux-shadow-soft) !important;
    --shadow: var(--lux-shadow) !important;
    --shadow-lg: 0 42px 110px -48px rgba(17, 21, 19, 0.45) !important;
    --ease: cubic-bezier(0.16, 1, 0.3, 1) !important;
}

html {
    background: var(--lux-paper);
    overflow-x: hidden;
}

body {
    background:
        linear-gradient(180deg, rgba(251, 250, 247, 0.96), rgba(243, 241, 235, 0.7) 58%, rgba(251, 250, 247, 1)),
        var(--lux-paper) !important;
    color: var(--lux-body) !important;
    letter-spacing: 0;
    overflow-x: hidden;
}

body::before {
    content: "";
    position: fixed;
    inset: 0;
    pointer-events: none;
    z-index: 999;
    opacity: 0.38;
    background-image:
        linear-gradient(rgba(17, 21, 19, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(17, 21, 19, 0.028) 1px, transparent 1px);
    background-size: 72px 72px;
    mask-image: linear-gradient(to bottom, transparent, black 16%, black 82%, transparent);
}

::selection {
    background: var(--lux-bronze);
    color: #fffaf1;
}

.container-global {
    max-width: 1320px;
}

.section-padding {
    padding-top: clamp(4.5rem, 7vw, 8rem) !important;
    padding-bottom: clamp(4.5rem, 7vw, 8rem) !important;
}

.eyebrow,
.ocf-page-header__eyebrow,
.ocf-cta__eyebrow {
    color: var(--lux-bronze) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.24em !important;
}

.heading-section,
.hero-form-card .hero-form-title,
.ocf-svc-card-body h3,
.ocf-faq-trigger,
.ocf-value-title,
.ocf-commitment h3 {
    font-family: Outfit, ui-sans-serif, system-ui, sans-serif !important;
    letter-spacing: -0.045em !important;
}

.heading-section {
    font-weight: 650 !important;
    line-height: 0.98 !important;
}

.heading-section.size-xl {
    font-size: clamp(3.25rem, 7.2vw, 6.85rem) !important;
    max-width: 10em;
}

.heading-section.size-lg,
h2.heading-section.size-lg {
    font-size: clamp(2.25rem, 3.8vw, 3.85rem) !important;
    line-height: 0.98 !important;
}

.text-body,
.ocf-service-areas__text,
.about-body .text-body,
.ocf-cta__text,
.ocf-detail-content,
.prose {
    color: var(--lux-body) !important;
}

/* Navigation */
.nav-bar,
.site-header {
    background: rgba(251, 250, 247, 0.78) !important;
    border-bottom: 1px solid rgba(31, 38, 35, 0.08) !important;
    backdrop-filter: blur(22px);
    -webkit-backdrop-filter: blur(22px);
}

.nav-inner {
    min-height: 5.25rem;
}

.nav-logo-placeholder,
.nav-logo-img {
    border-radius: 999px !important;
}

.nav-logo-placeholder {
    width: auto !important;
    min-width: 0 !important;
    height: auto !important;
    padding: 0.72rem 1.15rem !important;
    background: rgba(255, 255, 255, 0.58) !important;
    border: 1px solid rgba(31, 38, 35, 0.12) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.66);
}

.nav-logo-placeholder span {
    font-weight: 700 !important;
    letter-spacing: -0.02em !important;
}

.nav-link,
.nav-dropdown-trigger,
.nav-phone {
    color: var(--lux-ink-soft) !important;
    font-size: 0.92rem !important;
}

.nav-link::after {
    height: 1px !important;
    background: var(--lux-bronze) !important;
}

.nav-cta,
.btn-primary,
.btn-secondary,
.btn-ghost,
.ocf-form-submit,
.ocf-booking-submit,
.hero-form-card .form-submit-btn,
.ocf-mobile-cta,
.wpcf7 input[type="submit"] {
    border-radius: 999px !important;
    border: 1px solid rgba(138, 115, 86, 0.28) !important;
    background: var(--lux-ink) !important;
    color: #fffaf1 !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.08),
        0 18px 40px -28px rgba(17, 21, 19, 0.65) !important;
    transition: transform 0.32s var(--ease), background 0.32s var(--ease), border-color 0.32s var(--ease), box-shadow 0.32s var(--ease) !important;
}

.btn-primary,
.btn-secondary,
.btn-ghost,
.hero-form-card .form-submit-btn {
    padding: 1rem 1.55rem !important;
    font-size: 0.72rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.18em !important;
}

.nav-cta:hover,
.btn-primary:hover,
.btn-secondary:hover,
.btn-ghost:hover,
.ocf-form-submit:hover,
.ocf-booking-submit:hover,
.hero-form-card .form-submit-btn:hover,
.ocf-mobile-cta:hover,
.wpcf7 input[type="submit"]:hover {
    background: var(--lux-bronze) !important;
    border-color: rgba(138, 115, 86, 0.44) !important;
    color: #fffaf1 !important;
    transform: translateY(-2px) !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.14),
        0 24px 56px -32px rgba(111, 91, 67, 0.7) !important;
}

.nav-cta:active,
.btn-primary:active,
.btn-secondary:active,
.btn-ghost:active,
.hero-form-card .form-submit-btn:active {
    transform: translateY(0) scale(0.98) !important;
}

.nav-dropdown-panel,
.mobile-menu,
.dropdown-menu,
.testimonial-review-popover {
    background: rgba(251, 250, 247, 0.88) !important;
    border: 1px solid rgba(31, 38, 35, 0.1) !important;
    border-radius: 22px !important;
    box-shadow: var(--lux-shadow) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
}

.dropdown-item:hover,
.mobile-link:hover,
.mobile-accordion-trigger:hover {
    color: var(--lux-bronze) !important;
    background: rgba(138, 115, 86, 0.08) !important;
}

/* Hero */
.ocf-hero {
    min-height: min(860px, calc(100dvh - 2rem)) !important;
    background: var(--lux-paper) !important;
    color: var(--lux-ink) !important;
    isolation: isolate;
}

@media (min-width: 1024px) {
    .ocf-hero {
        margin-top: -6rem;
        padding-top: 12.5rem !important;
        padding-bottom: 6.5rem !important;
    }
}

.ocf-hero__media {
    inset: 0 !important;
    z-index: -2;
}

.ocf-hero__media img {
    opacity: 0.45;
    filter: saturate(0.82) contrast(0.92) brightness(1.1);
}

.ocf-hero__shade {
    z-index: -1;
    background:
        linear-gradient(90deg, rgba(251, 250, 247, 0.98) 0%, rgba(251, 250, 247, 0.9) 35%, rgba(251, 250, 247, 0.56) 68%, rgba(251, 250, 247, 0.82) 100%),
        linear-gradient(180deg, rgba(251, 250, 247, 1) 0%, rgba(251, 250, 247, 0.34) 42%, rgba(251, 250, 247, 1) 100%) !important;
}

.ocf-hero__grid {
    gap: clamp(2rem, 5vw, 6rem) !important;
}

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

.ocf-hero__rating {
    color: var(--lux-body) !important;
    margin-bottom: 1.35rem !important;
}

.ocf-hero__rating-value {
    color: var(--lux-ink) !important;
}

.ocf-hero__stars {
    color: var(--lux-bronze) !important;
}

.ocf-hero__title {
    color: var(--lux-ink) !important;
    margin-bottom: 1.5rem !important;
}

.ocf-hero__text {
    max-width: 34rem !important;
    color: var(--lux-ink-soft) !important;
    font-size: clamp(1.1rem, 1.7vw, 1.35rem) !important;
    line-height: 1.65 !important;
}

.hero-form-card,
.ocf-contact-form,
.ocf-contact-card,
.ocf-booking-panel,
.ocf-detail-sticky {
    background: rgba(255, 255, 255, 0.74) !important;
    border: 1px solid rgba(31, 38, 35, 0.12) !important;
    border-radius: 30px !important;
    box-shadow: var(--lux-shadow) !important;
    backdrop-filter: blur(24px);
    -webkit-backdrop-filter: blur(24px);
}

.hero-form-card {
    padding: clamp(1.25rem, 2.4vw, 2rem) !important;
}

.hero-form-card .hero-form-title {
    color: var(--lux-ink) !important;
    font-size: clamp(1.35rem, 2vw, 1.85rem) !important;
    font-weight: 700 !important;
    letter-spacing: -0.02em !important;
    word-spacing: 0.08em;
}

.hero-form-card > p {
    opacity: 1 !important;
    color: var(--lux-body) !important;
}

input,
textarea,
select,
.hero-form-card input,
.hero-form-card textarea,
.hero-form-card select,
.ocf-form-input,
.ocf-form-textarea,
.ocf-booking-input,
.ocf-booking-textarea,
.ocf-booking-select,
.wpcf7 input,
.wpcf7 textarea,
.wpcf7 select {
    background: rgba(251, 250, 247, 0.72) !important;
    border: 1px solid rgba(31, 38, 35, 0.14) !important;
    border-radius: 16px !important;
    color: var(--lux-ink) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.68) !important;
}

input:focus,
textarea:focus,
select:focus,
.hero-form-card input:focus,
.hero-form-card textarea:focus,
.hero-form-card select:focus,
.ocf-form-input:focus,
.ocf-form-textarea:focus,
.ocf-booking-input:focus,
.ocf-booking-textarea:focus,
.ocf-booking-select:focus {
    border-color: rgba(138, 115, 86, 0.62) !important;
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.74),
        0 0 0 4px rgba(138, 115, 86, 0.12) !important;
}

/* Cards and repeated surfaces */
.ocf-services,
.ocf-testimonials,
.ocf-faq,
.ocf-commitments,
.ocf-about-values {
    background: transparent !important;
}

.ocf-services-header,
.ocf-testimonials-header {
    margin-bottom: clamp(2rem, 4vw, 4.25rem) !important;
}

.ocf-services-heading,
.ocf-testimonials-heading {
    width: min(100%, 58rem) !important;
}

.ocf-services-heading .heading-section,
.ocf-testimonials-heading .heading-section,
.ocf-service-areas__title,
.ocf-faq .heading-section {
    max-width: 12.5em;
}

.ocf-svc-card,
.ocf-service-card,
.ocf-area-card,
.ocf-testimonial-card,
.testimonial-card,
.ocf-faq-item,
.ocf-value-card,
.post-card,
.ocf-article-card,
.ocf-booking-service-card,
.ocf-booking-time,
.ocf-detail-img,
.ocf-commitments-image {
    background: rgba(255, 255, 255, 0.7) !important;
    border: 1px solid rgba(31, 38, 35, 0.1) !important;
    border-radius: 26px !important;
    box-shadow: 0 18px 52px -42px rgba(17, 21, 19, 0.34) !important;
    overflow: hidden;
    transition: transform 0.38s var(--ease), border-color 0.38s var(--ease), box-shadow 0.38s var(--ease), background 0.38s var(--ease) !important;
}

.ocf-svc-card:hover,
.ocf-service-card:hover,
.ocf-area-card:hover,
.ocf-testimonial-card:hover,
.testimonial-card:hover,
.ocf-value-card:hover,
.post-card:hover,
.ocf-article-card:hover,
.ocf-booking-service-card:hover,
.ocf-booking-time:hover {
    transform: translateY(-6px) !important;
    background: rgba(255, 255, 255, 0.88) !important;
    border-color: rgba(138, 115, 86, 0.34) !important;
    box-shadow: 0 34px 78px -46px rgba(17, 21, 19, 0.46) !important;
}

.ocf-svc-card-img,
.post-card-bg,
.ocf-detail-img,
.about-image,
.ocf-commitments-image {
    background: var(--lux-ink) !important;
}

.ocf-svc-card-img img,
.post-card-bg img,
.post-card img,
.ocf-detail-img img,
.about-image img,
.ocf-commitments-image img,
.ocf-cta__image {
    filter: saturate(0.78) contrast(0.96) brightness(1.02);
    transition: transform 0.7s var(--ease), filter 0.7s var(--ease), opacity 0.7s var(--ease) !important;
}

.ocf-svc-card:hover img,
.post-card:hover img,
.ocf-service-card:hover img,
.ocf-area-card:hover img {
    transform: scale(1.055) !important;
    filter: saturate(0.92) contrast(1) brightness(1.02);
}

.ocf-svc-card-body {
    padding: 1.55rem !important;
}

.ocf-svc-card-body h3,
.ocf-testimonial-footer strong,
.ocf-commitment h3,
.ocf-value-title {
    color: var(--lux-ink) !important;
}

.ocf-svc-card-body p,
.ocf-testimonial-card blockquote,
.ocf-commitment p,
.ocf-value-card p,
.ocf-faq-answer p {
    color: var(--lux-body) !important;
}

.ocf-svc-arrow,
.ocf-svc-nav button,
.ocf-testimonial-nav button,
.ocf-faq-icon,
.testimonial-avatar,
.ocf-commitment-num,
.ocf-value-number,
.ocf-area-badge {
    color: var(--lux-bronze) !important;
}

.ocf-svc-arrow,
.ocf-svc-nav button,
.ocf-testimonial-nav button {
    background: rgba(255, 255, 255, 0.62) !important;
    border: 1px solid rgba(31, 38, 35, 0.1) !important;
    border-radius: 999px !important;
}

.ocf-svc-nav button:hover:not(:disabled),
.ocf-testimonial-nav button:hover {
    background: var(--lux-ink) !important;
    color: #fffaf1 !important;
    border-color: var(--lux-ink) !important;
}

.testimonial-quote-mark {
    color: rgba(138, 115, 86, 0.36) !important;
}

.testimonial-avatar {
    background: rgba(138, 115, 86, 0.12) !important;
    color: var(--lux-bronze-dark) !important;
}

/* About and commitments */
.ocf-about .about-grid,
.ocf-commitments-grid,
.ocf-service-areas__grid {
    gap: clamp(2.5rem, 6vw, 6.5rem) !important;
}

.ocf-about .about-image {
    border-radius: 30px !important;
    box-shadow: var(--lux-shadow) !important;
}

.about-image-accent {
    border-color: rgba(138, 115, 86, 0.32) !important;
    border-radius: 26px !important;
    opacity: 1 !important;
}

.ocf-commitments-list {
    border-top-color: rgba(31, 38, 35, 0.12) !important;
}

.ocf-commitment {
    border-bottom-color: rgba(31, 38, 35, 0.1) !important;
}

.ocf-commitment-num,
.ocf-value-number {
    font-weight: 500 !important;
    opacity: 0.74 !important;
}

/* Service areas and map */
.ocf-service-areas {
    background: transparent !important;
}

.ocf-service-areas__map {
    border-radius: 30px !important;
    border: 1px solid rgba(31, 38, 35, 0.1) !important;
    box-shadow: var(--lux-shadow-soft) !important;
}

.ocf-service-areas__map iframe {
    filter: saturate(0.72) contrast(0.96);
}

.ocf-service-areas__link,
.ocf-area-badge {
    background: rgba(255, 255, 255, 0.62) !important;
    border: 1px solid rgba(31, 38, 35, 0.12) !important;
    border-radius: 999px !important;
    color: var(--lux-ink-soft) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.62);
}

.ocf-service-areas__link:hover,
.ocf-area-badge:hover {
    background: var(--lux-ink) !important;
    color: #fffaf1 !important;
    border-color: var(--lux-ink) !important;
}

/* FAQ */
.ocf-faq-item {
    border-radius: 22px !important;
}

.ocf-faq-trigger {
    color: var(--lux-ink) !important;
}

.ocf-faq-item.open {
    border-color: rgba(138, 115, 86, 0.34) !important;
    background: rgba(255, 255, 255, 0.88) !important;
}

/* Page headers and rich content pages */
.page-header,
.ocf-article-hero {
    background: var(--lux-ink) !important;
    color: #fffaf1 !important;
}

.page-header--image {
    background-image:
        linear-gradient(90deg, rgba(17, 21, 19, 0.9) 0%, rgba(17, 21, 19, 0.72) 45%, rgba(17, 21, 19, 0.42) 100%),
        var(--page-header-image) !important;
}

.page-header .eyebrow,
.page-header .ocf-hero__title,
.ocf-article-hero-title,
.ocf-article-hero-meta {
    color: #fffaf1 !important;
}

.page-header-divider .divider {
    background: var(--lux-bronze) !important;
}

.ocf-detail-section,
.ocf-article-body,
.ocf-article-more {
    background: var(--lux-paper) !important;
}

.prose h2,
.prose h3,
.ocf-detail-content h2,
.ocf-detail-content h3 {
    color: var(--lux-ink) !important;
    letter-spacing: -0.035em;
}

.prose hr,
.ocf-detail-content hr {
    border-top-color: rgba(138, 115, 86, 0.28) !important;
}

.prose blockquote {
    border-left-color: var(--lux-bronze) !important;
    background: rgba(255, 255, 255, 0.56) !important;
    border-radius: 18px !important;
}

/* CTA */
.ocf-cta {
    background: transparent !important;
}

.ocf-cta__panel {
    border-radius: 34px !important;
    background: var(--lux-ink) !important;
    box-shadow: var(--lux-shadow) !important;
    border: 1px solid rgba(255, 250, 241, 0.12) !important;
}

.ocf-cta__shade {
    background:
        linear-gradient(90deg, rgba(17, 21, 19, 0.92) 0%, rgba(17, 21, 19, 0.68) 50%, rgba(17, 21, 19, 0.24) 100%),
        linear-gradient(180deg, rgba(17, 21, 19, 0.1), rgba(17, 21, 19, 0.64)) !important;
}

.ocf-cta__title,
.ocf-cta__eyebrow {
    color: #fffaf1 !important;
}

.ocf-cta__text {
    color: rgba(255, 250, 241, 0.74) !important;
}

/* Footer */
.site-footer {
    background: var(--lux-ink) !important;
    color: rgba(255, 250, 241, 0.68) !important;
    border-top: 1px solid rgba(255, 250, 241, 0.08) !important;
}

.site-footer h2,
.site-footer h3,
.site-footer h4,
.site-footer a {
    color: #fffaf1 !important;
}

.site-footer a:hover {
    color: #d4bf9a !important;
}

/* Mobile calibration */
@media (max-width: 767px) {
    .nav-inner {
        min-width: 0;
        gap: 0.75rem;
    }

    .nav-logo-placeholder {
        max-width: min(48vw, 14rem);
        padding: 0.62rem 0.95rem !important;
    }

    .nav-logo-placeholder span {
        display: block;
        max-width: 100%;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
    }

    .nav-right {
        gap: 0.5rem !important;
        min-width: 0;
    }

    .nav-phone {
        flex: 0 0 auto;
    }

    .nav-phone span {
        display: none !important;
    }

    .heading-section.size-xl {
        font-size: clamp(2.4rem, 11vw, 3.35rem) !important;
        max-width: 100%;
        line-height: 1.02 !important;
    }

    .heading-section.size-lg,
    h2.heading-section.size-lg {
        font-size: clamp(2.15rem, 9vw, 3.35rem) !important;
    }

    .ocf-hero {
        min-height: auto !important;
        padding-top: 6.5rem !important;
    }

    .ocf-hero__grid,
    .ocf-hero__content,
    .ocf-hero__form,
    .hero-form-card {
        width: 100%;
        min-width: 0;
        max-width: 100% !important;
    }

    .ocf-hero__title,
    .ocf-hero__text {
        width: 100%;
        max-width: 100% !important;
    }

    .ocf-hero__title {
        overflow-wrap: break-word;
    }

    .ocf-hero__title span {
        display: inline !important;
    }

    .ocf-hero__title span::after {
        content: " ";
    }

    .hero-form-card .form-submit-btn {
        width: 100%;
    }

    .ocf-hero__media img {
        opacity: 0.28;
    }

    .hero-form-card,
    .ocf-contact-form,
    .ocf-contact-card,
    .ocf-svc-card,
    .ocf-testimonial-card,
    .ocf-faq-item {
        border-radius: 22px !important;
    }
}
