/* ═══════════════════════════════════════════════════════════
   REFERENZ FRONT-PAGE LOOP  ·  rfp-*
   ═══════════════════════════════════════════════════════════ */



/* ── Slider shell ─────────────────────────────────────────── */
.rfp-slider {
    position: relative;
    overflow: hidden;
}

.rfp-slider__track {
    display: flex;
    align-items: stretch;
    /* transition injected by JS */
}

.rfp-slide {
    flex: 0 0 100%;
    min-width: 0;
    display: flex;
    flex-direction: column;
}

/* ── Bento grid ───────────────────────────────────────────── */
.rfp-bento {
    flex: 1;
    display: grid;
    grid-template-columns: 3fr 2fr;
    grid-template-rows: 1fr;
    gap: clamp(10px, 1.5vw, 16px);
    text-decoration: none;
    color: inherit;
    user-select: none;
    -webkit-user-drag: none;
}

/* ── Shared tile base ─────────────────────────────────────── */
.rfp-bento__images,
.rfp-bento__meta {
    background: var(--wp--preset--color--surface, #EAEAE6);
    border-radius: clamp(16px, 2vw, 24px);
    overflow: hidden;
    /* Safari: z-indexed children can escape overflow:hidden + border-radius */
    isolation: isolate;
}

/* ① Images — top left ─────────────────────────────────────── */
.rfp-bento__images {
    grid-column: 1;
    grid-row: 1;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: clamp(20px, 3.5vw, 48px) clamp(20px, 3.5vw, 48px) 0;
    min-height: clamp(260px, 30vw, 420px);
}

/* Device showcase — matches referenz-single hero (.ref-hero__showcase) */
.rfp-showcase {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    width: 100%;
    margin-top: auto;
    filter: drop-shadow(0 12px 28px rgba(0, 0, 0, 0.12));
}

.rfp-showcase__placeholder {
    margin-top: auto;
    width: 100%;
}

.rfp-showcase__item {
    --frame-w: 8px;
    --showcase-radius: clamp(6px, 1vw, 12px);
    background: rgba(0, 0, 0, 0.15);
    padding: var(--frame-w);
    padding-bottom: 0;
    border-radius: var(--showcase-radius) var(--showcase-radius) 0 0;
    position: relative;
    flex-shrink: 0;
}

.rfp-showcase__item img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: calc(var(--showcase-radius) - var(--frame-w)) calc(var(--showcase-radius) - var(--frame-w)) 0 0;
}

.rfp-showcase--both .rfp-showcase__landscape {
    flex: 4;
    min-width: 0;
    z-index: 1;
}

.rfp-showcase--both .rfp-showcase__mobile {
    flex: 1;
    min-width: 0;
    z-index: 2;
    aspect-ratio: 10 / 18;
    overflow: hidden;
    align-self: flex-end;
    margin-left: -15%;
}

.rfp-showcase:not(.rfp-showcase--both) .rfp-showcase__landscape {
    width: 90%;
}

/* ② Meta Card — top right ────────────────────────────────── */
.rfp-bento__meta {
    grid-column: 2;
    grid-row: 1;
    background: rgba(255, 255, 255, 0.35);
    border: 1px solid rgba(18, 18, 18, 0.08);
    border-radius: 20px;
    padding: clamp(24px, 3vw, 40px);
    display: flex;
    flex-direction: column;
    box-sizing: border-box;
    box-shadow: 0 4px 30px rgba(0, 0, 0, 0.02);
    transition: border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.rfp-bento:hover .rfp-bento__meta {
    border-color: rgba(18, 18, 18, 0.18);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.04);
}

/* Header: top-row (service pill + index) → client name */
.rfp-meta__header {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: clamp(24px, 3vw, 32px);
}

.rfp-meta__top-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.rfp-meta__service {
    display: inline-flex;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--wp--preset--color--hero-blue, #4375ea);
    background: rgba(67, 117, 234, 0.08);
    padding: 5px 12px;
    border-radius: 100px;
    line-height: 1;
    margin: 0;
}

.rfp-meta__index {
    font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
    font-size: 11px;
    font-weight: 600;
    color: rgba(18, 18, 18, 0.4);
    letter-spacing: 0.05em;
}

.rfp-meta__client {
    font-family: var(--wp--preset--font-family--heading);
    font-size: clamp(1.35rem, 2.2vw, 1.75rem);
    font-weight: 500;
    letter-spacing: -0.02em;
    color: var(--wp--preset--color--text-main, #121212);
    margin: 4px 0 0;
    line-height: 1.15;
}

/* Metrics — bordered grid with 1px separator trick */
.rfp-metrics {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1px;
    background-color: rgba(18, 18, 18, 0.08);
    border-radius: 14px;
    border: 1px solid rgba(18, 18, 18, 0.08);
    overflow: hidden;
    margin-bottom: auto;
}

/* Individual metric cells use surface bg */

.rfp-metric {
    background-color: #fff;
    padding: clamp(14px, 1.8vw, 20px) clamp(16px, 2vw, 24px);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    transition: background-color 0.3s ease;
}

.rfp-metric:hover {
    background-color: rgba(255, 255, 255, 0.5);
}

.rfp-metric__label-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.rfp-metric__label {
    font-size: clamp(0.8rem, 1.1vw, 0.875rem);
    font-weight: 500;
    color: var(--wp--preset--color--text-muted, #3D3D3D);
    letter-spacing: -0.01em;
    line-height: 1.2;
}

.rfp-metric__context {
    font-family: 'SF Mono', 'Fira Code', 'Consolas', monospace;
    font-size: 10px;
    color: rgba(18, 18, 18, 0.4);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.rfp-metric__value {
    font-family: var(--wp--preset--font-family--heading);
    font-size: clamp(1.5rem, 2.5vw, 2rem);
    font-weight: 600;
    letter-spacing: -0.03em;
    color: var(--wp--preset--color--status-green, #5eb94c);
    line-height: 1;
    text-align: right;
    white-space: nowrap;
}



/* CTA — bottom bar with arrow circle */
.rfp-meta__cta-wrap {
    padding-top: clamp(18px, 2.2vw, 24px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

.rfp-meta__cta-text {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--wp--preset--color--text-main, #121212);
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.rfp-bento__meta .arrow-icon--circle {
    width: 36px;
    height: 36px;
    border: 1px solid rgba(18, 18, 18, 0.08);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--wp--preset--color--text-main, #121212);
    transition: background-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                border-color 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

.rfp-bento__meta .arrow-icon--circle svg {
    width: 16px;
    height: 16px;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Hover across card scope */
.rfp-bento:hover .rfp-meta__cta-text {
    color: var(--wp--preset--color--hero-blue, #4375ea);
}

.rfp-bento:hover .rfp-bento__meta .arrow-icon--circle {
    background-color: var(--wp--preset--color--text-main, #121212);
    border-color: var(--wp--preset--color--text-main, #121212);
    color: #fff;
}


/* ── Navigation ────────────────────────────────────────────── */
.rfp-slider__nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: clamp(12px, 2vw, 24px);
    margin-top: clamp(20px, 3vw, 32px);
}

.rfp-nav-arrow {
    background: none;
    border: 1px solid var(--border-light, rgba(0, 0, 0, 0.1));
    border-radius: 50%;
    width: 45px;
    height: 45px;
    cursor: pointer;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    color: rgba(0, 0, 0, 0.4);
    transition: color 0.2s ease, border-color 0.2s ease, background 0.2s ease;
    flex-shrink: 0;
}

.rfp-nav-arrow:hover {
    color: var(--wp--preset--color--base, #1a1a1a);
    border-color: rgba(0, 0, 0, 0.2);
}

.rfp-nav-arrow--prev svg {
    transform: rotate(180deg);
}

.rfp-nav-arrow svg {
    width: 20px;
    height: 20px;
}

.rfp-slider__dots {
    display: flex;
    align-items: center;
    gap: 8px;
}

.rfp-dot {
    width: 12px;
    height: 12px;
    border-radius: 100px;
    background: rgba(0, 0, 0, 0.12);
    border: none;
    cursor: pointer;
    padding: 0;
    position: relative;
    overflow: hidden;
    transition: width 0.4s cubic-bezier(0.34, 1.56, 0.64, 1),
                background 0.3s ease;
    -webkit-tap-highlight-color: transparent;
}

/* Invisible 48×48 touch target (a11y) */
.rfp-dot::after {
    content: '';
    position: absolute;
    inset: 50% auto auto 50%;
    transform: translate(-50%, -50%);
    width: 48px;
    height: 48px;
}

.rfp-dot.is-active {
    width: 100px;
    background: rgba(0, 0, 0, 0.08);
}

.rfp-dot__fill {
    position: absolute;
    inset: 0;
    background: var(--wp--preset--color--accent, #fc490b);
    transform-origin: left center;
    transform: scaleX(0);
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 900px) {
    /* Stack tiles vertically */
    .rfp-bento {
        grid-template-columns: 1fr;
    }
    .rfp-bento__images { grid-column: 1; grid-row: 1; }
    .rfp-bento__meta   { grid-column: 1; grid-row: 2; }

    /* Wide side padding compresses screenshots naturally */
    .rfp-bento__images {
        padding: clamp(24px, 5vw, 40px) clamp(44px, 13vw, 72px) 0;
        min-height: clamp(210px, 40vw, 320px);
    }

    .rfp-metrics {
        margin-top: 16px;
        padding-top: 16px;
    }
    .rfp-meta__cta {
        padding-top: 16px;
    }
}

@media (max-width: 600px) {
    .rfp-bento__images {
        padding: clamp(20px, 5vw, 32px) clamp(36px, 11vw, 56px) 0;
        min-height: clamp(170px, 44vw, 250px);
    }
    .rfp-showcase--both .rfp-showcase__landscape { width: 76%; }
    .rfp-showcase--both .rfp-showcase__mobile    { width: 28%; margin-left: -11%; }
}

/* ── Custom Split Slide (style: "split") ──────────────── */
.rfp-bento--split {
    grid-template-columns: 3fr 2fr;
    grid-template-rows: 1fr;
    min-height: clamp(340px, calc(30vw + 96px), 520px);
}

.rfp-split__image {
    grid-column: 1;
    grid-row: 1;
    border-radius: clamp(16px, 2vw, 24px);
    overflow: hidden;
    isolation: isolate;
    background: var(--wp--preset--color--surface, #EAEAE6);
}

.rfp-split__image img {
    display: block;
    width: 100%;
    height: 120%;
    margin-top: -10%;
    object-fit: cover;
    object-position: center;
    will-change: transform;
}

/* ── Framed image variant (identisch zum Referenz-Showcase) ──── */
.rfp-split__image--framed {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: clamp(20px, 3.5vw, 48px) clamp(20px, 3.5vw, 48px) 0;
}

.rfp-split__image--framed .rfp-showcase__item img {
    height: auto;
    margin-top: 0;
    will-change: auto;
}

.rfp-split__html {
    grid-column: 2;
    grid-row: 1;
    background: var(--wp--preset--color--surface, #EAEAE6);
    border-radius: clamp(16px, 2vw, 24px);
    overflow: hidden;
    isolation: isolate;
    padding: clamp(30px, 4vw, 50px);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

/* ── Custom Slide: Structured ─────────────────────────────── */
.rfp-bento--structured {
    background: transparent;
    border: none;
    box-shadow: none;
}

.rfp-structured__content {
    padding: clamp(30px, 4vw, 50px);
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    color: var(--wp--preset--color--base, #1a1a1a);
}

.rfp-structured__title {
    font-size: var(--wp--preset--font-size--2-xl);
    line-height: 1.15;
    letter-spacing: -0.02em;
    font-weight: 600;
    margin: 0;
}

.rfp-structured__text {
    font-size: var(--wp--preset--font-size--base);
    line-height: 1.6;
    color: var(--wp--preset--color--text-main, #333);
    margin-bottom: clamp(28px, 5vw, 40px);
    max-width: 100%;
}

.rfp-structured__cta {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--wp--preset--color--accent, #fc490b);
    color: var(--wp--preset--color--contrast, #ffffff);
    padding: 16px 32px;
    border-radius: 100px;
    text-decoration: none;
    font-size: var(--wp--preset--font-size--base);
    font-weight: 600;
    letter-spacing: 0.02em;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.rfp-structured__cta:hover {
    opacity: 0.85;
}

/* Typography resets inside HTML content area */
.rfp-split__html > * { margin-top: 0; }
.rfp-split__html > * + * { margin-top: 0.75em; }
.rfp-split__html h1,
.rfp-split__html h2,
.rfp-split__html h3 {
    font-size: var(--wp--preset--font-size--xl);
    font-weight: 700;
    letter-spacing: -0.03em;
    line-height: 1.15;
    color: var(--wp--preset--color--base, #1a1a1a);
}
.rfp-split__html p {
    font-size: var(--wp--preset--font-size--base);
    line-height: 1.65;
    color: rgba(0, 0, 0, 0.6);
}
.rfp-split__html a {
    color: var(--wp--preset--color--accent, #fc490b);
    text-decoration: underline;
}

@media (max-width: 900px) {
    .rfp-bento--split {
        grid-template-columns: 1fr;
        grid-template-rows: clamp(200px, 50vw, 320px) auto;
        min-height: unset;
    }
    .rfp-split__image { grid-column: 1; grid-row: 1; }
    .rfp-split__html,
    .rfp-structured__content { grid-column: 1; grid-row: 2; }
}

@media (max-width: 600px) {
    .rfp-split__html {
        padding: clamp(20px, 5vw, 32px);
    }
    /* Flush text alignment with image on mobile */
    .rfp-structured__content {
        padding: clamp(24px, 5vw, 32px) 0 0 0;
    }
}


/* ═══════════════════════════════════════════════════════════
   INSIGHTS FEATURED POST — ba-hero card (extracted from blog-core.css)
   Only the styles needed for the fp-insights featured post card.
   Eliminates 52 KB blog-core.css dependency on the front-page.
   ═══════════════════════════════════════════════════════════ */

.ba-hero__card {
    display: grid;
    grid-template-columns: 1fr 1fr;
    background: #ffffff;
    border-radius: 8px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    border: 1px solid var(--wp--preset--color--surface);
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.3s;
}

.ba-hero__card:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.06);
}

.ba-hero__card > .ba-hero__img {
    width: 100%;
    height: 100%;
    min-height: 340px;
    object-fit: cover;
    display: block;
    /* Prevent white gap: img is direct grid child, must stretch to fill cell */
    align-self: stretch;
}

.ba-hero__img--placeholder {
    background: var(--wp--preset--color--surface);
    min-height: 340px;
}

.ba-hero__body {
    padding: var(--wp--preset--spacing--48);
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--wp--preset--spacing--16);
}

.ba-hero__meta {
    display: flex;
    align-items: center;
    gap: var(--wp--preset--spacing--12);
    font-size: var(--wp--preset--font-size--sm);
}

.ba-hero__title {
    font-family: var(--wp--preset--font-family--heading);
    font-size: var(--wp--preset--font-size--2xl);
    font-weight: 500;
    line-height: 1.1;
    letter-spacing: -0.04em;
    margin: 0;
    color: var(--wp--preset--color--text-main);
}

@media (max-width: 768px) {
    .ba-hero__card {
        grid-template-columns: 1fr;
    }
    .ba-hero__img {
        min-height: 220px;
    }
    .ba-hero__body {
        padding: var(--wp--preset--spacing--32);
    }
}


/* ═══════════════════════════════════════════════════════════
   PROMISE SECTION  ·  fp-promise-*
   Reuses: .rfp-showcase, .rfp-showcase__item, .rfp-bento__images
   ═══════════════════════════════════════════════════════════ */

.fp-promise {
    padding-block: clamp(32px, 5vw, 56px);
}


/* ── Row 1: Hero grid ─────────────────────────────────────── */
.fp-promise__hero {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    column-gap: clamp(20px, 2.5vw, 32px);
    align-items: center;
    margin-bottom: var(--wp--preset--spacing--32);
}

/* Left: image showcase (cols 1–7) */
.fp-promise__media {
    grid-column: 1 / 8;
    grid-row: 1;
}

/* Scope showcase width override to promise section */
.fp-promise__media .rfp-showcase:not(.rfp-showcase--both) .rfp-showcase__landscape {
    width: 88%;
}

/* Right: copy + proof (cols 8–12) */
.fp-promise__copy {
    grid-column: 8 / 13;
    grid-row: 1;
    display: flex;
    flex-direction: column;
}


/* ── Eyebrow ──────────────────────────────────────────────── */
.fp-promise__eyebrow {
    font-family: var(--wp--preset--font-family--body);
    font-size: 12px;
    font-weight: 600;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: var(--wp--preset--color--accent);
    margin-bottom: var(--wp--preset--spacing--16);
}


/* ── Title ────────────────────────────────────────────────── */
.fp-promise__title {
    font-family: var(--wp--preset--font-family--heading);
    font-size: var(--wp--preset--font-size--2xl);
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.04em;
    margin-bottom: var(--wp--preset--spacing--24);
}


/* ── Body ─────────────────────────────────────────────────── */
.fp-promise__body {
    margin-bottom: var(--wp--preset--spacing--32);
}

.fp-promise__body p {
    font-size: var(--wp--preset--font-size--base);
    line-height: 1.65;
    color: var(--wp--preset--color--text-muted);
    margin: 0;
}

.fp-promise__body p strong {
    color: var(--wp--preset--color--text-main);
    font-weight: 600;
}


/* ── Proof items (light theme, border-separated) ──────────── */
.fp-promise__proof {
    display: flex;
    flex-direction: column;
}

.fp-promise__proof-item {
    display: flex;
    align-items: center;
    gap: var(--wp--preset--spacing--12);
    padding: var(--wp--preset--spacing--16) 0;
}

.fp-promise__proof-item:nth-child(2) {
    border-top: 1px solid rgba(18, 18, 18, 0.08);
    border-bottom: 1px solid rgba(18, 18, 18, 0.08);
}

.fp-promise__proof-icon {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--wp--preset--color--accent);
}

.fp-promise__proof-icon svg {
    width: 18px;
    height: 18px;
}

.fp-promise__proof-label {
    font-family: var(--wp--preset--font-family--heading);
    font-size: var(--wp--preset--font-size--sm);
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--wp--preset--color--text-main);
}


/* ── Row 2: Pillars ───────────────────────────────────────── */
.fp-promise__pillars {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(16px, 1.8vw, 24px);
    margin-bottom: var(--wp--preset--spacing--32);
}

.fp-promise__pillar {
    background: rgba(255, 255, 255, 0.35);
    border: 1px solid rgba(18, 18, 18, 0.08);
    border-radius: var(--wp--custom--radius--card);
    padding: clamp(24px, 2.5vw, 32px);
    display: flex;
    flex-direction: column;
    transition:
        transform 0.5s var(--wp--custom--spring),
        box-shadow 0.5s var(--wp--custom--spring),
        border-color 0.3s ease;
}

.fp-promise__pillar:hover {
    transform: translateY(-4px);
    box-shadow: 0 16px 40px rgba(18, 18, 18, 0.04);
    border-color: rgba(0, 0, 0, 0.12);
}

.fp-promise__pillar-num {
    font-family: var(--wp--preset--font-family--heading);
    font-size: 12px;
    font-weight: 700;
    color: var(--wp--preset--color--accent);
    letter-spacing: 0.06em;
    margin-bottom: var(--wp--preset--spacing--16);
}

.fp-promise__pillar-title {
    font-family: var(--wp--preset--font-family--heading);
    font-size: var(--wp--preset--font-size--xl);
    font-weight: 600;
    line-height: 1.15;
    letter-spacing: -0.02em;
    margin-bottom: var(--wp--preset--spacing--8);
}

.fp-promise__pillar-text {
    font-size: var(--wp--preset--font-size--sm);
    line-height: 1.6;
    color: var(--wp--preset--color--text-muted);
    margin: 0;
}


/* ── Row 3: CTA ───────────────────────────────────────────── */
.fp-promise__cta {
    background: var(--wp--preset--color--surface);
    border-radius: var(--wp--custom--radius--card);
    padding: clamp(28px, 3.5vw, 44px) clamp(24px, 2.5vw, 32px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--wp--preset--spacing--48);
}

.fp-promise__cta-text {
    flex: 1;
    min-width: 0;
}

.fp-promise__cta-heading {
    font-family: var(--wp--preset--font-family--heading);
    font-size: var(--wp--preset--font-size--2xl);
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: -0.03em;
    margin: var(--wp--preset--spacing--4) 0;
}

.fp-promise__cta-sub {
    font-size: var(--wp--preset--font-size--sm);
    line-height: 1.5;
    color: var(--wp--preset--color--text-muted);
    margin: 0;
}

.fp-promise__cta-btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--wp--preset--color--hero-blue);
    color: #fff;
    padding: 14px 32px;
    border-radius: var(--wp--custom--radius--button);
    text-decoration: none;
    font-family: var(--wp--preset--font-family--body);
    font-size: var(--wp--preset--font-size--sm);
    font-weight: 600;
    letter-spacing: 0.02em;
    white-space: nowrap;
    flex-shrink: 0;
    transition: background 0.25s ease;
}

.fp-promise__cta-btn:hover {
    background: #3561c8;
    color: #fff;
}

.fp-promise__cta-btn svg {
    transition: transform 0.3s var(--wp--custom--spring);
}

.fp-promise__cta-btn:hover svg {
    transform: translateX(3px);
}


/* ── Row 4: Parallax Image Strip ──────────────────────────── */
.fp-promise__parallax {
    height: 300px;
    border-radius: var(--wp--custom--radius--card);
    overflow: hidden;
    margin-top: var(--wp--preset--spacing--32);
    position: relative;
}

.fp-promise__parallax img {
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    min-height: 130%;
    object-fit: cover;
    object-position: center;
    transform: translateY(-50%);
    will-change: transform;
}

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width: 900px) {
    .fp-promise__hero {
        grid-template-columns: 1fr;
        row-gap: var(--wp--preset--spacing--32);
    }
    .fp-promise__media {
        grid-column: 1 / -1;
        grid-row: 1;
    }
    .fp-promise__copy {
        grid-column: 1 / -1;
        grid-row: 2;
    }
    .fp-promise__pillars {
        grid-template-columns: 1fr;
        gap: 12px;
    }
    .fp-promise__cta {
        flex-direction: column;
        text-align: center;
        gap: var(--wp--preset--spacing--24);
    }
}

@media (max-width: 600px) {
    .fp-promise__cta-btn {
        width: fit-content;
        max-width: 100%;
        justify-content: center;
    }
}

