/**
 * P4PN Site Unified v1 — final consistency layer (all pages, all viewports).
 * Loads LAST. Uses fluid tokens only — no px breakpoint layout locks.
 */

/* ── Extended chrome tokens ── */
body.p4pn-fluid {
    --p4pn-header-h: var(--p4p-header, 72px);
    --p4pn-shell-max: min(100% - var(--p4pn-space-md) * 2, 72rem);
    --p4pn-tl-width: clamp(7.25rem, 13cqi, 9.5rem);
    --p4pn-tl-pad: clamp(0.6rem, 1.1cqi, 0.9rem);
    --p4pn-tl-radius: clamp(10px, 1.6cqi, 14px);
    --p4pn-tl-idx: clamp(0.82rem, 1.8cqi, 1.05rem);
    --p4pn-tl-label: clamp(0.52rem, 1.15cqi, 0.62rem);
    --p4pn-tl-hint: clamp(0.48rem, 1cqi, 0.56rem);
    --p4pn-btn-pad-y: clamp(0.5rem, 1.1cqi, 0.72rem);
    --p4pn-btn-pad-x: clamp(0.95rem, 2.2cqi, 1.35rem);
    --p4pn-btn-font: clamp(0.58rem, 1.25cqi, 0.68rem);
    --p4pn-lead-max: 62ch;
}

/* ═══════════════════════════════════════
   BUTTONS — one scale everywhere
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-btn-glow,
body.p4pn-fluid .p4p-btn-glow--ghost,
body.p4pn-fluid .p4p-btn-glow--accent,
body.p4pn-fluid .p4p-btn--primary,
body.p4pn-fluid .p4p-header__cta {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: clamp(0.35rem, 0.8cqi, 0.55rem) !important;
    padding: var(--p4pn-btn-pad-y) var(--p4pn-btn-pad-x) !important;
    font-size: var(--p4pn-btn-font) !important;
    font-weight: 800 !important;
    letter-spacing: 0.1em !important;
    text-transform: uppercase !important;
    line-height: 1.2 !important;
    border-radius: 999px !important;
    min-height: clamp(2rem, 4.2cqi, 2.45rem) !important;
    box-shadow: 0 clamp(4px, 0.8cqi, 8px) clamp(16px, 2.5cqi, 24px) rgba(0, 0, 0, 0.35) !important;
}

body.p4pn-fluid .p4p-btn-glow--ghost {
    background: rgba(8, 10, 18, 0.72) !important;
    color: rgba(255, 255, 255, 0.88) !important;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    box-shadow: none !important;
}

body.p4pn-fluid .p4p-btn {
    font-size: var(--p4pn-font-sm) !important;
    padding: var(--p4pn-btn-pad-y) var(--p4pn-btn-pad-x) !important;
    min-height: clamp(2rem, 4.2cqi, 2.45rem) !important;
}

body.p4pn-fluid .p4p-contact-float {
    font-size: var(--p4pn-font-xs) !important;
    padding: clamp(0.45rem, 1cqi, 0.6rem) clamp(0.65rem, 1.4cqi, 0.85rem) !important;
}

/* ═══════════════════════════════════════
   TYPOGRAPHY — unified hierarchy
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-kicker,
body.p4pn-fluid .p4p-footer-kicker {
    font-size: var(--p4pn-font-xs) !important;
    letter-spacing: 0.14em !important;
}

body.p4pn-fluid h1,
body.p4pn-fluid .p4p-hero-v4__title,
body.p4pn-fluid .p4pn-svc-hero__title,
body.p4pn-fluid .p4p-svc-fusion__title {
    font-size: var(--p4pn-font-3xl) !important;
    line-height: 1.06 !important;
}

body.p4pn-fluid h2,
body.p4pn-fluid .p4p-section-title,
body.p4pn-fluid .p4pn-title-clear,
body.p4pn-fluid .p4p-cap-band__title,
body.p4pn-fluid .p4pn-svc-cta__title {
    font-size: var(--p4pn-font-xl) !important;
    line-height: 1.12 !important;
}

body.p4pn-fluid h3,
body.p4pn-fluid .p4p-service-card__title,
body.p4pn-fluid .p4pn-svc-catalog__title {
    font-size: var(--p4pn-font-lg) !important;
    line-height: 1.2 !important;
}

body.p4pn-fluid .p4p-hero-v4__lead,
body.p4pn-fluid .p4pn-svc-hero__lead,
body.p4pn-fluid .p4p-section-intro,
body.p4pn-fluid .p4pn-svc-section-head__intro,
body.p4pn-fluid .p4p-svc-fusion__lead,
body.p4pn-fluid .p4pn-svc-cta__lead,
body.p4pn-fluid .p4p-cap-band__intro {
    font-size: var(--p4pn-font-sm) !important;
    line-height: 1.55 !important;
    max-width: var(--p4pn-lead-max);
}

body.p4pn-fluid .p4p-section__shell p,
body.p4pn-fluid .p4pn-cover-shell p,
body.p4pn-fluid .p4p-services-main__inner p {
    font-size: var(--p4pn-font-sm);
    line-height: 1.55;
}

/* ═══════════════════════════════════════
   SHELLS & BOXES — same width/padding
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-section__shell,
body.p4pn-fluid .p4pn-cover-shell,
body.p4pn-fluid .p4p-services-main__inner,
body.p4pn-fluid .p4p-services-section__shell,
body.p4pn-fluid .p4p-about-main__inner,
body.p4pn-fluid .p4p-blog-hub,
body.p4pn-fluid .p4p-portfolio-main__inner {
    width: var(--p4pn-shell-max) !important;
    max-width: var(--p4pn-shell-max) !important;
    margin-inline: auto !important;
    box-sizing: border-box !important;
}

body.p4pn-fluid .p4p-3d-box,
body.p4pn-fluid .p4p-luxury-panel,
body.p4pn-fluid .p4p-hero-v4__glass,
body.p4pn-fluid .p4pn-svc-catalog__link,
body.p4pn-fluid .p4p-service-card,
body.p4pn-fluid .p4p-svc-card__body {
    border-radius: var(--p4pn-radius-md) !important;
}

/* ═══════════════════════════════════════
   TIMELINE — home + services identical scale
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-tl-minimal,
body.p4pn-fluid .p4pn-tl {
    width: var(--p4pn-tl-width) !important;
    min-width: var(--p4pn-tl-width) !important;
    max-width: var(--p4pn-tl-width) !important;
    padding: var(--p4pn-tl-pad) !important;
    border-radius: var(--p4pn-tl-radius) !important;
    background: rgba(8, 8, 14, 0.9) !important;
    border: 1px solid rgba(255, 255, 255, 0.09) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: 0 clamp(8px, 1.5cqi, 16px) clamp(24px, 3cqi, 40px) rgba(0, 0, 0, 0.45) !important;
}

body.p4pn-fluid .p4p-tl-minimal__idx,
body.p4pn-fluid .p4pn-tl__idx {
    font-size: var(--p4pn-tl-idx) !important;
    line-height: 1 !important;
}

body.p4pn-fluid .p4p-tl-minimal__count,
body.p4pn-fluid .p4pn-tl__count {
    font-size: var(--p4pn-tl-hint) !important;
}

body.p4pn-fluid .p4p-tl-minimal__node .p4p-tl-node-label,
body.p4pn-fluid .p4pn-tl__node-label {
    font-size: var(--p4pn-tl-label) !important;
}

body.p4pn-fluid .p4p-tl-minimal__hint,
body.p4pn-fluid .p4pn-tl__hint {
    font-size: var(--p4pn-tl-hint) !important;
}

body.p4pn-fluid .p4p-tl-minimal__track,
body.p4pn-fluid .p4pn-tl__track {
    height: clamp(2px, 0.35cqi, 3px) !important;
}

/* ═══════════════════════════════════════
   COVER PAGES — kill legacy px shell wars
   ═══════════════════════════════════════ */
body.p4pn-cover-page .p4p-section__shell,
body.p4pn-cover-page .p4pn-cover-shell {
    width: min(100% - var(--p4pn-pad-x, var(--p4pn-space-md)) * 2, 72rem) !important;
    max-width: min(100% - var(--p4pn-pad-x, var(--p4pn-space-md)) * 2, 72rem) !important;
    transform: none !important;
}

body.p4pn-cover-page.p4pn-services .p4pn-cover-shell {
    padding-left: max(var(--p4pn-pad-x, 1rem), calc(var(--p4pn-tl-width) + var(--p4pn-space-sm))) !important;
}

body.p4pn-cover-page.p4pn-home .p4p-section__shell {
    padding-right: max(var(--p4pn-pad-x, 1rem), calc(var(--p4pn-tl-width) + var(--p4pn-space-sm))) !important;
}

body.p4pn-cover-page .p4p-hero-v4__title {
    font-size: var(--p4pn-font-3xl) !important;
}

body.p4pn-cover-page .p4p-next-indicator,
body.p4pn-cover-page .p4pn-cover-next {
    font-size: var(--p4pn-font-xs) !important;
}

/* Neutralize home-3d oversized buttons on cover */
body.p4pn-cover-page .p4p-btn-glow {
    padding: var(--p4pn-btn-pad-y) var(--p4pn-btn-pad-x) !important;
    font-size: var(--p4pn-btn-font) !important;
}

/* ═══════════════════════════════════════
   HEADER & FOOTER
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-header__inner {
    width: min(100% - var(--p4pn-space-md) * 2, 76rem) !important;
    margin-inline: auto !important;
}

body.p4pn-fluid .p4p-nav__link {
    font-size: var(--p4pn-font-xs) !important;
}

body.p4pn-fluid .p4pn-home-footer__inner {
    font-size: var(--p4pn-font-xs) !important;
}

body.p4pn-fluid .p4p-footer {
    font-size: var(--p4pn-font-sm);
}

/* ═══════════════════════════════════════
   INNER PAGES — neutralize v7–v14 px grids
   ═══════════════════════════════════════ */
body.p4pn-fluid:not(.p4pn-cover-page) .p4p-page--grid-full {
    container-type: inline-size;
}

body.p4pn-fluid .p4p-services-section__head .p4p-section-title {
    font-size: var(--p4pn-font-xl) !important;
}

body.p4pn-fluid .p4p-svc-lanes__grid,
body.p4pn-fluid .p4p-svc-nexus__grid,
body.p4pn-fluid .p4p-dental-cards,
body.p4pn-fluid .p4pn-svc-catalog {
    gap: var(--p4pn-space-sm) !important;
}

body.p4pn-fluid .p4p-svc-lane,
body.p4pn-fluid .p4p-svc-nexus__cell,
body.p4pn-fluid .p4p-dental-card {
    border-radius: var(--p4pn-radius-md) !important;
}

/* Service singles */
body.p4pn-fluid.p4p-page--service-single .p4p-services-hero__title,
body.p4pn-fluid.p4p-page--service-single .p4p-service-single-hero__title {
    font-size: var(--p4pn-font-2xl) !important;
}

body.p4pn-fluid.p4p-page--service-single .p4p-services-section__shell {
    width: var(--p4pn-shell-max) !important;
}

/* Blog */
body.p4pn-fluid.p4p-page--blog .p4p-blog-hub__title {
    font-size: var(--p4pn-font-2xl) !important;
}

body.p4pn-fluid.p4p-page--blog-single .p4p-article-hero__title {
    font-size: clamp(1.35rem, 4cqi, 2.25rem) !important;
}

/* Portfolio / marketplace / careers — section heads */
body.p4pn-fluid .p4p-portfolio-hero__title,
body.p4pn-fluid .p4p-careers-hero__title,
body.p4pn-fluid .p4p-mkt-hero__title {
    font-size: var(--p4pn-font-2xl) !important;
}

/* ═══════════════════════════════════════
   COARSE POINTER — hide side chrome, full width
   ═══════════════════════════════════════ */
@media (pointer: coarse) {
    body.p4pn-cover-page.p4pn-services .p4pn-cover-shell,
    body.p4pn-cover-page.p4pn-home .p4p-section__shell {
        padding-left: var(--p4pn-pad-x, var(--p4pn-space-md)) !important;
        padding-right: var(--p4pn-pad-x, var(--p4pn-space-md)) !important;
    }

    body.p4pn-fluid .p4p-tl-minimal,
    body.p4pn-fluid .p4pn-tl {
        display: none !important;
    }
}

/* ═══════════════════════════════════════
   PERF — no backdrop-filter globally
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-tl-minimal,
body.p4pn-fluid .p4p-hero-v4__glass,
body.p4pn-fluid .p4p-svc-card__body,
body.p4pn-fluid .p4p-luxury-panel,
body.p4pn-fluid .p4pn-home-footer__inner {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

@media (prefers-reduced-motion: reduce) {
    body.p4pn-fluid [data-p4pn-cover-target],
    body.p4pn-fluid [data-p4pn-fluid-block] {
        transform: none !important;
    }
}

/* ═══════════════════════════════════════
   OVERRIDE site-audit + legacy max-width locks
   ═══════════════════════════════════════ */
body.p4pn-fluid .p4p-page--grid-full .p4p-services-main__inner,
body.p4pn-fluid .p4p-page--grid-full .p4p-portfolio-main__inner,
body.p4pn-fluid .p4p-page--grid-full .p4p-about-main__inner,
body.p4pn-fluid .p4p-page--grid-full.p4p-page--careers .p4p-careers-main__inner,
body.p4pn-fluid .p4p-page--grid-full .p4p-page--about__content {
    max-width: var(--p4pn-shell-max) !important;
    width: var(--p4pn-shell-max) !important;
}

body.p4pn-fluid .p4p-section--experience .p4p-section__shell {
    max-width: min(100% - var(--p4pn-space-md) * 2, 60rem) !important;
}

body.p4pn-fluid .p4p-section--experience .p4p-term-readout__text {
    font-size: var(--p4pn-font-sm) !important;
}

body.p4pn-fluid .p4p-section--gateway .p4p-gateway-fuse__title {
    font-size: var(--p4pn-font-xl) !important;
}

/* ═══════════════════════════════════════
   COVER — block home-3d mobile stack break
   ═══════════════════════════════════════ */
@media (max-width: 768px) {
    body.p4pn-cover-page.p4pn-home {
        overflow: hidden !important;
        height: auto;
    }

    body.p4pn-cover-page.p4pn-home .p4p-home-main {
        height: 100dvh !important;
        overflow: hidden !important;
        perspective: inherit !important;
    }

    body.p4pn-cover-page.p4pn-home .p4p-section {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100dvh !important;
        min-height: 0 !important;
        padding: 0 !important;
        opacity: inherit !important;
        transform: inherit !important;
        filter: inherit !important;
        display: flex !important;
        align-items: center !important;
    }

    body.p4pn-cover-page.p4pn-home .p4p-section__shell {
        height: calc(100dvh - var(--p4pn-header-h)) !important;
        max-height: calc(100svh - var(--p4pn-header-h)) !important;
        width: min(100% - var(--p4pn-pad-x) * 2, 72rem) !important;
        padding: calc(var(--p4pn-header-h) + var(--p4pn-pad-y)) var(--p4pn-pad-x) var(--p4pn-pad-y) !important;
        transform: none !important;
    }

    body.p4pn-cover-page .p4p-btn-glow {
        width: auto !important;
        min-width: 0 !important;
    }

    /* Keep side timeline — do not collapse to bottom bar */
    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal {
        display: flex !important;
        flex-direction: column !important;
        position: fixed !important;
        right: max(0.65rem, env(safe-area-inset-right)) !important;
        left: auto !important;
        top: 50% !important;
        bottom: auto !important;
        width: var(--p4pn-tl-width) !important;
        height: auto !important;
        transform: translateY(-50%) !important;
        border-top: none !important;
        border-right: 1px solid rgba(255, 255, 255, 0.09) !important;
        padding: var(--p4pn-tl-pad) !important;
    }

    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal__meta,
    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal__hint,
    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal__orbit {
        display: revert !important;
    }

    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal__nodes {
        flex-direction: column !important;
        width: 100% !important;
        height: auto !important;
        justify-content: flex-start !important;
    }

    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal__node {
        width: 100% !important;
        height: auto !important;
    }

    body.p4pn-cover-page.p4pn-home .p4p-tl-minimal__node .p4p-tl-node-label {
        display: block !important;
    }
}

@media (max-width: 900px) and (pointer: fine) {
    body.p4pn-fluid .p4pn-tl__node-label {
        display: block !important;
    }

    body.p4pn-fluid .p4pn-tl {
        min-width: var(--p4pn-tl-width) !important;
        padding: var(--p4pn-tl-pad) !important;
    }
}

/* Next chip — unified sizing */
body.p4pn-fluid .p4pn-cover-next,
body.p4pn-fluid .p4p-next-indicator {
    padding: clamp(0.35rem, 0.8cqi, 0.5rem) clamp(0.55rem, 1.2cqi, 0.75rem) !important;
    font-size: var(--p4pn-font-xs) !important;
    border-radius: 999px !important;
}

body.p4pn-fluid .p4pn-cover-next__arrow,
body.p4pn-fluid .p4p-next-indicator__arrow {
    width: clamp(1.45rem, 3cqi, 1.65rem) !important;
    height: clamp(1.45rem, 3cqi, 1.65rem) !important;
    font-size: clamp(0.72rem, 1.5cqi, 0.85rem) !important;
}

/* Hero variants on cover */
body.p4pn-cover-page .p4p-hero-v3__title,
body.p4pn-cover-page .p4p-hero-v4__title {
    font-size: var(--p4pn-font-3xl) !important;
}

body.p4pn-cover-page .p4p-hero-v3__lead,
body.p4pn-cover-page .p4p-hero-v4__lead {
    font-size: var(--p4pn-font-sm) !important;
}

/* Inner page buttons — ghost variants */
body.p4pn-fluid .p4p-btn-ghost,
body.p4pn-fluid .p4p-btn-outline {
    font-size: var(--p4pn-btn-font) !important;
    padding: var(--p4pn-btn-pad-y) var(--p4pn-btn-pad-x) !important;
    min-height: clamp(2rem, 4.2cqi, 2.45rem) !important;
    border-radius: 999px !important;
}

/* Form inputs — consistent scale */
body.p4pn-fluid .p4p-form__input,
body.p4pn-fluid .p4p-form__textarea,
body.p4pn-fluid input[type="text"],
body.p4pn-fluid input[type="email"],
body.p4pn-fluid textarea {
    font-size: var(--p4pn-font-sm) !important;
    border-radius: var(--p4pn-radius-sm) !important;
    padding: var(--p4pn-space-sm) var(--p4pn-space-md) !important;
}

/* Mobile nav links */
body.p4pn-fluid .p4p-mobile-nav__link {
    font-size: var(--p4pn-font-sm) !important;
}
