﻿/* ==========================================================
   Project Page - Structure
   1) Project Page - Design Tokens
   2) Global Page Surface + Shared Floating UI
   3) Core Page Structure (Top to Bottom)
   4) Summary Block
   5) Rich Text Content Blocks
   6) Shared Switcher Controls
   7) Layout Primitives (Reusable)
   8) Specialized Layout Variants (by appearance in project pages)
   9) Shared Interactive Cursor Hint (appears over media showcases)
   10) Optional Generic Blocks (Non-critical)
   11) Footer Overrides (Project Pages)
   12) Desktop-only Overrides
   13) Responsive - Tablet / Mobile
   ========================================================== */

/* ==========================================================
   Project Page - Design Tokens
   ========================================================== */
:root {
    /* Main page structure */
    --project-top-offset: 152px;
    --project-main-bottom-space: 100px;
    --project-main-bottom-space-mobile: 10px;

    /* Hero typography (category + page title) */
    --project-category-font: "Poppins", sans-serif;
    --project-category-size: clamp(1.2rem, 2.1vw, 2rem);
    --project-category-weight: 300;
    --project-title-font: "Poppins", sans-serif;
    --project-title-size: clamp(2.3rem, 5.6vw, 4.6rem);
    --project-title-weight: 700;

    /* Section title (H2) scaling */
    --project-h2-size-min: 1.4rem;
    --project-h2-size-fluid: 7vw;
    --project-h2-size-max: 2.2rem;

    /* Summary block spacing */
    --project-summary-gap: 50px;
    --project-summary-side-padding: 30px;
    --project-after-summary-gap: 75px;
    --project-after-summary-gap-mobile: 40px;

    /* Summary/client typography */
    --project-client-name-size: clamp(1.5rem, 2.8vw, 2.8rem);
    --project-client-name-size-mobile: 2rem;

    /* Shared CTA / switch buttons */
    --project-cta-width: 100px;
    --project-cta-height: 46px;
    --project-cta-padding-y: 10px;
    --project-cta-padding-x: 60px;
    --project-cta-gap: 20px;
    --project-cta-mobile-font-min: 1rem;
    --project-cta-mobile-font-fluid: 4.6vw;

    /* Mobile media-controls spacing */
    --project-media-controls-gap-mobile: 20px;

    /* Reusable showcase layout */
    --project-media-copy-max-width: 600px;
    --project-showcase-copy-width: 600px;
    --project-showcase-gap: clamp(56px, 6vw, 110px);

    /* Shared media visuals */
    --project-carousel-radius: 10px;
}

/* ==========================================================
   Global Page Surface + Shared Floating UI
   ========================================================== */
body {
    background-color: var(--bg-light);
}

/* ==========================================================
   Core Page Structure (Top to Bottom)
   ========================================================== */
.project-main {
    width: min(100%, var(--page-max-width));
    margin: 0 auto;
    padding-top: var(--project-top-offset);
    padding-bottom: var(--project-main-bottom-space);
}

.project-hero {
    padding-bottom: 0;
}

.project-main > .project-hero + .section-spacing {
    margin-top: var(--project-after-summary-gap);
}

.project-header {
    text-align: center;
    margin-bottom: 0;
}

.project-category {
    margin-bottom: 4px;
    font-family: var(--project-category-font);
    font-size: var(--project-category-size);
    font-weight: var(--project-category-weight);
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: var(--text-grey);
}

.project-title {
    font-family: var(--project-title-font);
    font-size: var(--project-title-size);
    font-weight: var(--project-title-weight);
    line-height: 0.98;
    letter-spacing: -0.04em;
    margin-bottom: 0;
    text-transform: uppercase;
}

/* ==========================================================
   Summary Block
   ========================================================== */
.project-summary {
    margin-top: var(--project-summary-gap);
    border-top: 1px solid var(--grey);
    border-bottom: 1px solid var(--grey);
    padding: 40px 0;
    display: grid;
    grid-template-columns: minmax(160px, 0.65fr) minmax(0, 2fr);
    gap: clamp(18px, 3vw, 44px);
    align-items: center;
}

.project-client {
    padding-left: var(--project-summary-side-padding);
}

.project-client-label {
    margin-bottom: 4px;
    font-size: 22px;
    font-weight: 400;
    line-height: 1.1;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--text-grey);
}

.project-client-name {
    font-size: var(--project-client-name-size);
    font-weight: 600;
    line-height: 1;
    letter-spacing: -0.02em;
    text-transform: uppercase;
}

.project-description {
    font-size: var(--body-size);
    font-weight: 400;
    line-height: var(--body-leading);
    text-align: justify;
    color: var(--text-on-light);
    padding-right: var(--project-summary-side-padding);
}

/* ==========================================================
   Rich Text Content Blocks
   ========================================================== */
.project-rich-copy {
    margin: 0 0 28px;
    padding-left: var(--project-summary-side-padding);
    padding-right: var(--project-summary-side-padding);
}

.project-rich-title {
    margin: 0 0 var(--title-text-space, 10px);
    font-size: clamp(var(--project-h2-size-min), var(--project-h2-size-fluid), var(--project-h2-size-max));
    line-height: 1.05;
    letter-spacing: -0.03em;
}

.project-rich-text {
    margin: 0;
    font-size: var(--body-size);
    line-height: var(--body-leading);
    text-align: justify;
    color: var(--text-on-light);
}

.project-rich-text + .project-rich-text {
    margin-top: 14px;
}

.project-video-section + .project-video-section {
    margin-top: var(--section-space);
}

.canvas-showcase + .project-video-section--text-only {
    margin-top: var(--section-space);
}

.project-video-section--text-only .project-rich-copy {
    margin-bottom: 0;
    padding-left: var(--project-summary-side-padding);
    padding-right: var(--project-summary-side-padding);
}

/* ==========================================================
   Shared Switcher Controls
   ========================================================== */
.project-switcher-actions {
    margin-top: 14px;
    display: grid;
    grid-template-columns: auto auto;
    justify-content: flex-start;
    gap: var(--project-cta-gap, 10px);
    width: fit-content;
}

.project-switcher-button {
    border: 2px solid var(--grey);
    border-radius: 999px;
    width: var(--project-cta-width, 180px);
    min-height: var(--project-cta-height, 46px);
    padding: var(--project-cta-padding-y, 10px) var(--project-cta-padding-x, 16px);
    background: var(--bg-light);
    color: var(--text-grey);
    font: inherit;
    font-size: var(--project-cta-font-size, 1rem);
    line-height: 1;
    text-transform: uppercase;
    white-space: nowrap;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: opacity 180ms ease-out, transform 180ms ease-out, background-color 180ms ease-out, border-color 180ms ease-out;
}

.project-switcher-button.is-active {
    background: var(--bg-dark);
    border-color: var(--bg-dark);
    color: var(--text-on-dark);
    cursor: default;
    opacity: 0.9;
}

.project-switcher-button:hover:not(.is-active) {
    color: var(--text-on-light);
    border-color: var(--bg-dark);
    opacity: 1;
}

.project-switcher-button:active {
    transform: translateY(1px);
}

.js-project-video-switcher.is-playing .project-switcher-button.is-active {
    background: var(--bg-dark);
    border-color: var(--bg-dark);
}

/* AXA-specific top controls */
.project-switcher-topbar {
    display: flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    gap: 24px;
    margin: 0 auto 50px;
}

.project-switcher-topbar-label {
    margin: 0;
    font-size: var(--body-size);
    line-height: var(--body-leading);
    color: var(--text-on-light);
}

.project-switcher-topbar-actions {
    margin: 0;
}

.project-video-switcher {
    --video-switcher-cta-width: auto;
    --video-switcher-cta-height: 46px;
    --video-switcher-cta-padding-y: 10px;
    --video-switcher-cta-padding-x: 26px;
    --video-switcher-cta-font-size: 24px;
}

.project-video-switcher .project-switcher-button {
    width: var(--video-switcher-cta-width);
    min-height: var(--video-switcher-cta-height);
    padding: var(--video-switcher-cta-padding-y) var(--video-switcher-cta-padding-x);
    font-size: var(--video-switcher-cta-font-size);
}

/* ==========================================================
   Layout Primitives (Reusable)
   ========================================================== */
/* Centered row: text + media */
.project-showcase-row {
    display: grid;
    grid-template-columns: minmax(0, var(--project-showcase-copy-width)) auto;
    column-gap: var(--project-showcase-gap);
    justify-content: center;
    align-items: center;
    width: fit-content;
    margin: 0 auto;
}

.project-showcase-row > * {
    min-width: 0;
}

.project-showcase-row .project-media-switcher-copy,
.project-showcase-row .project-rich-copy {
    max-width: min(100%, var(--project-showcase-copy-width));
    padding-left: 0;
    padding-right: 0;
    margin-bottom: 0;
}

.project-showcase-row .project-media-switcher-right {
    width: auto;
    min-width: 0;
    padding: 0;
    align-items: flex-start;
    justify-content: center;
    justify-self: start;
}

/* Equal columns 50/50 */
.project-layout-50-50 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: clamp(100px, 4vw, 56px);
    align-items: stretch;
}

.project-layout-50-50 > * {
    min-width: 0;
}

.project-layout-50-50 .project-media-switcher-copy,
.project-layout-50-50 .project-media-switcher-right {
    width: 100%;
    min-width: 0;
    padding: clamp(16px, 3vw, 36px) 0;
}

.project-layout-50-50 .project-media-switcher-right {
    align-items: stretch;
    justify-content: center;
}

/* Constraint + alignment helpers */
.project-layout-50-50.is-copy-constrained .project-media-switcher-copy {
    max-width: min(100%, var(--project-media-copy-max-width));
    margin-left: auto;
    margin-right: auto;
}

.project-layout-50-50.is-copy-constrained .project-media-switcher-copy .project-switcher-actions {
    width: fit-content;
    margin-left: 0;
    margin-right: auto;
}

:is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-media-switcher-copy,
:is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-rich-copy {
    text-align: right;
}

:is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-media-switcher-text,
:is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-rich-text {
    text-align: justify;
    text-align-last: right;
}

:is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-media-switcher-right {
    align-items: flex-start;
}

.project-layout-50-50.is-copy-right.is-copy-constrained .project-media-switcher-copy,
.project-layout-50-50.is-copy-right.is-copy-constrained .project-rich-copy {
    max-width: min(100%, var(--project-media-copy-max-width));
    margin-left: auto;
    margin-right: 0;
}

.project-showcase-row.is-copy-right.is-copy-constrained .project-media-switcher-copy,
.project-showcase-row.is-copy-right.is-copy-constrained .project-rich-copy {
    max-width: min(100%, var(--project-showcase-copy-width));
    margin-left: auto;
    margin-right: 0;
}

:is(.project-layout-50-50, .project-showcase-row).is-copy-right.is-copy-constrained .project-media-switcher-copy .project-switcher-actions,
:is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-switcher-actions {
    margin-top: var(--title-text-space, 10px);
    width: fit-content;
    justify-content: start;
    align-self: flex-end;
    margin-left: auto;
    margin-right: 0;
}

/* ==========================================================
   Specialized Layout Variants (by appearance in project pages)
   ========================================================== */
/* Media-switcher based sections (slot + ai video) */
.project-media-switcher-copy {
    padding: clamp(16px, 3vw, 36px) clamp(20px, 3vw, 56px);
    max-width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 100%;
}

.project-media-switcher-right {
    justify-self: stretch;
    width: 100%;
    padding: clamp(8px, 2vw, 26px) clamp(20px, 3vw, 56px);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.media-switcher-showcase {
    --project-cta-width: auto;
    --project-cta-height: 46px;
    --project-cta-padding-y: 10px;
    --project-cta-padding-x: 26px;
    --project-cta-font-size: 24px;
    --slot-media-width: 620px;
}

.media-switcher-showcase .project-showcase-row {
    grid-template-columns: minmax(0, var(--project-showcase-copy-width)) minmax(0, var(--slot-media-width));
}

.media-switcher-showcase .project-media-switcher-right {
    width: var(--slot-media-width);
    max-width: 100%;
    min-width: 0;
}

.media-switcher-showcase .project-media-switcher-copy .project-switcher-actions,
.media-switcher-showcase .project-showcase-row.is-copy-constrained .project-media-switcher-copy .project-switcher-actions {
    margin-bottom: 18px;
}

.media-switcher-showcase--4x5 {
    --ai-video-media-width: 620px;
}

.media-switcher-showcase--4x5 .project-showcase-row {
    grid-template-columns: minmax(0, var(--project-showcase-copy-width)) minmax(0, var(--ai-video-media-width));
}

.media-switcher-showcase--4x5 .project-media-switcher-right {
    width: var(--ai-video-media-width);
    max-width: 100%;
    min-width: 0;
}

.project-image-carousel-section + .media-switcher-showcase--4x5 {
    margin-top: var(--section-space);
}

/* Email showcase layout */
.email-showcase-layout {
    display: grid;
    grid-template-columns: var(--email-showcase-frame-width) var(--email-showcase-copy-width);
    gap: var(--email-showcase-gap);
    align-items: center;
    width: fit-content;
    margin: 0 auto;
}

.email-showcase-copy {
    margin: 0;
    max-width: var(--email-showcase-copy-width);
    padding-left: 0;
    padding-right: 0;
}

/* Mobile canvas / mobile device showcase layout */
:is(.canvas-showcase-layout, .mobile-showcase-layout) {
    column-gap: var(--project-showcase-gap);
    align-items: center;
}

:is(.canvas-showcase, .mobile-showcase) + :is(.canvas-showcase, .mobile-showcase) {
    margin-top: var(--section-space);
}

:is(.canvas-showcase, .mobile-showcase) .project-showcase-row {
    grid-template-columns: minmax(0, var(--project-showcase-copy-width)) minmax(0, var(--canvas-showcase-phone-width));
}

:is(.canvas-showcase, .mobile-showcase) .project-showcase-row.is-reverse {
    column-gap: var(--project-showcase-gap);
    grid-template-columns: minmax(0, var(--canvas-showcase-phone-width)) minmax(0, var(--project-showcase-copy-width));
}

:is(.canvas-showcase, .mobile-showcase) .project-showcase-row.is-reverse :is(.canvas-showcase-phone-col, .mobile-showcase-device-col) {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    justify-content: flex-start;
}

:is(.canvas-showcase, .mobile-showcase) .project-showcase-row.is-reverse :is(.canvas-showcase-copy, .mobile-showcase-copy) {
    grid-column: 2;
    grid-row: 1;
}

:is(.canvas-showcase-copy, .mobile-showcase-copy) {
    width: min(100%, var(--project-showcase-copy-width));
    max-width: min(100%, var(--project-showcase-copy-width));
    margin: 0;
    padding-left: 0;
    padding-right: 0;
}

:is(.canvas-showcase-phone-col, .mobile-showcase-device-col) {
    display: flex;
    width: min(100%, var(--canvas-showcase-phone-width));
    max-width: min(100%, var(--canvas-showcase-phone-width));
    justify-content: flex-start;
}

/* Landscape carousel switcher (shared) */
.project-video-section--text-only + .media-landscape-section {
    margin-top: 0;
}

.media-carousel-switcher-top-controls .project-switcher-topbar {
    margin-bottom: 0;
    padding-block: var(--media-carousel-switcher-top-controls-block-space, 50px);
}

.media-carousel-switcher-top-controls .project-switcher-actions {
    display: flex;
    flex-wrap: nowrap;
}

/* Uber-specific stacked / 50-50 lottie/video layout */
.project-video-section--tight-lottie .project-rich-copy {
    margin-bottom: var(--uber-logo-media-space, 28px);
}

.project-video-section--text-only + .project-video-section--after-text-media-gap {
    margin-top: var(--uber-logo-media-space, 28px);
}

.media-lottie-split {
    align-items: center;
}

.media-lottie-split .project-rich-copy {
    margin-bottom: 0;
    padding-left: 0;
    padding-right: 0;
}

.media-lottie-split--stack-left {
    align-items: center;
}

.media-lottie-split--stack-left .media-lottie-stack {
    align-self: center;
}

.media-lottie-split--stack-left .media-lottie-video-wrap {
    align-self: stretch;
    display: flex;
    padding-right: 0;
}

.media-lottie-split--stack-left .media-lottie-video-frame {
    width: 100%;
}

.media-lottie-stack {
    display: flex;
    flex-direction: column;
    gap: var(--uber-logo-media-space, 28px);
}

.media-lottie-stack .project-rich-copy {
    margin-bottom: 0;
}

.media-lottie-stack .media-lottie-frame {
    margin-left: var(--project-summary-side-padding);
}

.media-lottie-empty-col {
    min-height: 1px;
}

.media-lottie-fullwidth-stack {
    display: flex;
    flex-direction: column;
}

.media-lottie-fullwidth-stack .media-lottie-frame {
    margin: 0;
}

.media-lottie-fullwidth-stack .media-lottie-frame + .media-lottie-frame {
    margin-top: var(--uber-logo-media-space, 28px);
}

.media-lottie-video-wrap {
    width: 100%;
}

.media-lottie-video-frame {
    margin: 0;
}

.project-media-source-switcher {
    --project-cta-width: auto;
    --project-cta-height: 46px;
    --project-cta-padding-y: 10px;
    --project-cta-padding-x: 26px;
    --project-cta-font-size: 24px;
    align-self: center;
    margin-top: 0;
    margin-left: auto;
    margin-right: auto;
}

/* Booth section spacing */
.project-3d-carousel-section {
    margin-top: var(--section-space);
}

/* ==========================================================
   Shared Interactive Cursor Hint (appears over media showcases)
   ========================================================== */
.drag-cursor-hint {
    position: fixed;
    left: 0;
    top: 0;
    padding: 7px 12px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--bg-dark) 82%, transparent);
    color: var(--text-on-dark);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    line-height: 1;
    pointer-events: none;
    opacity: 0;
    transform: translate3d(-9999px, -9999px, 0);
    transition: opacity 140ms ease-out;
    z-index: 120;
}

.drag-cursor-hint.is-visible {
    opacity: 1;
}

/* ==========================================================
   Optional Generic Blocks (Non-critical)
   ========================================================== */
.project-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(14px, 2.2vw, 24px);
}

.project-block {
    background: var(--bg-light);
    border-radius: 14px;
    padding: 24px;
}

.project-block h2 {
    font-size: 1.15rem;
    margin-bottom: 10px;
}

.project-block p {
    color: var(--text-on-light);
    line-height: 1.55;
}

/* ==========================================================
   Footer Overrides (Project Pages)
   ========================================================== */
.site-footer-copy {
    color: var(--text-grey);
}

body.project-page .site-footer {
    left: 0;
    width: 100%;
    margin-bottom: 0;
    transform: none;
    background-color: var(--bg-light);
    border-radius: 0;
    padding-top: 20px;
}

body.project-page .site-footer-copy {
    color: var(--text-grey);
    opacity: 1;
    font-weight: 400;
}

/* ==========================================================
   Desktop-only Overrides
   ========================================================== */
@media (min-width: 901px) {
    .project-page[data-project-slug="ubereat_ligue1"] .media-lottie-frame {
        width: calc(100% - 150px);
        margin-left: 75px;
        margin-right: 75px;
    }

    .media-lottie-split:not(.media-lottie-split--stack-left) .project-rich-copy {
        padding-left: 0;
        padding-right: var(--project-summary-side-padding);
    }

    .media-lottie-split--stack-left .project-rich-copy {
        padding-left: var(--project-summary-side-padding);
        padding-right: 0;
        max-width: calc(100% - var(--project-summary-side-padding));
        margin-left: auto;
        text-align: right;
    }

    .media-lottie-split--stack-left .project-rich-text {
        text-align: justify;
        text-align-last: right;
    }

    .media-lottie-split--stack-left .project-switcher-actions {
        justify-content: flex-end;
    }

    .project-video-section[aria-labelledby="ubereats-20-stadiums-5050-title"] .project-switcher-actions {
        justify-content: flex-end;
    }

    .media-lottie-split--stack-left .project-media-source-switcher {
        align-self: flex-end;
        margin-left: 0;
        margin-right: var(--project-summary-side-padding);
    }

    .project-video-section[aria-labelledby="ubereats-20-stadiums-5050-title"] .project-media-source-switcher {
        margin-left: auto;
        margin-right: 0;
        align-self: flex-end;
    }
}

/* ==========================================================
   Responsive - Tablet / Mobile
   ========================================================== */
@media (max-width: 1024px) {
    :root {
        /* Tablet overrides */
        --project-top-offset: 120px;
        --project-main-bottom-space: var(--project-main-bottom-space-mobile);
    }

    .project-grid {
        grid-template-columns: 1fr;
    }

    .project-summary {
        grid-template-columns: 1fr;
        align-items: start;
    }

    .project-description {
        padding-right: 0;
    }

    .project-client {
        padding-left: 0;
    }

    .project-rich-copy {
        padding-left: 0;
        padding-right: 0;
    }

    .project-video-section--text-only .project-rich-copy {
        padding-left: 0;
        padding-right: 0;
    }

    .email-showcase-layout {
        grid-template-columns: 1fr;
        gap: 28px;
        width: 100%;
        margin: 0;
    }

    .email-showcase-preview {
        justify-self: center;
        width: min(100%, var(--email-showcase-frame-width));
    }

    .email-showcase-copy {
        max-width: 100%;
    }
}

@media (max-width: 900px) {
    .project-showcase-row {
        grid-template-columns: 1fr;
        gap: var(--project-media-controls-gap-mobile);
        width: 100%;
    }

    .project-showcase-row .project-media-switcher-copy {
        padding-top: 0;
        padding-bottom: 0;
        min-height: auto;
    }

    .project-showcase-row .project-media-switcher-right {
        width: 100%;
        padding-top: 0;
        padding-bottom: 0;
        align-items: center;
        justify-content: flex-start;
    }

    .project-layout-50-50 {
        grid-template-columns: 1fr;
        gap: var(--project-media-controls-gap-mobile);
    }

    .project-layout-50-50 .project-media-switcher-copy {
        padding: 0;
        min-height: auto;
    }

    .project-layout-50-50 .project-media-switcher-right {
        width: 100%;
        padding: 0;
        align-items: center;
        justify-content: flex-start;
    }

    .project-layout-50-50.is-copy-constrained .project-media-switcher-copy .project-switcher-actions {
        margin-left: 0;
        margin-right: 0;
        align-self: stretch;
    }

    .project-switcher-topbar {
        margin-bottom: var(--project-media-controls-gap-mobile);
    }

    .media-carousel-switcher-top-controls .project-switcher-topbar {
        padding-top: var(--project-media-controls-gap-mobile);
        padding-bottom: 0;
        margin-bottom: var(--project-media-controls-gap-mobile);
    }

    .media-switcher-showcase .project-media-switcher-copy .project-switcher-actions,
    .media-switcher-showcase .project-showcase-row.is-copy-constrained .project-media-switcher-copy .project-switcher-actions {
        margin-bottom: 0;
    }

    .email-showcase-layout {
        gap: var(--project-media-controls-gap-mobile);
    }

    .project-showcase-row.is-copy-right.is-copy-constrained :is(.project-media-switcher-copy, .project-rich-copy) {
        margin-left: 0;
        margin-right: 0;
        max-width: 100%;
    }

    .project-showcase-row :is(.project-media-switcher-copy, .project-rich-copy),
    .project-layout-50-50 :is(.project-media-switcher-copy, .project-rich-copy),
    .email-showcase-copy,
    :is(.canvas-showcase-copy, .mobile-showcase-copy) {
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        margin-right: 0;
    }

    :is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-media-switcher-copy,
    :is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-rich-copy {
        text-align: left;
    }

    :is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-media-switcher-text,
    :is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-rich-text {
        text-align: justify;
        text-align-last: auto;
    }

    :is(.project-layout-50-50, .project-showcase-row).is-copy-right .project-switcher-actions {
        align-self: stretch;
        margin-left: 0;
        margin-right: 0;
    }

    /* Shared mobile switcher behavior: full-width + stacked */
    .project-switcher-actions,
    .media-switcher-showcase .project-media-switcher-copy .project-switcher-actions,
    .media-switcher-showcase .project-media-switcher-actions.project-switcher-actions,
    .media-switcher-showcase .project-showcase-row.is-copy-right.is-copy-constrained .project-media-switcher-copy .project-switcher-actions,
    .media-carousel-switcher-top-controls .project-switcher-actions,
    .project-switcher-top-controls .project-switcher-actions {
        display: grid;
        grid-template-columns: 1fr;
        width: 100%;
        justify-content: stretch;
        justify-items: stretch;
        align-self: stretch;
        margin-left: 0;
        margin-right: 0;
    }

    .project-switcher-button,
    .project-switcher-top-controls .project-switcher-button,
    .media-switcher-showcase .project-switcher-button {
        width: 100%;
        min-width: 0;
        max-width: 100%;
        padding-left: var(--project-cta-padding-x);
        padding-right: var(--project-cta-padding-x);
        font-size: min(
            var(--project-cta-font-size, var(--video-switcher-cta-font-size, 1rem)),
            clamp(
                var(--project-cta-mobile-font-min, 1rem),
                var(--project-cta-mobile-font-fluid, 4.6vw),
                var(--project-cta-font-size, var(--video-switcher-cta-font-size, 1rem))
            )
        );
    }

    :is(.media-switcher-showcase, .media-switcher-showcase--4x5) .project-showcase-row {
        grid-template-columns: 1fr;
    }

    :is(.media-switcher-showcase, .media-switcher-showcase--4x5) .project-media-switcher-right {
        width: 100%;
    }

    :is(.canvas-showcase, .mobile-showcase) .project-showcase-row {
        grid-template-columns: 1fr;
    }

    :is(.canvas-showcase, .mobile-showcase) .project-showcase-row.is-reverse {
        display: flex;
        flex-direction: column;
        gap: 20px;
    }

    :is(.canvas-showcase-layout, .mobile-showcase-layout).is-reverse :is(.canvas-showcase-phone-col, .mobile-showcase-device-col),
    :is(.canvas-showcase-layout, .mobile-showcase-layout).is-reverse :is(.canvas-showcase-copy, .mobile-showcase-copy) {
        grid-column: auto;
        grid-row: auto;
    }

    :is(.canvas-showcase-layout, .mobile-showcase-layout).is-reverse :is(.canvas-showcase-copy, .mobile-showcase-copy) {
        order: 1;
    }

    :is(.canvas-showcase-layout, .mobile-showcase-layout).is-reverse :is(.canvas-showcase-phone-col, .mobile-showcase-device-col) {
        order: 2;
    }

    :is(.canvas-showcase-phone-col, .mobile-showcase-device-col) {
        justify-self: center;
        margin-left: auto;
        margin-right: auto;
        justify-content: center;
    }

    /* Uber mobile stacking */
    .media-lottie-stack .media-lottie-frame {
        margin-left: 0;
    }

    .media-lottie-empty-col {
        display: none;
    }

    .project-video-section[aria-labelledby="ubereats-logo-animation-title"] .media-lottie-split .project-rich-copy {
        order: 1;
    }

    .project-video-section[aria-labelledby="ubereats-logo-animation-title"] .media-lottie-split .media-lottie-frame {
        order: 2;
    }

    /* AXA mobile top controls */
    .project-switcher-topbar {
        flex-direction: column;
        align-items: center;
        width: 100%;
        gap: 14px;
    }

    .project-switcher-topbar-label {
        order: 1;
        text-align: center;
    }

    .project-switcher-top-controls .project-switcher-actions {
        order: 2;
        margin-left: 0;
        margin-right: 0;
    }

    .project-switcher-top-controls .project-switcher-button {
        width: 100%;
        min-height: var(--video-switcher-cta-height);
        padding: var(--video-switcher-cta-padding-y) var(--video-switcher-cta-padding-x);
        font-size: min(
            var(--video-switcher-cta-font-size, 1rem),
            clamp(
                var(--project-cta-mobile-font-min, 1rem),
                var(--project-cta-mobile-font-fluid, 4.6vw),
                var(--video-switcher-cta-font-size, 1rem)
            )
        );
    }
}

@media (max-width: 768px) {
    .email-showcase-copy {
        order: 1;
    }

    .email-showcase-preview {
        order: 2;
        height: var(--email-showcase-frame-height-mobile);
    }

    .email-showcase-version-switch {
        display: none;
    }
}

@media (max-width: 640px) {
    :root {
        /* Mobile overrides */
        --project-top-offset: 96px;
        --project-after-summary-gap: var(--project-after-summary-gap-mobile);
        --project-client-name-size: var(--project-client-name-size-mobile);
    }

    body.project-page .site-footer {
        left: 50%;
        width: calc(100dvw - (2 * var(--page-gutter)));
        transform: translateX(-50%);
    }

    .project-switcher-topbar-actions {
        margin-left: auto;
        margin-right: auto;
    }
}

