body.listing-l3-body {
    --mobile-l3-bg: var(--listing-l3-bg);
    --mobile-l3-text: var(--listing-l3-text);
    --mobile-l3-muted: var(--listing-l3-muted);
    --mobile-l3-card: var(--listing-l3-card);
    --mobile-l3-border: var(--listing-l3-border);
    --mobile-l3-accent: var(--listing-l3-accent);
}

body.movie-l3-body {
    --mobile-l3-bg: var(--movie-l3-bg);
    --mobile-l3-text: var(--movie-l3-text);
    --mobile-l3-muted: var(--movie-l3-muted);
    --mobile-l3-card: var(--glass-card);
    --mobile-l3-border: var(--glass-border);
    --mobile-l3-accent: var(--movie-l3-accent);
}

body.event-l3-body {
    --mobile-l3-bg: var(--event-bg);
    --mobile-l3-text: var(--event-text);
    --mobile-l3-muted: var(--event-muted);
    --mobile-l3-card: var(--glass-card);
    --mobile-l3-border: var(--glass-border);
    --mobile-l3-accent: var(--event-accent);
}

.mobile-l3-shell {
    display: none;
}

@media (max-width: 768px) {
    body.mobile-l3-render {
        background: var(--mobile-l3-bg);
        color: var(--mobile-l3-text);
        padding-bottom: calc(96px + env(safe-area-inset-bottom));
    }

    body.event-l3-body.mobile-l3-render > .event-hero-container,
    body.event-l3-body.mobile-l3-render > .vitals-section-new,
    body.event-l3-body.mobile-l3-render > .event-l3-main {
        display: none !important;
    }

    .mobile-l3-shell {
        position: relative;
        display: block;
        width: min(100%, 520px);
        margin: 0 auto;
        padding: 0 14px calc(112px + env(safe-area-inset-bottom));
        box-sizing: border-box;
    }

    .mobile-l3-hero {
        margin: 0 -14px 18px;
        background: var(--mobile-l3-bg);
        border-bottom: 1px solid var(--mobile-l3-border);
    }

    .mobile-l3-hero-image {
        position: relative;
        overflow: hidden;
        background: color-mix(in srgb, var(--mobile-l3-accent) 10%, transparent);
        aspect-ratio: 1.45 / 1;
    }

    .mobile-l3-page-back {
        position: fixed;
        top: calc(16px + env(safe-area-inset-top));
        left: 1.2rem;
        z-index: 12000;
        width: 42px;
        height: 42px;
        min-width: 42px;
        border-radius: 50%;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 46%, transparent);
        background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%));
        color: #ffffff;
        -webkit-text-fill-color: #ffffff;
        text-decoration: none;
        box-shadow: var(--cd-soft-glow, 0 10px 24px rgba(255, 94, 0, 0.30), 0 0 16px rgba(255, 215, 0, 0.14));
        backdrop-filter: blur(18px) saturate(160%);
        -webkit-backdrop-filter: blur(18px) saturate(160%);
        box-sizing: border-box;
    }

    .mobile-l3-page-back span {
        display: none;
    }

    .mobile-l3-page-back::before {
        content: "\f053";
        font-family: "Font Awesome 6 Free";
        font-size: 1.04rem;
        font-weight: 900;
        line-height: 1;
        color: #ffffff;
        -webkit-text-fill-color: #ffffff;
    }

    body.light-mode .mobile-l3-page-back {
        border-color: color-mix(in srgb, var(--mobile-l3-accent) 46%, transparent);
        background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%));
        color: #ffffff;
        -webkit-text-fill-color: #ffffff;
    }

    .mobile-l3-page-back:focus-visible {
        outline: 3px solid color-mix(in srgb, var(--mobile-l3-accent) 68%, transparent);
        outline-offset: 3px;
    }

    .mobile-l3-hero-image img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .mobile-l3-image-badge {
        position: absolute;
        left: 18px;
        bottom: 18px;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        min-height: 38px;
        padding: 0 16px;
        border-radius: 999px;
        background: var(--cd-accent-gradient, linear-gradient(135deg, var(--mobile-l3-accent), var(--mobile-l3-accent)));
        color: var(--cd-theme-ink-on-solid, #ffffff);
        font-size: 0.78rem;
        font-weight: 950;
        letter-spacing: 0.1em;
        text-transform: uppercase;
    }

    .mobile-l3-title-block {
        padding: 20px 18px 22px;
    }

    .mobile-l3-eyebrow {
        margin: 0 0 8px;
        color: var(--mobile-l3-accent);
        font-size: 0.78rem;
        font-weight: 950;
        letter-spacing: 0.12em;
        text-transform: uppercase;
    }

    .mobile-l3-title {
        margin: 0;
        color: var(--mobile-l3-text);
        font-size: clamp(1.75rem, 8vw, 2.45rem);
        line-height: 1.04;
        font-weight: 950;
        letter-spacing: 0;
    }

    .mobile-l3-subtitle {
        margin: 10px 0 0;
        color: var(--mobile-l3-muted);
        font-size: 0.98rem;
        line-height: 1.42;
        font-weight: 650;
    }

    .mobile-l3-action-row,
    .mobile-l3-date-tabs {
        display: flex;
        gap: 10px;
        overflow-x: auto;
        padding: 2px 0 16px;
        scrollbar-width: none;
    }

    .mobile-l3-action-row::-webkit-scrollbar,
    .mobile-l3-date-tabs::-webkit-scrollbar {
        display: none;
    }

    .mobile-l3-action {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 9px;
        flex: 0 0 auto;
        min-height: 44px;
        padding: 0 16px;
        border-radius: 999px;
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 32%, transparent);
        background: color-mix(in srgb, var(--mobile-l3-accent) 12%, var(--mobile-l3-card));
        color: var(--mobile-l3-text);
        text-decoration: none;
        font-size: 0.86rem;
        font-weight: 900;
        box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
        transition-property: transform, background-color, border-color, box-shadow, color;
        transition-duration: 150ms;
        transition-timing-function: ease;
        -webkit-tap-highlight-color: transparent;
    }

    .mobile-l3-action i {
        font-size: 1.06rem;
        line-height: 1;
    }

    .mobile-l3-action.primary {
        background: var(--cd-accent-gradient, linear-gradient(135deg, var(--mobile-l3-accent), var(--mobile-l3-accent)));
        color: var(--cd-theme-ink-on-solid, #ffffff);
        border-color: transparent;
    }

    .mobile-l3-action:active,
    .mobile-l3-action[data-l3-processing="true"] {
        transform: scale(0.96);
        border-color: color-mix(in srgb, var(--mobile-l3-accent) 50%, var(--mobile-l3-border));
        background-color: color-mix(in srgb, var(--mobile-l3-accent) 14%, var(--mobile-l3-card));
        box-shadow: 0 5px 12px rgba(0, 0, 0, 0.10);
    }

    .mobile-l3-action:focus-visible,
    .listing-mobile-l3-share-actions .listing-l3-share-button:focus-visible {
        outline: 2px solid var(--mobile-l3-accent);
        outline-offset: 3px;
    }

    .listing-mobile-l3-shell .listing-mobile-l3-contact-actions {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px;
        overflow: visible;
        padding: 2px 0 16px;
    }

    .listing-mobile-l3-contact-actions .mobile-l3-action {
        width: 100%;
        min-width: 0;
        min-height: 48px;
        padding: 0 9px;
        gap: 7px;
        font-size: 0.78rem;
        white-space: nowrap;
    }

    .listing-mobile-l3-contact-actions.no-website .mobile-l3-action:first-child {
        grid-column: 2;
    }

    .listing-mobile-l3-contact-actions.no-website .mobile-l3-action:nth-child(2) {
        grid-column: 3;
    }

    .listing-mobile-l3-secondary-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        align-items: stretch;
        gap: 10px;
        overflow: visible;
        padding-bottom: 0;
    }

    .listing-mobile-l3-secondary-actions .listing-l3-share-panel {
        grid-column: 1 / -1;
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
        padding: 12px;
    }

    .listing-mobile-l3-secondary-actions .listing-l3-share-head {
        margin-bottom: 10px;
    }

    .listing-mobile-l3-secondary-actions .listing-l3-share-grid {
        grid-template-columns: repeat(5, minmax(38px, 1fr));
        gap: 8px;
    }

    .listing-mobile-l3-secondary-actions .listing-l3-copy-link {
        width: 48px;
        min-width: 48px;
        height: 48px;
        border-radius: 16px;
    }

    .listing-mobile-l3-secondary-actions .listing-l3-share-grid .listing-l3-share-button {
        width: 100%;
        min-width: 0;
        height: 48px;
        border-radius: 16px;
    }

    .listing-mobile-l3-secondary-actions .listing-l3-copy-link i,
    .listing-mobile-l3-secondary-actions .listing-l3-share-button i {
        font-size: 1.18rem;
        line-height: 1;
    }

    .listing-mobile-l3-secondary-actions > .mobile-l3-action {
        width: 100%;
        min-width: 0;
        min-height: 54px;
        box-sizing: border-box;
        padding: 0 12px;
    }

    .listing-mobile-l3-secondary-actions > .mobile-l3-action:only-of-type {
        grid-column: 1 / -1;
    }

    .listing-mobile-l3-actions-card {
        --listing-mobile-l3-tile-bg: rgba(255, 255, 255, 0.96);
        --listing-mobile-l3-tile-text: #261a16;
        --listing-mobile-l3-tile-muted: rgba(38, 26, 22, 0.66);
        display: grid;
        gap: 18px;
        padding: 20px;
        background: color-mix(in srgb, var(--mobile-l3-card) 86%, #ffffff 14%);
        box-shadow: 0 14px 34px rgba(18, 15, 12, 0.08);
    }

    .listing-mobile-l3-actions-card > h2 {
        margin-bottom: 0;
    }

    .listing-mobile-l3-action-group {
        display: grid;
        gap: 10px;
    }

    .listing-mobile-l3-action-group h3 {
        margin: 0;
        color: var(--mobile-l3-text);
        font-size: 0.82rem;
        line-height: 1.2;
        font-weight: 950;
        letter-spacing: 0;
        text-transform: uppercase;
    }

    .listing-mobile-l3-share-actions .listing-l3-share-panel {
        width: 100%;
        min-width: 0;
        box-sizing: border-box;
        padding: 0;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    .listing-mobile-l3-share-actions .listing-l3-share-head {
        display: none;
    }

    .listing-mobile-l3-share-actions .listing-l3-share-grid {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 8px;
    }

    .listing-mobile-l3-share-actions .listing-l3-share-button {
        width: 100%;
        min-width: 0;
        height: 66px;
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 6px;
        padding: 8px 5px;
        border-radius: 16px;
        border: 1px solid rgba(38, 26, 22, 0.10);
        background: var(--listing-mobile-l3-tile-bg);
        color: var(--listing-mobile-l3-tile-text);
        box-shadow: 0 8px 20px rgba(18, 15, 12, 0.07);
    }

    .listing-mobile-l3-share-actions .listing-l3-share-button i {
        color: var(--mobile-l3-accent);
        font-size: 1.18rem;
        line-height: 1;
    }

    .listing-mobile-l3-share-actions .listing-l3-share-label {
        display: block;
        max-width: 100%;
        color: var(--listing-mobile-l3-tile-muted);
        font-size: 0.68rem;
        line-height: 1;
        font-weight: 900;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }

    .listing-mobile-l3-share-actions .listing-l3-share-button:active,
    .listing-mobile-l3-share-actions .listing-l3-share-button[data-l3-processing="true"] {
        transform: scale(0.96);
        border-color: color-mix(in srgb, var(--mobile-l3-accent) 34%, rgba(38, 26, 22, 0.10));
        background-color: color-mix(in srgb, var(--mobile-l3-accent) 8%, #ffffff);
        box-shadow: 0 4px 12px rgba(18, 15, 12, 0.09);
    }

    .listing-mobile-l3-manage-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        overflow: visible;
        padding: 0;
    }

    .listing-mobile-l3-manage-actions.mobile-l3-action-row {
        display: grid;
        overflow: visible;
        padding: 0;
    }

    .listing-mobile-l3-manage-actions > .mobile-l3-action {
        width: 100%;
        min-width: 0;
        min-height: 68px;
        flex-direction: column;
        gap: 7px;
        padding: 10px 8px;
        border-radius: 18px;
        border: 1px solid rgba(38, 26, 22, 0.10);
        background: var(--listing-mobile-l3-tile-bg);
        color: var(--listing-mobile-l3-tile-text);
        box-shadow: 0 9px 22px rgba(18, 15, 12, 0.08);
        font-size: 0.82rem;
        line-height: 1.08;
        text-align: center;
    }

    .listing-mobile-l3-manage-actions > .mobile-l3-action i {
        color: var(--mobile-l3-accent);
        font-size: 1.16rem;
    }

    .listing-mobile-l3-manage-actions > .listing-mobile-l3-important-action {
        border-color: color-mix(in srgb, var(--mobile-l3-accent) 26%, rgba(38, 26, 22, 0.10));
        box-shadow: 0 11px 26px color-mix(in srgb, var(--mobile-l3-accent) 14%, rgba(18, 15, 12, 0.08));
    }

    .listing-mobile-l3-manage-actions > .listing-mobile-l3-report-action {
        grid-column: 1 / -1;
        min-height: 54px;
        flex-direction: row;
        justify-content: center;
        text-align: center;
        padding: 0 16px;
        border-color: rgba(187, 48, 48, 0.22);
        background: rgba(255, 255, 255, 0.94);
        color: #7f2b2b;
        box-shadow: none;
    }

    .listing-mobile-l3-manage-actions > .listing-mobile-l3-report-action i {
        color: #b43a3a;
    }

    .mobile-l3-facts {
        display: grid;
        gap: 10px;
        margin: 0 0 18px;
    }

    .mobile-l3-fact {
        display: grid;
        grid-template-columns: 54px minmax(0, 1fr);
        gap: 13px;
        align-items: center;
        min-height: 74px;
        padding: 12px 14px;
        border: 1px solid var(--mobile-l3-border);
        border-radius: 20px;
        background: var(--mobile-l3-card);
    }

    .mobile-l3-fact-link {
        color: inherit;
        text-decoration: none;
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
    }

    .mobile-l3-fact-link:focus-visible {
        outline: 2px solid var(--mobile-l3-accent);
        outline-offset: 3px;
    }

    .mobile-l3-fact-link:active {
        border-color: color-mix(in srgb, var(--mobile-l3-accent) 54%, var(--mobile-l3-border));
        background: color-mix(in srgb, var(--mobile-l3-accent) 8%, var(--mobile-l3-card));
    }

    .mobile-l3-fact i {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 52px;
        height: 52px;
        border-radius: 16px;
        background: color-mix(in srgb, var(--mobile-l3-accent) 15%, transparent);
        color: var(--mobile-l3-accent);
        font-size: 1.2rem;
    }

    .mobile-l3-fact span {
        display: block;
        margin: 0 0 4px;
        color: var(--mobile-l3-accent);
        font-size: 0.72rem;
        font-weight: 950;
        letter-spacing: 0.12em;
        text-transform: uppercase;
    }

    .mobile-l3-fact strong {
        display: block;
        color: var(--mobile-l3-text);
        font-size: 1.08rem;
        line-height: 1.2;
        font-weight: 900;
        overflow-wrap: anywhere;
    }

    .mobile-l3-card {
        margin: 0 0 14px;
        padding: 18px;
        border: 1px solid var(--mobile-l3-border);
        border-radius: 22px;
        background: var(--mobile-l3-card);
    }

    .mobile-l3-card h2 {
        margin: 0 0 12px;
        color: var(--mobile-l3-text);
        font-size: 1.18rem;
        line-height: 1.18;
        font-weight: 950;
        letter-spacing: 0;
    }

    .mobile-l3-card p,
    .mobile-l3-rich-text {
        margin: 0;
        color: var(--mobile-l3-muted);
        font-size: 0.98rem;
        line-height: 1.58;
    }

    .mobile-l3-rich-text :is(ol, ul) {
        margin: 0.35em 0 0;
        padding-inline-start: 1.25em;
    }

    .mobile-l3-rich-text li {
        margin: 0.2em 0;
        overflow-wrap: anywhere;
    }

    .event-mobile-l3-shell .event-mobile-l3-terms-text {
        font-size: 0.86rem;
        line-height: 1.5;
    }

    .mobile-l3-distance {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        margin-top: 10px;
        color: var(--mobile-l3-accent);
        font-size: 0.9rem;
        font-weight: 900;
    }

    .mobile-l3-location-card {
        position: relative;
    }

    .listing-mobile-l3-location-card {
        display: grid;
        gap: 14px;
        padding: 20px;
        box-shadow: 0 14px 34px rgba(18, 15, 12, 0.08);
    }

    .listing-mobile-l3-location-head {
        display: grid;
        grid-template-columns: 48px minmax(0, 1fr);
        gap: 12px;
        align-items: start;
    }

    .listing-mobile-l3-location-marker {
        display: inline-grid;
        width: 48px;
        height: 48px;
        place-items: center;
        border-radius: 16px;
        color: var(--mobile-l3-accent);
        background: color-mix(in srgb, var(--mobile-l3-accent) 12%, #ffffff);
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 22%, transparent);
        box-shadow: 0 8px 20px color-mix(in srgb, var(--mobile-l3-accent) 12%, transparent);
    }

    .listing-mobile-l3-location-title-row {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 8px;
        margin-bottom: 6px;
    }

    .listing-mobile-l3-location-title-row h2 {
        flex: 1 1 auto;
        min-width: 0;
        margin: 0;
        text-wrap: balance;
    }

    .listing-mobile-l3-location-title-row .listing-mobile-l3-location-distance {
        flex: 0 0 auto;
        margin: 0;
        align-self: flex-start;
        min-height: 24px;
        padding: 0 8px;
        font-size: 0.72rem;
        gap: 5px;
    }

    .listing-mobile-l3-location-title-row .listing-mobile-l3-location-distance i {
        font-size: 0.68rem;
    }

    .listing-mobile-l3-address {
        color: var(--mobile-l3-text);
        font-size: 1rem;
        line-height: 1.45;
        font-weight: 760;
        text-wrap: pretty;
    }

    .event-mobile-l3-shell .mobile-l3-location-card .event-mobile-l3-venue-name {
        margin: 0;
        font-size: 1.06rem;
        font-weight: 900;
    }

    .event-mobile-l3-shell .mobile-l3-location-card .event-mobile-l3-venue-address {
        margin: 6px 0 0;
        font-weight: 800;
    }

    .mobile-l3-location-distance,
    .listing-mobile-l3-location-distance {
        position: static;
        justify-self: start;
        display: inline-flex;
        align-items: center;
        gap: 7px;
        min-height: 32px;
        max-width: 100%;
        padding: 0 11px;
        border-radius: 999px;
        background: color-mix(in srgb, var(--mobile-l3-accent) 9%, #ffffff);
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 18%, transparent);
        color: var(--mobile-l3-accent);
        font-size: 0.78rem;
        line-height: 1;
        font-weight: 900;
        white-space: nowrap;
        box-shadow: none;
    }

    .listing-mobile-l3-map-action-row {
        padding-top: 2px;
    }

    .listing-mobile-l3-map-action {
        width: 100%;
        min-height: 52px;
        border-radius: 16px;
        box-shadow: 0 12px 26px color-mix(in srgb, var(--mobile-l3-accent) 22%, transparent);
    }

    .listing-mobile-l3-map-helper {
        color: var(--mobile-l3-muted);
        font-size: 0.78rem;
        font-weight: 750;
        text-align: center;
    }

    .mobile-l3-chip-row {
        display: flex;
        flex-wrap: wrap;
        gap: 8px;
        margin-top: 14px;
    }

    .mobile-l3-chip-row span {
        display: inline-flex;
        align-items: center;
        min-height: 30px;
        padding: 0 11px;
        border-radius: 999px;
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 28%, transparent);
        color: var(--mobile-l3-text);
        background: color-mix(in srgb, var(--mobile-l3-accent) 10%, transparent);
        font-size: 0.75rem;
        font-weight: 850;
    }

    .listing-mobile-l3-photos-card .listing-l3-photo-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 9px;
    }

    .listing-mobile-l3-photos-card .listing-l3-photo-tile {
        border-radius: 16px;
        aspect-ratio: 1 / 1;
    }

    .mobile-l3-date-tabs .nav-pill {
        flex: 0 0 78px;
        min-height: 92px;
        padding: 10px 8px;
        border-radius: 16px;
    }

    .movie-mobile-l3-shell .mobile-l3-date-tabs {
        gap: var(--home-rail-gap, 6px);
        padding-bottom: var(--home-rail-gap, 6px);
    }

    .movie-mobile-l3-shell .mobile-l3-date-tabs .nav-pill {
        display: grid;
        grid-template-rows: auto 1fr auto;
        align-items: center;
        justify-items: center;
        flex: 0 0 80px;
        min-height: 102px;
        padding: 10px 6px;
        border: 1.5px solid color-mix(in srgb, var(--mobile-l3-accent) 34%, var(--mobile-l3-border));
        border-radius: 17px;
        background: color-mix(in srgb, var(--mobile-l3-accent) 8%, var(--mobile-l3-card));
        color: var(--mobile-l3-text);
        box-shadow: none;
    }

    .movie-mobile-l3-shell .mobile-l3-date-tabs .nav-pill.active {
        border-color: transparent;
        background: var(--cd-accent-gradient, linear-gradient(135deg, var(--mobile-l3-accent), var(--mobile-l3-accent)));
        color: var(--cd-theme-ink-on-solid, #ffffff);
        box-shadow: 0 14px 30px color-mix(in srgb, var(--mobile-l3-accent) 24%, transparent);
    }

    .movie-date-tab-month,
    .movie-date-tab-weekday {
        color: currentColor;
        font-size: 0.78rem;
        font-weight: 950;
        letter-spacing: 0.12em;
    }

    .movie-date-tab-day {
        color: currentColor;
        font-size: 2.7rem;
        line-height: 0.95;
        font-weight: 950;
    }

    .mobile-l3-showtime-list {
        display: grid;
        gap: 12px;
        min-width: 0;
    }

    .mobile-l3-theatre-card,
    .mobile-l3-ticket-row {
        min-width: 0;
        overflow: hidden;
        padding: 14px;
        border: 1px solid var(--mobile-l3-border);
        border-radius: 18px;
        background: color-mix(in srgb, var(--mobile-l3-card) 84%, transparent);
    }

    .mobile-l3-theatre-head {
        display: grid;
        grid-template-columns: minmax(58px, 20%) minmax(0, 1fr);
        gap: 12px;
        align-items: center;
    }

    .mobile-l3-theatre-icon {
        display: inline-flex;
        align-items: center;
        justify-content: center;
        width: 50px;
        height: 50px;
        border-radius: 999px;
        justify-self: center;
        background: color-mix(in srgb, var(--mobile-l3-accent) 12%, var(--mobile-l3-card));
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 30%, transparent);
        color: var(--mobile-l3-accent);
        font-size: 1.05rem;
        overflow: hidden;
    }

    .mobile-l3-theatre-icon img {
        display: block;
        width: 100%;
        height: 100%;
        object-fit: cover;
    }

    .mobile-l3-theatre-copy {
        min-width: 0;
    }

    .mobile-l3-theatre-title-row {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 8px;
        margin-bottom: 6px;
    }

    .mobile-l3-theatre-card h3,
    .mobile-l3-ticket-row strong {
        margin: 0 0 6px;
        color: var(--mobile-l3-text);
        font-size: 1rem;
        line-height: 1.22;
        font-weight: 950;
    }

    .mobile-l3-theatre-title-row h3 {
        flex: 1 1 auto;
        min-width: 0;
        margin: 0;
    }

    .mobile-l3-theatre-card p,
    .mobile-l3-ticket-row span {
        display: block;
        margin: 0 0 10px;
        color: var(--mobile-l3-muted);
        font-size: 0.86rem;
        line-height: 1.35;
        overflow-wrap: anywhere;
    }

    .mobile-l3-theatre-left-col .mobile-l3-theatre-distance {
        flex: 0 0 auto;
        margin: 0;
        align-self: center;
        min-height: 24px;
        padding: 0 10px;
        font-size: 0.72rem;
        gap: 5px;
        background: rgba(255, 255, 255, 0.06) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
        color: var(--mobile-l3-muted) !important;
        font-weight: 750 !important;
        border-radius: 999px !important;
    }

    body.light-mode.movie-l3-body .mobile-l3-theatre-left-col .mobile-l3-theatre-distance {
        background: rgba(0, 0, 0, 0.04) !important;
        border: 1px solid rgba(0, 0, 0, 0.03) !important;
        color: var(--mobile-l3-muted) !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-left-col .mobile-l3-theatre-distance {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 3px !important;
        background: rgba(255, 94, 0, 0.06) !important;
        border: 1px solid rgba(255, 94, 0, 0.15) !important;
        color: var(--mobile-l3-accent) !important;
        font-size: 0.65rem !important;
        font-weight: 700 !important;
        padding: 3px 6px !important;
        border-radius: 6px !important;
        line-height: 1.1 !important;
        min-height: 20px !important;
        box-sizing: border-box !important;
        white-space: nowrap !important;
        width: 100% !important;
        max-width: 54px !important;
    }

    body.light-mode.movie-l3-body .movie-mobile-l3-shell .mobile-l3-theatre-left-col .mobile-l3-theatre-distance {
        background: rgba(255, 94, 0, 0.06) !important;
        border: 1px solid rgba(255, 94, 0, 0.15) !important;
        color: var(--mobile-l3-accent) !important;
    }

    .mobile-l3-theatre-left-col .mobile-l3-theatre-distance i {
        font-size: 0.6rem !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-card .showtime-chips {
        display: grid !important;
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
        gap: 8px !important;
        margin-top: 18px !important;
        padding-top: 18px !important;
        padding-bottom: 2px !important;
        border-top: 1px dashed rgba(255, 255, 255, 0.1) !important;
        min-width: 0 !important;
        max-width: 100% !important;
        overflow: hidden !important;
    }

    body.light-mode.movie-l3-body .movie-mobile-l3-shell .mobile-l3-theatre-card .showtime-chips {
        border-top: 1px dashed rgba(0, 0, 0, 0.08) !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-card .showtime-chip {
        box-sizing: border-box !important;
        min-width: 0 !important;
        max-width: 100% !important;
        width: 100% !important;
        min-height: 38px !important;
        padding: 0 6px !important;
        border-radius: 12px !important;
        font-size: 0.82rem !important;
        line-height: 1 !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        background: rgba(255, 255, 255, 0.06) !important;
        border: 1px solid rgba(255, 255, 255, 0.04) !important;
        color: #e8e8ed !important;
        font-weight: 600 !important;
        font-variant-numeric: tabular-nums !important;
    }

    body.light-mode.movie-l3-body .movie-mobile-l3-shell .mobile-l3-theatre-card .showtime-chip {
        background: #f5f5f7 !important;
        border: 1px solid rgba(0, 0, 0, 0.04) !important;
        color: #1d1d1f !important;
    }

    .movie-mobile-l3-shell .showtime-language-groups {
        margin-top: 18px !important;
        padding-top: 18px !important;
        border-top: 1px dashed rgba(255, 255, 255, 0.08) !important;
    }

    body.light-mode.movie-l3-body .movie-mobile-l3-shell .showtime-language-groups {
        border-top: 1px dashed rgba(0, 0, 0, 0.06) !important;
    }

    .movie-mobile-l3-shell .showtime-language-group {
        margin-top: 16px !important;
    }

    .movie-mobile-l3-shell .showtime-language-group:first-child {
        margin-top: 0 !important;
    }

    .movie-mobile-l3-shell .showtime-language-label {
        font-size: 0.72rem !important;
        font-weight: 700 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.05em !important;
        color: var(--mobile-l3-muted) !important;
        margin-bottom: 8px !important;
    }

    .movie-mobile-l3-shell .showtime-language-group .showtime-chips {
        margin-top: 6px !important;
        padding-top: 0 !important;
        border-top: 0 !important;
    }

    .mobile-l3-theatre-actions {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 10px;
        align-items: stretch;
        margin-top: 18px;
        padding-top: 18px;
        border-top: 1px dashed rgba(255, 255, 255, 0.08);
        min-width: 0;
    }

    body.light-mode.movie-l3-body .mobile-l3-theatre-actions {
        border-top: 1px dashed rgba(0, 0, 0, 0.06);
    }

    .mobile-l3-theatre-actions .mobile-l3-action {
        box-sizing: border-box;
        display: flex;
        align-items: center;
        justify-content: center;
        flex: none;
        width: 100%;
        max-width: 100%;
        min-width: 0;
        min-height: 42px;
        padding: 0 10px;
        gap: 6px;
        border-radius: 30px !important;
        font-size: 0.82rem !important;
        font-weight: 600 !important;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
        background: rgba(255, 255, 255, 0.05) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        color: #ffffff !important;
        box-shadow: none !important;
        transition: all 0.2s ease !important;
    }

    .mobile-l3-theatre-actions .mobile-l3-action i {
        color: var(--mobile-l3-accent) !important;
        font-size: 0.88rem !important;
        flex: 0 0 auto;
    }

    body.light-mode.movie-l3-body .mobile-l3-theatre-actions .mobile-l3-action {
        background: #ffffff !important;
        border: 1px solid rgba(0, 0, 0, 0.08) !important;
        color: #1d1d1f !important;
        box-shadow: 0 2px 6px rgba(0, 0, 0, 0.03) !important;
    }

    .mobile-l3-theatre-actions .mobile-l3-action:active {
        transform: scale(0.96) !important;
        background: rgba(255, 255, 255, 0.1) !important;
        border-color: rgba(255, 255, 255, 0.15) !important;
    }

    body.light-mode.movie-l3-body .mobile-l3-theatre-actions .mobile-l3-action:active {
        background: #f5f5f7 !important;
        border-color: rgba(0, 0, 0, 0.12) !important;
    }

    .mobile-l3-theatre-action-placeholder {
        visibility: hidden;
    }

    .event-mobile-l3-shell .mobile-l3-hero-image,
    .movie-mobile-l3-shell .mobile-l3-hero-image {
        aspect-ratio: auto;
        min-height: 0;
        background: color-mix(in srgb, var(--mobile-l3-accent) 12%, #111);
    }

    .event-mobile-l3-shell .mobile-l3-hero-image img,
    .movie-mobile-l3-shell .mobile-l3-hero-image img {
        width: 100%;
        height: auto;
        object-fit: contain;
    }

    /* Movie, listing, and event L3: match home feed edge rhythm (5px sides, 6px section gaps) */
    .mobile-l3-shell:is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) {
        --home-edge: 5px;
        --home-rail-gap: 6px;
        padding-left: var(--home-edge);
        padding-right: var(--home-edge);
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-hero {
        margin-left: calc(-1 * var(--home-edge));
        margin-right: calc(-1 * var(--home-edge));
        margin-bottom: var(--home-rail-gap);
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-image-badge {
        left: var(--home-edge);
        bottom: var(--home-edge);
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-title-block {
        padding: 12px var(--home-edge) 14px;
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-facts {
        gap: var(--home-rail-gap);
        margin-bottom: var(--home-rail-gap);
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-fact {
        padding: 10px 8px;
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-card {
        margin-bottom: var(--home-rail-gap);
        padding: 10px;
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .mobile-l3-card h2 {
        margin-bottom: 8px;
    }

    .listing-mobile-l3-shell .listing-mobile-l3-contact-actions {
        gap: var(--home-rail-gap);
        padding: 2px 0 var(--home-rail-gap);
    }

    .listing-mobile-l3-shell .listing-mobile-l3-location-card {
        gap: var(--home-rail-gap);
        padding: 10px;
    }

    .movie-mobile-l3-shell .mobile-l3-showtime-list {
        gap: 16px;
        margin-top: 24px;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-card {
        padding: 20px;
        border-radius: 24px;
        background: linear-gradient(180deg, rgba(255, 255, 255, 0.065) 0%, rgba(255, 255, 255, 0.035) 100%) !important;
        border: 1px solid rgba(255, 255, 255, 0.08) !important;
        box-shadow: 
            0 1px 3px rgba(0, 0, 0, 0.4), 
            0 8px 16px rgba(0, 0, 0, 0.35), 
            0 20px 40px rgba(0, 0, 0, 0.5),
            inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
    }

    body.light-mode.movie-l3-body .movie-mobile-l3-shell .mobile-l3-theatre-card {
        background: linear-gradient(180deg, #ffffff 0%, #fbfbfd 100%) !important;
        border: 1px solid rgba(0, 0, 0, 0.05) !important;
        box-shadow: 
            0 1px 3px rgba(0, 0, 0, 0.01), 
            0 8px 16px rgba(0, 0, 0, 0.02), 
            0 16px 32px rgba(0, 0, 0, 0.03), 
            0 24px 48px rgba(0, 0, 0, 0.03),
            inset 0 1px 0 rgba(255, 255, 255, 0.6) !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-icon {
        width: 46px !important;
        height: 46px !important;
        border-radius: 12px !important;
        background: rgba(255, 255, 255, 0.05) !important;
        border: 1px solid rgba(255, 255, 255, 0.1) !important;
    }

    body.light-mode.movie-l3-body .movie-mobile-l3-shell .mobile-l3-theatre-icon {
        background: #f8f9fa !important;
        border: 1px solid rgba(0, 0, 0, 0.05) !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-card h3 {
        font-size: 1.05rem !important;
        font-weight: 700 !important;
        letter-spacing: -0.015em !important;
        margin-bottom: 4px !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-card p {
        font-size: 0.82rem !important;
        line-height: 1.4 !important;
        margin: 0 !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-head {
        display: grid !important;
        grid-template-columns: 68px minmax(0, 1fr) !important;
        gap: 16px !important;
        align-items: stretch !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-left-col {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: flex-start !important;
        gap: 8px !important;
        padding-right: 14px !important;
        border-right: 1px solid var(--mobile-l3-border) !important;
        flex: 0 0 68px !important;
        box-sizing: border-box !important;
    }

    .movie-mobile-l3-shell .mobile-l3-theatre-right-col {
        display: flex !important;
        flex-direction: column !important;
        justify-content: flex-start !important;
        min-width: 0 !important;
        flex: 1 1 0% !important;
        padding-top: 2px !important;
    }

    .event-mobile-l3-shell .event-mobile-ticket-card {
        margin: 0 0 var(--home-rail-gap);
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .listing-mobile-l3-actions-card {
        --listing-mobile-l3-tile-bg: rgba(255, 255, 255, 0.96);
        --listing-mobile-l3-tile-text: #261a16;
        --listing-mobile-l3-tile-muted: rgba(38, 26, 22, 0.66);
        display: grid;
        gap: 12px;
        padding: 12px;
        background: color-mix(in srgb, var(--mobile-l3-card) 86%, #ffffff 14%);
        box-shadow: 0 14px 34px rgba(18, 15, 12, 0.08);
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .listing-mobile-l3-actions-card > h2 {
        margin-bottom: 0;
    }

    :is(.movie-mobile-l3-shell, .listing-mobile-l3-shell, .event-mobile-l3-shell) .listing-mobile-l3-share-actions .listing-l3-share-panel {
        padding: 0;
        border: 0;
        background: transparent;
        box-shadow: none;
    }

    :is(.movie-mobile-l3-shell, .event-mobile-l3-shell) .listing-mobile-l3-manage-actions > .mobile-l3-action:only-child {
        grid-column: 1 / -1;
    }

    .event-mobile-ticket-card {
        margin: 0 0 14px;
        padding: 28px 18px 24px;
        border: 1px solid color-mix(in srgb, var(--mobile-l3-text) 14%, transparent);
        border-radius: 28px;
        background:
            radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--mobile-l3-accent) 16%, transparent), transparent 34%),
            linear-gradient(145deg, #1f1f1f, #0b0b0b);
        color: #fff;
        box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
    }

    body.light-mode .event-mobile-ticket-card {
        border-color: color-mix(in srgb, var(--mobile-l3-accent) 24%, var(--mobile-l3-border));
        background:
            radial-gradient(circle at 50% 0%, color-mix(in srgb, var(--mobile-l3-accent) 16%, transparent), transparent 34%),
            linear-gradient(145deg, #ffffff, #f5f2ed);
        color: var(--mobile-l3-text);
    }

    .event-mobile-price {
        margin: 4px 0 28px;
        color: currentColor;
        text-align: center;
        font-size: 4.4rem;
        line-height: 0.95;
        font-weight: 950;
    }

    .event-mobile-booking-label {
        margin: 0 0 14px;
        color: var(--mobile-l3-accent);
        text-align: center;
        font-size: 0.78rem;
        font-weight: 950;
        letter-spacing: 0.14em;
        text-transform: uppercase;
    }

    .event-mobile-countdown {
        display: grid;
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 10px;
        max-width: 330px;
        margin: 0 auto 24px;
    }

    .event-mobile-countdown span {
        display: grid;
        gap: 6px;
        min-height: 78px;
        place-content: center;
        border: 1px solid rgba(255, 255, 255, 0.16);
        border-radius: 16px;
        background: rgba(255, 255, 255, 0.08);
        text-align: center;
    }

    body.light-mode .event-mobile-countdown span {
        border-color: color-mix(in srgb, var(--mobile-l3-text) 16%, transparent);
        background: rgba(0, 0, 0, 0.04);
    }

    .event-mobile-countdown strong {
        font-size: 1.8rem;
        line-height: 1;
        font-weight: 950;
    }

    .event-mobile-countdown em {
        color: color-mix(in srgb, currentColor 58%, transparent);
        font-style: normal;
        font-size: 0.72rem;
        font-weight: 800;
        letter-spacing: 0.14em;
        text-transform: uppercase;
    }

    .event-mobile-buy {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        min-height: 58px;
        margin: 0 0 22px;
        border: 0;
        border-radius: 18px;
        background: var(--cd-accent-gradient, linear-gradient(135deg, var(--mobile-l3-accent), var(--mobile-l3-accent)));
        color: var(--cd-theme-ink-on-solid, #ffffff);
        text-decoration: none;
        text-transform: uppercase;
        font-size: 0.94rem;
        font-weight: 950;
    }

    .event-mobile-ticket-list {
        display: grid;
        gap: 0;
    }

    .event-mobile-ticket-row {
        display: grid;
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 14px;
        align-items: center;
        padding: 18px 0;
        border-top: 1px solid rgba(255, 255, 255, 0.14);
    }

    body.light-mode .event-mobile-ticket-row {
        border-top-color: color-mix(in srgb, var(--mobile-l3-text) 12%, transparent);
    }

    .event-mobile-ticket-copy strong {
        display: block;
        color: currentColor;
        font-size: 1rem;
        line-height: 1.2;
        font-weight: 950;
        text-transform: uppercase;
    }

    .event-mobile-ticket-copy span {
        display: block;
        margin-top: 5px;
        color: color-mix(in srgb, currentColor 66%, transparent);
        font-size: 0.86rem;
        line-height: 1.35;
    }

    .event-mobile-ticket-side {
        display: grid;
        justify-items: end;
        gap: 7px;
    }

    .event-mobile-ticket-price {
        color: var(--mobile-l3-accent);
        font-size: 1.08rem;
        font-weight: 950;
    }

    .event-mobile-ticket-side button {
        min-height: 30px;
        padding: 0 16px;
        border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 70%, transparent);
        border-radius: 999px;
        background: transparent;
        color: var(--mobile-l3-accent);
        text-transform: uppercase;
        font-size: 0.72rem;
        font-weight: 950;
    }

    .event-mobile-flyer-card {
        padding: 12px;
        overflow: hidden;
    }

    .event-mobile-flyer-card h2 {
        padding: 6px 6px 0;
    }

    .event-mobile-bottom-image {
        display: block;
        width: 100%;
        height: auto;
        border-radius: 16px;
    }
}
