    html:has(body.page-project-presentation) {
        --project-pres-nav-height: 0px;
        scroll-behavior: smooth;
        scroll-padding-top: 0;
    }

    html:has(body.page-project-presentation) .container.mx-auto.mt-5 {
        margin-top: 0;
    }

    @media (prefers-reduced-motion: reduce) {
        html:has(body.page-project-presentation) {
            scroll-behavior: auto;
        }
    }

    html:has(body.page-project-presentation) footer {
        position: relative;
        z-index: 30;
        isolation: isolate;
        margin-top: 0;
    }

    html:has(body.page-project-presentation) .project-pres-page {
        position: relative;
        z-index: 1;
        min-height: 0;
        margin-bottom: 0;
        padding-bottom: 0;
    }

    .project-pres-panel {
        scroll-margin-top: var(--project-pres-nav-height, 0px);
        position: relative;
        border: none;
    }

    /* Dernière section : hauteur naturelle (évite chevauchement / sélection avec le footer) */
    .project-pres-panel--launch {
        min-height: 0;
    }

    .project-pres-panel:not(.project-pres-panel--launch) {
        min-height: calc(100dvh - var(--project-pres-nav-height, 5.5rem));
        min-height: calc(100svh - var(--project-pres-nav-height, 5.5rem));
        display: flex;
        flex-direction: column;
        scroll-snap-align: start;
    }

    /* Fondu blanc entre sections (bande courte, blanc marqué + filet) */
    .project-pres-panel::before,
    .project-pres-panel::after {
        content: "";
        position: absolute;
        left: 0;
        right: 0;
        height: clamp(0.35rem, 1.35vh, 0.75rem);
        pointer-events: none;
        z-index: 4;
    }

    .project-pres-panel::before {
        top: 0;
        border-top: 1px solid #ffffff;
        background: linear-gradient(180deg,
                #ffffff 0%,
                #ffffff 14%,
                rgba(255, 255, 255, 0.92) 28%,
                rgba(255, 255, 255, 0) 100%);
    }

    .project-pres-panel::after {
        bottom: 0;
        border-bottom: 1px solid #ffffff;
        background: linear-gradient(0deg,
                #ffffff 0%,
                #ffffff 12%,
                rgba(255, 255, 255, 0.9) 26%,
                rgba(255, 255, 255, 0) 100%);
    }

    .project-pres-panel--hero::before {
        display: none;
    }

    .project-pres-panel--hero::after {
        border-bottom: 1px solid #ffffff;
        background: linear-gradient(0deg,
                #ffffff 0%,
                #ffffff 14%,
                rgba(255, 255, 255, 0.75) 28%,
                rgba(255, 255, 255, 0) 100%);
    }

    .project-pres-panel--journey::before {
        border-top: 1px solid #ffffff;
        background: linear-gradient(180deg,
                #ffffff 0%,
                #ffffff 14%,
                rgba(255, 255, 255, 0.88) 28%,
                rgba(255, 255, 255, 0) 100%);
    }

    .project-pres-panel--journey::after {
        border-bottom: 1px solid #ffffff;
        background: linear-gradient(0deg,
                #ffffff 0%,
                #ffffff 12%,
                rgba(255, 255, 255, 0.85) 26%,
                rgba(255, 255, 255, 0) 100%);
    }

    .project-pres-panel--launch::after {
        display: none;
    }

    .project-pres-panel__inner {
        flex: 1 1 auto;
        display: flex;
        flex-direction: column;
        justify-content: center;
        width: 100%;
    }

    .project-pres-panel:not(.project-pres-panel--launch) .project-pres-panel__inner {
        flex: 1 1 auto;
    }

    .project-pres-panel--launch .project-pres-panel__inner {
        flex: 0 0 auto;
        justify-content: flex-start;
    }

    /* Texte / blocs : entrée au scroll */
    .project-pres-reveal {
        opacity: 0;
        transform: translate3d(0, 1.35rem, 0);
        transition:
            opacity 0.75s cubic-bezier(0.22, 1, 0.36, 1),
            transform 0.75s cubic-bezier(0.22, 1, 0.36, 1);
        transition-delay: var(--reveal-delay, 0ms);
    }

    .project-pres-reveal:not(.is-visible) {
        pointer-events: none;
        user-select: none;
    }

    .project-pres-reveal.is-visible {
        opacity: 1;
        transform: translate3d(0, 0, 0);
    }

    @media (prefers-reduced-motion: reduce) {
        .project-pres-reveal {
            opacity: 1;
            transform: none;
            transition: none;
        }
    }

    .project-pres-hero-bg {
        overflow: hidden;
        background-color: #141018;
    }

    .project-pres-hero-media {
        position: absolute;
        inset: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center;
        opacity: 0;
        transform: scale(1.008);
        transition:
            opacity 0.22s ease-out,
            transform 0.45s cubic-bezier(0.22, 1, 0.36, 1);
    }

    .project-pres-hero-media.is-loaded {
        opacity: 1;
        transform: scale(1);
    }

    @media (prefers-reduced-motion: reduce) {

        .project-pres-hero-media,
        .project-pres-hero-media.is-loaded {
            transition: none;
            transform: none;
            opacity: 1;
        }
    }

    .project-pres-hero-overlay {
        background:
            linear-gradient(180deg,
                rgba(8, 8, 12, 0.28) 0%,
                rgba(8, 8, 12, 0.48) 52%,
                rgba(8, 8, 12, 0.6) 100%);
    }

    .project-pres-hero-title {
        font-family: "Poppins", "Montserrat", "Avenir Next", "Segoe UI", Arial, sans-serif;
        font-weight: 300;
        font-size: clamp(2rem, 7.5vw, 5rem);
        line-height: 1.06;
        color: color-mix(in srgb, #ffffff 86%, transparent);
        letter-spacing: 0.02em;
        text-wrap: balance;
        text-shadow: 0 6px 22px rgba(0, 0, 0, 0.32);
    }

    .project-pres-highlight {
        font-weight: 600;
        color: #ffffff;
        text-shadow: 0 8px 18px rgba(0, 0, 0, 0.45);
    }

    .project-pres-muted {
        color: color-mix(in srgb, #ffffff 72%, transparent);
    }

    .project-pres-hero-brand {
        display: block;
        margin-bottom: 0.35rem;
        font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
        font-weight: 600;
        font-size: clamp(2rem, 7.5vw, 5rem);
        line-height: 1.06;
        letter-spacing: 0.14em;
        text-transform: uppercase;
    }

    .project-pres-hero-tagline {
        display: inline-block;
        margin: 0.85rem auto 0;
        max-width: min(32rem, 92vw);
        padding: 0.7rem 1.15rem;
        border-radius: 0.5rem;
        font-family: "Montserrat", "Segoe UI", sans-serif;
        font-size: clamp(0.98rem, 2.15vw, 1.22rem);
        line-height: 1.5;
        font-weight: 400;
        letter-spacing: 0.015em;
        color: color-mix(in srgb, #ffffff 88%, transparent);
        text-shadow: 0 3px 18px rgba(0, 0, 0, 0.32);
        border: 0;
        text-wrap: balance;
        background: color-mix(in srgb, #ffffff 9%, transparent);
        border: 1px solid color-mix(in srgb, #ffffff 22%, transparent);
        box-shadow:
            0 8px 28px -12px rgba(0, 0, 0, 0.35),
            inset 0 1px 0 color-mix(in srgb, #ffffff 18%, transparent);
        backdrop-filter: blur(6px);
        transition: opacity 0.6s ease, transform 0.6s ease;
    }

    .project-pres-hero-tagline__emph {
        font-weight: 600;
        color: #ffffff;
        white-space: nowrap;
    }

    .project-pres-reveal.is-visible .project-pres-hero-tagline {
        animation: project-pres-lead-in 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.12s both;
    }

    .project-pres-hero-chips {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 0.5rem 0.65rem;
        margin-top: 1.25rem;
        max-width: 44rem;
        margin-left: auto;
        margin-right: auto;
    }

    .project-pres-hero-chip {
        display: inline-flex;
        align-items: center;
        gap: 0.4rem;
        padding: 0.45rem 0.85rem;
        border-radius: 9999px;
        font-size: 0.76rem;
        font-weight: 600;
        line-height: 1.25;
        letter-spacing: 0.01em;
        backdrop-filter: blur(8px);
        box-shadow: 0 2px 10px -6px rgba(0, 0, 0, 0.18);
    }

    .project-pres-hero-chip .icon-nav {
        display: inline-flex;
        flex-shrink: 0;
        align-items: center;
        justify-content: center;
    }

    .project-pres-hero-chip .icon-nav svg {
        width: 1rem;
        height: 1rem;
        fill: currentColor;
    }

    .project-pres-hero-chip--booking {
        color: #ecfdf5;
        background: color-mix(in srgb, #059669 36%, transparent);
        border: 1px solid color-mix(in srgb, #6ee7b7 38%, transparent);
    }

    .project-pres-hero-chip--reminders {
        color: #f3e8ff;
        background: color-mix(in srgb, #7c3aed 38%, transparent);
        border: 1px solid color-mix(in srgb, #c4b5fd 38%, transparent);
    }

    .project-pres-hero-chip--devices {
        color: #eff6ff;
        background: color-mix(in srgb, #2563eb 36%, transparent);
        border: 1px solid color-mix(in srgb, #93c5fd 38%, transparent);
    }

    .project-pres-highlights {
        display: grid;
        gap: 0.85rem;
        margin-top: 2rem;
        margin-bottom: 0.5rem;
    }

    @media (min-width: 768px) {
        .project-pres-highlights {
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 1rem;
            margin-top: 2.5rem;
        }
    }

    .project-pres-highlight-card {
        display: flex;
        align-items: flex-start;
        gap: 0.75rem;
        padding: 1rem 1.05rem;
        border-radius: 0.85rem;
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 14%, #fff);
        background: color-mix(in srgb, #ffffff 75%, var(--color-primary, #6b21a8));
        transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .project-pres-highlight-card:hover {
        transform: translateY(-2px);
        box-shadow: 0 12px 28px -16px color-mix(in srgb, var(--color-primary, #6b21a8) 35%, transparent);
    }

    .project-pres-highlight-card .project-pres-icon {
        width: 2.5rem;
        height: 2.5rem;
        flex-shrink: 0;
    }

    .project-pres-highlight-card .project-pres-icon svg {
        width: 1.25rem;
        height: 1.25rem;
    }

    .project-pres-highlight-card strong {
        display: block;
        font-size: 0.92rem;
        font-weight: 600;
        line-height: 1.3;
        margin-bottom: 0.2rem;
    }

    .project-pres-highlight-card span {
        font-size: 0.82rem;
        line-height: 1.45;
        color: color-mix(in srgb, var(--color-base-content) 65%, transparent);
    }

    .project-pres-step__header {
        display: flex;
        align-items: center;
        gap: 0.85rem;
    }

    .project-pres-step__icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 2.75rem;
        height: 2.75rem;
        margin: 0;
        border-radius: 0.75rem;
        background: color-mix(in srgb, #fff 14%, transparent);
        border: 1px solid color-mix(in srgb, #fff 22%, transparent);
        color: color-mix(in srgb, #fff 95%, var(--color-secondary, #ec4899));
        flex-shrink: 0;
    }

    .project-pres-step__icon .icon-nav {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        line-height: 0;
    }

    .project-pres-step__icon .icon-nav svg {
        width: 1.35rem;
        height: 1.35rem;
        fill: currentColor;
        display: block;
    }

    .project-pres-step__title-wrap {
        flex: 1 1 auto;
        min-width: 0;
    }

    .project-pres-step__title-wrap h3 {
        margin: 0;
        line-height: 1.3;
    }

    .project-pres-hero-logo-shell {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: clamp(7.5rem, 20vw, 10.5rem);
        height: clamp(7.5rem, 20vw, 10.5rem);
        border-radius: 50%;
        background: #ffffff;
        border: 2px solid color-mix(in srgb, var(--color-primary, #6b21a8) 26%, #ffffff);
        box-shadow:
            0 18px 40px -20px rgba(0, 0, 0, 0.55),
            0 0 0 8px color-mix(in srgb, #fff 25%, transparent),
            0 0 0 1px rgba(255, 255, 255, 0.8) inset;
    }

    .project-pres-hero-logo {
        max-height: 62%;
        width: auto;
        max-width: 82%;
        object-fit: contain;
    }

    .project-pres-cta {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 0.55rem;
        min-height: 3.5rem;
        padding: 0.75rem 2.25rem;
        border-radius: 9999px;
        border: 1px solid color-mix(in srgb, #fff 70%, transparent);
        background: linear-gradient(135deg, color-mix(in srgb, var(--color-primary, #6b21a8) 88%, white) 0%, color-mix(in srgb, var(--color-primary, #6b21a8) 70%, black) 100%);
        color: #fff;
        font-weight: 600;
        letter-spacing: 0.035em;
        transition: transform 0.2s ease, box-shadow 0.25s ease, opacity 0.2s ease;
        box-shadow: 0 14px 28px -12px rgba(0, 0, 0, 0.45);
    }

    .project-pres-cta:hover {
        transform: translateY(-1px);
        opacity: 0.95;
        box-shadow: 0 18px 34px -13px rgba(0, 0, 0, 0.5);
    }

    .project-pres-cta__icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 1.15rem;
        height: 1.15rem;
        flex-shrink: 0;
    }

    .project-pres-cta__icon svg {
        width: 100%;
        height: 100%;
        display: block;
    }

    .project-pres-cta--outline {
        background: transparent;
        border: 2px solid color-mix(in srgb, #fff 85%, transparent);
        box-shadow: none;
    }

    .project-pres-cta--outline:hover {
        background: color-mix(in srgb, #fff 12%, transparent);
    }

    .project-pres-block {
        border: 2px solid color-mix(in srgb, var(--color-primary, #6b21a8) 26%, var(--color-base-300, #e5e5e5));
        border-radius: 0.75rem;
        background: var(--color-base-100, #fff);
        box-shadow: 0 14px 30px -22px color-mix(in srgb, var(--color-primary, #6b21a8) 35%, transparent);
    }

    .project-pres-icon {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 3.45rem;
        height: 3.45rem;
        border-radius: 0.9rem;
        background: color-mix(in srgb, var(--color-primary, #6b21a8) 10%, transparent);
        color: var(--color-primary, #6b21a8);
        transition: transform 0.3s ease, background 0.3s ease, box-shadow 0.3s ease;
    }

    .project-pres-icon svg {
        width: 1.65rem;
        height: 1.65rem;
    }

    .project-pres-scroll-icon {
        width: 3.25rem;
        height: 3.25rem;
        border-radius: 9999px;
        background: linear-gradient(135deg,
                color-mix(in srgb, var(--color-primary, #6b21a8) 26%, transparent) 0%,
                color-mix(in srgb, var(--color-secondary, #ec4899) 20%, transparent) 100%);
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 32%, #ffffff);
        color: #ffffff;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        backdrop-filter: blur(2px);
        box-shadow: 0 8px 20px -14px color-mix(in srgb, var(--color-primary, #6b21a8) 38%, transparent);
        transition: transform 0.2s ease, box-shadow 0.2s ease, filter 0.2s ease;
    }

    .project-pres-scroll-icon:hover {
        transform: translateY(-3px) scale(1.05);
        filter: brightness(1.06);
        box-shadow: 0 14px 28px -12px color-mix(in srgb, var(--color-primary, #6b21a8) 50%, transparent);
    }

    .project-pres-scroll-icon svg {
        width: 2rem;
        height: 2rem;
    }

    .project-pres-scroll-icon--light {
        color: #ffffff;
        background: linear-gradient(135deg,
                color-mix(in srgb, var(--color-primary, #6b21a8) 26%, transparent) 0%,
                color-mix(in srgb, var(--color-secondary, #ec4899) 20%, transparent) 100%);
        border-color: color-mix(in srgb, var(--color-primary, #6b21a8) 32%, #ffffff);
    }

    .project-pres-panel--features {
        position: relative;
        overflow: hidden;
        isolation: isolate;
    }

    .project-pres-panel--features .project-pres-panel__inner::after {
        content: "";
        position: absolute;
        inset: auto -12% 22% -12%;
        height: 220px;
        background:
            radial-gradient(55% 90% at 15% 50%, color-mix(in srgb, var(--color-primary, #6b21a8) 20%, transparent) 0%, transparent 78%),
            radial-gradient(60% 85% at 85% 55%, color-mix(in srgb, var(--color-secondary, #ec4899) 18%, transparent) 0%, transparent 80%);
        filter: blur(18px);
        opacity: 0.7;
        z-index: -1;
        pointer-events: none;
    }

    .project-pres-panel--features .project-pres-panel__inner {
        position: relative;
        z-index: 1;
    }

    .project-pres-curve-line {
        position: absolute;
        left: -4%;
        right: -4%;
        top: 38%;
        z-index: -1;
        pointer-events: none;
        opacity: 0.75;
        filter: drop-shadow(0 0 14px color-mix(in srgb, var(--color-primary, #6b21a8) 24%, transparent));
    }

    .project-pres-step {
        border: 1px solid color-mix(in srgb, var(--color-base-content, #111) 10%, transparent);
        border-radius: 1rem;
        background: var(--color-base-100, #fff);
        padding: 1.1rem 1.2rem;
    }

    .project-pres-step__badge {
        display: inline-block;
        margin-bottom: 0.35rem;
        padding: 0.15rem 0.5rem;
        border-radius: 9999px;
        font-size: 0.68rem;
        font-weight: 700;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        line-height: 1.2;
        background: color-mix(in srgb, var(--color-secondary, #ec4899) 40%, transparent);
        color: #fff;
    }

    @media (max-width: 768px) {

        .project-pres-panel__inner.px-6.py-16,
        .project-pres-panel__inner.px-6.py-16.md\:px-10.md\:py-20,
        .project-pres-panel__inner.px-6.py-16.md\:px-10.md\:py-24 {
            padding-top: 3.25rem;
            padding-bottom: 3.25rem;
        }

        .project-pres-panel__inner.px-6.pb-16.pt-28 {
            padding-top: 5.25rem;
            padding-bottom: 3.25rem;
        }
    }

    .project-pres-mock {
        border-radius: 0.75rem;
        border: 1px solid var(--color-base-300, #e5e5e5);
        background: var(--color-base-100, #fff);
        box-shadow: 0 24px 48px -12px color-mix(in srgb, var(--color-neutral, #000) 12%, transparent);
    }

    .project-pres-mock-bar {
        display: flex;
        align-items: center;
        gap: 0.35rem;
        padding: 0.65rem 0.85rem;
        border-bottom: 1px solid var(--color-base-300, #e5e5e5);
        background: var(--color-base-200, #f5f5f5);
    }

    .project-pres-mock-dot {
        width: 0.45rem;
        height: 0.45rem;
        border-radius: 9999px;
        background: color-mix(in srgb, var(--color-base-content, #333) 22%, transparent);
    }

    /* ——— Page : moins de blanc, identité Resaya ——— */
    .project-pres-page {
        background:
            radial-gradient(ellipse 120% 80% at 10% -20%, color-mix(in srgb, var(--color-primary, #6b21a8) 14%, transparent) 0%, transparent 55%),
            radial-gradient(ellipse 90% 60% at 95% 30%, color-mix(in srgb, var(--color-secondary, #ec4899) 10%, transparent) 0%, transparent 50%),
            linear-gradient(180deg, color-mix(in srgb, var(--color-base-200, #f4f4f5) 100%, #e8e4f0) 0%, var(--color-base-100, #fafafa) 38%, color-mix(in srgb, var(--color-base-200, #eee) 80%, #e2dce8) 100%);
    }

    .project-pres-eyebrow {
        display: inline-block;
        margin-bottom: 0.75rem;
        padding: 0.35rem 0.85rem;
        border-radius: 9999px;
        font-size: 0.72rem;
        font-weight: 600;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: var(--color-primary, #6b21a8);
        background: color-mix(in srgb, var(--color-primary, #6b21a8) 12%, transparent);
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 22%, transparent);
        transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .project-pres-reveal.is-visible .project-pres-eyebrow {
        animation: project-pres-eyebrow-in 0.65s cubic-bezier(0.22, 1, 0.36, 1) both;
    }

    @keyframes project-pres-eyebrow-in {
        from {
            opacity: 0;
            transform: translateY(0.35rem);
            letter-spacing: 0.18em;
        }

        to {
            opacity: 1;
            transform: translateY(0);
            letter-spacing: 0.12em;
        }
    }

    .project-pres-section-title {
        font-family: "Poppins", "Montserrat", "Segoe UI", sans-serif;
        font-weight: 600;
        letter-spacing: -0.02em;
        text-wrap: balance;
        line-height: 1.15;
    }

    .project-pres-section-lead {
        margin-top: 1rem;
        margin-left: auto;
        margin-right: auto;
        max-width: 40rem;
        font-size: 1.0625rem;
        line-height: 1.75;
        font-weight: 400;
        color: color-mix(in srgb, var(--color-base-content, #1a1a1a) 62%, transparent);
        text-wrap: pretty;
    }

    @media (min-width: 768px) {
        .project-pres-section-lead {
            font-size: 1.2rem;
            margin-top: 1.125rem;
        }
    }

    .project-pres-panel--journey .project-pres-section-lead {
        color: color-mix(in srgb, #ffffff 76%, transparent);
    }

    .project-pres-reveal.is-visible .project-pres-section-lead {
        animation: project-pres-lead-in 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.08s both;
    }

    @keyframes project-pres-lead-in {
        from {
            opacity: 0;
            transform: translateY(0.65rem);
        }

        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    .project-pres-panel--features {
        background:
            linear-gradient(165deg, color-mix(in srgb, var(--color-primary, #6b21a8) 8%, #f8f6fc) 0%, #f3f0f8 45%, color-mix(in srgb, var(--color-secondary, #ec4899) 6%, #faf8fb) 100%);
    }

    .project-pres-block {
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 18%, #ffffff);
        background: linear-gradient(145deg,
                color-mix(in srgb, #ffffff 92%, var(--color-primary, #6b21a8)) 0%,
                color-mix(in srgb, #ffffff 78%, var(--color-base-200, #f5f5f5)) 100%);
        box-shadow:
            0 20px 40px -24px color-mix(in srgb, var(--color-primary, #6b21a8) 35%, transparent),
            0 0 0 1px color-mix(in srgb, #fff 60%, transparent) inset;
        transition: transform 0.25s ease, box-shadow 0.25s ease;
    }

    .project-pres-block:hover {
        transform: translateY(-4px);
        box-shadow:
            0 28px 48px -22px color-mix(in srgb, var(--color-primary, #6b21a8) 42%, transparent),
            0 0 0 1px color-mix(in srgb, #fff 70%, transparent) inset;
    }

    .project-pres-block:hover .project-pres-icon {
        transform: scale(1.06) rotate(-2deg);
        background: color-mix(in srgb, var(--color-primary, #6b21a8) 18%, transparent);
        box-shadow: 0 8px 20px -10px color-mix(in srgb, var(--color-primary, #6b21a8) 35%, transparent);
    }

    .project-pres-panel--journey {
        background:
            linear-gradient(180deg, color-mix(in srgb, var(--color-primary, #6b21a8) 12%, #2d2438) 0%, #1a1522 55%, #121018 100%);
        color: #f4f0f8;
        border-color: color-mix(in srgb, #fff 8%, transparent);
    }

    .project-pres-panel--journey .project-pres-section-title,
    .project-pres-panel--journey h3 {
        color: #fff;
    }

    .project-pres-panel--journey .project-pres-eyebrow {
        color: color-mix(in srgb, #fff 90%, var(--color-secondary, #ec4899));
        background: color-mix(in srgb, #fff 10%, transparent);
        border-color: color-mix(in srgb, #fff 20%, transparent);
    }

    .project-pres-panel--journey p {
        color: color-mix(in srgb, #ffffff 72%, transparent);
    }

    .project-pres-step {
        border: 1px solid color-mix(in srgb, #fff 14%, transparent);
        background: color-mix(in srgb, #fff 8%, transparent);
        backdrop-filter: blur(8px);
        transition: transform 0.28s ease, border-color 0.28s ease, background 0.28s ease, box-shadow 0.28s ease;
    }

    .project-pres-step:hover {
        transform: translateY(-4px);
        border-color: color-mix(in srgb, #fff 32%, transparent);
        background: color-mix(in srgb, #fff 14%, transparent);
        box-shadow: 0 16px 36px -18px rgba(0, 0, 0, 0.35);
    }

    .project-pres-panel--journey .project-pres-step__badge {
        background: color-mix(in srgb, var(--color-secondary, #ec4899) 45%, transparent);
        color: #fff;
    }

    .project-pres-panel--journey .project-pres-step p {
        color: color-mix(in srgb, #ffffff 68%, transparent);
    }

    .project-pres-panel--pricing {
        background:
            radial-gradient(70% 50% at 50% 0%, color-mix(in srgb, var(--color-primary, #6b21a8) 16%, transparent) 0%, transparent 70%),
            linear-gradient(180deg, #ebe6f2 0%, #f7f5fa 100%);
    }

    .project-pres-pricing-shell {
        border: none;
        background: transparent;
        box-shadow: none;
        padding: 0;
    }

    .project-pres-pack {
        border-radius: 1rem;
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 20%, #fff);
        background: linear-gradient(160deg, #ffffff 0%, color-mix(in srgb, var(--color-primary, #6b21a8) 4%, #fff) 100%);
        padding: 1.5rem;
        box-shadow: 0 16px 36px -20px color-mix(in srgb, var(--color-primary, #6b21a8) 28%, transparent);
        height: 100%;
        transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
    }

    .project-pres-pack:hover {
        transform: translateY(-6px);
        box-shadow: 0 22px 44px -16px color-mix(in srgb, var(--color-primary, #6b21a8) 38%, transparent);
        border-color: color-mix(in srgb, var(--color-primary, #6b21a8) 38%, #fff);
    }

    .project-pres-pack--featured {
        border-width: 2px;
        border-color: var(--color-primary, #6b21a8);
        background: linear-gradient(155deg,
                color-mix(in srgb, var(--color-primary, #6b21a8) 12%, #fff) 0%,
                #ffffff 42%,
                color-mix(in srgb, var(--color-secondary, #ec4899) 8%, #fff) 100%);
        box-shadow: 0 24px 50px -18px color-mix(in srgb, var(--color-primary, #6b21a8) 45%, transparent);
        position: relative;
    }

    .project-pres-pack--free {
        border-style: dashed;
        border-color: color-mix(in srgb, var(--color-primary, #6b21a8) 35%, #ccc);
        background: color-mix(in srgb, var(--color-base-200, #f5f5f5) 60%, #fff);
    }

    .project-pres-pricing-grid {
        display: grid;
        gap: 1.25rem;
        align-items: stretch;
    }

    .project-pres-pricing-link {
        display: inline-block;
        font-size: 1rem;
        font-weight: 600;
        text-decoration: underline;
        text-underline-offset: 0.2em;
        transition: opacity 0.2s ease;
    }

    .project-pres-pricing-link:hover {
        opacity: 0.85;
    }

    @media (min-width: 768px) {
        .project-pres-pricing-grid {
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 1.5rem;
        }
    }

    .project-pres-pack__tag {
        position: absolute;
        top: -0.65rem;
        right: 1rem;
        padding: 0.2rem 0.65rem;
        border-radius: 9999px;
        font-size: 0.68rem;
        font-weight: 700;
        letter-spacing: 0.06em;
        text-transform: uppercase;
        color: #fff;
        background: linear-gradient(90deg, var(--color-primary, #6b21a8), var(--color-secondary, #ec4899));
    }

    .project-pres-panel--faq {
        background:
            linear-gradient(180deg, color-mix(in srgb, var(--color-base-200, #ece8f0) 100%, #ddd6e6) 0%, color-mix(in srgb, var(--color-primary, #6b21a8) 6%, #f0ecf5) 100%);
    }

    .project-pres-faq-list {
        display: flex;
        flex-direction: column;
        gap: 0.65rem;
    }

    .project-pres-faq-item {
        border-radius: 0.85rem;
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 16%, #fff);
        background: color-mix(in srgb, #ffffff 88%, transparent);
        box-shadow: 0 10px 28px -18px color-mix(in srgb, var(--color-primary, #6b21a8) 25%, transparent);
        overflow: hidden;
        transition: border-color 0.22s ease, box-shadow 0.22s ease, background 0.22s ease;
    }

    .project-pres-faq-item:hover {
        border-color: color-mix(in srgb, var(--color-primary, #6b21a8) 32%, #fff);
        background: #ffffff;
        box-shadow: 0 14px 32px -16px color-mix(in srgb, var(--color-primary, #6b21a8) 32%, transparent);
    }

    .project-pres-faq-item summary {
        display: block;
        padding: 1rem 1.15rem;
        font-weight: 600;
        font-size: 1rem;
        line-height: 1.4;
        cursor: pointer;
        list-style: none;
        color: var(--color-base-content, #1a1a1a);
    }

    .project-pres-faq-item summary::-webkit-details-marker,
    .project-pres-faq-item summary::marker {
        display: none;
        content: none;
    }

    .project-pres-faq-item[open] summary {
        color: var(--color-primary, #6b21a8);
    }

    .project-pres-faq-item__body {
        padding: 0 1.15rem 1.1rem;
        font-size: 0.95rem;
        line-height: 1.65;
        color: color-mix(in srgb, var(--color-base-content, #333) 78%, transparent);
    }

    .project-pres-panel--launch {
        background:
            radial-gradient(ellipse 80% 60% at 50% 100%, color-mix(in srgb, var(--color-primary, #6b21a8) 18%, transparent) 0%, transparent 65%),
            linear-gradient(180deg, #f8f6fc 0%, #ffffff 40%, color-mix(in srgb, var(--color-primary, #6b21a8) 5%, #f3eff8) 100%);
    }

    .project-pres-launch-card {
        border: 1px solid color-mix(in srgb, var(--color-primary, #6b21a8) 22%, #fff);
        background: linear-gradient(135deg, #ffffff 0%, color-mix(in srgb, var(--color-primary, #6b21a8) 5%, #faf8fc) 100%);
        box-shadow: 0 24px 56px -28px color-mix(in srgb, var(--color-primary, #6b21a8) 40%, transparent);
        transition: transform 0.32s ease, box-shadow 0.32s ease;
    }

    .project-pres-launch-card:hover {
        transform: translateY(-3px);
        box-shadow: 0 32px 64px -24px color-mix(in srgb, var(--color-primary, #6b21a8) 48%, transparent);
    }

    .project-pres-cta--on-dark {
        border-color: color-mix(in srgb, #fff 50%, transparent);
    }

    .project-pres-scroll-icon--on-dark {
        color: #fff;
        border-color: color-mix(in srgb, #fff 35%, transparent);
        background: color-mix(in srgb, #fff 12%, transparent);
    }

    @media (prefers-reduced-motion: reduce) {

        .project-pres-block:hover,
        .project-pres-block:hover .project-pres-icon,
        .project-pres-step:hover,
        .project-pres-pack:hover,
        .project-pres-faq-item:hover,
        .project-pres-launch-card:hover {
            transform: none;
        }

        .project-pres-reveal.is-visible .project-pres-eyebrow,
        .project-pres-reveal.is-visible .project-pres-section-lead,
        .project-pres-reveal.is-visible .project-pres-hero-tagline {
            animation: none;
        }

        .project-pres-highlight-card:hover {
            transform: none;
        }
    }