/* Source: patterns/immersive-panel-steps.css */
/* ===============================
   Pattern: Immersive Panel Steps
   Supports: NOFCC Section Background block
================================ */
.immersive-panel {
    position: relative;
    overflow: hidden;
    min-height: 72vh;
    padding: 96px 0 86px;
}
/* Legacy Cover support only.
   New NOFCC background image behaviour is owned by textures.css. */
.immersive-panel.has-parallax {
    background-position: center center;
    background-size: cover;
    background-repeat: no-repeat;
}
.immersive-panel .wp-block-cover__background {
    background:
        linear-gradient(
            90deg,
            rgba(15, 15, 16, 0.82) 0%,
            rgba(15, 15, 16, 0.62) 44%,
            rgba(15, 15, 16, 0.38) 100%
        ) !important;
    opacity: 1 !important;
}
/* Dark overlay only belongs to image mode. */
.immersive-panel.has-background-image .nofcc-section-background__overlay {
    background:
        linear-gradient(
            90deg,
            rgba(15, 15, 16, 0.82) 0%,
            rgba(15, 15, 16, 0.62) 44%,
            rgba(15, 15, 16, 0.38) 100%
        ) !important;
}
.immersive-panel.has-background-image::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        radial-gradient(circle at 18% 28%, rgba(255, 255, 255, 0.10), transparent 32%),
        linear-gradient(to bottom, rgba(0, 0, 0, 0.08), rgba(0, 0, 0, 0.28));
    pointer-events: none;
}
.immersive-panel .wp-block-cover__inner-container,
.immersive-panel .nofcc-section-background__inner {
    position: relative;
    z-index: 2;
    width: 100%;
}
.immersive-panel .container {
    width: min(100% - 48px, 1180px);
    max-width: 1180px;
    margin: 0 auto;
}
/* Main glass panel */
.immersive-panel__panel {
    max-width: 780px;
    padding: clamp(42px, 5vw, 58px);
    background: rgba(255, 255, 255, 0.84);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
}
.immersive-panel.has-background-image .immersive-panel__panel,
.immersive-panel.has-parallax .immersive-panel__panel {
    background: rgba(15, 15, 16, 0.46);
}
/* Image-mode typography */
.immersive-panel.has-background-image,
.immersive-panel.has-parallax {
    color: var(--color-white);
}
.immersive-panel.has-background-image .eyebrow,
.immersive-panel.has-parallax .eyebrow {
    color: rgba(255, 255, 255, 0.72);
}
.immersive-panel.has-background-image h2,
.immersive-panel.has-background-image h3,
.immersive-panel.has-parallax h2,
.immersive-panel.has-parallax h3 {
    color: var(--color-white);
}
.immersive-panel.has-background-image p,
.immersive-panel.has-parallax p {
    color: rgba(255, 255, 255, 0.82);
}
/* Main intro copy */
.immersive-panel p {
    max-width: 640px;
}
/* Steps wrapper */
.immersive-panel__steps {
    max-width: 100%;
    margin: 46px 0 0;
    padding-top: 30px;
    border-top: 1px solid rgba(31, 41, 55, 0.14);
}
.immersive-panel.has-background-image .immersive-panel__steps,
.immersive-panel.has-parallax .immersive-panel__steps {
    border-top-color: rgba(255, 255, 255, 0.22);
}
/* Steps grid
   Gutenberg often injects .wp-block-group__inner-container.
   The parent holds spacing/border. The inner container becomes the real grid.
================================ */
.immersive-panel__steps {
    display: block !important;
}
/* Normal Gutenberg front-end/editor structure */
.immersive-panel__steps > .wp-block-group__inner-container {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: clamp(38px, 5vw, 62px);
    row-gap: clamp(30px, 4vw, 46px);
    max-width: none;
    margin: 0;
    padding: 0;
    border: 0;
}
/* Fallback when no inner container exists */
.immersive-panel__steps:not(:has(> .wp-block-group__inner-container)) {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    column-gap: clamp(38px, 5vw, 62px);
    row-gap: clamp(30px, 4vw, 46px);
}
/* Step items */
.immersive-panel__steps article {
    min-width: 0;
    margin: 0 !important;
    padding: 0 !important;
}
/* Step headings intentionally reduced so they support,
   rather than compete with, the main section headline. */
.immersive-panel__steps article h3 {
    max-width: none;
    margin: 0 0 12px;
    font-size: clamp(1.15rem, 1.35vw, 1.45rem);
    line-height: 1.18;
    letter-spacing: 0.015em;
}
.immersive-panel__steps article p {
    max-width: none;
    margin: 0;
    font-size: 0.95rem;
    line-height: 1.62;
}
/* Softer body copy in image mode */
.immersive-panel.has-background-image .immersive-panel__steps article p,
.immersive-panel.has-parallax .immersive-panel__steps article p {
    color: rgba(255, 255, 255, 0.76);
}
/* Button row if manually added after steps */
.immersive-panel .wp-block-buttons {
    margin-top: 34px;
}
/* Responsive */
@media (max-width: 900px) {
    .immersive-panel {
        min-height: auto;
        padding: 82px 0 78px;
    }
    .immersive-panel .container {
        width: min(100% - 32px, 1180px);
    }
    .immersive-panel__panel {
        padding: 38px 30px;
    }
    .immersive-panel__steps {
        margin-top: 42px;
        padding-top: 28px;
    }
    .immersive-panel__steps > .wp-block-group__inner-container,
    .immersive-panel__steps:not(:has(> .wp-block-group__inner-container)) {
        column-gap: 34px;
        row-gap: 34px;
    }
}
@media (max-width: 640px) {
    .immersive-panel__steps > .wp-block-group__inner-container,
    .immersive-panel__steps:not(:has(> .wp-block-group__inner-container)) {
        grid-template-columns: 1fr;
        gap: 30px;
    }
    .immersive-panel__steps article h3,
    .immersive-panel__steps article p {
        max-width: none;
    }
    .immersive-panel__steps article h3 {
        font-size: clamp(1.2rem, 6vw, 1.45rem);
    }
}