:root {
        --mobile-bg: #FFFFFF;     --mobile-card-bg: rgba(255, 255, 255, 1.0);
    --mobile-glass: rgba(255, 255, 255, 0.9);
    --mobile-border: rgba(0, 0, 0, 0.06);
    --bg-mesh: #FFFFFF;

        --text-white: #1D1D1F;
    --text-muted: #48484A;
    --mobile-primary: #FF5E00;

        --modal-bg: #FFFFFF;
    --modal-inner-bg: rgba(0, 0, 0, 0.02);
    --input-bg: #FFFFFF;
    --input-border: rgba(0, 0, 0, 0.1);
    --input-text: #000000;

        --anima-speed: 3.5s;
    --category-radius: 20px;
}

.mobile-results .results-list.cinema-browser-active {
    display: block !important;
    width: 100% !important;
    max-width: calc(100vw - 18px) !important;
    margin: 0 auto !important;
    padding: 8px 0 calc(96px + env(safe-area-inset-bottom)) !important;
}

.cinema-browse-shell.cinema-reboot .cinema-controls,
.cinema-browse-shell.cinema-reboot .cinema-browser-grid,
.cinema-browse-shell.cinema-reboot .cinema-list-panel {
    display: none !important;
}

.cinema-browse-shell.cinema-reboot {
    --cinema-reboot-panel: #151517;
    --cinema-reboot-panel-2: #1c1c1f;
    --cinema-reboot-line: rgba(255, 255, 255, 0.1);
    --cinema-reboot-text: #f5f5f7;
    --cinema-reboot-muted: rgba(235, 235, 245, 0.62);
    --cinema-reboot-orange: #ff5e00;
    --cinema-reboot-orange-2: #ff9500;
    --cinema-reboot-red: #ff5a4f;
    display: flex;
    flex-direction: column;
    gap: 12px;
    color: var(--cinema-reboot-text);
    background: transparent;
}

.cinema-reboot-mobile-masthead {
    min-height: min(31vh, 230px);
    padding: calc(68px + env(safe-area-inset-top)) 28px 18px;
    display: grid;
    place-items: center;
    text-align: center;
}

.cinema-reboot-mobile-masthead > div {
    width: min(100%, 560px);
}

.cinema-reboot-mobile-masthead span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 28px;
    padding: 0 12px;
    border: 1px solid rgba(255, 149, 0, 0.22);
    border-radius: 999px;
    background: rgba(255, 94, 0, 0.1);
    color: #ffb15c;
    font-size: 0.7rem;
    font-weight: 900;
    line-height: 1;
    text-transform: uppercase;
}

.cinema-reboot-mobile-masthead h1 {
    margin: 12px 0 0 !important;
    color: #ffffff !important;
    font-size: clamp(2.85rem, 12.5vw, 3.35rem) !important;
    font-weight: 950 !important;
    line-height: 0.95 !important;
    letter-spacing: 0 !important;
    white-space: nowrap;
}

.cinema-reboot-mobile-masthead h1::first-line {
    color: #ffffff;
}

.cinema-reboot-mobile-masthead h1 {
    background: linear-gradient(105deg, #ffffff 0 34%, #ff5a4f 46%, #ff7a00 78%, #ff9500 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.cinema-reboot-mobile-masthead p {
    margin: 12px auto 0;
    max-width: 100%;
    color: rgba(245, 245, 247, 0.72);
    font-size: 0.9rem;
    font-weight: 750;
    line-height: 1.45;
    white-space: nowrap;
}

.cinema-reboot-detail-panel {
    position: relative;
    width: 100%;
    border: 1px solid var(--cinema-reboot-line);
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(24, 24, 27, 0.98), rgba(11, 11, 13, 0.98));
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.34);
    overflow: hidden;
}

.cinema-reboot-top-panel {
    position: relative;
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    display: flex;
    justify-content: flex-start;
    padding: 2px 0 8px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    overflow: visible;
}

.cinema-reboot-top-panel.is-centered,
.cinema-reboot-top-panel:has(.cinema-reboot-rail-frame.is-centered) {
    width: 100vw;
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    padding-inline: 0;
}

.cinema-reboot-rail-frame {
    position: relative;
    width: 100%;
    max-width: 100vw;
}

.cinema-reboot-rail-frame:not(.is-centered) {
    width: 100%;
}

.cinema-reboot-rail {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(162px, 44vw);
    gap: 14px;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    scroll-padding-inline: 24px;
    padding: 18px 24px 14px;
    scrollbar-width: none;
}

.cinema-reboot-rail::-webkit-scrollbar,
.cinema-reboot-date-tabs::-webkit-scrollbar {
    display: none;
}

.cinema-reboot-movie-card {
    position: relative;
    width: 100%;
    border: 1px solid rgba(255, 255, 255, 0.08);
    border-radius: 20px;
    background: #171719;
    color: var(--cinema-reboot-text);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    scroll-snap-align: start;
    text-align: center;
    transition: border-color 220ms ease, background 220ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.cinema-reboot-movie-card:hover,
.cinema-reboot-movie-card:focus-visible,
.cinema-reboot-movie-card.active {
    border-color: var(--category-accent-1, rgba(255, 94, 0, 0.75));
    background: linear-gradient(180deg, rgba(31, 31, 34, 0.98), rgba(18, 18, 20, 0.98));
    box-shadow: 0 16px 30px rgba(0, 0, 0, 0.44), 0 0 22px var(--category-accent-1, rgba(255, 94, 0, 0.24));
    outline: none;
    transform: translateY(-5px);
}

.cinema-reboot-movie-card img {
    width: 100%;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    background: #101012;
    display: block;
}

.cinema-reboot-card-copy {
    min-height: 88px;
    display: grid;
    grid-template-rows: minmax(0, 1fr) auto;
    align-items: start;
    gap: 8px;
    padding: 12px 10px;
    text-align: center;
}

.cinema-reboot-card-copy strong {
    color: #ffffff;
    font-size: 0.88rem;
    font-weight: 850;
    line-height: 1.18;
    letter-spacing: 0;
    text-align: center;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    justify-self: center;
}

.cinema-reboot-card-copy small {
    align-self: end;
    justify-self: center;
    max-width: 100%;
    color: #ffffff;
    font-size: 0.7rem;
    font-weight: 900;
    line-height: 1;
    padding: 7px 9px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--cinema-language-1, var(--cinema-reboot-orange)), var(--cinema-language-2, var(--cinema-reboot-orange-2)));
    box-shadow: 0 10px 20px var(--cinema-language-glow, rgba(255, 94, 0, 0.22));
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cinema-reboot-rail-arrow {
    position: absolute;
    top: 50%;
    z-index: 5;
    width: 34px;
    height: 34px;
    transform: translateY(-50%);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 50%;
    background: rgba(18, 18, 20, 0.66);
    color: var(--cinema-reboot-orange-2);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.38), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(18px) saturate(160%);
    -webkit-backdrop-filter: blur(18px) saturate(160%);
    transition: opacity 180ms ease, transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
}

.cinema-reboot-rail-arrow.left {
    left: 6px;
}

.cinema-reboot-rail-arrow.right {
    right: 6px;
}

.cinema-reboot-rail-arrow:hover,
.cinema-reboot-rail-arrow:focus-visible {
    border-color: rgba(255, 94, 0, 0.62);
    background: rgba(255, 94, 0, 0.12);
    color: #ffffff;
    outline: none;
    transform: translateY(-50%) scale(1.05);
}

.cinema-reboot-rail-arrow.is-hidden {
    opacity: 0;
    pointer-events: none;
    transform: translateY(-50%) scale(0.82);
}

.cinema-reboot-detail-panel {
    padding: 14px;
}

.cinema-reboot-detail-head {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 12px;
    align-items: start;
    padding-bottom: 14px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.cinema-reboot-detail-head > img {
    width: 86px;
    aspect-ratio: 3 / 4;
    object-fit: cover;
    border-radius: 18px;
    background: #101012;
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.34);
}

.cinema-reboot-detail-copy,
.cinema-reboot-title-row,
.cinema-reboot-theatre-content {
    min-width: 0;
}

.cinema-reboot-eyebrow {
    display: inline-block;
    margin-bottom: 7px;
    color: var(--cinema-reboot-orange-2);
    font-size: 0.66rem;
    font-weight: 900;
    letter-spacing: 0;
    text-transform: uppercase;
}

.cinema-reboot-title-row {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.cinema-reboot-title-row h2 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: clamp(1.28rem, 6vw, 1.8rem) !important;
    line-height: 1.08 !important;
    letter-spacing: 0 !important;
    overflow-wrap: anywhere;
}

.cinema-reboot-language-pill {
    justify-self: start;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 31px;
    padding: 0 11px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--cinema-language-1, var(--cinema-reboot-orange)), var(--cinema-language-2, var(--cinema-reboot-orange-2)));
    color: #ffffff;
    font-size: 0.74rem;
    font-weight: 950;
    line-height: 1;
    white-space: nowrap;
    box-shadow: 0 10px 20px var(--cinema-language-glow, rgba(255, 94, 0, 0.2));
}

.cinema-reboot-date-tabs {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    overflow-x: auto;
    padding: 2px 0 8px;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
}

.cinema-reboot-date-tab {
    flex: 0 0 58px;
    min-height: 66px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 14px;
    background: #202023;
    color: var(--cinema-reboot-text);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    font: inherit;
    scroll-snap-align: start;
}

.cinema-reboot-date-tab span,
.cinema-reboot-date-tab small {
    color: var(--cinema-reboot-muted);
    font-size: 0.64rem;
    font-weight: 850;
    line-height: 1;
}

.cinema-reboot-date-tab strong {
    color: #ffffff;
    font-size: 1.14rem;
    line-height: 1;
}

.cinema-reboot-date-tab:hover,
.cinema-reboot-date-tab:focus-visible,
.cinema-reboot-date-tab.active {
    border-color: rgba(255, 94, 0, 0.72);
    outline: none;
}

.cinema-reboot-date-tab.active {
    background: linear-gradient(135deg, var(--cinema-reboot-orange), var(--cinema-reboot-orange-2));
}

.cinema-reboot-date-tab.active span,
.cinema-reboot-date-tab.active small,
.cinema-reboot-date-tab.active strong {
    color: #ffffff;
}

.cinema-reboot-showtimes {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 14px;
}

.cinema-reboot-theatre-row {
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 12px;
    border: 1px solid rgba(255, 255, 255, 0.09);
    border-radius: 18px;
    background: var(--cinema-reboot-panel-2);
    padding: 14px;
    overflow: hidden;
    transition: border-color 220ms ease, background 220ms ease, box-shadow 220ms ease, transform 220ms ease;
}

.cinema-reboot-theatre-row:hover,
.cinema-reboot-theatre-row:focus-within {
    transform: translateY(-4px);
    border-color: rgba(255, 94, 0, 0.5);
    box-shadow: 0 22px 42px rgba(0, 0, 0, 0.44), 0 0 22px var(--category-accent-1, rgba(255, 94, 0, 0.2));
}

.cinema-reboot-theatre-info {
    display: grid;
    grid-template-columns: 76px minmax(0, 1fr);
    gap: 14px;
    align-items: stretch;
}

.cinema-reboot-theatre-image {
    width: 100%;
    height: 100%;
    min-height: 108px;
    border-radius: 14px;
    object-fit: cover;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(255, 94, 0, 0.2), rgba(255, 149, 0, 0.1));
    border: 1px solid rgba(255, 94, 0, 0.22);
    color: var(--cinema-reboot-orange-2);
    font-size: 1.2rem;
}

.cinema-reboot-theatre-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
}

.cinema-reboot-theatre-head {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
}

.cinema-reboot-theatre-head h3 {
    margin: 0 0 5px;
    color: #ffffff;
    font-size: 1.02rem;
    font-weight: 900;
    line-height: 1.18;
    letter-spacing: 0;
}

.cinema-reboot-theatre-title-line {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
    gap: 8px;
}

.cinema-reboot-theatre-title-line h3 {
    margin: 0;
}

.cinema-reboot-distance {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    min-height: 24px;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(255, 94, 0, 0.1);
    color: #ffb15c;
    font-size: 0.64rem;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
}

.cinema-reboot-theatre-head p {
    margin: 0;
    color: var(--cinema-reboot-muted);
    font-size: 0.76rem;
    font-weight: 650;
    line-height: 1.35;
}

.cinema-reboot-theatre-head p i {
    color: var(--cinema-reboot-red);
    margin-right: 5px;
}

.cinema-reboot-row-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    gap: 8px;
}

.cinema-reboot-row-actions a {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 12px;
    border: 1px solid rgba(255, 94, 0, 0.24);
    border-radius: 14px;
    background: rgba(255, 94, 0, 0.08);
    color: #ffb15c;
    text-decoration: none;
    font-size: 0.76rem;
    font-weight: 850;
}

.cinema-reboot-row-actions a:hover,
.cinema-reboot-row-actions a:focus-visible {
    border-color: rgba(255, 94, 0, 0.58);
    background: rgba(255, 94, 0, 0.15);
    color: #ffffff;
    outline: none;
}

.cinema-reboot-time-chips {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    padding-top: 14px;
}

.cinema-reboot-time-chips::before {
    content: '';
    position: absolute;
    top: 0;
    left: 50%;
    width: min(100%, 360px);
    height: 1px;
    transform: translateX(-50%);
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.13), transparent);
}

.cinema-reboot-time-chip {
    min-width: 58px;
    min-height: 34px;
    padding: 0 10px;
    border: 1px solid rgba(255, 94, 0, 0.3);
    border-radius: 14px;
    background: rgba(255, 94, 0, 0.1);
    color: #ffc28a;
    cursor: pointer;
    font: inherit;
    font-size: 0.76rem;
    font-weight: 850;
}

.cinema-reboot-time-chip:hover,
.cinema-reboot-time-chip:focus-visible {
    border-color: rgba(255, 94, 0, 0.72);
    background: rgba(255, 94, 0, 0.18);
    color: #ffffff;
    outline: none;
}

.cinema-browse-shell.cinema-reboot .cinema-muted,
.cinema-browse-shell.cinema-reboot .cinema-no-times,
.cinema-browse-shell.cinema-reboot .cinema-no-dates {
    color: var(--cinema-reboot-muted);
    font-size: 0.82rem;
    font-weight: 700;
}

.cinema-reboot-card-skeleton {
    min-height: 288px;
    border-radius: 18px;
    background: #171719;
    overflow: hidden;
}

.cinema-reboot-card-skeleton span,
.cinema-reboot-card-skeleton b,
.cinema-reboot-card-skeleton i {
    display: block;
    background: linear-gradient(90deg, rgba(255,255,255,0.06), rgba(255,255,255,0.14), rgba(255,255,255,0.06));
    background-size: 220% 100%;
    animation: cinemaSkeletonPulse 1.2s ease-in-out infinite;
}

.cinema-reboot-card-skeleton span {
    width: 100%;
    aspect-ratio: 3 / 4;
}

.cinema-reboot-card-skeleton b {
    height: 14px;
    margin: 12px 10px 8px;
    border-radius: 8px;
}

.cinema-reboot-card-skeleton i {
    width: 54%;
    height: 11px;
    margin: 0 auto;
    border-radius: 8px;
}

@media (max-width: 380px) {
    .mobile-results .results-list.cinema-browser-active {
        max-width: calc(100vw - 12px) !important;
    }

    .cinema-reboot-rail {
        grid-auto-columns: minmax(154px, 43vw);
        gap: 12px;
        padding-inline: 18px;
        scroll-padding-inline: 18px;
    }

    .cinema-reboot-card-copy {
        min-height: 84px;
        padding: 10px 8px;
    }

    .cinema-reboot-detail-panel {
        padding: 12px;
    }

    .cinema-reboot-theatre-row {
        padding: 12px;
    }

    .cinema-reboot-theatre-info {
        grid-template-columns: 68px minmax(0, 1fr);
        gap: 12px;
    }

    .cinema-reboot-theatre-image {
        min-height: 100px;
    }
}

body.dark-mode {
    --mobile-bg: #0A0A0B;
    --mobile-card-bg: #1C1C1E;
    --mobile-glass: rgba(0, 0, 0, 0.7);
    --mobile-border: rgba(255, 255, 255, 0.1);
    --bg-mesh: #0A0A0B;
    --text-white: #F5F5F7;
    --text-muted: #8E8E93;
    --modal-bg: #1C1C1E;
    --input-bg: #2C2C2E;
}

body {
    background: var(--bg-mesh);
    color: var(--text-white);
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif;
    margin: 0;
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;

        -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-touch-callout: none;
}

.contact-link, a, input, textarea {
    -webkit-user-select: text !important;
    user-select: text !important;
    -webkit-touch-callout: default !important;
}


body.light-mode .bottom-nav {
    background: rgba(255, 255, 255, 0.95) !important;
    border-top: 1px solid rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.05) !important;
}

body.light-mode .nav-tab {
    color: #48484A !important;
}

body.light-mode .nav-tab.active {
    color: #FFFFFF !important;
}

body.light-mode .side-menu {
    background: #FFFFFF !important;
    border-right: 1px solid rgba(0, 0, 0, 0.08) !important;
}

body.light-mode .menu-link {
    color: var(--text-white) !important;
}

body.light-mode .menu-link:active {
    background: rgba(0, 0, 0, 0.05) !important;
}

body.light-mode .icon-wrapper {
    background: #FFFFFF !important;
    border-color: rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05) !important;
}

body.light-mode .home-card {
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.08) !important;
}

body.light-mode .sub-cat-btn span {
    color: #48484A !important;
}

body.light-mode .contact-link {
    color: var(--text-white) !important;
}

body.light-mode .contact-link:active {
    background: rgba(255, 140, 0, 0.08) !important;
}

body.light-mode .contact-text label {
    color: rgba(0, 0, 0, 0.45) !important;
}

body.light-mode .contact-text span {
    color: #000000 !important;
}

.featured-mobile-section {
    padding: 0 1.5rem 24px;     background: var(--mobile-bg);
}


.form-section {
    margin-bottom: 28px;
    padding-top: 15px;
}

.featured-main-title {
    font-size: 1.6rem;
    font-weight: 800;
    color: var(--text-white);
    margin: 0 0 4px 0;
    letter-spacing: -0.5px;
}

.featured-sub-title {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin: 0;
}

.featured-card-container {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 16px;
    padding: 12px 1.5rem;
    margin: 0 -1.5rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; }

.featured-card-container::-webkit-scrollbar {
    display: none;
}

.featured-card-flyer {
    flex: 0 0 72%;     aspect-ratio: 9 / 14;
    scroll-snap-align: center;



    background: var(--mobile-card-bg);
    border: 1px solid var(--mobile-border);
    border-radius: 20px;
    overflow: hidden;
    box-shadow: 0 12px 35px rgba(0,0,0,0.25);
    position: relative;
    cursor: pointer;
    transition: transform 0.3s ease;
}

.featured-card-flyer .flyer-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.featured-card-flyer:active {
    transform: scale(0.97);
}

.featured-card-flyer.active {
    opacity: 1;
}

.featured-card-flyer .flyer-overlay {
    position: absolute;
    inset: 0;
    background: transparent;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 16px;
    z-index: 3;
}

.featured-card-flyer .flyer-tag {
    position: absolute;
    top: 12px;
    left: 12px;
    background: var(--mobile-primary);
    color: #fff;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", sans-serif;     font-size: 0.65rem;
    font-weight: 800;
    padding: 4px 10px;
    border-radius: 6px;
    letter-spacing: 0.5px;
    z-index: 4;
}


.featured-image-box-mobile img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.featured-tag-mobile {
    position: absolute;
    top: 12px;
    left: 12px;
    padding: 4px 10px;
    background: var(--mobile-primary);
    color: white;
    font-size: 0.6rem;
    font-weight: 800;
    border-radius: 6px;
    text-transform: uppercase;
}

.featured-card-info-mobile {
    padding: 16px;
}

.featured-meta-mobile {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    color: var(--mobile-primary);
    margin-bottom: 6px;
    display: block;
}



.featured-footer-mobile {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-top: 12px;
    border-top: 1px solid var(--mobile-border);
}

.featured-rating-mobile, .featured-event-mobile {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 700;
    color: var(--text-white);
}

.featured-rating-mobile i { color: #ff5e00; }
.featured-rating-mobile span { color: var(--text-muted); font-weight: 700; font-size: 0.8rem; }

.featured-event-mobile i { color: var(--mobile-primary); }

#featuredSectionMobile {
    background: var(--glass-bg);
    border-top: 1px solid var(--mobile-border);
    border-bottom: 1px solid var(--mobile-border);
    padding: 1.5rem 0;
}
body.light-mode #featuredSectionMobile {
    background: rgba(0,0,0,0.02);
}


body.light-mode .card-type-badge {
    background: rgba(255, 255, 255, 0.45) !important;
    backdrop-filter: blur(15px) !important;
    -webkit-backdrop-filter: blur(15px) !important;
    color: #000000 !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
}


body.light-mode .footer-right {
    color: #48484A !important;
}

body.light-mode .close-modal {
    background: #FFFFFF !important;
    color: #000000 !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
}

body.light-mode .listing-card {
    background: #FFFFFF !important;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.05) !important;
}

body.light-mode .side-menu-header {
    border-bottom-color: rgba(0, 0, 0, 0.05) !important;
}

* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    -webkit-tap-highlight-color: transparent;
}

.hidden,
[hidden] { display: none !important; }

button, input, select, textarea {
    font-family: inherit !important;
}

body {
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Icons", "Helvetica Neue", Helvetica, Arial, sans-serif;
    background-color: var(--mobile-bg);
    color: var(--text-white);
    line-height: 1.47;
    overflow-x: hidden;
}

h1, h2, h3, h4, h5, h6 {
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", sans-serif;
}

.nav-floating-fixed {
    position: fixed;
    top: calc(16px + env(safe-area-inset-top));
    z-index: 1100;
}
.nav-left { left: 1.2rem; }
.nav-right { right: 1.2rem; }

.round-btn {
    background: rgba(255, 255, 255, 0.55) !important;
    backdrop-filter: blur(55px) saturate(220%) !important;
    -webkit-backdrop-filter: blur(55px) saturate(220%) !important;
    border: 1px solid rgba(255, 255, 255, 0.45) !important;
    box-shadow: 0 12px 32px rgba(0,0,0,0.18), 0 4px 12px rgba(0,0,0,0.1) !important;
    width: 49px !important;
    height: 49px !important;
    border-radius: 40%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-size: 1.3rem !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
body.light-mode .round-btn {
    background: rgba(255, 255, 255, 0.95) !important;
    border-color: rgba(0,0,0,0.08) !important;
    color: #1D1D1F !important;
}
.round-btn:active {
    transform: scale(0.9);
    box-shadow: 0 4px 12px rgba(0,0,0,0.2) !important;
}

.mobile-page-back-btn {
    width: 42px !important;
    height: 42px !important;
    border-radius: 50% !important;
    color: var(--cd-text-on-accent, #ffffff) !important;
    -webkit-text-fill-color: var(--cd-text-on-accent, #ffffff) !important;
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%)) !important;
    border-color: color-mix(in srgb, var(--mobile-primary) 46%, transparent) !important;
    box-shadow: var(--cd-soft-glow, 0 10px 24px rgba(255, 94, 0, 0.30), 0 0 16px rgba(255, 215, 0, 0.14)) !important;
}

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

.page-back-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    font-size: 1.08rem;
    line-height: 1;
}


.logo {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-weight: 800;
    font-size: 1.85rem;
    letter-spacing: -1.2px;
}

.logo-chicago { color: #FFFFFF; }
.logo-desi {
    background: linear-gradient(135deg, #FF6E00 0%, #FF0000 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.header-left {
    position: absolute;
    left: 1.2rem;
    display: flex;
    align-items: center;
    gap: 12px;
}

#menuBtn {
    position: relative;
    left: 0;
}

.icon-btn {
    background: none;
    border: none;
    color: var(--text-white);
    font-size: 1.4rem;
    cursor: pointer;
}

body.light-mode .logo-chicago {
    color: #0a3f86 !important;
}



body.light-mode .mobile-search-row {
    background: rgba(0, 0, 0, 0.05) !important;
    border-color: rgba(0, 0, 0, 0.08) !important;
}

body.light-mode .location-select {
    background-color: rgba(0, 0, 0, 0.03) !important;
    color: var(--text-white) !important;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='black'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3Cpath%3E%3C/svg%3E");
}

.round-btn {
    width: 36px;
    height: 36px;
    background: rgba(255, 255, 255, 0.1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    margin-right: 8px;
    color: var(--text-muted);
}

body.light-mode .round-btn {
    background: rgba(0, 0, 0, 0.05);
    color: #1D1D1F;
    text-decoration: none;
}

.header-right {
    position: absolute;
    right: 1.2rem;
    display: flex;
    align-items: center;
    gap: 12px;
}

.header-location-wrapper {
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid var(--mobile-border);
    border-radius: 100px;
    padding: 2px 10px;
    display: flex;
    align-items: center;
    gap: 6px;
    max-width: 140px;
}

body.light-mode .header-location-wrapper {
    background: rgba(0, 0, 0, 0.05);
}

.header-location-wrapper select {
    background: none;
    border: none;
    color: var(--text-white);
    font-size: 0.82rem;
    font-weight: 600;
    padding: 4px 6px;
    -webkit-appearance: none;
    appearance: none;
    width: 100%;
}

.header-location-wrapper i {
    font-size: 0.7rem;
    color: var(--mobile-primary);
}

.promote-btn-sm {
    background: #FF8C00;
    color: #000;
    border: none;
    padding: 0.4rem 0.8rem;
    border-radius: 50px;
    font-weight: 700;
    font-size: 0.75rem;
}

.home-intro {
    margin-bottom: 2.2rem;
    padding: 0 0.2rem;
}

.home-intro h1 {
    font-family: -apple-system, BlinkMacSystemFont, 'SF Pro Text', 'SF Pro Display', 'Helvetica Neue', Helvetica, Arial, sans-serif;
    font-size: 2.8rem;
    font-weight: 800;
    margin: 0;
    letter-spacing: -2px;
    color: var(--text-white);
    line-height: 1;
}

.home-intro h1 span {
    background: linear-gradient(135deg, #FF6E00 0%, #FF0000 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.home-intro p {
    font-size: 1.1rem;
    color: var(--text-muted);
    margin: 12px 0 0;
    font-weight: 500;
    letter-spacing: -0.4px;
}

.home-feed-section {
    padding: calc(14px + env(safe-area-inset-top)) 0rem 5rem;
    overflow-x: hidden;
    background:
        linear-gradient(180deg, rgba(255, 245, 237, 0.98) 0%, rgba(255, 255, 255, 0.98) 46%, rgba(247, 247, 248, 1) 100%);
}

.header-container {
    padding: 10px 1.4rem;
    margin-bottom: 24px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    text-align: center;
}

.mobile-burger-btn {
    position: absolute;
    left: 1rem;
    color: var(--text-white);
    background: var(--mobile-glass);
    border: 1px solid var(--mobile-border);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    width: 40px;
    height: 40px;
}

.brand-group.centered-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
}

.brand-group h1 {
    font-size: 2.2rem;
    font-weight: 800;
    color: var(--text-white);
    margin: 0;
    letter-spacing: -1.5px;
    background: linear-gradient(135deg, #FF6E00 0%, #FF0000 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.brand-tagline.single-line-tagline {
    font-size: 0.72rem;
    font-weight: 600;
    color: var(--text-muted);
    margin: 2px 0 0;
    letter-spacing: -0.1px;
    max-width: 100%;
    text-align: center;
    white-space: nowrap;
    width: auto;
    text-overflow: clip;
}

.mobile-home-hero {
    display: grid;
    gap: 6px;
    padding: 0 0.5rem 14px;
}

.mobile-home-hero-card {
    position: relative;
    min-height: 194px;
    border-radius: 17px;
    overflow: hidden;
    background: #071a3b;
    box-shadow: 0 8px 18px rgba(21, 25, 34, 0.1);
    isolation: isolate;
    touch-action: pan-y;
    cursor: pointer;
}

.mobile-home-hero-card:active {
    transform: scale(0.985);
}

.mobile-home-hero-card:focus-visible {
    outline: 3px solid rgba(240, 90, 34, 0.28);
    outline-offset: 3px;
}

.mobile-home-hero-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
    opacity: 0.88;
    transition: opacity 220ms ease, transform 220ms ease;
}

.mobile-home-hero-shade {
    position: absolute;
    inset: 0;
    z-index: 1;
    background:
        linear-gradient(90deg, rgba(5, 23, 57, 0.94) 0%, rgba(5, 23, 57, 0.78) 38%, rgba(5, 23, 57, 0.12) 78%),
        linear-gradient(180deg, rgba(5, 18, 43, 0.08) 0%, rgba(5, 18, 43, 0.74) 100%);
}

.mobile-home-hero-copy {
    position: relative;
    z-index: 3;
    width: 59%;
    padding: 31px 19px;
    color: #ffffff;
}

.mobile-home-hero-copy h2 {
    margin: 0;
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
    font-size: 1.24rem;
    font-weight: 860;
    line-height: 1.22;
    letter-spacing: 0;
    text-wrap: balance;
}

.mobile-home-hero-copy p {
    margin: 16px 0 0;
    color: rgba(255, 255, 255, 0.92);
    -webkit-text-fill-color: rgba(255, 255, 255, 0.92);
    font-size: 0.76rem;
    font-weight: 660;
    line-height: 1.55;
    text-wrap: pretty;
}

.mobile-home-hero-skyline {
    position: absolute;
    right: 22px;
    bottom: 43px;
    z-index: 2;
    display: flex;
    align-items: flex-end;
    gap: 5px;
    height: 82px;
    opacity: 0.72;
}

.mobile-home-hero-skyline span {
    display: block;
    width: 13px;
    border-radius: 3px 3px 0 0;
    background: linear-gradient(180deg, rgba(9, 35, 82, 0.82), rgba(3, 12, 31, 0.9));
    box-shadow: inset 0 8px 0 rgba(255, 182, 73, 0.22), inset 0 28px 0 rgba(255, 255, 255, 0.06);
}

.mobile-home-hero-skyline span:nth-child(1) { height: 46px; }
.mobile-home-hero-skyline span:nth-child(2) { height: 70px; }
.mobile-home-hero-skyline span:nth-child(3) { height: 58px; }
.mobile-home-hero-skyline span:nth-child(4) { height: 82px; }
.mobile-home-hero-skyline span:nth-child(5) { height: 50px; }
.mobile-home-hero-skyline span:nth-child(6) { height: 64px; }

.mobile-home-hero-diya {
    position: absolute;
    right: 25px;
    bottom: 20px;
    z-index: 3;
    width: 81px;
    height: 28px;
    border-radius: 0 0 44px 44px;
    background: radial-gradient(circle at 50% 0%, #ffe3a1 0%, #ff9d2b 42%, #9b3d17 100%);
    box-shadow:
        0 0 26px rgba(255, 166, 52, 0.35),
        0 9px 12px rgba(0, 0, 0, 0.28);
}

.mobile-home-hero-flame {
    position: absolute;
    left: 36px;
    top: -34px;
    width: 20px;
    height: 42px;
    border-radius: 16px 16px 16px 2px;
    background: radial-gradient(circle at 50% 68%, #ffffff 0%, #fff4b2 25%, #ffb338 53%, #f05a22 100%);
    transform: rotate(10deg);
    box-shadow: 0 0 28px rgba(255, 189, 65, 0.66);
}

.mobile-home-hero-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    min-height: 10px;
}

.mobile-home-hero-dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: #e0e3e8;
    cursor: pointer;
    transition: width 160ms ease, background-color 160ms ease;
}

.mobile-home-hero-dot.is-active {
    width: 9px;
    background: #0a3f86;
}

@media (max-width: 360px) {
    .mobile-home-hero-copy {
        width: 64%;
        padding: 26px 16px;
    }

    .mobile-home-hero-copy h2 {
        font-size: 1.12rem;
    }
}


.home-feed-cards {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px 8px;
    padding: 0 0.5rem;
    margin-bottom: 40px;
}

.home-feed-cards .feed-card[data-home-feed-category="owners"] {
    grid-column: 1 / -1;
}

.mobile-home-event-section {
    margin: 0 0.5rem 16px;
}

.mobile-home-section-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 10px;
}

.mobile-home-section-heading h2 {
    margin: 0;
    color: var(--text-white);
    font-size: 1rem;
    font-weight: 860;
    line-height: 1.18;
    letter-spacing: 0;
}

.mobile-home-section-heading a {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    min-height: 40px;
    color: var(--mobile-primary);
    -webkit-text-fill-color: var(--mobile-primary);
    font-size: 0.76rem;
    font-weight: 820;
    line-height: 1;
    text-decoration: none;
    white-space: nowrap;
}

.mobile-home-event-rail {
    width: calc(100% + 1rem);
    margin-left: -0.5rem;
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: calc((100% - 8px) / 1.2);
    gap: 8px;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    padding: 0 0.5rem 2px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}

.mobile-home-event-rail::-webkit-scrollbar {
    display: none;
}

.mobile-home-event-card,
.mobile-home-event-skeleton {
    min-height: 285px;
    border-radius: 16px;
    overflow: hidden;
    background: var(--mobile-card-bg);
    box-shadow: 0 8px 18px rgba(21, 25, 34, 0.08);
    scroll-snap-align: start;
}

.mobile-home-event-card {
    position: relative;
    display: block;
    color: var(--text-white);
    text-decoration: none;
}

.mobile-home-event-card:active {
    transform: scale(0.97);
}

.mobile-home-event-media {
    position: relative;
    height: 160px;
    overflow: hidden;
    background: linear-gradient(135deg, #fde3c7, #e5f1ff);
}

.mobile-home-event-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    outline: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-home-event-date {
    position: absolute;
    top: 14px;
    right: 14px;
    width: 44px;
    min-height: 50px;
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.96);
    color: #172033;
    box-shadow: 0 6px 16px rgba(21, 25, 34, 0.12);
    font-variant-numeric: tabular-nums;
}

.mobile-home-event-date small {
    display: block;
    color: var(--mobile-primary);
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1.2;
    text-transform: uppercase;
}

.mobile-home-event-date strong {
    display: block;
    margin-top: 1px;
    font-size: 1.15rem;
    font-weight: 900;
    line-height: 1.1;
}

.mobile-home-event-body {
    display: grid;
    align-content: start;
    gap: 8px;
    padding: 16px 18px 18px;
}

.mobile-home-event-body h3 {
    min-height: auto;
    margin: 0 0 6px 0;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-white);
    -webkit-text-fill-color: var(--text-white);
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
    letter-spacing: 0;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.mobile-home-event-meta {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: var(--text-muted);
    -webkit-text-fill-color: var(--text-muted);
    font-size: 0.84rem;
    font-weight: 620;
    line-height: 1.2;
}

.mobile-home-event-meta i {
    width: 12px;
    color: #8a8f99;
    -webkit-text-fill-color: #8a8f99;
    text-align: center;
}

.mobile-home-event-meta span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-event-skeleton {
    background:
        linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.12), rgba(255,255,255,0.02)),
        var(--mobile-card-bg);
    background-size: 180% 100%;
    animation: cd-skeleton-shimmer 1.2s ease-in-out infinite;
}

body.dark-mode .mobile-home-event-card,
body.dark-mode .mobile-home-event-skeleton {
    box-shadow: 0 5px 13px rgba(0, 0, 0, 0.22);
}

body.dark-mode .mobile-home-event-media img {
    outline-color: rgba(255, 255, 255, 0.1);
}

.mobile-home-classified-rail,
.mobile-home-news-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-movie-rail,
.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    width: calc(100% + 1rem);
    margin-left: -0.5rem;
    display: grid;
    grid-auto-flow: column;
    gap: 8px;
    overflow-x: auto;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    padding: 0 0.5rem 2px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}

.mobile-home-movie-rail {
    grid-auto-columns: calc((100% - 8px) / 2.1);
}

.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    grid-auto-columns: calc((100% - 8px) / 2.5);
}

.mobile-home-classified-rail,
.mobile-home-news-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail {
    grid-auto-columns: calc((100% - 8px) / 1.2);
}

.mobile-home-classified-rail::-webkit-scrollbar,
.mobile-home-news-rail::-webkit-scrollbar,
.mobile-home-featured-business-rail::-webkit-scrollbar,
.mobile-home-featured-restaurant-rail::-webkit-scrollbar,
.mobile-home-movie-rail::-webkit-scrollbar,
.mobile-home-flyer-rail::-webkit-scrollbar,
.mobile-home-deals-rail::-webkit-scrollbar,
.mobile-home-exclusive-deals-rail::-webkit-scrollbar,
.mobile-home-business-promos-rail::-webkit-scrollbar {
    display: none;
}

.mobile-home-featured-business-card,
.mobile-home-movie-card,
.mobile-home-featured-business-skeleton,
.mobile-home-movie-skeleton {
    border-radius: 8px;
    overflow: hidden;
    background: var(--mobile-card-bg);
    box-shadow: 0 5px 13px rgba(21, 25, 34, 0.09);
    color: var(--text-white);
    text-decoration: none;
    scroll-snap-align: start;
}

.mobile-home-classified-column {
    scroll-snap-align: start;
    display: grid;
    grid-template-rows: auto auto;
    gap: 8px;
}

.mobile-home-classified-card {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 4px;
    border-radius: 16px;
    min-height: 148px;
    height: 148px;
    padding: 16px 18px 18px;
    box-sizing: border-box;
    background: var(--mobile-card-bg);
    box-shadow: 0 5px 13px rgba(21, 25, 34, 0.09);
    color: var(--text-white);
    text-decoration: none;
    overflow: hidden;
}

.mobile-home-classified-skeleton {
    border-radius: 16px;
    min-height: 304px;
}

.mobile-home-news-column {
    scroll-snap-align: start;
    display: grid;
    grid-template-rows: auto auto;
    gap: 8px;
}

.mobile-home-news-card {
    display: grid;
    border-radius: 16px;
    min-height: 148px;
    height: 148px;
    overflow: hidden;
    background: var(--mobile-card-bg);
    box-shadow: 0 5px 13px rgba(21, 25, 34, 0.09);
    color: var(--text-white);
    text-decoration: none;
}

.mobile-home-news-skeleton {
    border-radius: 16px;
    min-height: 304px;
}

.mobile-home-featured-business-card {
    display: grid;
    border-radius: 16px;
    min-height: 285px;
}

.mobile-home-featured-business-skeleton {
    border-radius: 16px;
}

.mobile-home-classified-card {
    min-height: 150px;
    padding: 9px;
    align-content: space-between;
    gap: 8px;
}

.mobile-home-classified-card:active,
.mobile-home-news-card:active,
.mobile-home-featured-business-card:active,
.mobile-home-movie-card:active {
    transform: scale(0.97);
}

.mobile-home-classified-tag,
.mobile-home-business-tag {
    width: fit-content;
    max-width: 100%;
    border-radius: 999px;
    background: linear-gradient(135deg, #ff8a00, #f23673);
    color: #fff;
    -webkit-text-fill-color: #fff;
    font-size: 0.52rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
    padding: 5px 7px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-classified-card h3,
.mobile-home-featured-business-card h3 {
    margin: 0;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-white);
    -webkit-text-fill-color: var(--text-white);
    font-weight: 820;
    line-height: 1.18;
    letter-spacing: 0;
    -webkit-box-orient: vertical;
}

.mobile-home-classified-card h3 {
    font-size: 0.72rem;
    -webkit-line-clamp: 3;
}

.mobile-home-classified-meta {
    display: grid;
    gap: 4px;
    min-width: 0;
    color: var(--text-muted);
    -webkit-text-fill-color: var(--text-muted);
    font-size: 0.58rem;
    font-weight: 650;
    line-height: 1.2;
}

.mobile-home-business-meta {
    display: grid;
    gap: 6px;
    min-width: 0;
    color: var(--text-muted);
    -webkit-text-fill-color: var(--text-muted);
    font-size: 0.84rem;
    font-weight: 620;
    line-height: 1.2;
}

.mobile-home-classified-meta span,
.mobile-home-business-meta span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-featured-business-media {
    position: relative;
    height: 160px;
    overflow: hidden;
    background: linear-gradient(135deg, #ffe7d1, #e9f7db);
}

.mobile-home-featured-business-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    outline: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-home-news-card {
    min-height: 285px;
    display: grid;
    grid-template-rows: auto 1fr;
    align-content: stretch;
}

.mobile-home-news-card.no-image {
    padding: 0;
    grid-template-rows: 1fr;
    min-height: 285px;
}

.mobile-home-news-media {
    height: 160px;
    overflow: hidden;
    background: linear-gradient(135deg, #fff0d9, #e5f1ff);
}

.mobile-home-news-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    outline: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-home-news-body {
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 8px;
    padding: 16px 18px 18px;
    overflow: hidden;
    box-sizing: border-box;
}

.mobile-home-news-card.no-image .mobile-home-news-body {
    padding: 16px 18px 18px;
}

.mobile-home-news-date {
    color: var(--mobile-primary);
    -webkit-text-fill-color: var(--mobile-primary);
    font-size: 0.56rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
}

.mobile-home-news-card h3 {
    margin: 0;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-white);
    -webkit-text-fill-color: var(--text-white);
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
    letter-spacing: 0;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
}

.mobile-home-news-card.no-image h3 {
    -webkit-line-clamp: 5;
    line-clamp: 5;
}

.mobile-home-news-card p {
    margin: 0;
    display: -webkit-box;
    overflow: hidden;
    color: var(--text-muted);
    -webkit-text-fill-color: var(--text-muted);
    font-size: 0.84rem;
    font-weight: 620;
    line-height: 1.3;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.mobile-home-business-tag {
    position: absolute;
    top: 14px;
    left: 14px;
    max-width: calc(100% - 28px);
    padding: 6px 12px;
    font-size: 0.68rem;
    font-weight: 900;
}

.mobile-home-featured-business-body {
    display: grid;
    align-content: start;
    gap: 8px;
    padding: 16px 18px 18px;
}

.mobile-home-featured-business-card h3 {
    min-height: auto;
    margin: 0 0 6px 0;
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
    -webkit-line-clamp: 2;
}

.mobile-home-movie-card {
    position: relative;
    display: block;
    aspect-ratio: 2 / 3;
    min-height: 152px;
}

.mobile-home-movie-poster {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    overflow: hidden;
}

.mobile-home-movie-poster img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    outline: 1px solid rgba(0, 0, 0, 0.1);
}

.mobile-home-movie-language {
    position: absolute;
    top: 6px;
    left: 6px;
    max-width: calc(100% - 12px);
    border-radius: 999px;
    background: linear-gradient(135deg, var(--cinema-language-1, #ff8a00), var(--cinema-language-2, #f23673));
    box-shadow: 0 8px 18px var(--cinema-language-glow, rgba(255, 94, 0, 0.22));
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
    font-size: 0.5rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
    padding: 5px 7px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-classified-skeleton,
.mobile-home-news-skeleton,
.mobile-home-featured-business-skeleton,
.mobile-home-movie-skeleton,
.mobile-home-flyer-skeleton,
.mobile-home-deals-skeleton,
.mobile-home-exclusive-deals-skeleton,
.mobile-home-business-promos-skeleton {
    min-height: 150px;
    background:
        linear-gradient(90deg, rgba(255,255,255,0.02), rgba(255,255,255,0.12), rgba(255,255,255,0.02)),
        var(--mobile-card-bg);
    background-size: 180% 100%;
    animation: cd-skeleton-shimmer 1.2s ease-in-out infinite;
}

.mobile-home-featured-business-skeleton {
    min-height: 285px;
}

.mobile-home-movie-skeleton {
    aspect-ratio: 2 / 3;
}

.mobile-home-flyer-skeleton,
.mobile-home-deals-skeleton,
.mobile-home-exclusive-deals-skeleton,
.mobile-home-business-promos-skeleton {
    aspect-ratio: 3 / 4;
}

body.dark-mode .mobile-home-classified-card,
body.dark-mode .mobile-home-news-card,
body.dark-mode .mobile-home-featured-business-card,
body.dark-mode .mobile-home-movie-card,
body.dark-mode .mobile-home-classified-skeleton,
body.dark-mode .mobile-home-news-skeleton,
body.dark-mode .mobile-home-featured-business-skeleton,
body.dark-mode .mobile-home-movie-skeleton,
body.dark-mode .mobile-home-flyer-card,
body.dark-mode .mobile-home-deals-card,
body.dark-mode .mobile-home-exclusive-deals-card,
body.dark-mode .mobile-home-business-promos-card,
body.dark-mode .mobile-home-flyer-skeleton,
body.dark-mode .mobile-home-deals-skeleton,
body.dark-mode .mobile-home-exclusive-deals-skeleton,
body.dark-mode .mobile-home-business-promos-skeleton {
    box-shadow: 0 5px 13px rgba(0, 0, 0, 0.22);
}

body.dark-mode .mobile-home-news-media img,
body.dark-mode .mobile-home-featured-business-media img,
body.dark-mode .mobile-home-movie-poster img {
    outline-color: rgba(255, 255, 255, 0.1);
}

.feed-card {
    position: relative;
    width: 100%;
    aspect-ratio: 2 / 1;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 16px 32px rgba(0,0,0,0.12);
    cursor: pointer;
    transition: transform 0.3s ease;
    background: #1c1c1e;
    border: 1px solid rgba(255,255,255,0.06);
}

.home-feed-cards .feed-card:active {
    transform: scale(0.97) !important;
}

.feed-card-image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
}

.feed-card-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(96, 96, 96, 0.22), rgba(96, 96, 96, 0.22)),
        linear-gradient(to top,
        rgba(0,0,0,0.6) 0%,
        transparent 30%);
    z-index: 2;
}

.feed-card-content {
    position: absolute;
    inset: 0;
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    z-index: 3;
}

.card-top-info {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
}

.card-tag {
    font-size: 0.75rem;
    font-weight: 800;
    color: rgba(255,255,255,0.7);
    text-transform: uppercase;
    letter-spacing: 1px;
}

.card-glass-title {
    font-size: 1.6rem;
    font-weight: 800;
    color: #fff;
    line-height: 1.1;
    letter-spacing: -0.5px;
    padding: 8px 16px;
    background: rgba(0, 0, 0, 0.45);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.15);
    display: inline-block;
}

.card-description {
    font-size: 0.95rem;
    color: rgba(255,255,255,0.8);
    margin-bottom: 20px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;     -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
}

.feed-card-footer {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-radius: 18px;
    padding: 7px 9px;
    display: flex;
    align-items: center;
    gap: 12px;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.footer-icon {
    width: 44px;
    height: 44px;
    border-radius: 10px;
    object-fit: cover;
}

.footer-text {
    flex: 1;
    display: flex;
    flex-direction: column;
}

.footer-title {
    font-size: 0.9rem;
    font-weight: 700;
    color: #fff;
}

.footer-subtitle {
    font-size: 0.95rem;
    font-weight: 700;
    color: rgba(255,255,255,0.9);
}



.footer-action-btn {
    background: #fff;
    color: #000;
    padding: 6px 20px;
    border-radius: 50px;
    font-size: 0.85rem;
    font-weight: 800;
    text-transform: uppercase;
    border: none;
}

body.light-mode .feed-card-footer {
    background: rgba(0,0,0,0.05);
    border-color: rgba(0,0,0,0.05);
}
body.light-mode .footer-action-btn {
    background: var(--mobile-primary);
    color: #fff;
}

.feed-section-header {
    padding: 0 1.4rem;
    margin-bottom: 16px;
}
.feed-section-header h2 {
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--text-white);
}

.category-pills-scroll {
    display: flex;
    gap: 12px;
    padding: 0 1.4rem 20px;
    overflow-x: auto;
    scrollbar-width: none;
    -ms-overflow-style: none;
}
.category-pills-scroll::-webkit-scrollbar {
    display: none;
}

.category-pill {
    padding: 10px 24px;
    background: var(--mobile-card-bg);
    border: 1px solid var(--mobile-border);
    border-radius: 50px;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--text-white);
    white-space: nowrap;
    transition: all 0.3s ease;
}

.category-pill.active {
    background: var(--mobile-primary);
    color: #fff;
    border-color: var(--mobile-primary);
    box-shadow: 0 4px 15px rgba(255, 140, 0, 0.3);
}

.featured-header-row {
    padding: 0 1.4rem 12px;
}

.home-grid-section.hidden {
    display: none !important;
}



.card-event {
    background: linear-gradient(135deg, #9b1e7e 0%, #4a2b66 50%, #1a527a 100%);
    box-shadow: 0 10px 25px rgba(155, 30, 126, 0.4);
}
.card-shopping {
    background: linear-gradient(135deg, #005f9e 0%, #408a83 100%);
    box-shadow: 0 10px 25px rgba(0, 95, 158, 0.4);
}
.card-learning {
    background: linear-gradient(135deg, #2e7d32 0%, #1b5e20 100%);
    box-shadow: 0 10px 25px rgba(46, 125, 50, 0.4);
}
.card-service {
    background: linear-gradient(135deg, #a03bff 0%, #1b8eb4 52%, #1b9b5a 90%);
    box-shadow: 0 10px 25px rgba(160, 59, 255, 0.4);
}
.card-realestate {
    background: linear-gradient(135deg, #4a8dc2 0%, #5a5ec4 100%);
    box-shadow: 0 10px 25px rgba(74, 141, 194, 0.4);
}
.card-realestate h3 { color: #FFFFFF !important; }
.card-realestate .card-icon { color: #FFFFFF; opacity: 0.15; }

.card-restaurant {
    background: linear-gradient(135deg, #d35400 0%, #c0392b 100%);
    box-shadow: 0 10px 25px rgba(211, 84, 0, 0.4);
}
.card-grocery {
    background: linear-gradient(135deg, #2c3e50 0%, #8e44ad 46%, #d35400 100%);
    box-shadow: 0 10px 25px rgba(44, 62, 80, 0.4);
}
.card-grocery h3 { color: #FFFFFF !important; }
.card-grocery .card-icon { color: #FFFFFF; opacity: 0.15; }

.card-temple {
    background: linear-gradient(135deg, #c0392b 0%, #8e44ad 55%, #c2185b 100%);
    box-shadow: 0 10px 25px rgba(192, 57, 43, 0.4);
}
.card-temple .card-icon {
    color: #FFD700;
    opacity: 0.15;
    font-size: 6.5rem;
    bottom: -10px;
    right: -10px;
}
.card-event .card-icon { color: white; opacity: 0.15; font-size: 6rem; right: -5px; }
.card-shopping .card-icon { color: #FFFACD; opacity: 0.18; font-size: 6rem; right: -5px; }
.card-learning .card-icon { color: white; opacity: 0.15; font-size: 6rem; right: -5px; }
.card-service .card-icon { color: white; opacity: 0.15; font-size: 6rem; right: -5px; }
.card-restaurant .card-icon { color: white; opacity: 0.15; font-size: 6rem; right: -5px; }
.card-grocery .card-icon { color: white; opacity: 0.15; font-size: 6rem; right: -5px; }
.card-realestate .card-icon { color: white; opacity: 0.15; font-size: 6rem; right: -5px; }
.card-organization {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    box-shadow: 0 10px 25px rgba(118, 75, 162, 0.35);
}
.card-organization h3 { color: white; }
.card-organization .card-icon {
    color: #FFFFFF;
    opacity: 0.15;
    font-size: 6rem;
    right: 5px;
}
.card-owners {
    background: linear-gradient(135deg, #2c3e50 0%, #000000 100%);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.4);
}
.card-owners .card-icon {
    color: #FFFFFF;
    opacity: 0.15;
    font-size: 6rem;
    right: 5px;
}
.card-about {
    background: linear-gradient(135deg, #1C1C1E 0%, #2C2C2E 100%);
    backdrop-filter: blur(30px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #FFFFFF !important;
}
.card-about h3 { text-shadow: none; font-weight: 600; }
.card-about .card-icon {
    color: var(--text-white);
    opacity: 0.12;
    font-size: 5.5rem;
}

.card-admin {
    background: linear-gradient(135deg, #B8860B 0%, #8B4513 100%);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.4);
    color: #FFFFFF !important;
}
.card-admin h3 { color: #FFFFFF !important; }
.card-admin .card-icon {
    color: #FFFFFF;
    opacity: 0.15;
    font-size: 5.5rem;
}

.home-card {
    animation: cardAppear 0.6s cubic-bezier(0.2, 0.8, 0.2, 1) both;
}

@keyframes cardAppear {
    from { opacity: 0; transform: translateY(30px) scale(0.85); filter: blur(10px); }
    to { opacity: 1; transform: translateY(0) scale(1); filter: blur(0); }
}

.home-card:nth-child(1) { animation-delay: 0.1s; }
.home-card:nth-child(2) { animation-delay: 0.15s; }
.home-card:nth-child(3) { animation-delay: 0.2s; }
.home-card:nth-child(4) { animation-delay: 0.25s; }
.home-card:nth-child(5) { animation-delay: 0.3s; }
.home-card:nth-child(6) { animation-delay: 0.35s; }
.home-card:nth-child(7) { animation-delay: 0.4s; }
.home-card:nth-child(8) { animation-delay: 0.45s; }
.home-card:nth-child(9) { animation-delay: 0.5s; }
.home-card:nth-child(10) { animation-delay: 0.55s; }
.home-card:nth-child(11) { animation-delay: 0.6s; }
.home-card:nth-child(12) { animation-delay: 0.65s; }

.mobile-hero {
    position: relative;
    width: 100%;
    height: auto;
    padding-top: calc(20px + env(safe-area-inset-top));
    padding-bottom: 2rem;
    overflow: hidden;
    background: var(--bg-mesh);
}

.hero-header-placeholder {
    height: 60px;
    width: 100%;
}


.hero-image-container {
    display: none;
}

.hero-overlay-gradient {
    display: none;
}

.mobile-hero h1,
.mobile-hero p,
.mobile-hero .stats-badge span {
    color: #1D1D1F !important;
}

.mobile-hero .stats-badge {
    border-color: rgba(255, 255, 255, 0.2) !important;
    background: rgba(255, 255, 255, 0.1) !important;
}

.hero-content {
    position: relative;
    z-index: 10;
    padding: 2.5rem 1.5rem 0.5rem;     display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.stats-badge {
    background: rgba(255, 255, 255, 0.1);
    backdrop-filter: blur(12px);
    border: 1px solid rgba(255, 255, 255, 0.2);
    padding: 0.5rem 1rem;
    border-radius: 100px;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 2rem;
    animation: fadeInUp 0.8s ease;
}

.stats-badge i {
    color: var(--mobile-primary);
    font-size: 0.9rem;
}

.stats-badge span {
    font-size: 0.8rem;
    font-weight: 600;
}

h1 {
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", system-ui, sans-serif;
    font-size: 2.6rem;
    line-height: 1.1;
    font-weight: 800;
    margin-bottom: 1.2rem;
    letter-spacing: -1.5px;
    color: var(--text-white);
}

.highlight {
    background: linear-gradient(135deg, #FF5E00 0%, #FF0000 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    display: inline-block;
}

p {
    font-size: 0.95rem;
    color: var(--text-muted);
    line-height: 1.5;
    max-width: 90%;
    margin-bottom: 2.5rem;
}

.mobile-search-row {
    width: 100%;
    background: rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 20px;
    padding: 0.8rem;
    display: flex;
    align-items: center;
    gap: 0.6rem;
    margin-bottom: 2.5rem;
}

.select-wrapper {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
}

.header-right {
    display: flex;
    align-items: center;
    gap: 8px;
}

.location-label {
    font-size: 0.65rem;
    color: rgba(255,140,0,0.8);
    background: rgba(255,140,0,0.1);
    padding: 2px 8px;
    border-radius: 10px;
    white-space: nowrap;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 1px solid rgba(255,140,0,0.2);
}

.gps-status {
    width: 10px;
    height: 10px;
    min-width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #555;
    transition: all 0.3s ease;
    cursor: pointer;
    box-shadow: 0 0 8px rgba(0,0,0,0.4);
    z-index: 1001;
    flex-shrink: 0;
}



.gps-status.searching {
    background: #FF8C00;
    box-shadow: 0 0 15px #FF8C00;
    animation: gpsPulse 1s infinite alternate;
}

.gps-status.active {
    background: #00C6FF;
    box-shadow: 0 0 15px #00C6FF;
}

.gps-status.error {
    background: #ff3b30;
    box-shadow: 0 0 15px #ff3b30;
}

@keyframes gpsPulse {
    from { opacity: 0.4; transform: scale(0.85); }
    to { opacity: 1; transform: scale(1.15); }
}

.location-select {
    padding: 8px 12px;
    border-radius: 12px;
    border: 1px solid var(--mobile-border);
    background: rgba(255, 255, 255, 0.05);
    color: #fff;
    font-size: 0.9rem;
    font-weight: 600;
    outline: none;
    cursor: pointer;
    backdrop-filter: blur(10px);
    appearance: none;
    padding-right: 32px;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='white'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3Cpath%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    background-size: 14px;
}

.select-wrapper select {
    width: 100%;
    background: none;
    border: none;
    color: #fff;
    font-size: 0.85rem;
    font-weight: 600;
    padding: 0.4rem 1.4rem 0.4rem 0;
    -webkit-appearance: none;
    appearance: none;
}

.select-wrapper i {
    position: absolute;
    right: 4px;
    font-size: 0.7rem;
    color: var(--text-muted);
}

.explore-btn {
    background: var(--mobile-explore-btn);
    color: #fff;
    border: none;
    padding: 0.6rem 1.2rem;
    border-radius: 14px;
    font-weight: 700;
    font-size: 0.85rem;
}

.mobile-sub-grid-container {
    width: 100vw;
    margin-left: -1.5rem;     overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    padding-bottom: 10px;
}

.mobile-sub-grid-container::-webkit-scrollbar {
    display: none;
}

.mobile-sub-grid {
    display: flex;
    flex-wrap: nowrap;
    gap: 16px;
    padding: 0 1.5rem 20px;
    scroll-snap-type: x mandatory;
}

.mobile-sub-grid.compact {
    gap: 12px;
}

.mobile-sub-grid.compact .sub-cat-btn {
    flex: 0 0 calc(50% - 1.5rem);     height: 140px;
    border-radius: 18px;
}

.mobile-sub-grid.compact .card-sub-title {
    font-size: 0.95rem;
}

.mobile-sub-grid-container.owners-actions-container {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    overflow-x: hidden;
    overflow-y: visible;
    padding-bottom: 20px;
}

.mobile-sub-grid.owners-actions-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
    padding: 0 0.5rem;
    scroll-snap-type: none;
}

.mobile-sub-grid.owners-actions-grid.compact .sub-cat-btn,
.mobile-sub-grid.owners-actions-grid .sub-cat-btn {
    flex: none;
    width: 100%;
    height: auto;
    aspect-ratio: 1.75 / 1;
    border-radius: 24px;
    scroll-snap-align: none;
}

.mobile-sub-grid.owners-actions-grid.compact .card-sub-title {
    font-size: 1.1rem;
}

.mobile-hero.mobile-l2-view .hero-content {
    align-items: stretch;
    text-align: center;
    padding: 0.85rem 1rem 0.75rem;
}

.mobile-hero.mobile-l2-view {
    padding-top: calc(8px + env(safe-area-inset-top));
    padding-bottom: 0;
}

.mobile-hero.mobile-l2-view .hero-header-placeholder {
    height: 12px;
}

.mobile-hero.mobile-l2-view #mobileHeroTitle {
    width: auto;
    max-width: calc(100% - 112px);
    margin: 0 auto 2rem;
    font-size: 2rem;
    line-height: 1.05;
    letter-spacing: 0;
    white-space: normal;
    overflow-wrap: anywhere;
    text-wrap: balance;
}

.mobile-hero.mobile-l2-view #mobileHeroSubtitle {
    display: none !important;
}

.mobile-hero.mobile-news-hero {
    padding-top: calc(6px + env(safe-area-inset-top));
    padding-bottom: 0;
}

.mobile-hero.mobile-news-hero .hero-content {
    padding: 0.75rem 1.5rem 0;
}

.mobile-hero.mobile-news-hero .hero-header-placeholder {
    height: 18px;
}

.mobile-hero.mobile-news-hero #mobileHeroTitle {
    margin-bottom: 0.8rem;
}

.mobile-hero.mobile-news-hero #mobileHeroSubtitle {
    margin-bottom: 0;
}

.mobile-hero.mobile-trending-hero {
    padding-top: calc(6px + env(safe-area-inset-top));
    padding-bottom: 0;
}

.mobile-hero.mobile-trending-hero .hero-content {
    padding: 0.75rem 1.5rem 0;
}

.mobile-hero.mobile-trending-hero .hero-header-placeholder {
    height: 18px;
}

.mobile-hero.mobile-trending-hero #mobileHeroTitle {
    max-width: min(calc(100% - 28px), 310px);
    margin-bottom: 0.75rem;
    font-size: 1.58rem;
    line-height: 1.05;
    letter-spacing: 0;
    white-space: normal;
    overflow-wrap: normal;
    text-wrap: balance;
    text-shadow: none !important;
}

.mobile-hero.mobile-trending-hero #mobileHeroSubtitle {
    display: none !important;
}

@media (max-width: 390px) {
    .mobile-hero.mobile-l2-view #mobileHeroTitle {
        font-size: 1.8rem;
    }

    .mobile-hero.mobile-trending-hero #mobileHeroTitle {
        font-size: 1.46rem;
    }
}

@media (max-width: 360px) {
    .mobile-hero.mobile-l2-view #mobileHeroTitle {
        font-size: 1.62rem;
    }

    .mobile-hero.mobile-trending-hero #mobileHeroTitle {
        font-size: 1.34rem;
    }
}

.mobile-sub-grid-container.mobile-l2-container {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    overflow-x: hidden;
    overflow-y: visible;
    padding-bottom: calc(130px + env(safe-area-inset-bottom));
}

.mobile-sub-grid-container.cinema-l2-container {
    width: 100%;
    margin-left: 0;
    overflow-x: hidden;
    overflow-y: visible;
    padding-bottom: calc(130px + env(safe-area-inset-bottom));
}

.mobile-sub-grid.mobile-l2-grid,
.mobile-sub-grid.cinema-l2-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 0 0 24px;
    scroll-snap-type: none;
}

.mobile-sub-grid.mobile-l2-grid .sub-cat-btn,
.mobile-sub-grid.cinema-l2-grid .sub-cat-btn {
    flex: none;
    width: 100%;
    height: auto;
    aspect-ratio: 3 / 2;
    border-radius: 24px;
    scroll-snap-align: none;
    overflow: hidden;
}

.mobile-sub-grid.mobile-l2-grid .card-sub-title,
.mobile-sub-grid.cinema-l2-grid .card-sub-title {
    font-size: 1.1rem;
}

.mobile-sub-grid.cinema-l2-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px 6px;
    padding: 0 0.5rem 24px;
}

.mobile-sub-grid-container.cinema-l2-container {
    width: 100vw;
    margin-left: -1rem;
    overflow-x: hidden;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card {
    height: auto;
    aspect-ratio: auto;
    background: transparent;
    border-radius: 0;
}

.cinema-l2-language-label {
    align-self: flex-start;
    display: inline-flex;
    min-height: 28px;
    align-items: center;
    justify-content: center;
    padding: 7px 11px;
    margin: 0 0 auto;
    border-radius: 10px;
    background: linear-gradient(135deg, var(--cinema-language-1, #ffd700), var(--cinema-language-2, #ff5e00));
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    opacity: 1 !important;
    box-shadow: 0 10px 22px var(--cinema-language-glow, rgba(255, 94, 0, 0.28));
    font-size: 0.68rem;
    font-weight: 900;
    line-height: 1;
    letter-spacing: 0.08em;
    text-shadow: none !important;
}

.cinema-l2-movie-card .card-content-overlay {
    align-items: flex-start;
    justify-content: space-between;
    padding: 18px;
    border-radius: 30px;
}

.cinema-l2-movie-card .card-footer-row {
    width: 100%;
}

.cinema-l2-poster-frame {
    display: block;
    position: relative;
    width: 100%;
    aspect-ratio: 2 / 3;
    overflow: hidden;
    border-radius: 18px;
    background: #130f1b;
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.cinema-l2-skeleton {
    width: 100%;
    height: auto;
    aspect-ratio: 2 / 3;
    border-radius: 24px;
    background: linear-gradient(90deg, rgba(255,255,255,0.06), rgba(255,255,255,0.14), rgba(255,255,255,0.06));
    background-size: 220% 100%;
    animation: cinemaSkeletonPulse 1.2s ease-in-out infinite;
}

.sub-cat-btn {
    flex: 0 0 82%;
    height: auto;
    aspect-ratio: 3 / 2;
    border-radius: 24px;
    overflow: hidden;
    position: relative;
    background: #000;
    border: 1px solid rgba(255,255,255,0.12);
    scroll-snap-align: center;
    box-shadow: 0 12px 24px rgba(0,0,0,0.15);
    transition: transform 0.3s ease;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 0;
    text-align: left;
}

.mobile-sub-grid .sub-cat-btn:active {
    transform: scale(0.97) !important;
}

.sub-cat-btn .card-bg-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: 1;
    width: 100%;
}

.card-content-overlay {
    position: absolute;
    inset: 0;
        background: linear-gradient(to bottom, transparent 90%, rgba(0,0,0,0.3) 100%);
    z-index: 2;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 20px;
}

.card-sub-info {
    display: flex;
    align-items: center;
    width: 100%;
}

.card-sub-text {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    padding: 8px 16px;
    border-radius: 14px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    max-width: 90%;
}

.card-sub-title {
    font-size: 1.1rem;
    font-weight: 800;
    color: #fff;
    margin: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.sub-cat-btn.active .card-sub-text {
    background: rgba(255, 94, 0, 0.25);
    border-color: rgba(255, 94, 0, 0.4);
}



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



.sub-cat-btn.active {
    box-shadow: 0 10px 30px rgba(255, 94, 0, 0.3);
}



@keyframes rotateMobileBeam {
    from { transform: translate(-50%, -50%) rotate(0deg); }
    to { transform: translate(-50%, -50%) rotate(360deg); }
}

.sub-cat-btn.active .icon-wrapper img {
    position: relative;
    z-index: 6;
    border-radius: 18.5px; }



.sub-cat-btn span {
    font-size: 0.75rem;
    font-weight: 700;
    color: rgba(255, 255, 255, 0.8);
    transition: color 0.3s, transform 0.3s;
    margin-top: 4px;
    text-transform: capitalize;
}

.sub-cat-btn.no-image {
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 16px;
    padding: 12px 8px;
    min-height: 70px;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.mobile-sub-grid.classifieds-filter-grid {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 5px;
    padding: 0 0.5rem 24px;
}

.mobile-sub-grid-container.classifieds-filter-container {
    width: 100vw !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    overflow-x: hidden !important;
}

.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn {
    width: 100%;
    height: auto;
    min-width: auto;
    min-height: 60px;
    flex: none;
    display: flex;
    flex-direction: column;
    gap: 0;
    aspect-ratio: 1.75 / 1;
    padding: 0;
    border-radius: 16px;
    background: color-mix(in srgb, var(--cd-theme-solid, var(--category-accent-1, var(--mobile-primary))) 14%, var(--cd-control-bg, rgba(255, 255, 255, 0.05)));
    border: 1px solid color-mix(in srgb, var(--cd-theme-solid, var(--category-accent-2, var(--mobile-primary))) 36%, var(--mobile-border, rgba(255, 255, 255, 0.12)));
    box-shadow: 0 12px 24px var(--cd-shadow, rgba(0, 0, 0, 0.15));
    justify-content: flex-end;
    align-items: stretch;
    overflow: hidden;
    text-align: left;
    white-space: normal;
}

.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn .card-content-overlay {
    justify-content: flex-end;
    align-items: flex-end;
    padding: 8px 10px;
    text-align: right;
}

.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn .card-sub-text {
    display: inline-flex;
    align-self: flex-end;
    width: max-content;
    max-width: calc(100% - 20px);
    min-height: 34px;
    box-sizing: border-box;
    padding: 7px 10px;
}

.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn .card-sub-title {
    width: max-content;
    max-width: 100%;
    font-size: 0.82rem;
    line-height: 1.15;
    text-align: right;
    white-space: normal;
}

.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn .card-sub-info {
    justify-content: flex-end;
}

.mobile-sub-grid.classifieds-filter-grid .classified-filter-icon,
.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn > i {
    position: absolute;
    top: 8px;
    left: 10px;
    right: auto;
    z-index: 3;
    width: 54px;
    height: 54px;
    display: grid;
    place-items: center;
    border-radius: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    pointer-events: none;
}

.mobile-sub-grid.classifieds-filter-grid .classified-filter-icon i,
.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn > i {
    font-size: 2.34rem;
    line-height: 1;
    background: linear-gradient(135deg, var(--classified-icon-1, #ff8a00), var(--classified-icon-2, #f23673));
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    -webkit-text-fill-color: transparent;
    filter: drop-shadow(0 8px 12px rgba(0, 0, 0, 0.18));
}

.mobile-sub-grid.classifieds-filter-grid .sub-cat-btn.classified-filter-btn.active {
    transform: translateY(-5px);
}

.classifieds-hero-search {
    position: relative;
    width: min(100%, 560px);
    margin: 12px auto 20px;
    display: flex;
    align-items: center;
}

.classifieds-hero-search.hidden {
    display: none !important;
}

.classifieds-hero-search-field {
    width: 100%;
    min-height: 50px;
    display: flex;
    align-items: center;
    gap: 11px;
    padding: 0 50px 0 16px;
    border: 1px solid color-mix(in srgb, var(--cd-theme-solid, var(--mobile-primary)) 22%, var(--mobile-border, rgba(0, 0, 0, 0.08)));
    border-radius: 18px;
    background: color-mix(in srgb, #ffffff 92%, var(--cd-primary, var(--mobile-primary)) 8%);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.1);
}

.classifieds-hero-search-field i {
    color: var(--mobile-primary);
    font-size: 0.9rem;
    flex: 0 0 auto;
}

.classifieds-hero-search-field input {
    width: 100%;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: #1d1d1f;
    -webkit-text-fill-color: #1d1d1f;
    font-size: 0.95rem;
    font-weight: 750;
    line-height: 1.2;
}

.classifieds-hero-search-field input::placeholder {
    color: rgba(29, 29, 31, 0.56);
    -webkit-text-fill-color: rgba(29, 29, 31, 0.56);
}

.classifieds-hero-search-field input::-webkit-search-cancel-button {
    -webkit-appearance: none;
    appearance: none;
}

.classifieds-hero-search-field:focus-within {
    border-color: color-mix(in srgb, var(--cd-theme-solid, var(--mobile-primary)) 58%, transparent);
    box-shadow: 0 14px 28px rgba(0, 0, 0, 0.1), 0 0 0 3px color-mix(in srgb, var(--cd-theme-solid, var(--mobile-primary)) 15%, transparent);
}

.classifieds-hero-search-clear {
    position: absolute;
    top: 50%;
    right: 7px;
    width: 36px;
    height: 36px;
    display: grid;
    place-items: center;
    transform: translateY(-50%);
    border: 0;
    border-radius: 14px;
    background: color-mix(in srgb, var(--cd-theme-solid, var(--mobile-primary)) 12%, transparent);
    color: var(--mobile-primary);
    cursor: pointer;
}

.classifieds-hero-search-clear.hidden {
    display: none !important;
}

.classifieds-hero-search-clear:focus-visible {
    outline: 2px solid var(--mobile-primary);
    outline-offset: 2px;
}



.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(5px);
    z-index: 2500;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.menu-overlay.active {
    opacity: 1;
    visibility: visible;
}

.side-menu {
    position: fixed;
    top: 0;
    left: -280px;
    width: 280px;
    height: 100%;
    background: var(--mobile-bg);
    border-right: 1px solid var(--mobile-border);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    z-index: 3000;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    box-shadow: 10px 0 30px rgba(0, 0, 0, 0.5);
    padding: 1.5rem;
    display: flex;
    flex-direction: column;
}

.side-menu.active {
    left: 0;
}

.side-menu-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 1.2rem;
    padding-bottom: 0.8rem;
    border-bottom: 1px solid var(--mobile-border);
    flex-shrink: 0;
}

.side-menu-content {
    flex-grow: 1;
    overflow-y: auto;
    padding-bottom: 2rem;
}

.side-menu-header .logo {
    font-size: 1.4rem;
}

.menu-section h3 {
    font-size: 0.8rem;
    text-transform: uppercase;
    color: var(--text-muted);
    letter-spacing: 1px;
    margin-bottom: 0.6rem;
}

.menu-link {
    width: 100%;
    display: flex;
    align-items: center;
    gap: 1rem;
    background: none;
    border: none;
    color: var(--text-white);
    padding: 0.8rem 1rem;
    font-size: 1rem;
    font-weight: 600;
    border-radius: 12px;
    transition: all 0.2s;
    text-align: left;
}

.menu-link i {
    width: 20px;
    color: var(--mobile-primary);
    font-size: 1.2rem;
}

.menu-link:active {
    background: rgba(255, 255, 255, 0.1);
    transform: scale(0.98);
}

.admin-link-menu {
    text-decoration: none !important;
    box-sizing: border-box;
}

.admin-link-menu:hover, .admin-link-menu:focus {
    background: rgba(255, 255, 255, 0.05);
}

.add-listing-btn-menu,
.promote-btn-menu {
    width: 100%;
    border: none;
    padding: 0.8rem 1rem;
    border-radius: 12px;
    font-weight: 700;
    font-size: 1rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    margin-top: 0.5rem;
    color: #FFFFFF;
    position: relative;
    transition: all 0.3s ease;
}



.add-listing-btn-menu {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%);
    box-shadow: 0 4px 15px rgba(255, 94, 0, 0.25);
    margin-bottom: 0.6rem;
}



.promote-btn-menu {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%);
    box-shadow: 0 4px 15px rgba(255, 94, 0, 0.22);
}





.add-listing-btn-menu:active,
.promote-btn-menu:active {
    transform: scale(0.98);
}

.promote-btn-menu i,
.add-listing-btn-menu i {
    font-size: 1.1rem;
}

.bottom-nav {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: calc(74px + env(safe-area-inset-bottom));
    background: rgba(15, 15, 15, 0.9);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    display: flex;
    align-items: center;
    justify-content: space-around;
    padding: 0 0.5rem calc(5px + env(safe-area-inset-bottom));
    z-index: 2000;
}


.nav-tab {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    background: none;
    border: none;
    color: var(--text-muted);
    padding: 0.6rem 0.5rem;     border-radius: 12px;
    transition: all 0.3s ease;
    flex: 1;
}

.nav-tab i {
    font-size: 1.35rem;
}

.nav-tab span {
    font-size: 0.65rem;     font-weight: 600;
    white-space: nowrap; }

.nav-tab.active {
    position: relative;
    overflow: hidden;
    color: #fff !important;
    background-size: 200% 200% !important;
    animation: nebulaFlow 2.5s ease-in-out infinite alternate;
    transition: all 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
    box-shadow: 0 5px 15px var(--category-glow, rgba(255,140,0,0.3));
    font-weight: 800;
}

.nav-tab.active i {
    transform: scale(1.15);
    transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes nebulaFlow {
    0% { background-position: 0% 50%; }
    100% { background-position: 100% 50%; }
}

.nav-tab.active[data-category="event"] { --category-glow: rgba(59, 207, 212, 0.5); background: linear-gradient(135deg, #3bcfd4, #fc9305, #f20094, #3bcfd4); }
.nav-tab.active[data-category="shopping"] { --category-glow: rgba(237, 227, 66, 0.5); background: linear-gradient(135deg, #ede342, #ff51eb, #ede342); }
.nav-tab.active[data-category="learning"] { --category-glow: rgba(255, 206, 6, 0.5); background: linear-gradient(135deg, #ffce06, #6c960d, #ffce06); }
.nav-tab.active[data-category="service"] { --category-glow: rgba(0, 198, 255, 0.5); background: linear-gradient(135deg, #00C6FF, #0072FF, #00C6FF); }
.nav-tab.active[data-category="realestate"] { --category-glow: rgba(240, 147, 251, 0.5); background: linear-gradient(135deg, #F093FB, #F5576C, #F093FB); }
.nav-tab.active[data-category="restaurant"] { --category-glow: rgba(42, 141, 8, 0.5); background: linear-gradient(135deg, #2a8d08, #f2e713, #f71e06, #2a8d08); }
.nav-tab.active[data-category="cinema"] { --category-glow: rgba(255, 0, 204, 0.5); background: linear-gradient(135deg, #FF00CC, #3333FF, #FF9900, #FF00CC); }
.nav-tab.active[data-category="owners"] { --category-glow: rgba(255, 94, 0, 0.5); background: linear-gradient(135deg, #ffb000, #ff7a00, #ff5e00, #ffb000); }
.nav-tab.active[data-category="classifieds"] { --category-glow: rgba(242, 54, 115, 0.48); background: linear-gradient(135deg, #ff8a00, #f23673, #ff8a00); }


.mobile-results {
    padding: 0 1.5rem 100px;
    background: var(--mobile-bg);
}

.results-list {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.results-list.cinema-mode {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.cinema-card {
    height: 100%;
    display: flex;
    flex-direction: column;
}

.listing-card {
    background: var(--mobile-card-bg);
    border-radius: 20px;
    overflow: hidden;
    border: 1px solid var(--mobile-border);
    backdrop-filter: blur(10px);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    flex-shrink: 0;
    width: 100%;
    display: flex;
    flex-direction: column;
}

.listing-card:active {
    transform: scale(0.98);
}

.card-image {
    position: relative;
    height: auto;
    aspect-ratio: 1.35 / 1;
    line-height: 0;
    overflow: hidden;
}

.mobile-results .results-list .listing-card:not(.event-card):not(.cinema-card) .card-image {
    height: auto !important;
    aspect-ratio: 1.65 / 1 !important;
}

.cinema-card .card-image {
    height: auto !important;
    aspect-ratio: 2 / 3 !important;
}

.mobile-results .results-list .listing-card.cinema-card .card-image {
    aspect-ratio: 2 / 3 !important;
}

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

.results-list.event-mode .card-image {
    height: auto !important;
    aspect-ratio: 1.65 / 1 !important;
    line-height: 0;
}

.mobile-results .results-list .listing-card.event-card .card-image {
    aspect-ratio: 1.65 / 1 !important;
}

.results-list.event-mode .card-image img {
    display: block;
    object-position: center top;
}

.results-list.event-mode .card-type-badge {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    line-height: 1;
}

.card-type-badge {
    position: absolute;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    line-height: 1;
    bottom: 12px;
    left: 12px;
    background: rgba(0, 0, 0, 0.25);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    padding: 5px 14px;
    border-radius: 12px;
    font-size: 0.62rem;
    font-weight: 800;
    color: #fff;
    letter-spacing: 0.8px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    box-shadow: 0 4px 15px rgba(0,0,0,0.2);
}

.cinema-card .card-type-badge {
    position: absolute !important;
    top: auto !important;
    bottom: 15px !important;
    left: 15px !important;
    background: #FF5E00 !important;     color: #FFFFFF !important;
    font-size: 0.85rem !important;
    font-weight: 900 !important;
    padding: 6px 14px !important;
    border-radius: 8px !important;
    box-shadow: 0 6px 20px rgba(255, 94, 0, 0.5) !important;
    border: 1.5px solid rgba(255,255,255,0.4) !important;
    letter-spacing: 1px !important;
    z-index: 20 !important;
    text-transform: uppercase !important;
}

body.light-mode .results-list.cinema-mode .listing-card.cinema-card .card-type-badge,
body.light-mode .cinema-card .card-image .card-type-badge {
    background: #FF5E00 !important;
    color: #FFFFFF !important;
    font-weight: 900 !important;
    border-color: rgba(255, 255, 255, 0.4) !important;
}

#listingDetailsModal.cinema-mode .details-header #detailsModalImg {
    object-fit: cover !important;
    background: transparent !important;
}

.playing-today-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    background: #FF5E00 !important;
    color: #fff !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    padding: 4px 10px !important;
    border-radius: 6px !important;
    box-shadow: 0 4px 12px rgba(255, 94, 0, 0.4) !important;
    z-index: 5;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 1px solid rgba(255,255,255,0.3) !important;
}

.card-info {
    padding: 1.2rem 1.2rem 0.2rem !important;
}

.cinema-card .card-info {
    padding: 10px 8px !important;
}

.cinema-card .card-top-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 0;
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
}

.cinema-card .card-header-row {
    margin-bottom: 0px !important;
}

.cinema-card h3 {
    font-size: 0.95rem !important;
    font-weight: 800;
    line-height: 1.2;
    margin: 0.2rem 0 0.9rem;
    padding-bottom: 0.85rem;
    min-height: 2.8rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.11);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

body.light-mode .cinema-card h3 {
    border-bottom-color: rgba(0, 0, 0, 0.09);
}

.cinema-card .contact-stack {
    margin: 4px 0 !important;
}

.cinema-card .contact-link {
    background: var(--modal-inner-bg) !important;
    border-radius: 14px !important;
    border: 1px solid var(--mobile-border) !important;
    display: flex !important;
    align-items: center !important;
    padding: 8px 10px !important;
    gap: 12px !important;
    margin-bottom: 10px !important;
    text-decoration: none !important;
    color: var(--text-white) !important;
}

.cinema-card .contact-link i {
    background: rgba(255, 140, 0, 0.1) !important;
    color: var(--mobile-primary) !important;
    border: 1px solid rgba(255, 140, 0, 0.2) !important;
    width: 38px !important;
    height: 38px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    font-size: 1.1rem !important;
    flex-shrink: 0 !important;
}

.cinema-card .contact-text label {
    display: block;
    font-size: 0.65rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    color: rgba(0, 0, 0, 0.45) !important;
    margin-bottom: 2px !important;
}

.cinema-card .contact-text span {
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    color: var(--text-white) !important;
}

.verified-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: #1B5E20 !important;     color: #FFFFFF !important;
    padding: 3px 10px;
    border-radius: 8px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: none;     letter-spacing: 0.2px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

.verified-badge i {
    color: #FFFFFF !important;
}

.card-info h3 {
    font-size: 1.15rem;
    font-weight: 800;
    margin-bottom: 0;
    line-height: 1.25;
    letter-spacing: -0.5px;
}

.trust-row {
    margin: 0 0 12px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.11) !important;
}

.card-header-row {
    margin-bottom: 12px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.11) !important;
}

body.light-mode .trust-row,
body.light-mode .card-header-row {
    border-bottom-color: rgba(0, 0, 0, 0.09) !important;
}

.contact-stack {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 10px 0 4px;
    background: transparent;
    border: none;
}


.listing-card {
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}

.card-footer {
    display: none !important;
    align-items: center;
    justify-content: space-between;
    padding: 0 !important;
    margin: 0 !important;
    border-top: none !important;
}

.footer-left, .footer-center, .footer-right {
    display: flex;
    align-items: center;
    flex: 1;
}

.footer-left {
    justify-content: flex-start;
}

.footer-center {
    justify-content: center;
}

.footer-right {
    justify-content: flex-end;
    gap: 6px;
    font-size: 0.85rem;
    color: var(--text-white);
    font-weight: 600;
}

.card-distance {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--mobile-primary);
}

.footer-right i {
    color: #ff5e00;
}


.contact-link:active {
    color: var(--text-muted);
}

.loading, .no-results, .error {
    text-align: center;
    padding: 3rem 0;
    color: var(--text-muted);
    font-style: italic;
}

.cd-reliability-state {
    width: 100%;
    box-sizing: border-box;
    color: var(--cd-text-main, var(--text-white, #ffffff));
    font-style: normal;
    scroll-margin-top: 96px;
}

.cd-reliability-state__status {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin: 0 0 16px;
    padding: 13px 14px;
    border: 1px solid var(--cd-border, var(--mobile-border, rgba(255, 255, 255, 0.12)));
    border-radius: 16px;
    background: var(--cd-card-bg, rgba(255, 255, 255, 0.06));
    box-shadow: 0 16px 38px var(--cd-shadow, rgba(0, 0, 0, 0.18)), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.cd-reliability-state__status i {
    color: var(--cd-primary, var(--mobile-primary, #ff5e00));
    margin-top: 2px;
}

.cd-reliability-state__status strong,
.cd-reliability-state__status span {
    display: block;
    text-align: left;
    letter-spacing: 0;
}

.cd-reliability-state__status strong {
    color: var(--cd-text-main, var(--text-white, #ffffff));
    font-size: 0.96rem;
    font-weight: 850;
    line-height: 1.25;
}

.cd-reliability-state__status span {
    margin-top: 3px;
    color: var(--cd-text-muted, var(--text-muted, rgba(255, 255, 255, 0.66)));
    font-size: 0.84rem;
    font-weight: 560;
    line-height: 1.35;
}

.cd-skeleton-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 14px;
}

.cd-skeleton-card {
    min-height: 188px;
    padding: 14px;
    border: 1px solid var(--cd-border, var(--mobile-border, rgba(255, 255, 255, 0.10)));
    border-radius: 18px;
    background: var(--cd-card-bg, rgba(255, 255, 255, 0.055));
    box-shadow: 0 16px 36px var(--cd-shadow, rgba(0, 0, 0, 0.16)), inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.cd-skeleton-media,
.cd-skeleton-line,
.cd-skeleton-actions i {
    display: block;
    border-radius: 12px;
    background: linear-gradient(90deg, rgba(255, 255, 255, 0.06), rgba(255, 255, 255, 0.14), rgba(255, 255, 255, 0.06));
    background-size: 220% 100%;
    animation: cd-skeleton-shimmer 1.4s ease-in-out infinite;
}

.cd-skeleton-media {
    height: 94px;
    margin-bottom: 14px;
}

.cd-reliability-state--event .cd-skeleton-media,
.cd-reliability-state--trending .cd-skeleton-media {
    height: 136px;
}

.cd-reliability-state--search .cd-skeleton-media {
    height: 42px;
}

.cd-skeleton-line {
    height: 12px;
    margin-top: 9px;
}

.cd-skeleton-line--title {
    width: 72%;
    height: 17px;
}

.cd-skeleton-line--short {
    width: 46%;
}

.cd-skeleton-actions {
    display: flex;
    gap: 9px;
    margin-top: 16px;
}

.cd-skeleton-actions i {
    width: 82px;
    height: 30px;
    border-radius: 999px;
}

body.light-mode .cd-skeleton-media,
body.light-mode .cd-skeleton-line,
body.light-mode .cd-skeleton-actions i {
    background: linear-gradient(90deg, rgba(15, 23, 42, 0.055), rgba(15, 23, 42, 0.12), rgba(15, 23, 42, 0.055));
    background-size: 220% 100%;
}

@keyframes cd-skeleton-shimmer {
    0% { background-position: 120% 0; }
    100% { background-position: -120% 0; }
}

.fadeIn {
    animation: fadeIn 0.5s ease forwards;
}

@keyframes fadeIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

.details-modal {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.45) !important;     backdrop-filter: blur(5px) !important;     z-index: 5000;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
}

.details-modal.active {
    opacity: 1;
    visibility: visible;
}

.modal-content {
    background: transparent !important;
    width: 97%;
    max-height: 90vh;
    height: auto;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    overflow-y: auto;
    position: relative;
    transform: translateY(20px);
    transition: all 0.3s ease;
}

.details-modal.active .modal-content {
    transform: translateY(0);
}

body.light-mode .modal-content {
    background: #FFFFFF !important;
    color: #1D1D1F;
    box-shadow: 0 10px 40px rgba(0,0,0,0.2) !important;
    border-radius: 28px !important;
}

body.light-mode #schedule7DayModal .modal-content {
    background: #ffffff !important;
    color: #17171c !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 22px 60px rgba(15, 23, 42, 0.18) !important;
}

body.light-mode #schedule7DayModal .modal-title {
    color: #17171c !important;
}

body.light-mode #schedule7DayModal #scheduleModalContent > div {
    background: rgba(15, 23, 42, 0.04) !important;
}

.modal-content.listing-card-vibe {
    background: var(--mobile-card-bg) !important;
    border-radius: 28px !important;
    overflow: hidden !important;
}

.modal-content.listing-card-vibe .details-header {
    height: 250px !important;
    width: 100% !important;
    position: relative !important;
    background: #000 !important;
}

.modal-content.listing-card-vibe .details-header #detailsModalImg {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover;
}

.modal-content.listing-card-vibe .details-body {
    padding: 24px !important;
}

.modal-content.listing-card-vibe #detailsModalTitle {
    font-size: 1.8rem !important;
    font-weight: 800 !important;
    margin-bottom: 12px !important;
    color: var(--text-white) !important;
}

.modal-content:active {
    transform: none;
}

.close-modal {
    position: absolute;
    top: 1rem;
    right: 1rem;
    background: rgba(0, 0, 0, 0.6);
    border: none;
    color: white;
    font-size: 1.8rem;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    z-index: 100;
    display: flex;
    align-items: center;
    justify-content: center;
}

.premium-modal-header {
    height: 140px;
    position: relative;
}

.premium-header-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.premium-header-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 1.5rem;
    background: linear-gradient(to top, rgba(0,0,0,0.9), transparent);
}

.premium-header-overlay h2 {
    font-size: 1.4rem;
    margin-bottom: 0.2rem;
}

.premium-header-overlay p {
    font-size: 0.85rem;
    opacity: 0.8;
}

.promote-modal-body {
    padding: 1.5rem;
}

.promote-form {
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
}

.form-group {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.form-group label {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--text-muted);
}

.input-with-icon {
    position: relative;
    display: flex;
    align-items: center;
}

.input-with-icon i {
    position: absolute;
    left: 1rem;
    color: var(--text-muted);
}

.input-with-icon input, .input-with-icon select, .input-with-icon textarea {
    width: 100%;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: #fff;
    padding: 0.8rem 1rem 0.8rem 2.8rem;
    border-radius: 10px;
    outline: none;
    font-size: 0.95rem;
}

body.light-mode .input-with-icon input,
body.light-mode .input-with-icon select,
body.light-mode .input-with-icon textarea {
    background: #F2F2F7;
    border: 1.5px solid rgba(0, 0, 0, 0.1);
    color: #000000;
}

body.light-mode .input-with-icon input::placeholder,
body.light-mode .input-with-icon textarea::placeholder {
    color: #888;
}

body.light-mode .form-group label,
body.light-mode .input-with-icon i {
    color: #1D1D1F;
    font-weight: 700;
}

.input-with-icon textarea {
    padding-top: 1rem;
}

.premium-submit-btn {
    background: var(--mobile-explore-btn);
    color: #000;
    border: none;
    padding: 1rem;
    border-radius: 12px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.8rem;
    margin-top: 1rem;
}

.form-message {
    padding: 0.8rem;
    border-radius: 8px;
    font-size: 0.85rem;
    text-align: center;
}

.form-message.success {
    background: rgba(56, 239, 125, 0.15);
    color: #38ef7d;
}

.form-message.error {
    background: rgba(255, 0, 0, 0.15);
    color: #ff4d4d;
}

.form-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 15px;
}

.full-width {
    grid-column: 1 / -1;
}

.premium-form .form-group label {
    margin-bottom: 8px;
    display: block;
    color: rgba(255,255,255,0.5);
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.premium-form .input-with-icon input,
.premium-form .input-with-icon select,
.premium-form .input-with-icon textarea {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid rgba(255, 255, 255, 0.08);
    transition: all 0.3s ease;
}

.premium-form .input-with-icon input:focus,
.premium-form .input-with-icon select:focus,
.premium-form .input-with-icon textarea:focus {
    background: rgba(255, 255, 255, 0.06);
    border-color: rgba(255, 255, 255, 0.2);
    box-shadow: 0 0 15px rgba(255, 255, 255, 0.05);
}


.header-right {
    position: absolute;
    right: 1.2rem;
    display: flex;
    align-items: center;
    gap: 8px;
}

.header-search-btn {
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(0, 0, 0, 0.05);
    color: var(--text-white);
    margin-left: auto;
    font-size: 1.1rem;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.05);
}

.search-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
        background: rgba(255, 255, 255, 0.85);
    z-index: 5000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.35s cubic-bezier(0.165, 0.84, 0.44, 1);
    backdrop-filter: blur(40px) saturate(180%);
    -webkit-backdrop-filter: blur(40px) saturate(180%);
    contain: strict;
}


.search-overlay.active {
    opacity: 1;
    visibility: visible;
}

.search-overlay-header {
    background: transparent;
    padding: calc(30px + env(safe-area-inset-top)) 1.2rem 15px;     display: flex;
    justify-content: center;
    align-items: center;
}

.search-brand h1 {
    font-size: 1.8rem;
    font-weight: 800;
    margin: 0;
    letter-spacing: -1px;
    color: #1D1D1F !important;
    text-shadow: none;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", sans-serif;
}

.search-bar-container {
    display: flex;
    align-items: center;
    padding: calc(20px + env(safe-area-inset-top)) 1.2rem 10px;
    background: transparent;
    border-bottom: none;
    gap: 12px;
}

.search-input-wrapper {
    flex: 1;
    display: flex;
    align-items: center;
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(25px) saturate(210%) !important;
    -webkit-backdrop-filter: blur(25px) saturate(210%) !important;
    border: 0.5px solid rgba(0, 0, 0, 0.08) !important;
    padding: 4px 16px;
    border-radius: 40px;
    gap: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

.search-input-wrapper i.search-icon {
    color: #8E8E93;
    font-size: 1.1rem;
}

#mobileSearchInput {
    flex: 1;
    border: none;
    background: transparent;
    padding: 12px 0;
    font-size: 1.05rem;
    font-weight: 500;
    color: #1D1D1F;
    outline: none;
}

#mobileSearchInput::placeholder {
    color: #8E8E93;
}

.clear-search-btn {
    background: rgba(255, 255, 255, 0.8) !important;
    backdrop-filter: blur(25px) saturate(210%) !important;
    -webkit-backdrop-filter: blur(25px) saturate(210%) !important;
    border: 0.5px solid rgba(0, 0, 0, 0.08) !important;
    color: #1D1D1F;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    padding: 0;
    transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
    cursor: pointer;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

.clear-search-btn:active {
    transform: scale(0.92);
    background: rgba(255, 255, 255, 0.2);
}



.active-search-results {
    height: calc(100vh - 75px - env(safe-area-inset-top));
    overflow-y: auto;
    padding: 1.2rem;
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    box-sizing: border-box;
    content-visibility: auto;
}

.active-search-results > * {
    flex-shrink: 0;
}

.search-placeholder {
    height: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    color: #8E8E93;
    padding: 5rem 2rem;
}

.search-placeholder i {
    font-size: 4.5rem;
    margin-bottom: 25px;
    color: #C7C7CC;
    opacity: 0.5;
    background: none;
    filter: none;
}

.search-placeholder p {
    font-size: 0.85rem;
    line-height: 1.5;
    font-weight: 700;
    letter-spacing: 0.1px;
    max-width: 280px;
    text-transform: uppercase;
    opacity: 0.6;
}

.contact-link {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 14px 10px;
    background: transparent;
    border: none;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    color: rgba(255, 255, 255, 0.9);
    text-decoration: none;
    transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1);
    width: 100%;
    box-sizing: border-box;
    border-radius: 0;
}

.mobile-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    height: 74px;
    background: rgba(10, 10, 12, 0.75);
    backdrop-filter: blur(25px);
    -webkit-backdrop-filter: blur(25px);
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: env(safe-area-inset-top) 1.2rem 0;
    z-index: 1000;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.contact-link:last-child {
    border-bottom: none;
}

.contact-link.event-highlight label {
    color: #ff5e00 !important;
    font-weight: 800 !important;
}

.contact-link.event-highlight span {
    color: var(--text-white) !important;
    font-size: 1.12rem !important;
    font-weight: 800 !important;
    text-shadow: 0 0 10px rgba(255, 94, 0, 0.25);
}

body.light-mode .contact-link.event-highlight span {
    color: #FF4500 !important;
}

.contact-link i {
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 140, 0, 0.08);     border: 1px solid rgba(255, 140, 0, 0.15);
    border-radius: 12px;
    color: var(--mobile-primary);
    font-size: 1.1rem;
    transition: all 0.3s ease;
    flex-shrink: 0;
    box-shadow: 0 0 15px rgba(255, 140, 0, 0.05);
}

.contact-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
    flex: 1;
    overflow: hidden;
}

.contact-text label {
    font-size: 0.7rem;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: rgba(255, 255, 255, 0.4);
    font-weight: 700;
}

.contact-text span {
    font-size: 0.95rem;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.95);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    display: block;
}

.contact-link:active {
    background: rgba(255, 255, 255, 0.03);
    padding-left: 14px;
}

.contact-link:active i {
    background: var(--mobile-primary);
    color: #fff;
    transform: scale(1.05);
    box-shadow: 0 0 20px rgba(255, 140, 0, 0.3);
}


@media (max-width: 600px) {
    .premium-modal {
        width: 94%;
        border-radius: 24px;
        max-height: 92vh;
    }

    .map-overlay-header {
        background: transparent;
        backdrop-filter: none;
        border: none;
        padding: 10px;
    }

    .details-body {
        padding: 0 20px 24px;
        margin-top: -30px;
    }

    #detailsModalTitle {
        font-size: 1.5rem;
    }

    .modal-event-datetime {
        padding: 12px;
        border-radius: 14px;
    }
}


.modal-content {
    background: transparent !important;
    color: var(--text-white) !important;
    border: none !important;
    box-shadow: none !important;
}

.details-body {
    background: transparent !important;
    color: var(--text-white) !important;
}

.modal-title {
    color: var(--text-white) !important;
    font-weight: 800;
}

.modal-subtitle {
    color: var(--text-muted) !important;
}

.form-group label {
    color: var(--text-muted) !important;
    font-weight: 700 !important;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    font-size: 0.7rem;
}

.input-with-icon input,
.input-with-icon select,
.input-with-icon textarea {
    background: var(--input-bg) !important;
    border: 1px solid var(--input-border) !important;
    color: var(--input-text) !important;
    border-radius: 12px !important;
    font-family: inherit;
    -webkit-appearance: none;
    appearance: none;
}

.input-with-icon i {
    color: var(--text-muted) !important;
}

.listing-card {
    background: var(--mobile-card-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}

.listing-card:active {
    transform: scale(0.98) !important;
    box-shadow: 0 4px 15px rgba(0,0,0,0.2) !important;
}

.listing-card h3 {
    color: var(--text-white) !important;
}

.card-footer {
    border-top: none !important;
}

.footer-right, .card-distance {
    color: var(--text-muted) !important;
}

.contact-link {
    color: var(--text-white) !important;
    background: var(--modal-inner-bg) !important;
    border-radius: 14px !important;
    border: 1px solid var(--mobile-border) !important;
    display: flex !important;
    align-items: center !important;
    padding: 7px 6px !important;
    gap: 10px !important;
    margin-bottom: 8px !important;
    text-decoration: none !important;
}

.contact-link i {
    background: rgba(255, 140, 0, 0.1) !important;
    color: var(--mobile-primary) !important;
    border: 1px solid rgba(255, 140, 0, 0.2) !important;
    width: 36px !important;
    height: 36px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 10px;
    font-size: 1.1rem;
}

.contact-link:active {
    background: rgba(255, 140, 0, 0.12) !important;
    transform: scale(0.97);
}

.contact-text label {
    color: var(--text-muted) !important;
    font-size: 0.65rem !important;
    font-weight: 700 !important;
}

body.light-mode .contact-text label {
    color: #48484A !important;
}

.contact-text span {
    color: var(--text-white) !important;
    font-size: 0.9rem !important;
    font-weight: 600 !important;
}

body.light-mode .contact-text span {
    color: #1D1D1F !important;
}



.menu-overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.4);
    z-index: 2000;
    opacity: 0;
    visibility: hidden;
    transition: all 0.3s ease;
    backdrop-filter: blur(4px);
}

.menu-overlay.active {
    opacity: 1;
    visibility: visible;
}

.side-menu {
    position: fixed;
    bottom: calc(32px + env(safe-area-inset-bottom));
    top: auto;
    left: -100%;
    width: 80%;
    height: auto;
    max-height: calc(100vh - 80px);
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(15px) saturate(160%) !important;
    -webkit-backdrop-filter: blur(15px) saturate(160%) !important;


    z-index: 7000;
    border-radius: 32px;
    border: 1px solid rgba(255, 255, 255, 0.45) !important;
    box-shadow: 0 15px 50px rgba(0, 0, 0, 0.18);
    transition: all 0.5s cubic-bezier(0.16, 1, 0.3, 1);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.side-menu.active {
    left: 14px;
}

.side-menu-header {
    padding: 24px 20px 16px;
    border-bottom: 0.5px solid rgba(0,0,0,0.05);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 15px;
}

.side-menu-header .logo-text {
    font-weight: 800;
    font-size: 1.6rem;
    letter-spacing: -1.2px;
    margin: 0;
    background: linear-gradient(135deg, #FF6E00 0%, #FF0000 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.close-menu-btn {
    background: rgba(0,0,0,0.04);
    border: none;
    color: #1D1D1F;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    font-size: 1rem;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.2s ease;
}

.side-menu-content {
    padding: 8px 12px 14px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.mobile-menu-link {
    display: flex;
    align-items: center;
    gap: 14px;
    width: 100%;
    padding: 12px 14px;
    background: transparent;
    border: none;
    border-radius: 18px;
    font-family: inherit;
    font-size: 1.05rem;
    font-weight: 700;
    color: #1D1D1F;
    margin-bottom: 1px;
    text-align: left;
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.mobile-menu-link:active {
    background: rgba(0,0,0,0.1) !important;
    transform: scale(0.96);
    transition: transform 0.1s ease;
}

.mobile-menu-link i {
    width: 36px;
    height: 36px;
    border-radius: 40%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.15rem;
    color: white;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    transition: transform 0.3s ease;
}

.mobile-menu-link:active i {
    transform: scale(0.9);
}

.menu-item-cinema i { background: linear-gradient(135deg, #FF00CC, #3333FF, #FF9900); }
.menu-item-restaurant i { background: linear-gradient(135deg, #FF3D00, #FF6E40); }
.menu-item-shopping i { background: linear-gradient(135deg, #D500F9, #AA00FF); }
.menu-item-event i { background: linear-gradient(135deg, #F50057, #C62828); }
.menu-item-grocery i { background: linear-gradient(135deg, #00C853, #1B5E20); }
.menu-item-temple i { background: linear-gradient(135deg, #FFAB00, #FF6D00); }
.menu-item-service i { background: linear-gradient(135deg, #007AFF, #00D2FF); }
.menu-item-organization i { background: linear-gradient(135deg, #C51162, #880E4F); }
.menu-item-learning i { background: linear-gradient(135deg, #00B8D4, #00838F); }
.menu-item-realestate i { background: linear-gradient(135deg, #6200ea, #7c4dff); }
.menu-item-owners i { background: linear-gradient(135deg, #ffb000, #ff7a00, #ff5e00); }

.privacy-content p {
    color: var(--text-white) !important;
    opacity: 0.9;
    font-size: 0.95rem;
    line-height: 1.6;
}

.details-contact-column {
    margin-top: 20px !important;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.listing-card {
    transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    position: relative;
    overflow: hidden;
}

.listing-card:active {
    transform: scale(0.97);
    box-shadow: 0 0 20px var(--category-accent-1, var(--mobile-primary));
}

.listing-card::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    background: radial-gradient(circle, var(--category-accent-1, #ff8c00) 0%, transparent 70%);
    transform: translate(-50%, -50%) scale(0);
    opacity: 0;
    transition: transform 0.5s, opacity 0.5s;
    pointer-events: none;
    z-index: 0;
}

.listing-card:active::after {
    transform: translate(-50%, -50%) scale(2.5);
    opacity: 0.15;
}


.modal-title {
    font-size: 2.2rem;
    font-weight: 800;
    color: #ffffff !important;
    margin: 0;
    line-height: 1.1;
    letter-spacing: -0.01em;
}

body.light-mode .modal-title {
    color: #1D1D1F !important;
}

.modal-subtitle {
    font-size: 1.1rem;
    color: rgba(255, 255, 255, 0.9) !important;
    margin-top: 15px !important;
    margin-bottom: 30px !important;
    max-width: 95%;
    line-height: 1.5;
    display: block;
}

body.light-mode .modal-subtitle {
    color: #48484A !important;
}

.privacy-header {
    background: linear-gradient(135deg, #f7ba2c, #ea5459);
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.privacy-header-icon {
    font-size: 3rem;
    color: white;
    filter: drop-shadow(0 0 10px rgba(0,0,0,0.2));
}

.privacy-body {
    padding: 1.5rem 1.5rem 3rem !important;
    margin-top: 0 !important;
}

.privacy-content {
    line-height: 1.7;
    color: var(--text-white);
}

.privacy-content h3 {
    font-size: 1.1rem;
    font-weight: 700;
    margin: 1.5rem 0 0.5rem;
    color: var(--mobile-primary);
}

.privacy-content p {
    margin-bottom: 1rem;
    opacity: 0.9;
}

.last-updated {
    font-size: 0.8rem;
    opacity: 0.6;
    margin-top: 2rem;
    padding-top: 1rem;
    border-top: 1px solid var(--mobile-border);
}

.contact-header {
    background: linear-gradient(135deg, #f7ba2c, #ea5459);
    height: 120px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.contact-header-icon {
    font-size: 3rem;
    color: white;
    filter: drop-shadow(0 0 10px rgba(0,0,0,0.2));
}

.contact-body {
    padding: 1.5rem 1.5rem 3rem !important;
    margin-top: 0 !important;
}

body.light-mode .modal-subtitle { color: #48484A; }

.hidden { display: none !important; }



.promote-modal {
    padding: 0 !important;
    background: var(--modal-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    backdrop-filter: blur(30px);
    -webkit-backdrop-filter: blur(30px);
}

.promote-header-new {
    position: relative;
    padding: 32px 24px 24px;
    text-align: center;
    overflow: hidden;
    background: #FFD700;     background: linear-gradient(135deg, #FFD700 0%, #FF8C00 100%);
}

.promote-header-gradient {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(255, 255, 255, 0.1);
    z-index: 1;
}

.promote-header-content {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.promote-icon-container {
    width: 64px;
    height: 64px;
    background: rgba(255, 255, 255, 0.2);
    border-radius: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    color: #FFFFFF;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
    margin-bottom: 8px;
    border: 1px solid rgba(255, 255, 255, 0.3);
}

@keyframes floatIcon {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-10px); }
}

.logo {
    font-size: 1.5rem;
    font-weight: 800;
    color: var(--text-white);
    letter-spacing: -1px;
    display: flex;
    align-items: center;
    gap: 2px;
}

.logo span {
    background: linear-gradient(135deg, #FFD700 0%, #FFA500 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-weight: 900;
}

.promote-modal .modal-title {
    font-size: 1.75rem;
    font-weight: 800;
    margin: 0;
    letter-spacing: -0.5px;
    color: var(--text-white);
}

.promote-modal .modal-subtitle {
    font-size: 0.9rem;
    color: var(--text-muted);
    margin: 0;
    max-width: 280px;
}

.premium-form-new {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 32px;
}

.form-section {
    position: relative;
}


.section-header-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 24px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
    padding-bottom: 8px;
}

.step-num {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--mobile-primary);
    opacity: 0.9;
}

.section-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-white);
    margin: 0;
    text-transform: none;
    letter-spacing: 0;
}

.request-type-selector {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.type-option {
    cursor: pointer;
    position: relative;
}

.type-option input {
    position: absolute;
    opacity: 0;
}

.option-content {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 16px;
    background: var(--modal-inner-bg);
    border: 1px solid var(--mobile-border);
    border-radius: 16px;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.type-option input:checked + .option-content {
    background: rgba(255, 140, 0, 0.08);
    border-color: var(--mobile-primary);
    box-shadow: 0 4px 15px rgba(255, 140, 0, 0.1);
}

.option-content i {
    font-size: 20px;
    color: var(--text-muted);
    transition: color 0.3s;
}

.type-option input:checked + .option-content i {
    color: var(--mobile-primary);
}

.option-text {
    display: flex;
    flex-direction: column;
}

.option-title {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--text-white);
}

.option-desc {
    font-size: 0.75rem;
    color: var(--text-muted);
}

.form-grid-new {
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.input-group {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.input-group label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--text-muted);
}

.input-wrapper {
    position: relative;
    display: flex;
    align-items: center;
}

.input-wrapper i {
    position: absolute;
    left: 16px;
    color: var(--text-muted);
    font-size: 14px;
    transition: color 0.3s;
}

.input-wrapper input,
.input-wrapper select,
.input-wrapper textarea {
    width: 100%;
    background: var(--input-bg) !important;
    border: 1.5px solid var(--input-border) !important;
    border-radius: 12px !important;
    padding: 12px 16px 12px 44px !important;
    color: var(--input-text) !important;
    font-size: 0.95rem;
    outline: none;
    transition: all 0.3s;
}

.input-wrapper select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='rgba(255,255,255,0.3)'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 16px;
}

.input-wrapper textarea {
    padding-top: 14px !important;
    resize: none;
}

.input-wrapper input:focus,
.input-wrapper select:focus,
.input-wrapper textarea:focus {
    background: var(--modal-inner-bg) !important;
    border-color: var(--mobile-primary) !important;
    box-shadow: 0 0 0 4px rgba(255, 140, 0, 0.1);
}

.input-wrapper input:focus + i,
.input-wrapper select:focus + i,
.input-wrapper textarea:focus + i {
    color: var(--mobile-primary);
}

.premium-button-v2 {
    position: relative;
    background: linear-gradient(135deg, #FFD700 0%, #FF4500 100%) !important;
    border: none;
    border-radius: 14px;
    padding: 18px;
    cursor: pointer;
    overflow: hidden;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: 0 8px 25px rgba(255, 69, 0, 0.3);
}

.premium-button-v2:hover {
    box-shadow: 0 8px 30px rgba(255, 140, 0, 0.4);
}

.premium-button-v2:active {
    transform: translateY(0);
}

.btn-content {
    position: relative;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    color: white;
    font-weight: 800;
    font-size: 1.05rem;
    letter-spacing: 0.5px;
}

.btn-shimmer {
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(
        90deg,
        transparent,
        rgba(255, 255, 255, 0.2),
        transparent
    );
    transition: none;
    animation: shimmer 3s infinite;
}

@keyframes shimmer {
    0% { left: -100%; }
    100% { left: 100%; }
}

.full-width {
    grid-column: 1 / -1;
}




.modal-mode-free .promote-header-new {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
}
.modal-mode-free .submit-btn.premium-button-v2 {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
    box-shadow: 0 8px 25px rgba(255, 94, 0, 0.3) !important;
}

.modal-mode-promote .promote-header-new {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
}
.modal-mode-promote .submit-btn.premium-button-v2 {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
    box-shadow: 0 8px 25px rgba(255, 94, 0, 0.3) !important;
}

.modal-mode-free .promote-header-new {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
}
.modal-mode-free .submit-btn.premium-button-v2 {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
    box-shadow: 0 8px 25px rgba(255, 94, 0, 0.3) !important;
}

.modal-mode-promote .promote-header-new {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
}
.modal-mode-promote .submit-btn.premium-button-v2 {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
    box-shadow: 0 8px 25px rgba(255, 94, 0, 0.3) !important;
}

body.light-mode :is(#promoteBusinessModal, #privacyPolicyModal, #contactUsModal, #claimListingModal) .modal-content {
    background: var(--modal-bg) !important;
    color: var(--text-white) !important;
    border: 1px solid var(--mobile-border) !important;
    box-shadow: 0 24px 64px rgba(0, 0, 0, 0.44), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

body.light-mode :is(#promoteBusinessModal, #privacyPolicyModal, #contactUsModal, #claimListingModal) .close-modal {
    background: rgba(15, 12, 22, 0.76) !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.18) !important;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.26) !important;
}

body.light-mode :is(#privacyPolicyModal, #contactUsModal) :is(.privacy-body, .contact-body) {
    background: transparent !important;
    color: var(--text-white) !important;
}

body.light-mode :is(#privacyPolicyModal, #contactUsModal) :is(.modal-title, .contact-text span, .privacy-content p) {
    color: var(--text-white) !important;
}

body.light-mode #contactUsModal .contact-body .modal-title,
body.light-mode #contactUsModal .contact-text span {
    color: #1D1D1F !important;
}

body.light-mode :is(#privacyPolicyModal, #contactUsModal) :is(.modal-subtitle, .privacy-content) {
    color: var(--text-muted) !important;
}

.event-highlight-row {
    display: flex;
    gap: 10px;
    margin-top: 5px !important;
    margin-bottom: 12px !important;     padding-bottom: 0px;
}

.event-badge {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px 6px;     border-radius: 14px;
    font-size: 0.82rem;     font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.2px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.04);
    white-space: nowrap; }

.date-badge {
    background: rgba(255, 140, 0, 0.1) !important;
    color: #FF5E00 !important;
    border: 1.5px solid rgba(255, 94, 0, 0.3) !important;
}

.time-badge {
    background: rgba(0, 122, 255, 0.1) !important;
    color: #007AFF !important;
    border: 1.5px solid rgba(0, 122, 255, 0.3) !important;
}

.map-toggle-container {
    position: fixed;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1000;
    display: flex;
    justify-content: center;
    width: auto;
}

.map-toggle-btn {
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(15px);
    -webkit-backdrop-filter: blur(15px);
    border: 1px solid rgba(255, 94, 0, 0.3);
    padding: 12px 24px;
    border-radius: 40px;
    color: var(--mobile-primary);
    font-weight: 600;
    font-size: 0.95rem;
    display: flex;
    align-items: center;
    gap: 10px;
    box-shadow: 0 8px 32px rgba(255, 94, 0, 0.15);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
}

.map-toggle-btn:active {
    transform: scale(0.95);
    background: var(--mobile-primary);
    color: white;
}

.news-ticker-container {
    margin: 0 16px 16px;
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 94, 0, 0.2);
    border-radius: 12px;
    height: 40px;
    display: flex;
    align-items: center;
    overflow: hidden;
    position: relative;
    box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

.ticker-label {
    background: linear-gradient(135deg, #FF5E00, #F2994A);
    color: white;
    padding: 0 12px;
    height: 100%;
    display: flex;
    align-items: center;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 1px;
    z-index: 2;
    position: relative;
}

.ticker-wrapper {
    flex: 1;
    overflow: hidden;
}

.ticker-content {
    display: flex;
    white-space: nowrap;
    padding-left: 100%;
    animation: marquee 25s linear infinite;
    font-size: 0.85rem;
    color: #333;
    font-weight: 500;
}

@keyframes marquee {
    0% { transform: translateX(0); }
    100% { transform: translateX(-100%); }
}

.ticker-item {
    padding: 0 40px;
    position: relative;
}

.ticker-item::after {
    content: "•";
    position: absolute;
    right: 15px;
    color: var(--primary-color);
}

.movie-meta-stack {
    margin-top: 12px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    border-top: 1px dashed rgba(0,0,0,0.1);
    padding-top: 12px;
}

.movie-badge {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 0.85rem;
    color: #444;
}

.movie-badge i {
    color: var(--primary-color);
    width: 14px;
}

.movie-badge.showtimes-badge {
    font-weight: 600;
    color: #FF5E00;
}

.movie-book-btn {
    margin-top: 4px;
    width: 100%;
    justify-content: center;
    padding: 10px;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 600;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
    background: linear-gradient(135deg, #FF5E00, #F2994A);
    color: white;
    box-shadow: 0 4px 12px rgba(255, 94, 0, 0.2);
    transition: transform 0.2s ease;
}

.movie-book-btn:active {
    transform: scale(0.98);
}

.map-toggle-btn i {
    font-size: 1.1rem;
}

.mobile-map-container {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 50;
    background: var(--mobile-bg);
}

.cd-map-marker {
    background: var(--mobile-primary);
    border: 2px solid white;
    border-radius: 50% 50% 50% 0;
    transform: rotate(-45deg);
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
}

.cd-map-marker i {
    transform: rotate(45deg);
    color: white;
    font-size: 12px;
}

.leaflet-popup-content-wrapper {
    border-radius: 16px !important;
    padding: 0 !important;
    overflow: hidden;
    box-shadow: 0 10px 25px rgba(0,0,0,0.1) !important;
}

.leaflet-popup-content {
    margin: 0 !important;
    width: 220px !important;
}

.map-popup-card {
    padding: 15px;
}

.map-popup-title {
    font-weight: 700;
    font-size: 1rem;
    margin-bottom: 4px;
    color: var(--text-white);
}

.map-popup-type {
    font-size: 0.8rem;
    color: var(--mobile-primary);
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
    display: block;
}

.map-popup-btn {
    display: block;
    width: 100%;
    padding: 8px;
    background: var(--mobile-primary);
    color: white;
    text-align: center;
    border-radius: 8px;
    text-decoration: none;
    font-size: 0.85rem;
    font-weight: 600;
    margin-top: 10px;
}

.deal-meta-stack {
    margin-top: 15px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.deal-badge-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.deal-category-badge {
    background: rgba(255, 94, 0, 0.1);
    color: var(--mobile-primary);
    padding: 4px 10px;
    border-radius: 6px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
}

.deal-expiry-badge {
    font-size: 0.75rem;
    color: #666;
    font-weight: 600;
}

.deal-expiry-badge.expired {
    color: #cc0000;
}

.coupon-box {
    background: #fff;
    border: 2px dashed var(--mobile-primary);
    border-radius: 12px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 4px 12px rgba(255, 94, 0, 0.05);
}

.coupon-box:active {
    transform: scale(0.98);
    background: rgba(255, 94, 0, 0.05);
}

.coupon-code {
    font-size: 1.2rem;
    font-weight: 800;
    color: var(--mobile-primary);
    letter-spacing: 2px;
}

.copy-hint {
    font-size: 0.65rem;
    font-weight: 700;
    color: #999;
    letter-spacing: 1px;
}

.deal-terms-text {
    font-size: 0.8rem;
    color: #777;
    line-height: 1.4;
    font-style: italic;
}

.desi-toast {
    position: fixed;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%) translateY(100px);
    background: rgba(0, 0, 0, 0.85);
    color: white;
    padding: 12px 24px;
    border-radius: 30px;
    font-size: 0.9rem;
    font-weight: 600;
    z-index: 10000;
    transition: transform 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    pointer-events: none;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
}

.desi-toast.show {
    transform: translateX(-50%) translateY(0);
}

.classified-meta-stack {
    margin-top: 15px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.classified-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.classified-price-tag {
    font-size: 1.1rem;
    font-weight: 800;
    color: var(--mobile-primary);
}

.classified-location-badge {
    font-size: 0.75rem;
    color: #666;
    background: #f0f0f0;
    padding: 4px 8px;
    border-radius: 4px;
    font-weight: 600;
}

.classified-desc-text {
    font-size: 0.85rem;
    color: #444;
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.classified-action-row {
    display: flex;
    gap: 10px;
    margin-top: 5px;
}

.classified-contact-btn {
    flex: 1;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border-radius: 10px;
    font-size: 0.9rem;
    font-weight: 700;
    text-decoration: none;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.classified-contact-btn:active {
    transform: scale(0.96);
    opacity: 0.9;
}

.mobile-results .results-list.classifieds-mode {
    gap: 10px;
    padding-top: 12px;
}

.classified-result-card {
    display: flex;
    flex-direction: column;
    gap: 11px;
    min-height: 0;
    padding: 14px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    border-radius: 16px;
    background:
        radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.055), transparent 34%),
        linear-gradient(180deg, rgba(31, 31, 35, 0.98), rgba(17, 17, 20, 0.98));
    box-shadow: 0 16px 38px rgba(0, 0, 0, 0.24);
    color: #f5f5f7;
    cursor: pointer;
    overflow: hidden;
    position: relative;
    transition: transform 0.2s ease, border-color 0.2s ease;
}

.classified-result-card:active {
    transform: scale(0.98);
    border-color: rgba(255, 138, 0, 0.32);
}

body.light-mode .classified-result-card {
    background: #ffffff;
    border-color: rgba(0, 0, 0, 0.08);
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.07);
    color: #1d1d1f;
}

.classified-result-content {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 7px;
}

.classified-result-kicker,
.classified-result-meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 7px;
}

.classified-result-lane,
.classified-result-featured {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 999px;
    border: 1px solid rgba(255, 138, 0, 0.22);
    background: rgba(255, 138, 0, 0.1);
    color: #ffb35c;
    font-size: 0.68rem;
    font-weight: 850;
    line-height: 1;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.classified-result-featured {
    border-color: rgba(242, 54, 115, 0.24);
    background: rgba(242, 54, 115, 0.11);
    color: #ff8fb7;
}

body.light-mode .classified-result-lane {
    color: #bd4c00;
    background: rgba(255, 138, 0, 0.12);
}

body.light-mode .classified-result-featured {
    color: #b91d53;
    background: rgba(242, 54, 115, 0.09);
}

.classified-result-card h3 {
    margin: 0;
    color: #f5f5f7;
    font-size: 1rem;
    line-height: 1.18;
    font-weight: 850;
    letter-spacing: 0;
}

body.light-mode .classified-result-card h3 {
    color: #1d1d1f;
}

.classified-result-card p {
    margin: 0;
    color: rgba(245, 245, 247, 0.72);
    font-size: 0.84rem;
    line-height: 1.38;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

body.light-mode .classified-result-card p {
    color: #55565d;
}

.classified-result-meta {
    color: rgba(245, 245, 247, 0.68);
    font-size: 0.78rem;
    font-weight: 750;
    line-height: 1.2;
}

body.light-mode .classified-result-meta,
body.light-mode .classified-result-disclosure {
    color: #686a70;
}

.classified-result-meta span {
    display: inline-flex;
    align-items: center;
    gap: 5px;
}

.classified-result-meta i {
    color: var(--mobile-primary);
    font-size: 0.72rem;
}

.classified-result-price {
    color: var(--mobile-primary) !important;
    font-weight: 900;
}

.classified-result-disclosure {
    color: rgba(245, 245, 247, 0.58);
    font-size: 0.68rem;
    font-weight: 750;
}

.classified-result-card .classified-result-details {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    align-self: flex-start;
    min-height: 34px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    background: rgba(255, 122, 24, 0.12) !important;
    border: 1px solid rgba(255, 122, 24, 0.22) !important;
    color: #ffd9bd !important;
    box-shadow: none !important;
    font-size: 0.72rem !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    text-decoration: none !important;
    line-height: 1 !important;
}

.classified-result-card .classified-result-details::after {
    display: none !important;
}

body.light-mode .classified-result-card .classified-result-details {
    color: #bd4c00 !important;
}

.whatsapp-btn {
    background: #25D366;
    color: white;
}

.call-btn {
    background: var(--mobile-primary);
    color: white;
}

.email-btn {
    background: #444;
    color: white;
}

.sports-meta-stack {
    margin-top: 14px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sports-header-row {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.sports-match-badge {
    background: rgba(255, 107, 107, 0.1);
    color: #ff6b6b;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    border: 1px solid rgba(255, 107, 107, 0.2);
}

.sports-timing-badge {
    background: rgba(0, 0, 0, 0.05);
    color: #666;
    padding: 6px 12px;
    border-radius: 20px;
    font-size: 11px;
    font-weight: 600;
}

.sports-teams-row {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.sports-teams-title {
    margin: 0;
    font-size: 18px;
    font-weight: 800;
    color: var(--mobile-text);
    letter-spacing: -0.5px;
}

.sports-location-text {
    margin: 0;
    font-size: 13px;
    color: #888;
    display: flex;
    align-items: center;
    gap: 5px;
}

.sports-action-btn {
    background: var(--mobile-primary);
    color: white;
    text-decoration: none;
    padding: 14px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 700;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    transition: all 0.2s ease;
    box-shadow: 0 4px 15px rgba(255, 107, 107, 0.2);
}

.sports-action-btn:active {
    transform: scale(0.96);


.mobile-map-container {
    position: relative;
    border-radius: 20px;
    overflow: hidden;
    box-shadow: inset 0 0 15px rgba(0,0,0,0.05);
}

.user-location-marker {
    position: relative;
    width: 20px;
    height: 20px;
}

.user-location-dot {
    width: 14px;
    height: 14px;
    background: #007AFF;
    border: 3px solid white;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    box-shadow: 0 0 10px rgba(0,122,255,0.5);
    z-index: 10;
}

.user-location-pulse {
    width: 100%;
    height: 100%;
    background: rgba(0,122,255,0.4);
    border-radius: 50%;
    position: absolute;
    top: 0;
    left: 0;
    animation: locationPulse 2s infinite ease-out;
}

@keyframes locationPulse {
    0% { transform: scale(1); opacity: 1; }
    100% { transform: scale(3); opacity: 0; }
}

.recenter-map-btn {
    position: absolute;
    bottom: 25px;
    left: 20px;     width: 50px;
    height: 50px;
    background: white;
    border: none;
    border-radius: 50%;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.3rem;
    color: #444;
    z-index: 1000;
    cursor: pointer;
    transition: all 0.3s ease;
}

.recenter-map-btn:active {
    transform: scale(0.9);
    background: #f8f8f8;
}

.map-bottom-sheet {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    background: rgba(255, 255, 255, 0.98);
    backdrop-filter: blur(10px);
    border-radius: 24px 24px 0 0;
    box-shadow: 0 -5px 25px rgba(0,0,0,0.1);
    z-index: 20000;     transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    transform: translateY(100%);
    padding-bottom: env(safe-area-inset-bottom, 20px);
}

.map-bottom-sheet.active {
    transform: translateY(0);
}

.sheet-handle {
    width: 40px;
    height: 5px;
    background: #eee;
    border-radius: 10px;
    margin: 12px auto;
}

.sheet-content {
    padding: 0 20px 20px;
}

.sheet-header-box {
    margin-bottom: 4px;
}

.sheet-type {
    display: inline-block;
    padding: 4px 10px;
    background: rgba(235,84,36,0.1);
    color: #eb5424;
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    border-radius: 6px;
    margin-bottom: 6px;
}

.sheet-title {
    font-size: 1.35rem;
    font-weight: 850;
    color: #1a1a1a;
    line-height: 1.1;
    letter-spacing: -0.5px;
}

.sheet-address {
    font-size: 0.85rem;
    color: #777;
    margin-top: 6px;
    display: flex;
    align-items: center;
    gap: 6px;
    font-weight: 500;
}

.sheet-stats-row {
    display: flex;
    align-items: center;
    gap: 15px;
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid #f0f0f0;
}

.sheet-stat-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.85rem;
    font-weight: 700;
    color: #444;
}

.sheet-stat-item i {
    color: #FF9500;
}

.sheet-actions-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    margin-top: 25px;
}

.sheet-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 14px 10px;
    background: #f8f8f8;
    border: none;
    border-radius: 16px;
    color: #1a1a1a;
    font-size: 0.7rem;
    font-weight: 800;
    transition: all 0.2s cubic-bezier(0.18, 0.89, 0.32, 1.28);
    text-decoration: none;
}

.sheet-btn i {
    font-size: 1.3rem;
    color: #eb5424;
}

.sheet-btn:active {
    transform: scale(0.92);
    background: #eee;
}

.sheet-btn.primary-action {
    background: #eb5424;
    color: white;
}

.sheet-btn.primary-action i {
    color: white;
}

.close-sheet-btn {
    position: absolute;
    top: 15px;
    right: 15px;
    width: 32px;
    height: 32px;
    background: #f0f0f0;
    border: none;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #888;
    font-size: 0.9rem;
    z-index: 10;
}

.cd-map-marker {
    background: white;
    border-radius: 50% 50% 50% 0;
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 12px rgba(0,0,0,0.25);
    transform: rotate(-45deg);
    border: 2px solid #eb5424;
    transition: all 0.3s cubic-bezier(0.18, 0.89, 0.32, 1.28);
}

.cd-map-marker i {
    transform: rotate(45deg);
    color: #eb5424;
    font-size: 1rem;
}

.marker-shopping .cd-map-marker { border-color: #FF2D55; }
.marker-shopping .cd-map-marker i { color: #FF2D55; }

.marker-service .cd-map-marker { border-color: #007AFF; }
.marker-service .cd-map-marker i { color: #007AFF; }

.marker-temple .cd-map-marker { border-color: #FF9500; }
.marker-temple .cd-map-marker i { color: #FF9500; }

.marker-learning .cd-map-marker { border-color: #5856D6; }
.marker-learning .cd-map-marker i { color: #5856D6; }

.marker-realestate .cd-map-marker { border-color: #4CD964; }
.marker-realestate .cd-map-marker i { color: #4CD964; }

.back-from-map-btn {
    position: absolute;
    top: 20px;
    left: 20px;
    width: 45px;
    height: 45px;
    background: white;
    border: none;
    border-radius: 50%;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    color: #1a1a1a;
    z-index: 1500;
    cursor: pointer;
    transition: all 0.3s ease;
}

.back-from-map-btn:active {
    transform: scale(0.9);
    background: #f0f0f0;
}


    }

.mobile-bottom-nav {
    position: fixed;
    bottom: calc(20px + env(safe-area-inset-bottom));
    left: 14px;
    right: 14px;
    width: auto;
    height: 58px;
    background: rgba(255, 255, 255, 0.78) !important;
    backdrop-filter: blur(45px) saturate(210%) !important;
    -webkit-backdrop-filter: blur(45px) saturate(210%) !important;
    display: flex;
    justify-content: space-evenly;
    align-items: center;
    border: 0.5px solid rgba(255, 255, 255, 0.4) !important;
    z-index: 6000;
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.15) !important;
    border-radius: 40px;
    padding: 0 10px;
    will-change: transform, opacity;
}

.nav-item-wrapper {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2px;
    flex: 1;
    color: #8E8E93;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

.nav-icon-container {
    width: 38px;
    height: 38px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 40%;
    font-size: 1.25rem;
    transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.nav-item-wrapper span {
    font-size: 0.65rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.1px !important;
    margin-top: 2px;
}

.nav-item-wrapper#navBurger.active { color: #007AFF; }
.nav-item-wrapper#navBurger.active .nav-icon-container {
    background: linear-gradient(135deg, #007AFF 0%, #0056D2 100%);
    color: #fff;
    box-shadow: 0 10px 25px rgba(0, 122, 255, 0.35) !important;
    transform: translateY(-8px) scale(1.15) !important;
}

.nav-item-wrapper#navHome.active { color: #FF0000; }
.nav-item-wrapper#navHome.active .nav-icon-container {
    background: linear-gradient(135deg, #FF6E00 0%, #FF0000 100%);
    color: #fff;
    box-shadow: 0 10px 25px rgba(255, 0, 0, 0.4) !important;
    transform: translateY(-8px) scale(1.15) !important;
}

.nav-item-wrapper#navSearch.active { color: #FFD60A; }
.nav-item-wrapper#navSearch.active .nav-icon-container {
    background: linear-gradient(135deg, #FFD60A 0%, #FF9F0A 100%);
    color: #fff;
    box-shadow: 0 10px 25px rgba(255, 214, 10, 0.4) !important;
    transform: translateY(-8px) scale(1.15) !important;
}

#mobileMain, #homeFeedSection, #mobileResultsList {
    padding-bottom: calc(75px + env(safe-area-inset-bottom));
}

.listing-profile-modal {
    padding: 0 !important;
    overflow-y: auto !important;
    max-height: 90vh !important;
    border-radius: 20px 20px 0 0 !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    background: #fff !important;
    box-shadow: 0 -10px 40px rgba(0,0,0,0.2) !important;
    z-index: 9000 !important;
}

.listing-profile-modal .close-modal {
    top: 15px !important;
    right: 15px !important;
    background: rgba(0,0,0,0.5) !important;
    color: #fff !important;
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 18px !important;
    z-index: 10 !important;
}

.details-hero {
    position: relative;
    height: auto;
    aspect-ratio: 3 / 2;
    background: #f0f0f0;
}

.details-hero img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.details-hero-overlay {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    padding: 30px 20px 20px;
    background: linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.4) 60%, transparent 100%);
    color: white;
}

.details-cat-tag {
    display: inline-block;
    padding: 4px 10px;
    background: var(--mobile-primary);
    color: white;
    font-size: 0.7rem;
    font-weight: 800;
    text-transform: uppercase;
    border-radius: 6px;
    margin-bottom: 8px;
    letter-spacing: 0.5px;
}

.details-main-title {
    font-size: 1.6rem;
    font-weight: 800;
    letter-spacing: -0.5px;
    line-height: 1.2;
    text-shadow: 0 2px 10px rgba(0,0,0,0.3);
}

.details-body-content {
    padding: 24px 20px 40px;
}

.details-info-grid {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-bottom: 30px;
}

.info-item-box {
    display: flex;
    gap: 16px;
    align-items: flex-start;
}

.info-icon-box {
    width: 40px;
    height: 40px;
    background: rgba(255, 94, 0, 0.08);
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--mobile-primary);
    flex-shrink: 0;
}

.info-text-box h4 {
    font-size: 0.65rem;
    font-weight: 800;
    color: #8E8E93;
    text-transform: uppercase;
    margin-bottom: 2px;
}

.info-text-box p {
    font-size: 0.95rem;
    color: #1C1C1E;
    font-weight: 600;
    line-height: 1.4;
}

.details-desc-section {
    margin-top: 10px;
    padding-top: 24px;
    border-top: 1px solid #F2F2F7;
}

.details-desc-section h3 {
    font-size: 1rem;
    font-weight: 800;
    margin-bottom: 12px;
    color: #1C1C1E;
}

.details-desc-section p {
    font-size: 0.95rem;
    color: #3A3A3C;
    line-height: 1.6;
}

.details-actions-row {
    display: flex;
    gap: 12px;
    margin-bottom: 30px;
}

.details-action-circle {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    text-decoration: none;
}

.circle-icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: #F2F2F7;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #1C1C1E;
    font-size: 1.3rem;
    transition: all 0.2s ease;
}

.details-action-circle:active .circle-icon {
    transform: scale(0.9);
    background: #E5E5EA;
}

.details-action-circle span {
    font-size: 0.7rem;
    font-weight: 700;
    color: #48484A;
}

.details-action-circle.primary .circle-icon {
    background: var(--mobile-primary);
    color: white;
}

.details-action-circle.primary span {
    color: var(--mobile-primary);
}

#listingDetailsModal {
    z-index: 50000;
    align-items: flex-end;
    background: rgba(0, 0, 0, 0.58) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
}

#listingDetailsModal .modal-content.listing-card-vibe {
    width: 100% !important;
    max-width: 430px !important;
    max-height: 88vh !important;
    border-radius: 28px 28px 0 0 !important;
    background: #ffffff !important;
    border: 1px solid rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 -24px 60px rgba(0, 0, 0, 0.28) !important;
    overflow-y: auto !important;
    z-index: 50001 !important;
}

#listingDetailsModal .details-header {
    height: 235px !important;
    background: #111 !important;
}

#listingDetailsModal .details-header #detailsModalImg {
    filter: saturate(1.05);
}

#listingDetailsModal .details-hero-overlay {
    padding: 90px 20px 20px;
    background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.48) 58%, rgba(0, 0, 0, 0.08) 100%);
}

#listingDetailsModal .details-cat-tag {
    background: linear-gradient(135deg, #ffb000, #ff5e00);
    box-shadow: 0 8px 18px rgba(255, 94, 0, 0.28);
}

#listingDetailsModal #detailsModalTitle {
    color: #ffffff !important;
    font-size: 1.65rem !important;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.55);
}

#listingDetailsModal .details-body-content {
    background: #ffffff;
    padding: 22px 20px calc(34px + env(safe-area-inset-bottom)) !important;
}

#listingDetailsModal .details-actions-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin-bottom: 24px;
}

#listingDetailsModal .details-action-circle {
    min-width: 0;
}

#listingDetailsModal .circle-icon {
    background: #f2f2f7;
    color: #1c1c1e;
}

#listingDetailsModal .details-action-circle.primary .circle-icon {
    background: linear-gradient(135deg, #ffb000, #ff5e00);
    box-shadow: 0 10px 22px rgba(255, 94, 0, 0.24);
}

#listingDetailsModal .details-info-grid {
    gap: 12px;
    margin-bottom: 22px;
}

#listingDetailsModal .info-item-box {
    padding: 14px;
    border: 1px solid rgba(0, 0, 0, 0.06);
    border-radius: 16px;
    background: rgba(248, 248, 250, 0.92);
}

#listingDetailsModal .info-text-box p {
    color: #1c1c1e;
}

#listingDetailsModal .details-desc-section {
    border-top: 1px solid rgba(0, 0, 0, 0.08);
}

#listingDetailsModal.event-mode .modal-content,
#listingDetailsModal.cinema-mode .modal-content {
    width: 100% !important;
    max-width: 430px !important;
    border-radius: 28px 28px 0 0 !important;
}

.loading-shimmer-container { padding: 20px; }
.shimmer-header { height: 220px; background: #eee; border-radius: 16px; margin-bottom: 20px; animation: shimmerAnim 1.5s infinite; }
.shimmer-line { height: 16px; background: #eee; border-radius: 4px; margin-bottom: 10px; animation: shimmerAnim 1.5s infinite; }
@keyframes shimmerAnim { 0% { opacity: 0.5; } 50% { opacity: 1; } 100% { opacity: 0.5; } }

.map-overlay-header {
    position: absolute;
    bottom: calc(75px + env(safe-area-inset-bottom));
    top: auto !important;
    left: 0;
    width: 100%;
    z-index: 1000;
    padding: 15px;
    background: linear-gradient(to top, rgba(245, 247, 250, 0.95) 0%, rgba(245, 247, 250, 0.7) 60%, transparent 100%);
    pointer-events: none;
}

.custom-map-pin {
    background: none !important;
    border: none !important;
    perspective: 1000px;
    height: 70px !important;
    margin: 0 !important;
    pointer-events: auto !important;
    width: 56px !important;
}

.pin-container {
    height: 70px;
    width: 56px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    transition: all 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
    cursor: pointer;
    filter: drop-shadow(0 4px 8px rgba(0,0,0,0.2));
    pointer-events: auto;
    touch-action: manipulation;
    transform-origin: 50% 100%;
    will-change: transform, filter;
}

.pin-container.selected {
    transform: scale(1.25);
    z-index: 1000 !important;
    filter: drop-shadow(0 8px 16px rgba(255, 94, 0, 0.4));
}

.pin-body {
    width: 32px;
    height: 32px;
    background: var(--pin-gradient, linear-gradient(135deg, #2E7D32 0%, #43A047 100%));
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    border: 2px solid white;
    z-index: 2;
    overflow: hidden;
    box-shadow: inset 0 2px 4px rgba(255, 255, 255, 0.3);
}

.pin-body::before {
    content: "";
    position: absolute;
    top: 2px;
    left: 20%;
    width: 60%;
    height: 30%;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.4), transparent);
    border-radius: 50%;
    pointer-events: none;
}

.pin-container.selected .pin-body {
    background: linear-gradient(135deg, #FF9500 0%, #FF5E00 100%);
    box-shadow: inset 0 2px 6px rgba(255, 255, 255, 0.4), 0 0 15px rgba(255, 94, 0, 0.5);
}

.pin-inner-circle {
    width: 20px;
    height: 20px;
    background: rgba(255, 255, 255, 0.95);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.pin-inner-circle i {
    font-size: 10px;
    color: var(--pin-color, #2E7D32);
    transition: color 0.3s ease;
}

.pin-container.selected .pin-inner-circle i {
    color: #FF5E00;
}

.pin-pointer {
    width: 0;
    height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 10px solid white;
    margin-top: -3px;
    position: relative;
    z-index: 1;
}

.pin-container { --pin-gradient: linear-gradient(135deg, #00897B 0%, #26A69A 100%); --pin-color: #00897B; }


.map-header-greeting, .map-search-glass {
    display: none !important; }

.map-category-scroller {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(44px, 1fr)) !important;
    gap: 16px 18px !important;
    padding: 12px 22px !important;
    pointer-events: auto !important;
    width: 100% !important;
    max-width: 430px !important;
    margin: 0 auto !important;
    justify-items: center !important;
    align-items: center !important;
}

.map-category-scroller::-webkit-scrollbar { display: none !important; }

.map-empty-state {
    position: absolute;
    inset: 0;
    z-index: 900;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    pointer-events: none;
    background: linear-gradient(180deg, rgba(10, 8, 18, 0.04), rgba(10, 8, 18, 0.10));
    transition: opacity 0.25s ease, visibility 0.25s ease;
}

.map-empty-state.hidden {
    opacity: 0;
    visibility: hidden;
}

.map-empty-card {
    max-width: 290px;
    padding: 22px 20px;
    border-radius: 24px;
    text-align: center;
    color: var(--text-white);
    background: var(--cd-surface-gradient);
    border: 1px solid var(--mobile-border);
    box-shadow: 0 18px 44px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(24px) saturate(145%);
    -webkit-backdrop-filter: blur(24px) saturate(145%);
}

.map-empty-card i {
    width: 48px;
    height: 48px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 18px;
    margin-bottom: 14px;
    color: #1b1300;
    background: var(--cd-accent-gradient);
    box-shadow: 0 12px 28px rgba(255, 94, 0, 0.28);
}

.map-empty-card h3 {
    margin: 0;
    font-size: 1.05rem;
    line-height: 1.25;
    font-weight: 850;
    letter-spacing: -0.02em;
}

.map-empty-card p {
    margin: 8px 0 0;
    color: var(--text-muted);
    font-size: 0.82rem;
    line-height: 1.35;
    font-weight: 650;
}

.map-context-label,
.map-loading-indicator {
    position: absolute;
    left: 16px;
    right: 72px;
    z-index: 2100;
    min-height: 38px;
    display: flex;
    align-items: center;
    gap: 9px;
    padding: 9px 13px;
    border-radius: 16px;
    color: var(--text-white);
    background: var(--cd-control-bg);
    border: 1px solid var(--mobile-border);
    box-shadow: 0 14px 34px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(22px) saturate(145%);
    -webkit-backdrop-filter: blur(22px) saturate(145%);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.01em;
}

.map-context-label {
    top: calc(18px + env(safe-area-inset-top));
}

.map-loading-indicator {
    top: calc(64px + env(safe-area-inset-top));
}

.map-context-label.hidden,
.map-loading-indicator.hidden {
    display: none !important;
}

.listing-profile-modal {
    position: fixed !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%) !important;
    width: 96% !important;
    max-width: 460px !important;
    height: 70vh !important;
    min-height: unset !important;
    max-height: 78vh !important;
    display: flex !important;
    flex-direction: column !important;
    z-index: 25000 !important;
    margin: 0 !important;
    padding: 0 !important;
    pointer-events: auto !important;
    border-radius: 24px !important;
    overflow: hidden !important;
    background: transparent !important;
}

#listingDetailsContent {
    height: auto;
    min-height: 0;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch;
    width: 100% !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
}

.listing-profile-modal .listing-card {
    margin: 0 !important;
    box-shadow: none !important;
    border-radius: 24px !important;
    background: transparent !important;
    width: 100% !important;
    border: none !important;
    height: auto !important;
    min-height: 0 !important;
}

#listingDetailsContent .listing-card {
    border: 1px solid rgba(0,0,0,0.1) !important;
    box-shadow: 0 10px 30px rgba(0,0,0,0.15) !important;
    height: auto !important;
    border-radius: 20px !important;
    background: #fff !important;
    overflow: visible !important; }

.circle-nav {
    display: flex;
    overflow-x: auto;
    gap: 6px;     padding: 8px 5px !important;
    justify-content: center !important;
}

.map-cat-btn {
    width: 38px !important;
    height: 38px !important;
    border-radius: 40% !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex-shrink: 0 !important;
    background: var(--cat-bg, linear-gradient(135deg, #2E7D32 0%, #43A047 100%)) !important;
    box-shadow: 0 8px 20px var(--cat-shadow, rgba(0, 0, 0, 0.2)) !important;
    color: #FFFFFF !important;
    font-size: 1.4rem !important;
    border: none !important;
    transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1), box-shadow 0.2s ease !important;
    pointer-events: auto !important;
    cursor: pointer !important;
}

.map-cat-btn:active {
    transform: scale(0.85) !important;     box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
}

.map-cat-btn[data-map-cat="restaurant"] { --cat-bg: linear-gradient(135deg, #FF3D00, #FF6E40); --cat-shadow: rgba(255, 61, 0, 0.35); }
.map-cat-btn[data-map-cat="shopping"] { --cat-bg: linear-gradient(135deg, #D500F9, #AA00FF); --cat-shadow: rgba(213, 0, 249, 0.35); }
.map-cat-btn[data-map-cat="grocery"] { --cat-bg: linear-gradient(135deg, #00C853, #1B5E20); --cat-shadow: rgba(0, 200, 83, 0.35); }
.map-cat-btn[data-map-cat="temple"] { --cat-bg: linear-gradient(135deg, #FFAB00, #FF6D00); --cat-shadow: rgba(255, 171, 0, 0.35); }
.map-cat-btn[data-map-cat="service"] { --cat-bg: linear-gradient(135deg, #2962FF, #0091EA); --cat-shadow: rgba(41, 98, 255, 0.35); }
.map-cat-btn[data-map-cat="organization"] { --cat-bg: linear-gradient(135deg, #C51162, #880E4F); --cat-shadow: rgba(197, 17, 98, 0.35); }
.map-cat-btn[data-map-cat="learning"] { --cat-bg: linear-gradient(135deg, #00B8D4, #00838F); --cat-shadow: rgba(0, 184, 212, 0.35); }
.map-cat-btn[data-map-cat="realestate"] { --cat-bg: linear-gradient(135deg, #6200ea, #7c4dff); --cat-shadow: rgba(98, 0, 234, 0.35); }
.map-cat-btn[data-map-cat="event"] { --cat-bg: linear-gradient(135deg, #F50057, #C62828); --cat-shadow: rgba(245, 0, 87, 0.35); }

.map-cat-btn[data-map-cat="location"] { --cat-bg: linear-gradient(135deg, #303F9F, #3F51B5); --cat-shadow: rgba(48, 63, 159, 0.35); }
.map-cat-btn[data-map-cat="zoomin"] { --cat-bg: linear-gradient(135deg, #827717, #CDDC39); --cat-shadow: rgba(130, 119, 23, 0.35); }
.map-cat-btn[data-map-cat="cinema"] { --cat-bg: linear-gradient(135deg, #FF00CC, #3333FF); --cat-shadow: rgba(255, 0, 204, 0.35); }
.map-cat-btn[data-map-cat="zoomout"] { --cat-bg: linear-gradient(135deg, #3E2723, #795548); --cat-shadow: rgba(62, 39, 35, 0.35); }

.map-cat-btn.active {
    background: var(--cat-bg) !important;
    color: #FFFFFF !important;
    box-shadow: 0 12px 30px var(--cat-shadow) !important;
    border: none !important;
    transform: scale(1.15) translateY(-8px) !important;
    z-index: 2;
}

.map-cat-btn i {
    margin: 0 !important;
    text-shadow: 0 2px 4px rgba(0,0,0,0.15);
}

.custom-map-pin {
    width: 36px !important;
    height: 46px !important;
}

.pin-container {
    width: 36px !important;
    height: 46px !important;
    filter: drop-shadow(0 3px 5px rgba(0,0,0,0.18)) !important;
    transform-origin: 50% 100%;
}

.pin-container.selected {
    transform: scale(1.18) !important;
}

.pin-svg {
    position: absolute;
    inset: 0;
    width: 36px;
    height: 46px;
}

.pin-container .fa-solid {
    position: absolute;
    top: 11px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 2;
    color: var(--pin-color, #2E7D32);
    font-size: 0.58rem;
}

.pin-body,
.pin-pointer,
.pin-inner-circle {
    display: none !important;
}

.map-pin-enter {
    animation: mapPinPop 0.28s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.map-pin-exit {
    opacity: 0 !important;
    transform: scale(0.76) translateY(6px) !important;
    transition: opacity 0.16s ease, transform 0.16s ease;
}

.custom-map-cluster {
    background: transparent !important;
    border: none !important;
}

.map-cluster-bubble {
    width: 44px;
    height: 44px;
    border-radius: 18px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 0.9rem;
    font-weight: 900;
    background: linear-gradient(135deg, var(--cluster-a, #ffd700), var(--cluster-b, #ff5e00));
    border: 2px solid rgba(255, 255, 255, 0.86);
    box-shadow: 0 8px 18px rgba(8, 4, 15, 0.26);
}

.map-spider-leg {
    stroke-linecap: round;
}

@keyframes mapPinPop {
    from { opacity: 0; transform: translateY(10px) scale(0.72); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}


.listing-profile-modal .listing-card-outer {
    width: 100% !important;
}



.listing-profile-modal .close-modal {
    position: absolute !important;
    top: 15px !important;
    right: 15px !important;
    background: #FF6B00 !important;     color: #fff !important;
    width: 36px !important;
    height: 36px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 1.1rem !important;     box-shadow: 0 4px 15px rgba(0,0,0,0.3) !important;
    border: 2px solid #fff !important;
    z-index: 22000 !important;
    opacity: 1 !important;
    visibility: visible !important;
    padding: 0 !important;
}

.professional-title {
    font-size: 0.52rem !important;
    text-transform: uppercase !important;
    letter-spacing: 0.8px !important;
    color: #8E8E93 !important;
    margin-top: 2px !important;
    margin-bottom: 8px !important;
    font-weight: 700 !important;
    display: block !important;
    line-height: 1.2 !important;
    width: 100% !important;
    text-align: left !important;
}

body.dark-mode .professional-title {
    color: #aaa !important;
}

.user-location-marker {
    background: transparent;
    border: none;
}

.user-dot-pulse {
    width: 20px;
    height: 20px;
    background: #007AFF;
    border: 3px solid #FFFFFF;
    border-radius: 50%;
    position: relative;
    box-shadow: 0 0 10px rgba(0, 122, 255, 0.4);
}

.user-dot-pulse::after {
    content: '';
    position: absolute;
    top: -3px;
    left: -3px;
    right: -3px;
    bottom: -3px;
    border-radius: 50%;
    background: rgba(0, 122, 255, 0.3);
    animation: userPulse 2s infinite ease-out;
    z-index: -1;
}

@keyframes userPulse {
    0% { transform: scale(1); opacity: 0.8; }
    50% { opacity: 0.4; }
    100% { transform: scale(3.5); opacity: 0; }
}

.map-recenter-btn {
    position: absolute;
    bottom: 30px;
    right: 20px;
    width: 48px;
    height: 48px;
    background: rgba(255, 255, 255, 0.95);
    border: none;
    border-radius: 14px;
    color: #007AFF;
    font-size: 1.3rem;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    z-index: 4000;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.165, 0.84, 0.44, 1);
    backdrop-filter: blur(10px);
}

.map-recenter-btn:active {
    transform: scale(0.92);
    background: #FFFFFF;
}

.map-nav-cluster {
    position: absolute;
    right: 20px;
    bottom: 40px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 1001;
}

.map-ctrl-btn {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.95);
    border: 1px solid rgba(0, 0, 0, 0.05);
    color: #1D1D1F;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 4px 15px rgba(0,0,0,0.15);
    backdrop-filter: blur(10px);
    cursor: pointer;
    transition: all 0.2s;
}

.map-ctrl-btn:active {
    transform: scale(0.92);
    background: #F2F2F7;
}

#recenterMapBtn {
    background: #E65100;
    color: white;
}

.map-controls-stack {
    position: absolute;
    top: calc(15px + env(safe-area-inset-top));
    right: 15px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    z-index: 2000;
}

.map-compass-btn {
    width: 38px;
    height: 38px;
    background: linear-gradient(135deg, #1a2a6c, #2a4858) !important;
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border: none !important;
    border-radius: 35%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    cursor: pointer;
    pointer-events: auto !important;
    padding: 4px 0 0;
}

.map-side-btn {
    width: 38px;
    height: 38px;
    border: none !important;
    border-radius: 35%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-size: 1.1rem;
    box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.map-side-btn:active {
    transform: scale(0.92);
}

.zoom-in-btn {
    background: linear-gradient(135deg, #9E9D24, #827717) !important; }

.zoom-out-btn {
    background: linear-gradient(135deg, #4E342E, #3E2723) !important; }

.locate-btn {
    background: linear-gradient(135deg, #3F51B5, #303F9F) !important; }

.map-compass-btn:active {
    transform: scale(0.92);
}

.north-label {
    font-size: 0.62rem;
    font-weight: 900;
    color: #FFFFFF;
    line-height: 1;
    margin-bottom: -1px;
    text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}

.map-compass-btn i {
    font-size: 1.05rem;
    transform: rotate(-45deg);     color: #FFFFFF !important;
    -webkit-background-clip: unset;
    background-clip: unset;
    -webkit-text-fill-color: unset;
    filter: drop-shadow(0 2px 3px rgba(0,0,0,0.2));
}



.stale-listing {
    opacity: 0.75;
}
.verified-badge {
    color: #34C759;
    margin-left: 4px;
}
.freshness-tag {
    font-size: 11px;
    color: rgba(255,255,255,0.5);
    margin-top: 2px;
}

.report-btn {
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    color: #FF5E00 !important;
}
.report-btn.claim {
    color: #34C759 !important;
}

.premium-select-wrapper {
    position: relative;
    width: 100%;
}

.premium-select-wrapper select {
    width: 100%;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    color: #fff !important;
    padding: 12px 40px 12px 15px !important;
    font-size: 0.95rem !important;
    font-family: inherit !important;
    cursor: pointer !important;
    appearance: none !important;
    -webkit-appearance: none !important;
    -moz-appearance: none !important;
    transition: all 0.3s !important;
}

.premium-select-wrapper select:focus {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: #FF9500 !important;
    box-shadow: 0 0 15px rgba(255, 149, 0, 0.2) !important;
    outline: none !important;
}

.premium-select-wrapper .select-chevron {
    position: absolute;
    right: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: #FF9500 !important;
    font-size: 0.9rem;
    pointer-events: none;
    z-index: 2;
}

.premium-form textarea {
    width: 100% !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 12px !important;
    color: #fff !important;
    padding: 12px 15px !important;
    font-family: inherit !important;
    font-size: 0.95rem !important;
    margin-top: 10px !important;
    transition: all 0.3s !important;
}

.premium-form textarea:focus {
    background: rgba(255, 255, 255, 0.1) !important;
    border-color: #FF9500 !important;
    outline: none !important;
}


#listingDetailsModal.cinema-mode .modal-content {
    background: #0f0f12 !important;
    border: 1.5px solid rgba(255, 94, 0, 0.3) !important;
}

#listingDetailsModal.cinema-mode .details-body *,
#listingDetailsModal.cinema-mode .contact-text span {
    color: #ffffff !important;
}

#listingDetailsModal.cinema-mode #detailsModalTitle {
    color: #ffffff !important;
}

#listingDetailsModal.cinema-mode .details-header #detailsModalImg {
    object-fit: cover !important;
    background: transparent !important;
}

#listingDetailsModal.event-mode .details-header #detailsModalImg {
    display: block !important;
    object-fit: cover !important;
    object-position: center top !important;
    aspect-ratio: 3 / 2 !important;
}

#listingDetailsModal.event-mode .details-header {
    height: auto !important;
    aspect-ratio: 3 / 2 !important;
    line-height: 0 !important;
}

#listingDetailsModal.event-mode .modal-content {
    width: min(90vw, 350px) !important;
    max-width: 350px !important;
    border-radius: 18px !important;
}

#listingDetailsModal.event-mode .details-body {
    padding: 16px !important;
}

#listingDetailsModal.event-mode #detailsModalTitle {
    font-size: 1.22rem !important;
}

.movie-meta-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
    margin-bottom: 5px;
}

.meta-badge {
    background: rgba(255,255,255,0.1);
    backdrop-filter: blur(4px);
    border: 1px solid rgba(255,255,255,0.15);
    color: #fff;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 0.65rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.8px;
}

.meta-badge.highlight {
    background: rgba(255, 94, 0, 0.2);
    border-color: rgba(255, 94, 0, 0.5);
    color: #FF9500;
}



.cinema-schedule-section {

    margin-top: 20px;
    padding-top: 15px;
    border-top: 1px solid rgba(255,255,255,0.12);
    display: none; }

#listingDetailsModal.cinema-mode .cinema-schedule-section {
    display: block;
}

.schedule-day-block {
    margin-bottom: 24px;
}

.schedule-day-header {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 15px;
}

.schedule-day-title {
    font-size: 0.8rem;
    font-weight: 800;
    color: #FF5E00;
    text-transform: uppercase;
    letter-spacing: 1.2px;
}

.schedule-badge-today {
    background: #FF3B30;
    color: #fff;
    font-size: 0.6rem;
    font-weight: 900;
    padding: 3px 8px;
    border-radius: 6px;
    box-shadow: 0 4px 10px rgba(255, 59, 48, 0.3);
}

.showtime-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.showtime-pill {
    background: rgba(255,255,255,0.08);
    border: 1px solid rgba(255,255,255,0.12);
    color: #fff;
    padding: 10px 18px;
    border-radius: 14px;
    font-size: 0.9rem;
    font-weight: 700;
}

.showtime-pill:active {
    background: rgba(255, 94, 0, 0.2);
    border-color: #FF5E00;
    color: #FF5E00;
}

.theatre-info-block {
    margin-top: 15px;
    margin-bottom: 25px;
    background: rgba(255,255,255,0.04);
    padding: 20px;
    border-radius: 20px;
    border: 1px solid rgba(255,255,255,0.08);
}

.theatre-info-title {
    font-size: 0.7rem;
    font-weight: 800;
    color: rgba(255,255,255,0.5);
    text-transform: uppercase;
    margin-bottom: 10px;
    letter-spacing: 1px;
}

.theatre-info-name {
    font-size: 1.15rem;
    font-weight: 800;
    color: #fff;
    margin-bottom: 6px;
    line-height: 1.2;
}

.theatre-website-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: #FF9500;
    text-decoration: none;
    font-size: 0.95rem;
    font-weight: 700;
    margin-top: 15px;
    padding: 8px 0;
}

.business-hours-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 6px 14px;
    border-radius: 22px;
    background: rgba(142, 142, 147, 0.06);
}

.business-hours-row {
    display: grid;
    grid-template-columns: minmax(112px, 0.72fr) minmax(0, 1fr);
    gap: 14px;
    align-items: start;
    padding: 16px 0;
    border-bottom: 1px solid rgba(142, 142, 147, 0.13);
}

.business-hours-row:last-child {
    border-bottom: none;
}

.business-hours-row.today-highlight {
    margin: 0 -4px;
    padding: 16px 4px;
    border-radius: 16px;
    background: rgba(52, 199, 89, 0.08) !important;
}

.business-hours-day {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
}

.business-hours-day-name {
    color: var(--text-white);
    font-size: 0.98rem;
    font-weight: 800;
    line-height: 1.2;
}

.business-hours-row.today-highlight .business-hours-day-name {
    color: #34c759;
}

.business-hours-today-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    padding: 3px 7px;
    border-radius: 7px;
    background: #34c759;
    color: #ffffff;
    font-size: 0.62rem;
    font-weight: 900;
    letter-spacing: 0.04em;
}

.business-hours-time {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 5px;
    color: #8E8E93;
    font-size: 0.96rem;
    font-weight: 700;
    line-height: 1.22;
    text-align: right;
    overflow-wrap: normal;
}

.business-hours-row.today-highlight .business-hours-time {
    color: var(--text-white);
    font-weight: 850;
}

.business-hours-time.is-closed {
    color: rgba(142, 142, 147, 0.86);
}

.business-hours-session {
    display: block;
    white-space: nowrap;
}

@media (max-width: 420px) {
    .business-hours-row {
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .business-hours-day {
        justify-content: space-between;
    }

    .business-hours-time {
        align-items: flex-start;
        text-align: left;
        font-size: 1rem;
    }

    .business-hours-session {
        white-space: normal;
    }
}

.no-schedule-msg {
    color: rgba(255,255,255,0.5);
    font-size: 0.95rem;
    padding: 30px 0;
    text-align: center;
    font-weight: 500;
}

.mobile-results .results-list .listing-card {
    background:
        radial-gradient(circle at 20% 0%, rgba(255, 255, 255, 0.055), transparent 34%),
        linear-gradient(180deg, rgba(31, 31, 35, 0.98), rgba(17, 17, 20, 0.98)) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 24px 70px rgba(0, 0, 0, 0.38) !important;
    color: #f5f5f7 !important;
}

.mobile-results .results-list .card-info {
    background: transparent !important;
    color: #f5f5f7 !important;
    padding: 1.05rem 1.05rem 1rem !important;
}

.mobile-results .results-list .trust-row,
.mobile-results .results-list .card-header-row,
.mobile-results .results-list .cinema-card h3 {
    border-bottom-color: rgba(255, 255, 255, 0.12) !important;
}

.mobile-results .results-list .trust-row {
    color: rgba(245, 245, 247, 0.86) !important;
}

.mobile-results .results-list .card-info h3,
.mobile-results .results-list .listing-card h3 {
    color: #f5f5f7 !important;
    letter-spacing: 0 !important;
}

.mobile-results .results-list .contact-stack {
    gap: 10px !important;
    margin: 0 !important;
}

.mobile-results .results-list .contact-link,
body.light-mode .mobile-results .results-list .contact-link {
    background: rgba(255, 255, 255, 0.045) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 16px !important;
    color: #f5f5f7 !important;
    padding: 10px 12px !important;
    gap: 14px !important;
    margin-bottom: 0 !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035) !important;
}

.mobile-results .results-list .contact-link i,
body.light-mode .mobile-results .results-list .contact-link i {
    width: 42px !important;
    height: 42px !important;
    border-radius: 12px !important;
    background: rgba(255, 94, 0, 0.14) !important;
    border: 1px solid rgba(255, 94, 0, 0.28) !important;
    color: #ff6a00 !important;
    box-shadow: 0 0 18px rgba(255, 94, 0, 0.08) !important;
}

.mobile-results .results-list .contact-text label,
body.light-mode .mobile-results .results-list .contact-text label,
.mobile-results .results-list .cinema-card .contact-text label {
    color: rgba(245, 245, 247, 0.52) !important;
    font-size: 0.68rem !important;
    font-weight: 800 !important;
    letter-spacing: 0.14em !important;
}

.mobile-results .results-list .contact-text span,
body.light-mode .mobile-results .results-list .contact-text span,
.mobile-results .results-list .cinema-card .contact-text span {
    color: #f5f5f7 !important;
    font-size: 0.96rem !important;
    font-weight: 700 !important;
    line-height: 1.28 !important;
}

.mobile-results .results-list .contact-link.event-highlight label {
    color: rgba(255, 149, 0, 0.78) !important;
}

.mobile-results .results-list .contact-link.event-highlight span,
body.light-mode .mobile-results .results-list .contact-link.event-highlight span {
    color: #ffffff !important;
    font-size: 1.06rem !important;
}

.mobile-results .results-list .card-distance,
body.light-mode .mobile-results .results-list .card-distance {
    color: rgba(245, 245, 247, 0.82) !important;
}

.mobile-results .results-list .trust-row.card-meta-bottom,
.trust-row.card-meta-bottom {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(82px, auto) minmax(0, 1fr) !important;
    align-items: center !important;
    column-gap: 8px !important;
    margin: 12px 0 0 !important;
    padding: 12px 0 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-bottom: none !important;
    font-size: 0.85rem !important;
    width: 100% !important;
}

.trust-row.card-meta-bottom .trust-slot {
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
}

.trust-row.card-meta-bottom .trust-slot-left {
    justify-content: flex-start !important;
}

.trust-row.card-meta-bottom .trust-slot-rating,
.trust-row.card-meta-bottom .card-rating-row {
    min-width: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
    color: #ff9500 !important;
    text-align: center !important;
}

.trust-row.card-meta-bottom .trust-slot-right {
    justify-content: flex-end !important;
    color: #8e8e93 !important;
    font-weight: 500 !important;
    text-align: right !important;
}

body.light-mode .mobile-results .results-list .trust-row.card-meta-bottom,
body.light-mode .trust-row.card-meta-bottom {
    border-top-color: rgba(255, 255, 255, 0.12) !important;
    border-bottom: none !important;
}

#listingDetailsModal.listing-profile-modal {
    background:
        radial-gradient(circle at 50% 100%, rgba(255, 94, 0, 0.20), transparent 38%),
        rgba(4, 3, 10, 0.68) !important;
    backdrop-filter: blur(18px) saturate(1.1) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.1) !important;
}

#listingDetailsModal .modal-content.listing-card-vibe {
    width: min(calc(100% - 18px), 430px) !important;
    max-width: 430px !important;
    max-height: min(82vh, 690px) !important;
    min-height: min(560px, calc(100vh - 120px)) !important;
    border-radius: 30px 30px 0 0 !important;
    background:
        linear-gradient(180deg, rgba(39, 30, 22, 0.98), rgba(18, 13, 10, 0.99)) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow:
        0 -26px 70px rgba(0, 0, 0, 0.46),
        inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    color: #f8f5ff !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    padding-bottom: calc(12px + env(safe-area-inset-bottom)) !important;
}

#listingDetailsModal .modal-content.listing-card-vibe::before {
    content: "";
    display: block;
    width: 42px;
    height: 4px;
    margin: 8px auto 8px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.26);
}

#listingDetailsModal .details-header,
#listingDetailsModal.event-mode .details-header,
#listingDetailsModal.cinema-mode .details-header {
    height: 182px !important;
    aspect-ratio: auto !important;
    border-radius: 22px !important;
    margin: 0 13px 0 !important;
    overflow: hidden !important;
    background: #0d0a12 !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32) !important;
}

#listingDetailsModal .details-header #detailsModalImg {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    filter: brightness(0.96) saturate(0.98) contrast(1.02) !important;
    transform: scale(1.015);
}

#listingDetailsModal .details-hero-overlay {
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-end !important;
    min-height: 100% !important;
    padding: 50px 16px 15px !important;
    background:
        linear-gradient(180deg, rgba(6, 4, 10, 0.04) 0%, rgba(6, 4, 10, 0.12) 38%, rgba(6, 4, 10, 0.72) 100%) !important;
}

#listingDetailsModal .details-cat-tag {
    width: fit-content !important;
    max-width: 100% !important;
    min-height: 22px !important;
    padding: 4px 9px !important;
    border-radius: 8px !important;
    background: linear-gradient(135deg, rgba(255, 176, 0, 0.96), rgba(255, 94, 0, 0.96)) !important;
    border: 1px solid rgba(255, 255, 255, 0.14) !important;
    color: #fff !important;
    font-size: 0.58rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.10em !important;
    line-height: 1 !important;
    margin: 0 0 8px !important;
    box-shadow: 0 8px 18px rgba(255, 94, 0, 0.18) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

#listingDetailsModal #detailsModalTitle {
    color: #ffffff !important;
    font-size: clamp(1.1rem, 5.55vw, 1.46rem) !important;
    font-weight: 900 !important;
    line-height: 1.04 !important;
    letter-spacing: 0 !important;
    margin: 0 !important;
    text-shadow: 0 3px 18px rgba(0, 0, 0, 0.82) !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

#listingDetailsModal.event-mode #detailsModalTitle {
    font-size: clamp(1.16rem, 5.8vw, 1.5rem) !important;
}

#listingDetailsModal .details-subtitle {
    color: rgba(255, 255, 255, 0.70) !important;
    font-size: 0.70rem !important;
    font-weight: 560 !important;
    line-height: 1.25 !important;
    margin: 6px 0 0 !important;
    max-width: 96% !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.65) !important;
}

#listingDetailsModal .listing-profile-modal .close-modal,
#listingDetailsModal .close-modal,
#listingDetailsModal.listing-profile-modal .close-modal {
    top: 20px !important;
    right: 20px !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(15, 12, 22, 0.75) !important;
    border: 1px solid rgba(255, 255, 255, 0.25) !important;
    color: #fff !important;
    font-size: 1.15rem !important;
    line-height: 1 !important;
    padding: 0 !important;
    box-shadow: 0 10px 26px rgba(0, 0, 0, 0.26) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
}

#listingDetailsModal .close-modal:active {
    transform: scale(0.93) !important;
}

#listingDetailsModal .details-body-content {
    background:
        radial-gradient(circle at 50% 0%, rgba(255, 94, 0, 0.10), transparent 34%),
        transparent !important;
    padding: 14px 14px calc(18px + env(safe-area-inset-bottom)) !important;
}

#listingDetailsModal .details-actions-row {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    margin: 0 0 12px !important;
}

#listingDetailsModal .details-action-circle {
    min-height: 44px !important;
    width: 100% !important;
    min-width: 0 !important;
    flex-direction: row !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    padding: 0 10px !important;
    border-radius: 14px !important;
    background: rgba(255, 255, 255, 0.065) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.88) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045) !important;
    transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, box-shadow 180ms ease !important;
}

#listingDetailsModal .details-action-placeholder {
    display: block !important;
    min-height: 44px !important;
    width: 100% !important;
    pointer-events: none !important;
    visibility: hidden !important;
}

#listingDetailsModal .details-action-circle:active {
    transform: translateY(1px) scale(0.985) !important;
}

#listingDetailsModal .details-action-circle.primary {
    background: linear-gradient(135deg, #ffb000, #ff5e00) !important;
    border-color: rgba(255, 255, 255, 0.18) !important;
    box-shadow: 0 14px 28px rgba(255, 94, 0, 0.24) !important;
}

#listingDetailsModal .circle-icon {
    width: 25px !important;
    height: 25px !important;
    min-width: 25px !important;
    border-radius: 9px !important;
    background: rgba(255, 255, 255, 0.10) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.88) !important;
    font-size: 0.92rem !important;
}

#listingDetailsModal .details-action-circle.primary .circle-icon {
    background: rgba(255, 255, 255, 0.20) !important;
    border-color: rgba(255, 255, 255, 0.22) !important;
    color: #fff !important;
    box-shadow: none !important;
}

#listingDetailsModal .details-action-label {
    color: rgba(255, 255, 255, 0.88) !important;
    font-size: 0.68rem !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

#listingDetailsModal .details-action-circle.primary .details-action-label {
    color: #fff !important;
}

#listingDetailsModal .details-info-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 11px !important;
    margin: 0 !important;
}

#listingDetailsModal .info-item-box {
    padding: 12px 12px !important;
    gap: 12px !important;
    align-items: flex-start !important;
    border-radius: 15px !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(255, 255, 255, 0.055) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035) !important;
}

#listingDetailsModal .info-icon-box {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    border-radius: 10px !important;
    background: rgba(255, 94, 0, 0.14) !important;
    border: 1px solid rgba(255, 94, 0, 0.22) !important;
    color: #ff7a1a !important;
    font-size: 0.82rem !important;
}

#listingDetailsModal .info-text-box {
    min-width: 0 !important;
    flex: 1 !important;
}

#listingDetailsModal .info-text-box h4 {
    color: rgba(255, 255, 255, 0.50) !important;
    font-size: 0.62rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.13em !important;
    line-height: 1 !important;
    margin: 0 0 3px !important;
}

#listingDetailsModal .info-text-box p {
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 0.88rem !important;
    font-weight: 620 !important;
    line-height: 1.28 !important;
    margin: 0 !important;
    overflow-wrap: anywhere !important;
}

#listingDetailsModal .hours-info-box {
    padding-bottom: 12px !important;
}

#listingDetailsModal .details-hours-list {
    display: grid !important;
    gap: 4px !important;
}

#listingDetailsModal .details-hours-list.single-line {
    display: block !important;
}

#listingDetailsModal .details-hours-row {
    display: grid !important;
    grid-template-columns: minmax(76px, 0.34fr) minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: baseline !important;
    font-size: 0.76rem !important;
    line-height: 1.22 !important;
}

#listingDetailsModal .details-hours-row span {
    color: rgba(255, 255, 255, 0.54) !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
}

#listingDetailsModal .details-hours-row strong {
    color: rgba(255, 255, 255, 0.82) !important;
    font-weight: 500 !important;
}

#listingDetailsModal .details-desc-section {
    margin-top: 10px !important;
    padding-top: 10px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.10) !important;
}

#listingDetailsModal .details-desc-section h3 {
    color: #fff !important;
    font-size: 0.9rem !important;
    margin-bottom: 7px !important;
}

#listingDetailsModal .details-desc-section p {
    color: rgba(255, 255, 255, 0.72) !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
}

#listingDetailsModal .detail-template-header.compact-hero,
#listingDetailsModal.place-mode .details-header,
#listingDetailsModal.service-mode .details-header {
    height: 158px !important;
}

#listingDetailsModal .details-hero-overlay.strong {
    background: linear-gradient(180deg, rgba(6, 4, 10, 0.10) 0%, rgba(6, 4, 10, 0.24) 30%, rgba(6, 4, 10, 0.84) 100%) !important;
}

#listingDetailsModal .detail-template {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

#listingDetailsModal .detail-summary-strip {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 9px !important;
}

#listingDetailsModal .detail-summary-item {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-height: 58px !important;
    padding: 11px 12px !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
}

#listingDetailsModal .detail-summary-item i {
    width: 30px !important;
    height: 30px !important;
    border-radius: 10px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255, 122, 24, 0.14) !important;
    color: #ffae76 !important;
    flex-shrink: 0 !important;
}

#listingDetailsModal .detail-summary-item.success i {
    background: rgba(52, 199, 89, 0.16) !important;
    color: #9ff0b8 !important;
}

#listingDetailsModal .detail-summary-item small {
    display: block !important;
    color: rgba(255, 255, 255, 0.52) !important;
    font-size: 0.6rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.1em !important;
    line-height: 1 !important;
    margin-bottom: 4px !important;
    text-transform: uppercase !important;
}

#listingDetailsModal .detail-summary-item strong {
    display: block !important;
    color: #ffffff !important;
    font-size: 0.83rem !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
}

#listingDetailsModal .detail-section {
    padding: 15px 15px 16px !important;
    border-radius: 18px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
}

#listingDetailsModal .detail-section-heading {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    margin-bottom: 10px !important;
}

#listingDetailsModal .detail-section-heading h3 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: 0.96rem !important;
    font-weight: 860 !important;
    line-height: 1.15 !important;
}

#listingDetailsModal .detail-section-body {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

#listingDetailsModal .detail-info-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

#listingDetailsModal .detail-info-row {
    display: grid !important;
    grid-template-columns: minmax(84px, 0.5fr) minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: start !important;
}

#listingDetailsModal .detail-info-row span {
    color: rgba(255, 255, 255, 0.52) !important;
    font-size: 0.72rem !important;
    font-weight: 720 !important;
    line-height: 1.25 !important;
}

#listingDetailsModal .detail-info-row strong {
    color: rgba(255, 255, 255, 0.90) !important;
    font-size: 0.84rem !important;
    font-weight: 640 !important;
    line-height: 1.35 !important;
}

#listingDetailsModal .detail-chip-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

#listingDetailsModal .detail-chip-row.accent .detail-chip {
    background: rgba(255, 122, 24, 0.14) !important;
    border-color: rgba(255, 122, 24, 0.20) !important;
}

#listingDetailsModal .detail-chip {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 28px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.07) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.82) !important;
    font-size: 0.74rem !important;
    font-weight: 760 !important;
}

#listingDetailsModal .detail-rich-text {
    margin: 0 !important;
    color: rgba(255, 255, 255, 0.76) !important;
    font-size: 0.9rem !important;
    line-height: 1.5 !important;
}

#listingDetailsModal .detail-inline-link {
    color: #ffd9bd !important;
    font-size: 0.82rem !important;
    font-weight: 760 !important;
    text-decoration: none !important;
}

#listingDetailsModal .detail-secondary-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

#listingDetailsModal .detail-secondary-button {
    min-height: 40px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: rgba(255, 255, 255, 0.90) !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 0.78rem !important;
    font-weight: 780 !important;
}

#listingDetailsModal .detail-secondary-button.active {
    background: rgba(255, 122, 24, 0.16) !important;
    border-color: rgba(255, 122, 24, 0.22) !important;
    color: #ffffff !important;
}

#listingDetailsModal .event-actions,
#listingDetailsModal .place-actions,
#listingDetailsModal .service-actions {
    margin-bottom: 0 !important;
}

@media (max-width: 390px) {
    #listingDetailsModal .detail-summary-strip {
        grid-template-columns: 1fr !important;
    }

    #listingDetailsModal .detail-info-row {
        grid-template-columns: 1fr !important;
        gap: 4px !important;
    }
}

#listingDetailsModal.event-mode .modal-content.listing-card-vibe,
#listingDetailsModal.cinema-mode .modal-content.listing-card-vibe {
    width: min(calc(100% - 18px), 430px) !important;
    max-width: 430px !important;
    min-height: min(560px, calc(100vh - 120px)) !important;
    border-radius: 30px 30px 0 0 !important;
}

#listingDetailsModal.event-mode .details-header,
#listingDetailsModal.cinema-mode .details-header {
    height: 182px !important;
    aspect-ratio: auto !important;
}

#listingDetailsModal.listing-profile-modal {
    position: fixed !important;
    inset: 0 !important;
    top: 0 !important;
    left: 0 !important;
    transform: none !important;
    width: 100% !important;
    max-width: none !important;
    height: 100% !important;
    max-height: none !important;
    min-height: 100% !important;
    padding: calc(96px + env(safe-area-inset-top)) 0 0 !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    z-index: 50000 !important;
    flex-direction: row !important;
    align-items: flex-end !important;
    justify-content: center !important;
}

#listingDetailsModal.listing-profile-modal:not(.active) {
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
}

#listingDetailsModal.listing-profile-modal.active {
    opacity: 1 !important;
    visibility: visible !important;
    pointer-events: auto !important;
}

#listingDetailsModal.listing-profile-modal:not(.active) .modal-content {
    pointer-events: none !important;
}

#listingDetailsModal #listingDetailsContent {
    width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    display: block !important;
    padding: 0 !important;
    border: none !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    opacity: 1 !important;
    visibility: visible !important;
    overflow: visible !important;
    z-index: auto !important;
}

#listingDetailsModal .modal-content.listing-card-vibe {
    box-sizing: border-box !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

#listingDetailsModal .details-header,
#listingDetailsModal.event-mode .details-header,
#listingDetailsModal.cinema-mode .details-header {
    width: auto !important;
    max-width: none !important;
    box-sizing: border-box !important;
}

#listingDetailsModal .details-body,
#listingDetailsModal .details-body-content {
    margin-top: 0 !important;
    box-sizing: border-box !important;
}

:root,
body.dark-mode {
    --mobile-bg: #050505;
    --mobile-card-bg: rgba(255, 255, 255, 0.045);
    --mobile-glass: rgba(15, 15, 18, 0.74);
    --mobile-border: rgba(255, 255, 255, 0.12);
    --bg-mesh: #050505;
    --text-white: #ffffff;
    --text-muted: rgba(255, 255, 255, 0.62);
    --mobile-primary: #ff5e00;
    --modal-bg: #050505;
    --modal-inner-bg: rgba(255, 255, 255, 0.045);
    --input-bg: rgba(255, 255, 255, 0.07);
    --input-border: rgba(255, 255, 255, 0.14);
    --input-text: #ffffff;
    --cd-accent-gradient: linear-gradient(135deg, #ffd700 0%, #ff5e00 100%);
    --cd-surface-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.058) 0%, rgba(255, 255, 255, 0.032) 100%);
    --cd-control-bg: rgba(15, 15, 18, 0.78);
    --cd-inner-bg: rgba(255, 255, 255, 0.055);
    --cd-nav-bg: rgba(5, 5, 5, 0.9);
    --cd-hero-glow: rgba(255, 94, 0, 0.14);
    --cd-shadow: rgba(0, 0, 0, 0.34);
}

body.light-mode {
    --mobile-bg: #f7f8fa;
    --mobile-card-bg: rgba(255, 255, 255, 0.84);
    --mobile-glass: rgba(255, 255, 255, 0.76);
    --mobile-border: rgba(0, 0, 0, 0.08);
    --bg-mesh: #f7f8fa;
    --text-white: #17171c;
    --text-muted: rgba(23, 23, 28, 0.64);
    --mobile-primary: #ff5e00;
    --modal-bg: #f7f8fa;
    --modal-inner-bg: rgba(255, 255, 255, 0.84);
    --input-bg: rgba(255, 255, 255, 0.86);
    --input-border: rgba(0, 0, 0, 0.1);
    --input-text: #17171c;
    --cd-accent-gradient: linear-gradient(135deg, #ffd700 0%, #ff5e00 100%);
    --cd-surface-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 255, 255, 0.82) 100%);
    --cd-control-bg: rgba(255, 255, 255, 0.86);
    --cd-inner-bg: rgba(23, 23, 28, 0.045);
    --cd-nav-bg: rgba(255, 255, 255, 0.92);
    --cd-hero-glow: rgba(255, 94, 0, 0.1);
    --cd-shadow: rgba(15, 23, 42, 0.12);
}

body,
body.dark-mode,
body.light-mode {
    background: var(--mobile-bg) !important;
    color: var(--text-white) !important;
}

#mobileMain,
#homeFeedSection,
.featured-mobile-section,
.mobile-results,
body.light-mode #featuredSectionMobile {
    background: transparent !important;
}

.brand-tagline.single-line-tagline,
.featured-sub-title,
.footer-right,
.card-distance,
.sub-cat-btn span,
body.light-mode .sub-cat-btn span {
    color: var(--text-muted) !important;
}

.round-btn,
body.light-mode .round-btn,
.icon-wrapper,
body.light-mode .icon-wrapper,
.location-select,
body.light-mode .location-select,
.header-location-wrapper,
.mobile-search-row,
body.light-mode .mobile-search-row,
.side-menu,
body.light-mode .side-menu {
    background: var(--cd-control-bg) !important;
    border-color: var(--mobile-border) !important;
    color: var(--text-white) !important;
    box-shadow: 0 14px 34px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
}

body.light-mode .logo-chicago,
.logo-chicago {
    color: var(--text-white) !important;
}

.logo-desi,
.brand-group h1 {
    background: var(--cd-accent-gradient) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

.feed-card,
.listing-card,
body.light-mode .listing-card,
.mobile-results .results-list .listing-card,
#featuredSectionMobile .listing-card,
.sub-cat-btn.no-image,
.feed-card-footer,
body.light-mode .feed-card-footer {
    background: var(--cd-surface-gradient) !important;
    border: 1px solid var(--mobile-border) !important;
    box-shadow: 0 18px 48px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
    color: var(--text-white) !important;
}

.feed-card::after,
.card-image::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    pointer-events: none !important;
    background:
        linear-gradient(180deg, rgba(11, 6, 20, 0.10), rgba(11, 6, 20, 0.24)),
        linear-gradient(to top, rgba(11, 6, 20, 0.72) 0%, rgba(11, 6, 20, 0.42) 34%, rgba(11, 6, 20, 0.05) 72%, transparent 100%) !important;
    z-index: 2 !important;
}

.feed-card-overlay {
    background:
        linear-gradient(rgba(96, 96, 96, 0.22), rgba(96, 96, 96, 0.22)),
        linear-gradient(to top, rgba(0, 0, 0, 0.68) 0%, rgba(72, 72, 72, 0.24) 42%, transparent 100%) !important;
}

.home-feed-cards .feed-card::after {
    background:
        linear-gradient(rgba(96, 96, 96, 0.18), rgba(96, 96, 96, 0.18)),
        linear-gradient(to top, rgba(0, 0, 0, 0.58) 0%, rgba(48, 48, 48, 0.28) 34%, rgba(48, 48, 48, 0.05) 72%, transparent 100%) !important;
}

.feed-card-content,
.card-type-badge,
.playing-today-badge,
.listing-actions-overlay {
    z-index: 3;
}

.card-glass-title,
.footer-action-btn,
body.light-mode .footer-action-btn,
.promote-btn-menu,
.explore-btn,
.nav-tab.active {
    background: var(--cd-accent-gradient) !important;
    color: #1b1300 !important;
    box-shadow: 0 14px 30px rgba(255, 94, 0, 0.26) !important;
}

.add-listing-btn-menu {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
    box-shadow: 0 14px 28px rgba(255, 94, 0, 0.24) !important;
}

.promote-btn-menu {
    background: linear-gradient(135deg, #ffb000 0%, #ff5e00 100%) !important;
    box-shadow: 0 14px 28px rgba(255, 94, 0, 0.24) !important;
}

body.light-mode .card-type-badge,
.card-type-badge,
.details-cat-tag,
.verified-badge,
.playing-today-badge {
    background: var(--cd-accent-gradient) !important;
    color: #1b1300 !important;
    border: 1px solid color-mix(in srgb, var(--mobile-primary) 45%, transparent) !important;
    box-shadow: 0 10px 22px rgba(255, 94, 0, 0.18) !important;
}

.contact-link,
body.light-mode .contact-link,
.mobile-results .results-list .contact-link,
body.light-mode .mobile-results .results-list .contact-link,
.input-with-icon input,
.input-with-icon select,
.input-with-icon textarea,
body.light-mode .input-with-icon input,
body.light-mode .input-with-icon select,
body.light-mode .input-with-icon textarea {
    background: var(--cd-inner-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    color: var(--text-white) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035) !important;
}

.contact-link i,
body.light-mode .mobile-results .results-list .contact-link i {
    background: color-mix(in srgb, var(--mobile-primary) 14%, transparent) !important;
    border-color: color-mix(in srgb, var(--mobile-primary) 24%, transparent) !important;
    color: var(--mobile-primary) !important;
}

.contact-text label,
body.light-mode .contact-text label,
.mobile-results .results-list .contact-text label,
body.light-mode .mobile-results .results-list .contact-text label {
    color: var(--text-muted) !important;
}

.contact-text span,
body.light-mode .contact-text span,
.mobile-results .results-list .contact-text span,
body.light-mode .mobile-results .results-list .contact-text span {
    color: var(--text-white) !important;
}

.mobile-bottom-nav,
body.light-mode .mobile-bottom-nav {
    background: var(--cd-nav-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    box-shadow: 0 22px 54px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.nav-item-wrapper,
.nav-item-wrapper#navBurger.active,
.nav-item-wrapper#navHome.active,
.nav-item-wrapper#navSearch.active {
    color: var(--text-muted) !important;
}

.nav-item-wrapper.active,
.nav-item-wrapper#navBurger.active,
.nav-item-wrapper#navHome.active,
.nav-item-wrapper#navSearch.active {
    color: var(--text-white) !important;
}

.nav-item-wrapper.active .nav-icon-container,
.nav-item-wrapper#navBurger.active .nav-icon-container,
.nav-item-wrapper#navHome.active .nav-icon-container,
.nav-item-wrapper#navSearch.active .nav-icon-container {
    background: var(--cd-accent-gradient) !important;
    color: #1b1300 !important;
    box-shadow: 0 12px 28px rgba(255, 94, 0, 0.32), 0 0 18px rgba(255, 215, 0, 0.14) !important;
}

.nav-icon-container {
    background: rgba(255, 255, 255, 0.045);
    color: inherit;
}

.side-menu-header {
    border-bottom-color: rgba(255, 255, 255, 0.12) !important;
}

.menu-link {
    color: var(--text-white) !important;
}

.menu-link:active,
body.light-mode .menu-link:active {
    background: color-mix(in srgb, var(--mobile-primary) 12%, transparent) !important;
}

.mobile-hero {
    background: transparent !important;
}

.mobile-hero h1,
body.light-mode .mobile-hero h1 {
    color: var(--text-white) !important;
    text-shadow: 0 12px 32px rgba(0, 0, 0, 0.34) !important;
}

.mobile-hero h1 .highlight,
body.light-mode .mobile-hero h1 .highlight {
    background: var(--cd-accent-gradient) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

.mobile-hero p,
body.light-mode .mobile-hero p,
.mobile-hero .stats-badge span,
body.light-mode .mobile-hero .stats-badge span {
    color: var(--text-muted) !important;
}

.mobile-hero .stats-badge,
body.light-mode .mobile-hero .stats-badge {
    background: var(--cd-inner-bg) !important;
    border-color: var(--mobile-border) !important;
}

.round-btn,
.nav-icon-container,
.contact-link i,
.mobile-menu-link i,
.info-icon-box,
.circle-icon,
.sheet-stat-item i,
.map-side-btn,
.map-compass-btn {
    width: 34px !important;
    height: 34px !important;
    min-width: 34px !important;
    border-radius: 12px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--cd-control-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    color: var(--text-white) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055), 0 8px 18px var(--cd-shadow) !important;
}

.contact-link i,
.info-icon-box,
.circle-icon {
    background: color-mix(in srgb, var(--mobile-primary) 14%, transparent) !important;
    border-color: color-mix(in srgb, var(--mobile-primary) 22%, transparent) !important;
    color: var(--mobile-primary) !important;
}

#backToHomeBtn.mobile-page-back-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    border-radius: 50% !important;
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%)) !important;
    border-color: color-mix(in srgb, var(--mobile-primary) 46%, transparent) !important;
    color: var(--cd-text-on-accent, #ffffff) !important;
    -webkit-text-fill-color: var(--cd-text-on-accent, #ffffff) !important;
    box-shadow: var(--cd-soft-glow, 0 10px 24px rgba(255, 94, 0, 0.30), 0 0 16px rgba(255, 215, 0, 0.14)) !important;
}

#backToHomeBtn.mobile-page-back-btn .page-back-icon {
    width: 19px !important;
    height: 19px !important;
    font-size: 1.04rem !important;
}

.feed-card,
.listing-card,
.sub-cat-btn,
.mobile-menu-link,
.details-action-circle,
.nav-icon-container,
.card-image img,
.feed-card-image {
    transition:
        transform 180ms ease,
        box-shadow 220ms ease,
        border-color 220ms ease,
        filter 220ms ease !important;
}

.feed-card:active,
.listing-card:active,
.sub-cat-btn:active {
    transform: translateY(-2px) scale(0.985) !important;
    box-shadow: 0 22px 54px var(--cd-shadow), 0 0 26px rgba(255, 94, 0, 0.12) !important;
}

.feed-card:active .feed-card-image,
.listing-card:active .card-image img,
.sub-cat-btn:active .card-bg-img {
    transform: scale(1.035) !important;
    filter: saturate(1.04) brightness(1.02) !important;
}

@supports (animation-timeline: view()) {
    .feed-card-image,
    .listing-card .card-image img,
    .sub-cat-btn .card-bg-img {
        animation: cdImageScrollZoom linear both;
        animation-timeline: view();
        animation-range: entry 0% cover 70%;
        transform-origin: center center;
    }

    @keyframes cdImageScrollZoom {
        from {
            transform: scale(1.012);
            filter: saturate(0.98) brightness(0.96);
        }
        to {
            transform: scale(1.04);
            filter: saturate(1.05) brightness(1.02);
        }
    }
}

.nav-item-wrapper.active .nav-icon-container,
.nav-item-wrapper#navBurger.active .nav-icon-container,
.nav-item-wrapper#navHome.active .nav-icon-container,
.nav-item-wrapper#navSearch.active .nav-icon-container {
    animation: navGlowPulse 2.4s ease-in-out infinite alternate;
}

@keyframes navGlowPulse {
    from { box-shadow: 0 10px 24px rgba(255, 94, 0, 0.26), 0 0 12px rgba(255, 215, 0, 0.10); }
    to { box-shadow: 0 14px 32px rgba(255, 94, 0, 0.42), 0 0 22px rgba(255, 215, 0, 0.18); }
}

.search-overlay,
body.light-mode .search-overlay {
    --search-accent: var(--cd-theme-solid, var(--mobile-primary));
    background: var(--mobile-bg) !important;
    color: var(--text-white) !important;
}

.search-bar-container {
    position: sticky !important;
    top: calc(16px + env(safe-area-inset-top)) !important;
    z-index: 3 !important;
    margin: calc(18px + env(safe-area-inset-top)) 18px 16px !important;
    padding: 0 !important;
    gap: 10px !important;
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}

.search-input-wrapper {
    min-height: 58px !important;
    padding: 0 18px !important;
    background: var(--cd-control-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    border-radius: 999px !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    backdrop-filter: blur(24px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(150%) !important;
}

.search-input-wrapper:focus-within,
.clear-search-btn:focus-visible { border-color: color-mix(in srgb, var(--search-accent) 34%, var(--mobile-border)) !important; }

.search-input-wrapper input,
#mobileSearchInput {
    color: var(--text-white) !important;
    min-width: 0 !important;
    padding: 0 !important;
    height: 58px !important;
}

.search-input-wrapper input::placeholder,
#mobileSearchInput::placeholder {
    color: var(--text-muted) !important;
}

.search-icon {
    color: var(--cd-secondary, var(--search-accent)) !important;
}

body.light-mode .search-icon {
    color: var(--cd-accent-readable, var(--search-accent)) !important;
}

.clear-search-btn {
    color: var(--text-muted) !important;
    width: 58px !important;
    height: 58px !important;
    min-width: 58px !important;
    background: var(--cd-control-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    border-radius: 999px !important;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    backdrop-filter: blur(24px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(24px) saturate(150%) !important;
}

.search-placeholder {
    margin: 34px 20px 0 !important;
    padding: 34px 22px !important;
    border-radius: 24px !important;
    background: var(--cd-surface-gradient) !important;
    border: 1px solid var(--mobile-border) !important;
    box-shadow: 0 18px 44px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
}

.search-placeholder i {
    font-size: 2.8rem !important;
    color: var(--mobile-primary) !important;
    filter: drop-shadow(0 0 18px rgba(255, 94, 0, 0.24));
}

.search-placeholder p {
    color: var(--text-muted) !important;
    font-size: 0.95rem !important;
    line-height: 1.45 !important;
    margin-top: 14px !important;
}

.search-placeholder::after {
    display: none;
}

.side-menu,
body.light-mode .side-menu {
    background: var(--cd-nav-bg) !important;
    border-color: var(--mobile-border) !important;
    box-shadow: 0 24px 64px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
}

.side-menu-header,
body.light-mode .side-menu-header {
    padding: 20px 18px 14px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
}

.side-menu-content {
    padding: 10px 12px 16px !important;
}

.side-menu-header .logo-text {
    background: var(--cd-accent-gradient) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
}

.close-menu-btn {
    background: rgba(255, 255, 255, 0.07) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    color: rgba(248, 245, 255, 0.82) !important;
}

.mobile-menu-link,
body.light-mode .mobile-menu-link {
    min-height: 48px !important;
    padding: 10px 12px !important;
    gap: 12px !important;
    color: rgba(248, 245, 255, 0.86) !important;
    font-size: 0.96rem !important;
    font-weight: 720 !important;
    border-radius: 16px !important;
}

.mobile-menu-link i {
    width: 30px !important;
    height: 30px !important;
    min-width: 30px !important;
    border-radius: 10px !important;
    font-size: 0.92rem !important;
    background: var(--cd-accent-gradient) !important;
}

.mobile-menu-link:active,
body.light-mode .mobile-menu-link:active {
    background: rgba(255, 255, 255, 0.08) !important;
}

.brand-group h1,
.mobile-hero h1,
.featured-main-title,
.listing-card h3,
.card-glass-title,
.card-sub-title {
    font-weight: 850 !important;
    letter-spacing: 0 !important;
}

.brand-tagline,
.mobile-hero p,
.featured-sub-title,
.card-description,
.contact-text span,
.details-subtitle {
    font-weight: 560 !important;
}

:root {
    --label-primary-bg: var(--cd-accent-gradient);
    --label-secondary-bg: var(--cd-inner-bg);
    --label-neutral-bg: transparent;
    --label-border: var(--mobile-border);
    --label-shadow: 0 10px 22px rgba(255, 94, 0, 0.16);
}

.card-type-badge,
.details-cat-tag,
.playing-today-badge,
.card-glass-title,
.footer-action-btn,
.ticker-label,
.deal-category-badge,
.sports-match-badge,
.event-badge {
    min-height: 24px !important;
    padding: 4px 9px !important;
    border-radius: 9px !important;
    background: var(--label-primary-bg) !important;
    background-image: var(--label-primary-bg) !important;
    background-color: transparent !important;
    border: 1px solid var(--mobile-border) !important;
    color: #1b1300 !important;
    box-shadow: var(--label-shadow) !important;
    font-size: 0.64rem !important;
    font-weight: 850 !important;
    line-height: 1 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.details-cat-tag {
    min-height: 22px !important;
    padding: 4px 9px !important;
    border-radius: 8px !important;
    font-size: 0.58rem !important;
}

body.light-mode .results-list .listing-card .card-type-badge,
body.light-mode .results-list.cinema-mode .listing-card.cinema-card .card-type-badge,
body.light-mode .cinema-card .card-image .card-type-badge,
.cinema-card .card-type-badge {
    background: var(--label-primary-bg) !important;
    background-image: var(--label-primary-bg) !important;
    background-color: transparent !important;
    color: #1b1300 !important;
}

.sheet-type,
.meta-badge,
.featured-tag-mobile,
.flyer-tag,
.card-tag,
.stats-badge,
.freshness-tag,
.schedule-badge-today,
.showtime-pill,
.business-hours-today-badge {
    min-height: 24px !important;
    padding: 5px 10px !important;
    border-radius: 9px !important;
    background: var(--label-secondary-bg) !important;
    border: 1px solid var(--label-border) !important;
    color: var(--text-muted) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
    font-size: 0.64rem !important;
    font-weight: 780 !important;
    line-height: 1 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.verified-badge,
.date-badge,
.time-badge,
.movie-badge,
.deal-expiry-badge,
.classified-location-badge,
.sports-timing-badge,
.classified-price-tag {
    min-height: 24px !important;
    padding: 5px 10px !important;
    border-radius: 9px !important;
    background: var(--label-neutral-bg) !important;
    border: 1px solid var(--mobile-border) !important;
    color: var(--text-muted) !important;
    box-shadow: none !important;
    font-size: 0.64rem !important;
    font-weight: 760 !important;
    line-height: 1 !important;
    letter-spacing: 0.06em !important;
}

.meta-badge.highlight,
.deal-expiry-badge.expired {
    background: color-mix(in srgb, var(--mobile-primary) 12%, transparent) !important;
    border-color: color-mix(in srgb, var(--mobile-primary) 30%, transparent) !important;
    color: var(--mobile-primary) !important;
}

.home-feed-cards {
    gap: 16px 8px !important;
    margin-bottom: 48px !important;
}

.results-list,
.results-list.cinema-mode {
    gap: 1.75rem !important;
}

.mobile-sub-grid,
.mobile-sub-grid.owners-actions-grid {
    gap: 18px !important;
}

.mobile-sub-grid.mobile-l2-grid:not(.event-l2-scroll-grid):not(.cinema-l2-grid):not(.classifieds-filter-grid),
.mobile-sub-grid.owners-actions-grid {
    gap: 20px !important;
    padding: 0 0.5rem !important;
}

.mobile-sub-grid.mobile-l2-grid:not(.event-l2-scroll-grid):not(.cinema-l2-grid):not(.classifieds-filter-grid) .sub-cat-btn,
.mobile-sub-grid.owners-actions-grid .sub-cat-btn {
    aspect-ratio: 1.75 / 1 !important;
}

.mobile-sub-grid-container.directory-l2-rail-container {
    overflow-x: auto !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}

.mobile-sub-grid-container.mobile-l2-container.directory-l2-rail-container {
    padding-bottom: 8px !important;
}

.mobile-sub-grid-container.directory-l2-rail-container::-webkit-scrollbar {
    display: none;
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail {
    --directory-l2-edge: 16px;
    --directory-l2-gap: 0.5rem;
    --directory-l2-card-width: calc((100vw - (var(--directory-l2-edge) * 2) - (var(--directory-l2-gap) * 1.1)) / 1.5);
    display: flex !important;
    grid-template-columns: none !important;
    flex-wrap: nowrap !important;
    gap: var(--directory-l2-gap) !important;
    padding: 0 var(--directory-l2-edge) 12px !important;
    scroll-snap-type: x mandatory !important;
    scroll-padding-inline: var(--directory-l2-edge);
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail:not(.event-l2-scroll-grid):not(.cinema-l2-grid):not(.classifieds-filter-grid) {
    gap: var(--directory-l2-gap) !important;
    padding: 0 var(--directory-l2-edge) 12px !important;
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail .sub-cat-btn {
    flex: 0 0 var(--directory-l2-card-width) !important;
    width: var(--directory-l2-card-width) !important;
    min-width: var(--directory-l2-card-width) !important;
    aspect-ratio: 3 / 2 !important;
    border-radius: 12px !important;
    scroll-snap-align: start !important;
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail:not(.event-l2-scroll-grid):not(.cinema-l2-grid):not(.classifieds-filter-grid) .sub-cat-btn {
    border-radius: 12px !important;
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail .card-content-overlay {
    padding: 10px !important;
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail .card-sub-text {
    max-width: 100%;
    padding: 6px 9px;
    border-radius: 10px;
}

.mobile-sub-grid.mobile-l2-grid.directory-l2-rail .card-sub-title {
    font-size: 0.78rem !important;
    line-height: 1.1;
}

.mobile-sub-grid.classifieds-filter-grid {
    gap: 5px !important;
    padding: 0 0.5rem 24px !important;
}

.feed-card,
.listing-card,
.sub-cat-btn {
    box-shadow: 0 20px 48px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
}

.card-type-badge,
.details-cat-tag,
.playing-today-badge,
.ticker-label,
.deal-category-badge,
.sports-match-badge,
.event-badge {
    box-shadow: 0 8px 18px rgba(255, 94, 0, 0.14) !important;
    font-weight: 800 !important;
}

.card-glass-title {
    font-size: clamp(1.24rem, 6.4vw, 1.7rem) !important;
    line-height: 1.08 !important;
}

.card-description,
.brand-tagline,
.mobile-hero p,
.featured-sub-title {
    color: var(--text-muted) !important;
}

.mobile-bottom-nav,
body.light-mode .mobile-bottom-nav {
    box-shadow: 0 18px 42px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.07) !important;
}

.nav-icon-container {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045) !important;
}

.nav-item-wrapper.active .nav-icon-container,
.nav-item-wrapper#navBurger.active .nav-icon-container,
.nav-item-wrapper#navHome.active .nav-icon-container,
.nav-item-wrapper#navSearch.active .nav-icon-container {
    transform: translateY(-6px) scale(1.08) !important;
}

@keyframes navGlowPulse {
    from { box-shadow: 0 9px 20px rgba(255, 94, 0, 0.20), 0 0 8px rgba(255, 215, 0, 0.08); }
    to { box-shadow: 0 12px 26px rgba(255, 94, 0, 0.30), 0 0 14px rgba(255, 215, 0, 0.12); }
}

.round-btn,
.nav-icon-container,
.contact-link i,
.mobile-menu-link i,
.info-icon-box,
.circle-icon,
.sheet-stat-item i,
.map-side-btn,
.map-compass-btn {
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045), 0 7px 14px rgba(0, 0, 0, 0.16) !important;
}

.search-placeholder {
    min-height: 330px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.side-menu-content {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.mobile-menu-link {
    letter-spacing: 0 !important;
}

.mobile-menu-link i {
    box-shadow: 0 8px 16px rgba(255, 94, 0, 0.18) !important;
}

.listing-actions-overlay {
    position: absolute !important;
    right: 12px !important;
    bottom: 12px !important;
    z-index: 10 !important;
    display: flex !important;
    gap: 8px !important;
}

.listing-image-action {
    width: 34px !important;
    height: 32px !important;
    border-radius: 10px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 255, 255, 0.22) !important;
    background: rgba(18, 12, 29, 0.76) !important;
    color: #ff9f0a !important;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.28), inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
    backdrop-filter: blur(12px) saturate(145%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(145%) !important;
    padding: 0 !important;
    cursor: pointer !important;
}

.listing-image-action.claim {
    color: #34c759 !important;
}

.listing-image-action i {
    font-size: 0.78rem !important;
}

.active-search-results {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
    padding: 0 18px calc(170px + env(safe-area-inset-bottom)) !important;
}

.search-overlay {
    --search-shell-inset: clamp(18px, 3.5vw, 34px);
}

.search-overlay .search-bar-container {
    margin-left: var(--search-shell-inset) !important;
    margin-right: var(--search-shell-inset) !important;
    box-sizing: border-box !important;
}

.search-overlay .active-search-results {
    padding-left: var(--search-shell-inset) !important;
    padding-right: var(--search-shell-inset) !important;
    align-items: stretch !important;
}

.search-overlay .search-placeholder {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

.search-overlay ~ .mobile-bottom-nav,
.mobile-bottom-nav {
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: calc(74px + env(safe-area-inset-bottom)) !important;
    padding: 8px 10px calc(8px + env(safe-area-inset-bottom)) !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    justify-content: space-between !important;
    background: var(--cd-nav-bg) !important;
    border-width: 1px 0 0 !important;
    border-color: var(--mobile-border) !important;
    box-shadow: 0 -16px 38px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.07) !important;
    backdrop-filter: blur(28px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(28px) saturate(150%) !important;
}

.mobile-bottom-nav .nav-item-wrapper {
    flex: 1 1 14.285% !important;
    min-width: 0 !important;
}

.mobile-bottom-nav .nav-icon-container {
    width: 40px !important;
    height: 40px !important;
    border-radius: 14px !important;
    font-size: 1.25rem !important;
}

.mobile-bottom-nav .nav-icon-container i {
    width: 22px !important;
    height: 22px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 22px !important;
    line-height: 1 !important;
}

.mobile-bottom-nav .nav-primary-icon.nav-icon-swapping {
    animation: bottomNavPrimarySwap 180ms ease-out both;
}

@keyframes bottomNavPrimarySwap {
    from {
        opacity: 0;
        transform: scale(0.9);
    }
    to {
        opacity: 1;
        transform: scale(1);
    }
}

.mobile-bottom-nav .nav-item-wrapper.active .nav-icon-container,
.mobile-bottom-nav .nav-item-wrapper#navBurger.active .nav-icon-container,
.mobile-bottom-nav .nav-item-wrapper#navHome.active .nav-icon-container,
.mobile-bottom-nav .nav-item-wrapper#navSearch.active .nav-icon-container,
.mobile-bottom-nav .nav-item-wrapper#navTheme.active .nav-icon-container {
    transform: none !important;
    box-shadow: 0 10px 24px rgba(255, 94, 0, 0.30), 0 0 16px rgba(255, 215, 0, 0.14) !important;
}

.mobile-bottom-nav #navTheme .nav-icon-container {
    background: var(--cd-control-bg) !important;
    border: 1px solid var(--mobile-border) !important;
}

.mobile-bottom-nav #navTheme.active .nav-icon-container {
    background: var(--cd-accent-gradient) !important;
    color: var(--cd-text-on-accent) !important;
}

.mobile-theme-menu {
    position: fixed;
    left: 14px;
    right: 14px;
    bottom: calc(84px + env(safe-area-inset-bottom));
    z-index: 6050;
    pointer-events: auto;
}

.mobile-theme-panel {
    width: 100%;
    box-sizing: border-box;
    padding: 14px;
    border-radius: 22px;
    background: var(--cd-nav-bg);
    border: 1px solid var(--mobile-border);
    box-shadow: 0 -10px 34px var(--cd-shadow), inset 0 1px 0 rgba(255, 255, 255, 0.08);
    backdrop-filter: blur(28px) saturate(150%);
    -webkit-backdrop-filter: blur(28px) saturate(150%);
}

.theme-menu-section + .theme-menu-section {
    margin-top: 12px;
}

.theme-menu-kicker {
    display: block;
    margin: 0 0 8px;
    color: var(--cd-text-muted);
    font-size: 0.68rem;
    font-weight: 850;
    line-height: 1;
    text-transform: uppercase;
}

.theme-menu-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
}

.theme-menu-choice,
.theme-swatch-choice {
    min-width: 0;
    border: 1px solid var(--mobile-border);
    background: var(--cd-control-bg);
    color: var(--cd-text-main);
    font: inherit;
    font-weight: 800;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

.theme-menu-choice {
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    font-size: 0.86rem;
}

.theme-menu-choice i {
    width: 18px;
    height: 18px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.theme-swatch-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 7px;
}

.theme-swatch-choice {
    min-height: 58px;
    padding: 7px 4px;
    border-radius: 15px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    font-size: clamp(0.58rem, 2.8vw, 0.68rem);
    line-height: 1;
}

.theme-swatch-dot {
    width: 24px;
    height: 24px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.24);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.24);
}

.theme-swatch-choice[data-theme-choice="sunset"] .theme-swatch-dot {
    background: linear-gradient(135deg, #ffd700 0%, #ffb000 42%, #ff5e00 100%);
}

.theme-swatch-choice[data-theme-choice="royal"] .theme-swatch-dot {
    background: linear-gradient(135deg, #facc15 0%, #a855f7 48%, #7c3aed 100%);
}

.theme-swatch-choice[data-theme-choice="peacock"] .theme-swatch-dot {
    background: linear-gradient(135deg, #f4c430 0%, #00a6a6 48%, #008c8c 100%);
}

.theme-swatch-choice[data-theme-choice="bollywood"] .theme-swatch-dot {
    background: linear-gradient(135deg, #f59e0b 0%, #fb7185 45%, #e11d48 100%);
}

.theme-swatch-choice[data-theme-choice="fresh"] .theme-swatch-dot {
    background: linear-gradient(135deg, #facc15 0%, #22c55e 45%, #16a34a 100%);
}

.theme-menu-choice.active,
.theme-swatch-choice.active {
    border-color: color-mix(in srgb, var(--cd-primary) 48%, transparent);
    background: color-mix(in srgb, var(--cd-primary) 16%, var(--cd-control-bg));
    box-shadow: var(--cd-soft-glow);
}

#mobileMain, #homeFeedSection, #mobileResultsList {
    padding-bottom: calc(92px + env(safe-area-inset-bottom)) !important;
}

.active-search-results .search-result-card {
    display: grid !important;
    grid-template-columns: 120px minmax(0, 1fr) !important;
    gap: 0 !important;
    align-items: stretch !important;
    min-height: 120px !important;
    padding: 0 !important;
    border-radius: 15px !important;
    background: var(--cd-surface-gradient) !important;
    border: 1px solid var(--mobile-border) !important;
    box-shadow: 0 20px 40px var(--cd-shadow) !important;
    color: var(--text-white) !important;
    overflow: hidden !important;
}

body.dark-mode .active-search-results .search-result-card {
    background: var(--cd-surface-gradient) !important;
}

.active-search-results .search-result-thumb {
    position: relative !important;
    width: 120px !important;
    height: 100% !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: rgba(255, 255, 255, 0.04) !important;
}

.active-search-results .search-result-thumb-fallback {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background:
        radial-gradient(circle at 35% 20%, rgba(255, 122, 24, 0.26), transparent 36%),
        color-mix(in srgb, var(--mobile-primary) 12%, transparent) !important;
    color: rgba(255, 255, 255, 0.72) !important;
    z-index: 0 !important;
}

.active-search-results .search-result-thumb-fallback i {
    font-size: 1.65rem !important;
    filter: drop-shadow(0 8px 18px rgba(0, 0, 0, 0.28)) !important;
}

.active-search-results .search-result-thumb::after {
    content: "" !important;
    position: absolute !important;
    inset: 0 !important;
    background: linear-gradient(180deg, rgba(11, 6, 20, 0.02), rgba(11, 6, 20, 0.28)) !important;
    pointer-events: none !important;
    z-index: 2 !important;
}

.active-search-results .search-result-thumb img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    z-index: 1 !important;
}

.active-search-results .search-result-content {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 16px 16px 16px 18px !important;
}

.active-search-results .search-result-topline {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.active-search-results .search-result-thumb .card-type-badge {
    position: absolute !important;
    bottom: 10px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    min-width: unset !important;
    min-height: unset !important;
    height: auto !important;
    padding: 6px 14px !important;
    background: rgba(0, 0, 0, 0.5) !important;
    backdrop-filter: blur(16px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(16px) saturate(180%) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    color: #ffffff !important;
    font-size: 0.62rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    line-height: 1 !important;
    z-index: 10 !important;
    border-radius: 999px !important;
    text-align: center !important;
    white-space: nowrap !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

body.dark-mode .active-search-results .search-result-thumb .card-type-badge {
    background: rgba(255, 255, 255, 0.12) !important;
}

.active-search-results .search-result-topline > span:not(.card-type-badge) {
    color: rgba(248, 245, 255, 0.66) !important;
    font-size: 0.72rem !important;
    font-weight: 780 !important;
    white-space: nowrap !important;
}

.active-search-results .search-result-card h3 {
    color: #ffffff !important;
    font-size: 1.08rem !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    margin: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.active-search-results .search-card-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px 16px !important;
    margin-top: 2px !important;
}

.active-search-results .search-grid-item {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

.active-search-results .search-grid-item i {
    font-size: 0.85rem !important;
    width: 16px !important;
    text-align: center !important;
    color: var(--search-grid-color, var(--mobile-primary)) !important;
    -webkit-text-fill-color: var(--search-grid-color, var(--mobile-primary)) !important;
}

.active-search-results .search-grid-item span {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.mobile-results .mobile-utility-card {
    display: grid !important;
    grid-template-columns: 120px minmax(0, 1fr) !important;
    gap: 0 !important;
    align-items: stretch !important;
    min-height: 120px !important;
    padding: 0 !important;
    border-radius: 15px !important;
    background: var(--cd-surface-gradient) !important;
    border: 1px solid var(--mobile-border) !important;
    color: var(--text-white) !important;
    overflow: hidden !important;
}

.mobile-results .mobile-utility-card .search-result-thumb {
    position: relative !important;
    width: 120px !important;
    height: 100% !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: rgba(255, 255, 255, 0.04) !important;
}

.mobile-results .mobile-utility-card .search-result-thumb-fallback {
    position: absolute !important;
    inset: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background:
        radial-gradient(circle at 35% 20%, rgba(255, 122, 24, 0.26), transparent 36%),
        color-mix(in srgb, var(--mobile-primary) 12%, transparent) !important;
    color: rgba(255, 255, 255, 0.72) !important;
    z-index: 0 !important;
}

.mobile-results .mobile-utility-card .search-result-thumb-fallback i {
    font-size: 1.65rem !important;
}

.mobile-results .mobile-utility-card .search-result-thumb img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center !important;
    display: block !important;
    z-index: 1 !important;
}

.mobile-results .mobile-utility-card .search-result-content {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 16px 16px 16px 18px !important;
}

.mobile-results .mobile-utility-card .card-type-badge {
    position: absolute !important;
    bottom: 10px !important;
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    width: auto !important;
    min-width: unset !important;
    min-height: unset !important;
    height: auto !important;
    padding: 6px 14px !important;
    background: rgba(255, 255, 255, 0.12) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    color: #ffffff !important;
    font-size: 0.62rem !important;
    font-weight: 900 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
    line-height: 1 !important;
    z-index: 10 !important;
    border-radius: 999px !important;
    text-align: center !important;
    white-space: nowrap !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

.mobile-results .mobile-utility-card h3 {
    color: #ffffff !important;
    font-size: 1.08rem !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    margin: 0 !important;
}

.mobile-results .mobile-utility-card .search-result-summary {
    color: rgba(255, 255, 255, 0.68) !important;
    font-size: 0.82rem !important;
    line-height: 1.35 !important;
    margin: 0 !important;
}

.mobile-results .mobile-utility-card .search-card-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px 16px !important;
    margin-top: 2px !important;
}

.mobile-results .mobile-utility-card .search-grid-item {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 0.8rem !important;
    font-weight: 600 !important;
}

.mobile-results .mobile-utility-card .search-grid-item i {
    font-size: 0.85rem !important;
    width: 16px !important;
    text-align: center !important;
    color: var(--search-grid-color, var(--mobile-primary)) !important;
    -webkit-text-fill-color: var(--search-grid-color, var(--mobile-primary)) !important;
}

.mobile-results .mobile-utility-card .search-grid-item span {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.mobile-results .mobile-utility-card .mobile-utility-action-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding-top: 2px !important;
}

.mobile-results .mobile-utility-card .mobile-utility-action-button,
.mobile-results .mobile-utility-card .mobile-utility-paid-disclosure {
    min-height: 34px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    padding: 0 10px !important;
    border-radius: 10px !important;
    font-size: 0.74rem !important;
    font-weight: 850 !important;
    line-height: 1 !important;
}

.mobile-results .mobile-utility-card .mobile-utility-action-button {
    border: 1px solid rgba(255, 94, 0, 0.35) !important;
    background: rgba(255, 94, 0, 0.1) !important;
    color: #ffffff !important;
    font-family: inherit !important;
}

.mobile-results .mobile-utility-card .mobile-utility-action-button.active {
    border-color: rgba(255, 94, 0, 0.58) !important;
    background: linear-gradient(135deg, #ff5e00, #f19e18) !important;
}

.mobile-results .mobile-utility-card .mobile-utility-paid-disclosure {
    border: 1px solid var(--mobile-border) !important;
    background: rgba(255, 255, 255, 0.08) !important;
    color: rgba(255, 255, 255, 0.72) !important;
}

.mobile-results .results-list.news-mode {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
}

.mobile-news-digest-header {
    display: grid !important;
    grid-template-columns: 54px minmax(0, 1fr) !important;
    gap: 13px !important;
    align-items: center !important;
    padding: 16px !important;
    border-radius: 22px !important;
    border: 1px solid rgba(255, 94, 0, 0.18) !important;
    background:
        linear-gradient(135deg, rgba(255, 94, 0, 0.14), rgba(255, 255, 255, 0.05)),
        var(--cd-surface-gradient) !important;
    color: var(--text-white) !important;
}

.mobile-news-digest-icon {
    width: 54px !important;
    height: 54px !important;
    display: grid !important;
    place-items: center !important;
    border-radius: 18px !important;
    background: rgba(255, 94, 0, 0.14) !important;
    border: 1px solid rgba(255, 94, 0, 0.26) !important;
    color: var(--mobile-primary) !important;
    font-size: 1.2rem !important;
}

.mobile-news-digest-header p,
.mobile-news-digest-header h2,
.mobile-news-digest-header span {
    margin: 0 !important;
    min-width: 0 !important;
}

.mobile-news-digest-header p {
    color: var(--mobile-primary) !important;
    font-size: 0.7rem !important;
    font-weight: 950 !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.1em !important;
}

.mobile-news-digest-header h2 {
    margin-top: 5px !important;
    color: var(--text-white) !important;
    font-size: 1.15rem !important;
    line-height: 1.14 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
}

.mobile-news-digest-header span {
    display: block !important;
    margin-top: 5px !important;
    color: var(--text-muted) !important;
    font-size: 0.82rem !important;
    line-height: 1.35 !important;
    font-weight: 700 !important;
}

.mobile-results .mobile-community-news-card {
    display: flex !important;
    flex-direction: column !important;
    gap: 6px !important;
    padding: 18px !important;
    border-radius: 22px !important;
    border: 1px solid var(--mobile-border) !important;
    background:
        radial-gradient(circle at 100% 0%, rgba(255, 94, 0, 0.18), transparent 34%),
        var(--cd-surface-gradient) !important;
    color: var(--text-white) !important;
    overflow: hidden !important;
}

.mobile-news-card-topline,
.mobile-news-card-footer {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.mobile-news-card-topline {
    justify-content: space-between !important;
}

.mobile-news-card-topline span,
.mobile-news-card-footer span,
.mobile-news-read-link {
    min-width: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    color: var(--text-muted) !important;
    font-size: 0.72rem !important;
    line-height: 1.2 !important;
    font-weight: 850 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
}

.mobile-news-card-topline span:first-child {
    color: var(--mobile-primary) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
}

.mobile-news-freshness-head {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    margin: 0 0 12px !important;
    padding: 0 2px !important;
}

.mobile-news-freshness-head h3 {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    margin: 0 !important;
    color: var(--text-white) !important;
    font-size: 1rem !important;
    line-height: 1.16 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
}

.mobile-news-freshness-head h3 i,
.mobile-news-freshness-head > span {
    color: var(--mobile-primary) !important;
}

.mobile-news-freshness-head p {
    margin: 5px 0 0 !important;
    color: var(--text-muted) !important;
    font-size: 0.72rem !important;
    font-weight: 760 !important;
    line-height: 1.34 !important;
}

.mobile-news-freshness-head > span {
    flex: 0 0 auto !important;
    display: inline-flex !important;
    align-items: center !important;
    min-height: 24px !important;
    padding: 0 9px !important;
    border: 1px solid rgba(255, 94, 0, 0.22) !important;
    border-radius: 999px !important;
    background: rgba(255, 94, 0, 0.12) !important;
    font-size: 0.64rem !important;
    font-weight: 950 !important;
    white-space: nowrap !important;
}

.mobile-news-card-freshness,
.mobile-home-news-freshness {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    min-width: 0 !important;
}

.mobile-news-new-badge {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 18px !important;
    padding: 0 6px !important;
    border-radius: 999px !important;
    background: rgba(255, 94, 0, 0.16) !important;
    color: var(--mobile-primary) !important;
    -webkit-text-fill-color: var(--mobile-primary) !important;
    font-size: 0.58rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

.mobile-news-card-main {
    display: block !important;
}

.mobile-community-news-card.no-image .mobile-news-card-main {
    display: block !important;
}

.mobile-news-card-copy {
    min-width: 0 !important;
}

.mobile-news-card-copy h3 {
    margin: 0 !important;
    color: var(--text-white) !important;
    font-size: 1.2rem !important;
    line-height: 1.18 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
}

.mobile-news-card-copy p {
    margin: 8px 0 0 !important;
    color: var(--text-muted) !important;
    font-size: 0.92rem !important;
    line-height: 1.48 !important;
    font-weight: 650 !important;
}

.mobile-news-card-copy .mobile-news-read-link {
    float: right !important;
    clear: none !important;
    display: inline-flex !important;
    justify-content: center !important;
    min-height: 30px !important;
    min-width: 86px !important;
    margin: 8px 0 0 13px !important;
    padding: 0 10px !important;
    vertical-align: middle !important;
    white-space: nowrap !important;
}

.mobile-news-card-media {
    position: relative !important;
    float: right !important;
    width: 86px !important;
    height: 86px !important;
    min-height: 86px !important;
    align-self: start !important;
    margin: 0 0 8px 13px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
    background:
        linear-gradient(135deg, rgba(255, 94, 0, 0.20), rgba(23, 23, 28, 0.08)) !important;
    border: 1px solid rgba(255, 94, 0, 0.18) !important;
    color: var(--mobile-primary) !important;
    display: grid !important;
    place-items: center !important;
}

.mobile-news-card-media img {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.mobile-news-card-media i {
    position: relative !important;
    z-index: 1 !important;
    font-size: 1.35rem !important;
}

.mobile-news-card-footer {
    justify-content: flex-end !important;
    flex-wrap: wrap !important;
    padding-top: 0 !important;
}

.mobile-news-card-footer span {
    max-width: 46% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.mobile-news-read-link {
    flex: 0 0 auto !important;
    margin-left: auto !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 94, 0, 0.28) !important;
    background: rgba(255, 94, 0, 0.10) !important;
    color: var(--mobile-primary) !important;
    font: inherit !important;
    cursor: pointer !important;
}

.active-search-results .search-result-role,
.active-search-results .search-result-location {
    display: none !important;
}

.active-search-results .search-result-location {
    color: rgba(248, 245, 255, 0.58) !important;
    font-size: 0.76rem !important;
    font-weight: 500 !important;
}

.active-search-results .search-result-meta {
    display: grid !important;
    grid-template-columns: 1fr 0.95fr 0.74fr 0.95fr !important;
    align-items: center !important;
    column-gap: 6px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    color: rgba(248, 245, 255, 0.64) !important;
    font-size: 0.68rem !important;
    font-weight: 680 !important;
}

.active-search-results .search-meta-slot {
    min-width: 0 !important;
    height: 18px !important;
    display: flex !important;
    align-items: center !important;
    overflow: hidden !important;
}

.active-search-results .search-meta-slot:nth-child(3) {
    justify-content: center !important;
}

.active-search-results .search-meta-slot:nth-child(4) {
    justify-content: flex-end !important;
}

.active-search-results .search-meta-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 3px !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    color: rgba(248, 245, 255, 0.64) !important;
}

.active-search-results .search-card-actions {
    display: none !important;
}

.active-search-results .search-action-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    min-height: 44px !important;
    padding: 0 18px !important;
    border-radius: 999px !important;
    font-size: 0.88rem !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    background: rgba(255, 255, 255, 0.08) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
    transition: all 0.2s ease !important;
}

.active-search-results .search-action-link.primary {
    background: var(--cd-accent-gradient) !important;
    border: 0 !important;
    box-shadow: 0 8px 20px rgba(255, 94, 0, 0.25) !important;
    color: #1b1300 !important;
}

.active-search-results .search-action-link i {
    font-size: 0.95rem !important;
}

.active-search-results .search-action-link:active {
    transform: scale(0.96) !important;
    opacity: 0.9 !important;
}

.active-search-results .event-search-card,
.active-search-results .place-search-card,
.active-search-results .service-search-card {
    grid-template-columns: 120px minmax(0, 1fr) !important;
    align-items: stretch !important;
    padding: 0 !important;
    gap: 0 !important;
}

.active-search-results .event-search-card .search-result-thumb,
.active-search-results .place-search-card .search-result-thumb,
.active-search-results .service-search-card .search-result-thumb {
    width: 120px !important;
    height: 100% !important;
    border-radius: 0 !important;
}

.active-search-results .event-search-card .search-result-content,
.active-search-results .place-search-card .search-result-content,
.active-search-results .service-search-card .search-result-content {
    justify-content: flex-start !important;
    gap: 10px !important;
}

.search-result-inline-note {
    color: rgba(248, 245, 255, 0.66) !important;
    font-size: 0.72rem !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
}

.search-meta-pill-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 7px !important;
}

.search-meta-pill {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 24px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.07) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.78) !important;
    font-size: 0.72rem !important;
    font-weight: 760 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.search-meta-pill.accent,
.search-meta-pill.accent-soft {
    background: rgba(255, 122, 24, 0.16) !important;
    border-color: rgba(255, 122, 24, 0.22) !important;
    color: #ffd8c0 !important;
}

.search-meta-pill.success {
    background: rgba(52, 199, 89, 0.14) !important;
    border-color: rgba(52, 199, 89, 0.18) !important;
    color: #b8ffd0 !important;
}

.search-meta-pill.muted {
    color: rgba(248, 245, 255, 0.60) !important;
}

.search-detail-stack {
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.search-result-caption {
    margin: 0 !important;
    color: rgba(248, 245, 255, 0.60) !important;
    font-size: 0.8rem !important;
    line-height: 1.32 !important;
    font-weight: 540 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.search-card-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-top: auto !important;
    padding-top: 4px !important;
}

.search-action-link {
    min-height: 44px !important;
    padding: 0 13px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.88) !important;
    text-decoration: none !important;
    font-size: 0.8rem !important;
    font-weight: 800 !important;
}

.search-action-link.primary {
    background: var(--cd-accent-gradient) !important;
    border-color: transparent !important;
    color: #1b1300 !important;
}

.event-search-card .search-result-location strong {
    color: #ffffff !important;
    font-weight: 760 !important;
}

.active-search-results .cinema-search-result-card {
    display: grid !important;
    grid-template-columns: 120px minmax(0, 1fr) !important;
    gap: 0 !important;
    align-items: stretch !important;
    min-height: 0 !important;
    padding: 0 !important;
    border-radius: 15px !important;
    overflow: hidden !important;
}

.active-search-results .cinema-search-result-thumb {
    position: relative !important;
    width: 120px !important;
    height: 100% !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: rgba(255, 255, 255, 0.06) !important;
}

.active-search-results .cinema-search-result-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
}

.active-search-results .cinema-search-result-content {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 16px 16px 16px 18px !important;
}

.cinema-search-result-head {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
    min-width: 0 !important;
}

.cinema-search-language-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 28px !important;
    padding: 0 14px !important;
    border-radius: 13px !important;
    background: linear-gradient(135deg, var(--cinema-language-1, #ffd700), var(--cinema-language-2, #ff5e00)) !important;
    color: #1b1300 !important;
    font-size: 0.74rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.active-search-results .cinema-search-result-card h3 {
    margin: 2px 0 0 0 !important;
    color: #ffffff !important;
    font-size: 1.25rem !important;
    line-height: 1.12 !important;
    font-weight: 850 !important;
    letter-spacing: -0.01em !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.cinema-search-result-summary {
    margin: 0 !important;
    color: rgba(248, 245, 255, 0.68) !important;
    font-size: 0.88rem !important;
    line-height: 1.3 !important;
    font-weight: 640 !important;
}

.cinema-search-theatre-list {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.cinema-search-theatre-preview {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    padding-top: 14px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
}

.cinema-search-theatre-row {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 10px !important;
}

.cinema-search-theatre-copy {
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.cinema-search-theatre-copy strong {
    color: rgba(255, 255, 255, 0.92) !important;
    font-size: 0.95rem !important;
    line-height: 1.18 !important;
    font-weight: 780 !important;
}

.cinema-search-theatre-copy span {
    color: rgba(248, 245, 255, 0.60) !important;
    font-size: 0.78rem !important;
    line-height: 1.25 !important;
    font-weight: 560 !important;
}

.cinema-search-theatre-meta {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
}

.cinema-search-theatre-distance {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    color: rgba(248, 245, 255, 0.70) !important;
    font-size: 0.78rem !important;
    font-weight: 740 !important;
    white-space: nowrap !important;
}

.cinema-search-theatre-distance i {
    color: #ff9f0a !important;
}

.cinema-search-theatre-map {
    width: 34px !important;
    height: 34px !important;
    border-radius: 12px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    color: rgba(255, 255, 255, 0.82) !important;
    text-decoration: none !important;
}

.cinema-search-showtime-chips {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

.cinema-search-showtime-chip {
    min-width: 82px !important;
    height: 38px !important;
    padding: 0 12px !important;
    border-radius: 12px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--cd-accent-gradient) !important;
    color: #1b1300 !important;
    text-decoration: none !important;
    font-size: 0.86rem !important;
    font-weight: 860 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    white-space: nowrap !important;
}

.cinema-search-showtime-chip.compact {
    min-width: 76px !important;
    height: 38px !important;
    padding: 0 12px !important;
    font-size: 0.8rem !important;
}

.cinema-search-result-footer {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding-top: 14px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1) !important;
    margin-top: 2px !important;
    color: rgba(248, 245, 255, 0.62) !important;
    font-size: 0.82rem !important;
    font-weight: 700 !important;
}

.cinema-search-result-footer strong {
    color: rgba(255, 255, 255, 0.76) !important;
    font-size: 0.75rem !important;
    font-weight: 760 !important;
}

#listingDetailsModal.cinema-search-detail-mode .modal-content.listing-card-vibe {
    width: min(calc(100% - 16px), 430px) !important;
    max-width: 430px !important;
    max-height: min(84vh, 760px) !important;
    min-height: 0 !important;
}

#listingDetailsModal.cinema-search-detail-mode #listingDetailsContent {
    padding: 14px 14px calc(18px + env(safe-area-inset-bottom)) !important;
}

.cinema-search-detail-sheet {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

.cinema-search-detail-head {
    display: grid !important;
    grid-template-columns: 108px minmax(0, 1fr) !important;
    gap: 14px !important;
    align-items: center !important;
}

.cinema-search-detail-poster {
    width: 108px !important;
    aspect-ratio: 3 / 4 !important;
    border-radius: 14px !important;
    object-fit: cover !important;
    display: block !important;
}

.cinema-search-detail-copy {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.cinema-search-detail-copy h2 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: 1.9rem !important;
    line-height: 1.02 !important;
    font-weight: 900 !important;
    letter-spacing: 0 !important;
}

.cinema-search-detail-copy p {
    margin: 0 !important;
    color: rgba(248, 245, 255, 0.66) !important;
    font-size: 0.92rem !important;
    line-height: 1.3 !important;
    font-weight: 620 !important;
}

.cinema-search-detail-date-strip {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
}

.cinema-search-detail-date-strip > span {
    color: rgba(248, 245, 255, 0.60) !important;
    font-size: 0.74rem !important;
    font-weight: 760 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.cinema-search-detail-date-tabs {
    display: flex !important;
    gap: 10px !important;
    overflow-x: auto !important;
    padding-bottom: 4px !important;
    -ms-overflow-style: none !important;
    scrollbar-width: none !important;
}

.cinema-search-detail-date-tabs::-webkit-scrollbar {
    display: none !important;
}

.cinema-search-detail-date-tab {
    flex: 0 0 auto !important;
    width: 82px !important;
    min-height: 92px !important;
    padding: 12px 8px !important;
    border-radius: 22px !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: rgba(255, 255, 255, 0.04) !important;
    color: rgba(248, 245, 255, 0.80) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
}

.cinema-search-detail-date-tab span,
.cinema-search-detail-date-tab small {
    font-size: 0.72rem !important;
    font-weight: 820 !important;
    letter-spacing: 0.04em !important;
}

.cinema-search-detail-date-tab strong {
    font-size: 2rem !important;
    line-height: 1 !important;
    font-weight: 900 !important;
}

.cinema-search-detail-date-tab.active {
    background: var(--cd-accent-gradient) !important;
    border-color: transparent !important;
    color: #1b1300 !important;
}

.cinema-search-detail-theatres {
    display: flex !important;
    flex-direction: column !important;
    gap: 14px !important;
}

.cinema-search-detail-theatre {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 16px 16px 10px !important;
    border-radius: 15px !important;
    background: linear-gradient(180deg, rgba(41, 31, 58, 0.96), rgba(22, 16, 33, 0.98)) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
}

.cinema-search-detail-theatre-head {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 10px !important;
}

.cinema-search-detail-theatre-copy {
    min-width: 0 !important;
}

.cinema-search-detail-theatre-copy h3 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: 1.02rem !important;
    line-height: 1.16 !important;
    font-weight: 820 !important;
}

.cinema-search-detail-theatre-copy p {
    margin: 5px 0 0 !important;
    color: rgba(248, 245, 255, 0.58) !important;
    font-size: 0.8rem !important;
    line-height: 1.3 !important;
    font-weight: 560 !important;
}

.cinema-search-detail-distance {
    display: inline-flex !important;
    align-items: center !important;
    gap: 5px !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    color: rgba(255, 255, 255, 0.84) !important;
    font-size: 0.8rem !important;
    font-weight: 780 !important;
    white-space: nowrap !important;
}

.cinema-search-detail-distance i {
    color: #ff9f0a !important;
}

.cinema-search-showtime-chips.large .cinema-search-showtime-chip {
    min-width: 72px !important;
    height: 38px !important;
    padding: 0 8px !important;
    font-size: 0.8rem !important;
}

.cinema-search-detail-actions {
    display: flex !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
}

.cinema-search-detail-link {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 120px !important;
    height: 40px !important;
    padding: 0 16px !important;
    border-radius: 999px !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    background: rgba(255, 255, 255, 0.05) !important;
    color: rgba(255, 255, 255, 0.90) !important;
    text-decoration: none !important;
    font-size: 0.86rem !important;
    font-weight: 760 !important;
}

.cinema-search-detail-empty {
    color: rgba(248, 245, 255, 0.54) !important;
    font-size: 0.84rem !important;
    font-weight: 560 !important;
}

.active-search-results .search-meta-verified {
    color: rgba(248, 245, 255, 0.76) !important;
}

.active-search-results .search-meta-rating {
    justify-self: center !important;
    color: rgba(248, 245, 255, 0.72) !important;
}

.active-search-results .search-meta-distance {
    justify-self: end !important;
    color: rgba(248, 245, 255, 0.68) !important;
    font-weight: 780 !important;
}

.active-search-results .search-meta-open {
    justify-self: start !important;
    color: rgba(91, 236, 137, 0.92) !important;
}

.active-search-results .search-meta-open i {
    color: #ff9f0a !important;
}

.active-search-results .search-meta-closed {
    justify-self: start !important;
    color: rgba(255, 94, 115, 0.86) !important;
}

.active-search-results .search-meta-closed i {
    color: #ff9f0a !important;
}

body:not(.map-active) #backToHomeBtn.hidden,
#backToHomeBtn.hidden {
    display: none !important;
}

body.map-active #backToHomeBtn {
    display: none !important;
}

.feed-card-content {
    padding: 20px !important;
}

.card-top-info {
    width: 100% !important;
    align-items: center !important;
    text-align: center !important;
}

.card-glass-title {
    border-radius: 18px !important;
    padding: 6px 13px !important;
    max-width: min(92%, 340px) !important;
    text-align: center !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: clip !important;
    font-size: clamp(0.96rem, 4.9vw, 1.3rem) !important;
    line-height: 1 !important;
}

.map-controls-stack {
    top: calc(18px + env(safe-area-inset-top)) !important;
    right: 14px !important;
    gap: 9px !important;
    z-index: 7000 !important;
    pointer-events: auto !important;
}

.map-compass-btn,
.map-side-btn {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    border-radius: 13px !important;
    color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.24) !important;
    box-shadow: 0 12px 28px rgba(8, 4, 15, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.map-compass-btn {
    background: var(--cd-accent-gradient) !important;
}

.zoom-in-btn {
    background: var(--cd-accent-gradient) !important;
}

.zoom-out-btn {
    background: var(--cd-accent-gradient) !important;
}

.locate-btn {
    background: var(--cd-accent-gradient) !important;
}

.map-compass-btn i,
.map-side-btn i,
.north-label {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}
.results-list.cinema-mode:has(.cinema-browse-shell),
.mobile-results .results-list.cinema-mode:has(.cinema-browse-shell) {
    display: block !important;
    max-width: min(1440px, calc(100vw - 48px)) !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding-top: 24px !important;
}

.cinema-browse-shell {
    --cinema-bg: rgba(20, 14, 30, 0.78);
    --cinema-panel: linear-gradient(180deg, rgba(43, 31, 61, 0.88), rgba(18, 12, 29, 0.96));
    --cinema-panel-soft: linear-gradient(180deg, rgba(52, 38, 74, 0.72), rgba(21, 14, 34, 0.88));
    --cinema-border: rgba(255, 255, 255, 0.13);
    --cinema-text: #f8f5ff;
    --cinema-muted: rgba(248, 245, 255, 0.64);
    --cinema-orange: #ff9f0a;
    --cinema-hot: #ff5e00;
    color: var(--cinema-text);
    line-height: 1.2;
}

.cinema-controls {
    position: sticky;
    top: 12px;
    z-index: 20;
    padding: 14px;
    border-radius: 28px;
    background: var(--cd-control-bg);
    border: 1px solid var(--cinema-border);
    box-shadow: 0 22px 54px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.07);
    backdrop-filter: blur(24px) saturate(150%);
    -webkit-backdrop-filter: blur(24px) saturate(150%);
}

.cinema-mode-tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding: 6px;
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.055);
    border: 1px solid rgba(255, 255, 255, 0.08);
}

.cinema-mode-tabs button,
.cinema-filter-bar select,
.cinema-search-field,
.cinema-toggle,
.cinema-load-more,
.cinema-showtime-chip,
.cinema-date-tab {
    font: inherit;
}

.cinema-mode-tabs button {
    min-height: 44px;
    border: 0;
    border-radius: 16px;
    color: var(--cinema-muted);
    background: transparent;
    font-weight: 850;
    letter-spacing: 0.01em;
    cursor: pointer;
}

.cinema-mode-tabs button.active {
    color: #ffffff;
    background: linear-gradient(135deg, rgba(255, 94, 0, 0.96), rgba(255, 159, 10, 0.9));
    box-shadow: 0 12px 28px rgba(255, 94, 0, 0.26);
}

.cinema-filter-bar {
    display: grid;
    grid-template-columns: minmax(220px, 1.4fr) repeat(3, minmax(130px, 0.7fr)) auto minmax(150px, 0.8fr);
    gap: 10px;
    margin-top: 12px;
    align-items: center;
}

.cinema-search-field,
.cinema-filter-bar select,
.cinema-toggle {
    min-height: 42px;
    border-radius: 15px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.07);
    color: var(--cinema-text);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055);
}

.cinema-filter-bar select option {
    color: #17111f;
}

.cinema-search-field {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 0 13px;
}

.cinema-search-field i {
    color: var(--cinema-orange);
}

.cinema-search-field input {
    width: 100%;
    border: 0;
    outline: 0;
    background: transparent;
    color: var(--cinema-text);
    font-weight: 700;
}

.cinema-search-field input::placeholder {
    color: rgba(248, 245, 255, 0.48);
}

.cinema-filter-bar select {
    padding: 0 12px;
    font-weight: 750;
    outline: 0;
}

.cinema-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 0 12px;
    color: var(--cinema-muted);
    font-weight: 800;
    white-space: nowrap;
}

.cinema-toggle input {
    accent-color: var(--cinema-orange);
}

.cinema-browser-grid {
    display: grid;
    grid-template-columns: minmax(320px, 0.85fr) minmax(0, 1.55fr);
    gap: 18px;
    margin-top: 18px;
    align-items: start;
}

.cinema-list-panel,
.cinema-detail-panel,
.cinema-empty-state {
    border-radius: 28px;
    background: var(--cinema-panel);
    border: 1px solid var(--cinema-border);
    box-shadow: 0 22px 58px rgba(0, 0, 0, 0.34), inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.cinema-list-panel {
    max-height: min(760px, calc(100vh - 190px));
    overflow: auto;
    padding: 10px;
    display: flex;
    flex-direction: column;
    gap: 9px;
    position: sticky;
    top: 142px;
}

.cinema-list-item {
    width: 100%;
    display: grid;
    grid-template-columns: 58px minmax(0, 1fr) 18px;
    gap: 12px;
    align-items: center;
    min-height: 82px;
    padding: 10px;
    border-radius: 20px;
    border: 1px solid transparent;
    color: var(--cinema-text);
    background: rgba(255, 255, 255, 0.045);
    text-align: left;
    cursor: pointer;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.cinema-list-item:hover,
.cinema-list-item:focus-visible,
.cinema-list-item.active {
    transform: translateY(-1px);
    border-color: rgba(255, 159, 10, 0.46);
    background: linear-gradient(135deg, rgba(255, 94, 0, 0.18), rgba(255, 255, 255, 0.07));
    box-shadow: 0 12px 28px rgba(255, 94, 0, 0.12);
    outline: none;
}

.cinema-list-item img {
    width: 58px;
    height: 76px;
    object-fit: cover;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.08);
}

.cinema-list-copy {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.cinema-list-copy strong {
    color: #ffffff;
    font-size: 0.98rem;
    font-weight: 900;
    letter-spacing: -0.01em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cinema-list-copy small,
.cinema-list-copy em,
.cinema-muted {
    color: var(--cinema-muted);
    font-size: 0.76rem;
    font-style: normal;
    font-weight: 680;
    line-height: 1.3;
}

.cinema-list-copy em {
    color: rgba(255, 214, 142, 0.88);
}

.cinema-theatre-icon,
.cinema-theatre-large-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(255, 94, 0, 0.22), rgba(255, 159, 10, 0.16));
    border: 1px solid rgba(255, 159, 10, 0.24);
    color: var(--cinema-orange);
}

.cinema-theatre-icon {
    width: 58px;
    height: 58px;
    border-radius: 18px;
}

.cinema-detail-panel,
.cinema-empty-state {
    padding: 20px;
    min-width: 0;
}

.cinema-detail-hero,
.cinema-theatre-hero {
    display: grid;
    grid-template-columns: 148px minmax(0, 1fr);
    gap: 18px;
    align-items: center;
}

.cinema-theatre-hero {
    grid-template-columns: 92px minmax(0, 1fr);
}

.cinema-detail-hero img {
    width: 148px;
    aspect-ratio: 2 / 3;
    object-fit: cover;
    border-radius: 22px;
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.34);
}

.cinema-theatre-large-icon {
    width: 92px;
    height: 92px;
    border-radius: 28px;
    font-size: 2rem;
}

.cinema-eyebrow,
.cinema-section-heading small {
    display: block;
    color: rgba(255, 159, 10, 0.86);
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-size: 0.68rem;
    font-weight: 900;
}

.cinema-detail-panel h2 {
    margin: 6px 0 6px;
    color: #ffffff;
    font-size: clamp(1.55rem, 2.2vw, 2.45rem);
    line-height: 1.04;
    letter-spacing: -0.04em;
}

.cinema-detail-panel p,
.cinema-synopsis {
    margin: 0;
    color: var(--cinema-muted);
    font-weight: 650;
    line-height: 1.45;
}

.cinema-detail-meta,
.cinema-action-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.cinema-detail-meta span,
.cinema-action-row a,
.cinema-showtime-card-head a {
    color: #ffffff;
    text-decoration: none;
    border-radius: 999px;
    padding: 8px 11px;
    background: rgba(255, 255, 255, 0.075);
    border: 1px solid rgba(255, 255, 255, 0.11);
    font-size: 0.78rem;
    font-weight: 850;
}

.cinema-synopsis {
    margin-top: 12px;
}

.cinema-stats-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin: 20px 0;
}

.cinema-stats-row span {
    min-height: 74px;
    border-radius: 20px;
    padding: 13px;
    background: rgba(255, 255, 255, 0.055);
    border: 1px solid rgba(255, 255, 255, 0.10);
    color: var(--cinema-muted);
    font-size: 0.76rem;
    font-weight: 780;
}

.cinema-stats-row strong {
    display: block;
    color: #ffffff;
    font-size: 1.35rem;
    line-height: 1;
    margin-bottom: 7px;
}

.cinema-section-heading {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 12px;
    margin: 8px 0 12px;
}

.cinema-section-heading span {
    color: #ffffff;
    font-size: 1.08rem;
    font-weight: 900;
}

.cinema-section-heading small {
    color: rgba(248, 245, 255, 0.52);
    text-transform: none;
    letter-spacing: 0;
    text-align: right;
}

.cinema-showtime-list {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.cinema-showtime-card {
    border-radius: 15px;
    padding: 14px 14px 10px;
    background: var(--cinema-panel-soft);
    border: 1px solid rgba(255, 255, 255, 0.105);
}

.cinema-showtime-card-head,
.cinema-movie-row-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 12px;
}

.cinema-showtime-card h3 {
    margin: 0 0 4px;
    color: #ffffff;
    font-size: 1rem;
    line-height: 1.2;
}

.cinema-showtime-card p {
    margin: 0;
    color: var(--cinema-muted);
    font-size: 0.8rem;
}

.cinema-movie-row-head {
    justify-content: flex-start;
}

.cinema-movie-row-head img {
    width: 48px;
    height: 68px;
    object-fit: cover;
    border-radius: 12px;
}

.cinema-date-tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 2px 0 10px;
}

.cinema-date-tab,
.cinema-showtime-chip,
.cinema-load-more {
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: var(--cinema-text);
    background: rgba(255, 255, 255, 0.07);
    cursor: pointer;
}

.cinema-date-tab {
    flex: 0 0 auto;
    min-height: 34px;
    border-radius: 999px;
    padding: 0 12px;
    font-size: 0.76rem;
    font-weight: 850;
}

.cinema-date-tab.active,
.cinema-showtime-chip:hover,
.cinema-showtime-chip:focus-visible {
    background: linear-gradient(135deg, rgba(255, 94, 0, 0.92), rgba(255, 159, 10, 0.88));
    border-color: rgba(255, 199, 116, 0.65);
    color: #ffffff;
    outline: none;
}

.cinema-format-stack {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cinema-format-label {
    color: rgba(248, 245, 255, 0.58);
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-weight: 900;
    margin-bottom: 7px;
}

.cinema-showtime-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.cinema-showtime-chip {
    min-height: 38px;
    border-radius: 13px;
    padding: 0 12px;
    font-size: 0.85rem;
    font-weight: 900;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.16);
}

.cinema-load-more {
    min-height: 44px;
    border-radius: 16px;
    font-weight: 900;
    margin: 4px;
}

.cinema-empty-state {
    text-align: center;
    padding: 44px 22px;
}

.cinema-empty-state h3 {
    margin: 0 0 8px;
    color: #ffffff;
}

.cinema-empty-state p {
    color: var(--cinema-muted);
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

@media (max-width: 900px) {
    .results-list.cinema-mode:has(.cinema-browse-shell),
    .mobile-results .results-list.cinema-mode:has(.cinema-browse-shell) {
        max-width: 100% !important;
        padding-top: 12px !important;
    }

    .cinema-controls {
        position: relative;
        top: auto;
        border-radius: 24px;
        padding: 12px;
    }

    .cinema-filter-bar {
        display: flex;
        overflow-x: auto;
        gap: 8px;
        padding-bottom: 4px;
        scroll-snap-type: x proximity;
    }

    .cinema-search-field {
        min-width: 230px;
    }

    .cinema-filter-bar select,
    .cinema-toggle {
        min-width: max-content;
        flex: 0 0 auto;
        scroll-snap-align: start;
    }

    .cinema-browser-grid {
        display: flex;
        flex-direction: column;
        gap: 14px;
    }

    .cinema-list-panel {
        position: static;
        max-height: none;
        overflow: visible;
        border-radius: 24px;
    }

    .cinema-detail-panel {
        border-radius: 24px;
        padding: 14px;
    }

    .cinema-detail-hero,
    .cinema-theatre-hero {
        grid-template-columns: 92px minmax(0, 1fr);
        gap: 12px;
    }

    .cinema-detail-hero img {
        width: 92px;
        border-radius: 16px;
    }

    .cinema-detail-panel h2 {
        font-size: 1.35rem;
    }

    .cinema-stats-row {
        grid-template-columns: repeat(3, minmax(0, 1fr));
        gap: 7px;
    }

    .cinema-stats-row span {
        min-height: 64px;
        padding: 10px 8px;
        font-size: 0.66rem;
    }

    .cinema-stats-row strong {
        font-size: 1.08rem;
    }

    .cinema-section-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .cinema-section-heading small {
        text-align: left;
    }

    .cinema-showtime-card-head {
        align-items: flex-start;
        flex-direction: column;
    }

    .cinema-showtime-chip {
        min-height: 42px;
        min-width: 74px;
    }
}

.results-list.cinema-browser-active,
.mobile-results .results-list.cinema-browser-active {
    display: block !important;
    grid-template-columns: none !important;
    max-width: min(1440px, calc(100vw - 48px)) !important;
    width: 100% !important;
    margin: 0 auto !important;
    padding-top: 24px !important;
}

.cinema-skeleton,
.cinema-skeleton-row span,
.cinema-skeleton-list-item span,
.cinema-skeleton-list-item b,
.cinema-skeleton-list-item i,
.cinema-skeleton-detail span,
.cinema-skeleton-detail b,
.cinema-skeleton-detail i {
    display: block;
    border-radius: 16px;
    background: linear-gradient(90deg, rgba(255,255,255,0.06), rgba(255,255,255,0.13), rgba(255,255,255,0.06));
    background-size: 220% 100%;
    animation: cinemaSkeletonPulse 1.2s ease-in-out infinite;
}

.cinema-skeleton.wide {
    height: 54px;
}

.cinema-skeleton-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 10px;
    margin-top: 12px;
}

.cinema-skeleton-row span {
    height: 42px;
}

.cinema-skeleton-list-item,
.cinema-skeleton-detail {
    display: grid;
    grid-template-columns: 58px 1fr;
    gap: 12px;
    padding: 10px;
}

.cinema-skeleton-list-item span {
    width: 58px;
    height: 76px;
}

.cinema-skeleton-list-item b,
.cinema-skeleton-detail b {
    height: 18px;
    margin: 7px 0 10px;
}

.cinema-skeleton-list-item i,
.cinema-skeleton-detail i {
    height: 12px;
    margin-top: 7px;
}

.cinema-skeleton-detail {
    grid-template-columns: 148px 1fr;
}

.cinema-skeleton-detail span {
    width: 148px;
    height: 222px;
}

@keyframes cinemaSkeletonPulse {
    from { background-position: 120% 0; }
    to { background-position: -120% 0; }
}

.cinema-page-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 8px 8px 10px;
    color: rgba(248, 245, 255, 0.64);
    font-size: 0.74rem;
    font-weight: 850;
}

.cinema-page-actions {
    display: inline-flex;
    gap: 6px;
}

.cinema-page-actions button {
    min-height: 32px;
    border-radius: 999px;
    border: 1px solid rgba(255, 255, 255, 0.12);
    background: rgba(255, 255, 255, 0.07);
    color: #ffffff;
    font-weight: 900;
    padding: 0 10px;
    cursor: pointer;
}

.cinema-page-actions button:disabled {
    cursor: not-allowed;
    opacity: 0.42;
}

.cinema-list-empty {
    padding: 24px 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.045);
    color: var(--cinema-muted);
    text-align: center;
}

.cinema-list-empty strong,
.cinema-list-empty span,
.cinema-card-meta,
.cinema-action-disabled {
    display: block;
}

.cinema-list-empty strong {
    color: #ffffff;
    margin-bottom: 5px;
}

.cinema-card-meta {
    margin-top: 7px;
    color: rgba(255, 214, 142, 0.86);
    font-size: 0.72rem;
    font-weight: 850;
}

.cinema-action-row.compact {
    margin-top: -4px;
    justify-content: flex-end;
}

.cinema-action-disabled {
    border-radius: 999px;
    padding: 8px 11px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: rgba(255, 255, 255, 0.035);
    color: rgba(248, 245, 255, 0.42);
    font-size: 0.78rem;
    font-weight: 850;
}

.cinema-synopsis.muted,
.cinema-no-dates,
.cinema-no-times {
    color: rgba(248, 245, 255, 0.50);
}

.cinema-browse-shell {
    --cinema-panel: linear-gradient(180deg, rgba(37, 27, 55, 0.72), rgba(15, 11, 24, 0.9));
    --cinema-panel-soft: linear-gradient(180deg, rgba(43, 31, 61, 0.62), rgba(21, 15, 34, 0.82));
    --cinema-border: rgba(255, 255, 255, 0.10);
    --cinema-muted: rgba(235, 229, 245, 0.58);
    --cinema-orange: #ff9f0a;
}

.cinema-controls {
    position: relative;
    top: auto;
    max-width: 460px;
    padding: 6px;
    border-radius: 22px;
    background: rgba(31, 23, 46, 0.72);
    border-color: rgba(255, 255, 255, 0.09);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.26), inset 0 1px 0 rgba(255, 255, 255, 0.055);
}

.cinema-filter-bar,
.cinema-page-row,
.cinema-stats-row {
    display: none !important;
}

.cinema-browser-grid {
    grid-template-columns: minmax(280px, 0.7fr) minmax(0, 1.7fr);
    gap: 16px;
    margin-top: 14px;
}

.cinema-list-panel,
.cinema-detail-panel,
.cinema-empty-state {
    border-radius: 24px;
    background: var(--cinema-panel);
    border-color: var(--cinema-border);
    box-shadow: 0 18px 46px rgba(0, 0, 0, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.cinema-list-panel {
    top: 24px;
    max-height: min(760px, calc(100vh - 72px));
    padding: 8px;
    gap: 8px;
}

.cinema-list-item {
    grid-template-columns: 54px minmax(0, 1fr);
    min-height: 74px;
    padding: 9px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.035);
}

.cinema-list-item:hover,
.cinema-list-item:focus-visible,
.cinema-list-item.active {
    transform: none;
    border-color: rgba(255, 159, 10, 0.46);
    background: linear-gradient(135deg, rgba(255, 159, 10, 0.13), rgba(255, 255, 255, 0.045));
    box-shadow: inset 0 0 0 1px rgba(255, 159, 10, 0.08), 0 10px 26px rgba(0, 0, 0, 0.22);
}

.cinema-list-item img,
.cinema-theatre-icon {
    width: 54px;
    height: 60px;
    border-radius: 15px;
}

.cinema-list-item img {
    object-fit: cover;
}

.cinema-list-copy {
    gap: 5px;
}

.cinema-list-copy strong {
    font-size: 0.94rem;
    letter-spacing: -0.015em;
}

.cinema-list-copy small {
    font-size: 0.78rem;
    font-weight: 760;
}

.cinema-list-copy em,
.cinema-list-item > i {
    display: none !important;
}

.cinema-detail-panel {
    padding: 18px;
}

.cinema-detail-hero {
    grid-template-columns: 118px minmax(0, 1fr);
    align-items: start;
}

.cinema-detail-hero img {
    width: 118px;
    border-radius: 18px;
}

.cinema-detail-panel h2 {
    font-size: clamp(1.45rem, 2vw, 2.15rem);
    letter-spacing: -0.035em;
}

.cinema-section-heading {
    margin-top: 18px;
}

.cinema-showtime-card {
    border-radius: 20px;
    background: rgba(255, 255, 255, 0.045);
    border-color: rgba(255, 255, 255, 0.095);
}

.cinema-showtime-chip {
    min-height: 40px;
    border-radius: 14px;
    background: rgba(255, 159, 10, 0.11);
    border-color: rgba(255, 159, 10, 0.22);
    color: #fff4df;
}

@media (max-width: 900px) {
    .cinema-controls {
        max-width: none;
        border-radius: 22px;
    }

    .cinema-browser-grid {
        margin-top: 12px;
    }

    .cinema-list-panel {
        max-height: none;
    }

    .cinema-detail-hero,
    .cinema-theatre-hero {
        grid-template-columns: 86px minmax(0, 1fr);
    }

    .cinema-detail-hero img {
        width: 86px;
    }
}

.cinema-mode-tabs button {
    transition: transform 140ms ease, background 140ms ease, box-shadow 140ms ease, color 140ms ease;
}

.cinema-mode-tabs button:hover,
.cinema-mode-tabs button:focus-visible {
    transform: translateY(-1px);
    color: #ffffff;
    outline: none;
}

.cinema-list-panel {
    padding: 7px;
    gap: 7px;
}

.cinema-list-item {
    position: relative;
    overflow: hidden;
    min-height: 76px;
    padding: 8px 10px 8px 8px;
    border-color: rgba(255, 255, 255, 0.045);
    transition: transform 150ms ease, background 150ms ease, border-color 150ms ease, box-shadow 150ms ease;
    will-change: transform;
}

.cinema-list-item::before {
    content: "";
    position: absolute;
    inset: 10px auto 10px 0;
    width: 3px;
    border-radius: 999px;
    background: transparent;
    transition: background 150ms ease, box-shadow 150ms ease;
}

.cinema-list-item:hover,
.cinema-list-item:focus-visible {
    transform: translateY(-2px) scale(1.01);
    border-color: rgba(255, 159, 10, 0.28);
    background: linear-gradient(135deg, rgba(255, 255, 255, 0.07), rgba(255, 159, 10, 0.06));
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.28), 0 0 24px rgba(255, 159, 10, 0.08);
}

.cinema-list-item.active {
    transform: scale(1.012);
    border-color: rgba(255, 159, 10, 0.62);
    background: linear-gradient(135deg, rgba(255, 159, 10, 0.18), rgba(255, 255, 255, 0.07));
    box-shadow: inset 0 0 0 1px rgba(255, 159, 10, 0.14), 0 16px 34px rgba(0, 0, 0, 0.32), 0 0 28px rgba(255, 159, 10, 0.12);
}

.cinema-list-item.active::before {
    background: linear-gradient(180deg, #ffb13d, #ff6a00);
    box-shadow: 0 0 16px rgba(255, 159, 10, 0.62);
}

.cinema-list-item img,
.cinema-theatre-icon {
    box-shadow: 0 10px 22px rgba(0, 0, 0, 0.24);
}

.cinema-list-copy strong {
    color: #fffaf2;
    font-size: 0.98rem;
    font-weight: 950;
}

.cinema-list-copy small {
    color: rgba(235, 229, 245, 0.58);
    font-size: 0.75rem;
    letter-spacing: 0.01em;
}

.cinema-next-badge {
    display: inline-flex !important;
    align-items: center;
    width: fit-content;
    gap: 5px;
    margin-top: 2px;
    padding: 4px 8px;
    border-radius: 999px;
    color: #ffd890 !important;
    background: rgba(255, 159, 10, 0.11);
    border: 1px solid rgba(255, 159, 10, 0.18);
    font-size: 0.68rem !important;
    font-weight: 900 !important;
    line-height: 1;
}

.cinema-detail-panel {
    padding: 18px;
}

.cinema-detail-hero,
.cinema-theatre-hero {
    position: relative;
    overflow: hidden;
    padding: 18px;
    border-radius: 24px;
    background: radial-gradient(circle at 18% 10%, rgba(255, 159, 10, 0.16), transparent 34%), linear-gradient(135deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.025));
    border: 1px solid rgba(255, 255, 255, 0.08);
    align-items: center;
}

.cinema-detail-hero {
    grid-template-columns: 142px minmax(0, 1fr);
    gap: 20px;
}

.cinema-detail-hero img {
    width: 142px;
    border-radius: 20px;
    box-shadow: 0 22px 48px rgba(0, 0, 0, 0.45), 0 0 34px rgba(255, 159, 10, 0.13);
}

.cinema-detail-copy {
    min-width: 0;
}

.cinema-detail-panel h2 {
    margin-top: 0;
    margin-bottom: 8px;
    font-size: clamp(2rem, 3.5vw, 3.45rem);
    line-height: 0.98;
    letter-spacing: -0.055em;
}

.cinema-detail-panel p {
    font-size: 0.92rem;
}

.cinema-detail-meta {
    margin-top: 10px;
}

.cinema-quick-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.cinema-quick-stats span {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    min-height: 34px;
    padding: 0 11px;
    border-radius: 999px;
    color: rgba(248, 245, 255, 0.76);
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.10);
    font-size: 0.75rem;
    font-weight: 850;
}

.cinema-quick-stats i {
    color: var(--cinema-orange);
    font-size: 0.78rem;
}

.cinema-quick-stats strong {
    color: #ffffff;
    font-size: 0.9rem;
}

.cinema-synopsis {
    margin-top: 14px;
    max-width: 74ch;
}

.cinema-section-heading {
    margin: 20px 0 14px;
}

.cinema-section-heading span {
    font-size: 1.18rem;
    letter-spacing: -0.02em;
}

.cinema-section-heading small {
    display: none;
}

.cinema-showtime-list {
    gap: 14px;
}

.cinema-showtime-card {
    padding: 16px;
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.032));
    transition: transform 150ms ease, border-color 150ms ease, box-shadow 150ms ease, background 150ms ease;
}

.cinema-showtime-card:hover {
    transform: translateY(-1px);
    border-color: rgba(255, 159, 10, 0.18);
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.22);
}

.cinema-showtime-card-head {
    align-items: flex-start;
    margin-bottom: 13px;
}

.cinema-showtime-card h3 {
    font-size: 1.08rem;
    font-weight: 950;
    letter-spacing: -0.015em;
}

.cinema-showtime-card p {
    color: rgba(235, 229, 245, 0.54);
    font-weight: 700;
}

.cinema-date-tabs {
    gap: 6px;
    padding-bottom: 9px;
}

.cinema-date-tab {
    min-height: 30px;
    padding: 0 10px;
    font-size: 0.7rem;
    transition: transform 130ms ease, background 130ms ease, border-color 130ms ease, color 130ms ease;
}

.cinema-date-tab:hover,
.cinema-date-tab:focus-visible {
    transform: translateY(-1px);
    outline: none;
}

.cinema-showtime-chips {
    gap: 9px;
}

.cinema-showtime-chip {
    min-height: 44px;
    border-radius: 999px;
    padding: 0 16px;
    font-size: 0.9rem;
    transition: transform 140ms ease, background 140ms ease, border-color 140ms ease, box-shadow 140ms ease;
}

.cinema-showtime-chip:hover,
.cinema-showtime-chip:focus-visible {
    transform: translateY(-2px);
    box-shadow: 0 12px 24px rgba(255, 159, 10, 0.16), 0 10px 22px rgba(0, 0, 0, 0.22);
}

@media (max-width: 900px) {
    .cinema-list-item:hover,
    .cinema-list-item:focus-visible,
    .cinema-list-item.active {
        transform: none;
    }

    .cinema-detail-hero,
    .cinema-theatre-hero {
        padding: 13px;
        border-radius: 20px;
        align-items: start;
    }

    .cinema-detail-hero {
        grid-template-columns: 96px minmax(0, 1fr);
        gap: 13px;
    }

    .cinema-detail-hero img {
        width: 96px;
    }

    .cinema-detail-panel h2 {
        font-size: clamp(1.45rem, 7vw, 2rem);
    }

    .cinema-quick-stats span {
        min-height: 32px;
        padding: 0 9px;
        font-size: 0.68rem;
    }

    .cinema-showtime-card {
        padding: 13px;
    }

    .cinema-showtime-chip {
        min-height: 44px;
        min-width: 78px;
    }
}

.cinema-browse-shell {
    --cinema-panel: linear-gradient(180deg, rgba(28, 28, 30, 0.96), rgba(13, 13, 15, 0.98));
    --cinema-panel-soft: linear-gradient(180deg, rgba(24, 24, 26, 0.98), rgba(14, 14, 16, 0.98));
    --cinema-border: rgba(255, 255, 255, 0.085);
    --cinema-muted: rgba(235, 235, 245, 0.56);
    --cinema-text: #f5f5f7;
    --cinema-orange: #ff9f0a;
}

.cinema-controls,
.cinema-list-panel,
.cinema-detail-panel,
.cinema-empty-state {
    background: linear-gradient(145deg, rgba(28, 28, 30, 0.98), rgba(16, 16, 18, 0.98)) !important;
    border-color: rgba(255, 255, 255, 0.085) !important;
    box-shadow: 0 18px 48px rgba(0, 0, 0, 0.48), inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
}

.cinema-mode-tabs {
    background: rgba(255, 255, 255, 0.04);
    border-color: rgba(255, 255, 255, 0.075);
}

.cinema-mode-tabs button.active {
    background: #ffcc00;
    color: #141416;
    box-shadow: 0 12px 28px rgba(255, 204, 0, 0.18);
}

.cinema-list-item {
    background: rgba(255, 255, 255, 0.035) !important;
    border-color: rgba(255, 255, 255, 0.055) !important;
}

.cinema-list-item:hover,
.cinema-list-item:focus-visible {
    background: rgba(255, 255, 255, 0.065) !important;
    border-color: rgba(255, 204, 0, 0.22) !important;
    box-shadow: 0 14px 30px rgba(0, 0, 0, 0.34), 0 0 18px rgba(255, 204, 0, 0.055) !important;
}

.cinema-list-item.active {
    background: linear-gradient(135deg, rgba(255, 204, 0, 0.13), rgba(255, 255, 255, 0.06)) !important;
    border-color: rgba(255, 204, 0, 0.56) !important;
    box-shadow: inset 0 0 0 1px rgba(255, 204, 0, 0.10), 0 16px 34px rgba(0, 0, 0, 0.36) !important;
}

.cinema-list-item.active::before {
    background: linear-gradient(180deg, #ffcc00, #ff7a00);
    box-shadow: 0 0 14px rgba(255, 204, 0, 0.46);
}

.cinema-next-badge {
    color: #ffd76a !important;
    background: rgba(255, 204, 0, 0.09) !important;
    border-color: rgba(255, 204, 0, 0.18) !important;
}

.cinema-detail-panel {
    padding: 20px !important;
}

.cinema-detail-hero {
    grid-template-columns: minmax(160px, 230px) minmax(0, 1fr) !important;
    gap: clamp(22px, 3vw, 34px) !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    overflow: visible !important;
    align-items: start !important;
}

.cinema-detail-hero img {
    width: 100% !important;
    max-width: 230px;
    aspect-ratio: 2 / 3;
    border-radius: 8px !important;
    object-fit: cover;
    box-shadow: 0 28px 70px rgba(0, 0, 0, 0.68), 0 0 34px rgba(255, 204, 0, 0.07) !important;
}

.cinema-title-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin: 2px 0 14px;
}

.cinema-title-badges span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 6px;
    background: rgba(255, 255, 255, 0.075);
    color: rgba(245, 245, 247, 0.82);
    font-size: 0.72rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.12em;
}

.cinema-title-badges span.hot {
    color: #ffcc00;
    background: transparent;
    padding-left: 4px;
}

.cinema-detail-panel h2 {
    max-width: 11ch;
    margin-bottom: 22px !important;
    font-size: clamp(3rem, 6vw, 5.7rem) !important;
    line-height: 0.92 !important;
    letter-spacing: -0.075em !important;
    text-transform: uppercase;
}

.cinema-synopsis {
    max-width: 760px !important;
    margin-top: 0 !important;
    color: rgba(235, 235, 245, 0.62) !important;
    font-size: 1.02rem !important;
    line-height: 1.75 !important;
    font-weight: 650 !important;
}

.cinema-detail-meta {
    gap: 0 !important;
    margin-top: 24px !important;
}

.cinema-detail-meta span {
    min-width: 132px;
    padding: 0 22px 0 0 !important;
    margin-right: 22px;
    border: 0 !important;
    border-right: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: #f5f5f7 !important;
    font-size: 0.9rem !important;
    line-height: 1.25;
}

.cinema-detail-meta span:last-child {
    border-right: 0 !important;
}

.cinema-detail-meta small {
    display: block;
    margin-bottom: 5px;
    color: rgba(235, 235, 245, 0.42);
    font-size: 0.62rem;
    font-weight: 950;
    text-transform: uppercase;
    letter-spacing: 0.16em;
}

.cinema-quick-stats {
    margin-top: 22px !important;
}

.cinema-quick-stats span {
    min-height: 32px !important;
    background: rgba(255, 255, 255, 0.055) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.cinema-quick-stats i {
    color: #ffcc00 !important;
}

.cinema-section-heading {
    margin: 42px 0 16px !important;
}

.cinema-section-heading span {
    color: rgba(245, 245, 247, 0.72) !important;
    font-size: 0.78rem !important;
    font-weight: 950 !important;
    text-transform: uppercase;
    letter-spacing: 0.24em !important;
}

.cinema-showtime-list {
    gap: 18px !important;
}

.cinema-showtime-card {
    display: grid;
    grid-template-columns: minmax(230px, 0.42fr) minmax(0, 1fr);
    column-gap: 24px;
    align-items: start;
    padding: 26px 28px !important;
    border-radius: 10px !important;
    background: linear-gradient(180deg, rgba(20, 20, 22, 0.92), rgba(12, 12, 14, 0.96)) !important;
    border-color: rgba(255, 255, 255, 0.045) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.025);
}

.cinema-showtime-card-head {
    grid-column: 1;
    grid-row: 1 / 3;
    display: block !important;
    margin: 0 !important;
}

.cinema-card-times {
    grid-column: 2;
    min-width: 0;
}

.cinema-showtime-card h3 {
    margin-bottom: 12px !important;
    color: #f5f5f7 !important;
    font-size: 1.24rem !important;
    line-height: 1.05 !important;
    text-transform: uppercase;
    letter-spacing: -0.035em !important;
}

.cinema-showtime-card p {
    color: rgba(235, 235, 245, 0.42) !important;
    font-size: 0.78rem !important;
    line-height: 1.45;
}

.cinema-showtime-card p i {
    color: rgba(235, 235, 245, 0.38);
    margin-right: 5px;
}

.cinema-action-row.compact {
    justify-content: flex-start !important;
    margin-top: 16px !important;
}

.cinema-action-row a {
    background: rgba(255, 255, 255, 0.055) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.cinema-date-tabs {
    padding: 0 0 12px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.055);
    margin-bottom: 14px;
}

.cinema-date-tab {
    min-height: 42px !important;
    min-width: 58px;
    border-radius: 6px !important;
    background: rgba(255, 255, 255, 0.065) !important;
    border-color: rgba(255, 255, 255, 0.075) !important;
    color: rgba(245, 245, 247, 0.72) !important;
}

.cinema-date-tab.active {
    background: #ffcc00 !important;
    border-color: #ffcc00 !important;
    color: #111113 !important;
    box-shadow: 0 10px 22px rgba(255, 204, 0, 0.18);
}

.cinema-format-label {
    margin: 0 0 10px !important;
    color: #ff8a70 !important;
    font-size: 0.66rem !important;
    letter-spacing: 0.22em !important;
}

.cinema-format-group {
    padding-top: 2px;
}

.cinema-showtime-chip {
    min-width: 88px;
    min-height: 48px !important;
    border-radius: 5px !important;
    background: rgba(255, 255, 255, 0.075) !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
    color: rgba(245, 245, 247, 0.84) !important;
    box-shadow: none !important;
}

.cinema-showtime-chip:hover,
.cinema-showtime-chip:focus-visible {
    background: #ff7f73 !important;
    border-color: #ff7f73 !important;
    color: #111113 !important;
    box-shadow: 0 12px 28px rgba(255, 127, 115, 0.18) !important;
}

@media (max-width: 900px) {
    .cinema-detail-hero {
        grid-template-columns: 100px minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .cinema-detail-panel h2 {
        max-width: none;
        font-size: clamp(1.55rem, 8vw, 2.4rem) !important;
        line-height: 1 !important;
    }

    .cinema-title-badges {
        gap: 6px;
        margin-bottom: 10px;
    }

    .cinema-title-badges span {
        min-height: 24px;
        font-size: 0.58rem;
        padding: 0 7px;
    }

    .cinema-detail-meta span {
        min-width: 0;
        margin-right: 12px;
        padding-right: 12px !important;
    }

    .cinema-showtime-card {
        display: block;
        padding: 16px !important;
        border-radius: 14px !important;
    }

    .cinema-card-times {
        margin-top: 14px;
    }

    .cinema-date-tab {
        min-height: 36px !important;
    }

    .cinema-showtime-chip {
        min-width: 76px;
        min-height: 44px !important;
    }
}

.cinema-detail-panel h2 {
    max-width: 100% !important;
    font-size: clamp(2.15rem, 4.15vw, 4.25rem) !important;
    line-height: 0.96 !important;
    letter-spacing: -0.065em !important;
    overflow-wrap: anywhere;
    word-break: normal;
}

.cinema-theatre-hero .cinema-detail-panel h2,
.cinema-theatre-hero h2 {
    font-size: clamp(2rem, 3.5vw, 3.65rem) !important;
    max-width: 14ch !important;
}

.cinema-quick-stats {
    gap: 10px !important;
}

.cinema-quick-stats span {
    min-height: 42px !important;
    padding: 9px 14px !important;
    border-radius: 12px !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.04)) !important;
    border-color: rgba(255, 255, 255, 0.105) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035);
}

.cinema-quick-stats strong {
    font-size: 1rem !important;
}

.cinema-theatre-icon.cinema-theatre-image,
.cinema-theatre-large-icon.cinema-theatre-image {
    object-fit: cover;
    background: rgba(255, 255, 255, 0.06) !important;
}

.cinema-theatre-large-icon.cinema-theatre-image {
    width: 150px !important;
    height: 150px !important;
    border-radius: 12px !important;
}

.cinema-theatre-hero {
    grid-template-columns: 150px minmax(0, 1fr) !important;
    gap: 28px !important;
}

.cinema-showtime-card p,
.cinema-list-item.theatre .cinema-list-copy small,
.cinema-theatre-hero > .cinema-detail-copy > p {
    text-transform: none;
}

@media (max-width: 900px) {
    .cinema-detail-panel h2 {
        font-size: clamp(1.55rem, 7vw, 2.35rem) !important;
        letter-spacing: -0.045em !important;
    }

    .cinema-theatre-hero {
        grid-template-columns: 82px minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .cinema-theatre-large-icon.cinema-theatre-image,
    .cinema-theatre-large-icon {
        width: 82px !important;
        height: 82px !important;
        border-radius: 14px !important;
    }

    .cinema-quick-stats span {
        min-height: 38px !important;
        border-radius: 11px !important;
    }
}

.cinema-detail-hero {
    grid-template-columns: minmax(190px, 285px) minmax(0, 1fr) !important;
    gap: clamp(26px, 3.4vw, 42px) !important;
    margin-bottom: 26px !important;
}

.cinema-detail-hero > img {
    max-width: 285px !important;
    min-height: 420px;
}

.cinema-movie-date-tabs {
    display: flex;
    gap: 14px;
    margin: 4px 0 24px;
    padding: 4px 0 2px;
    overflow-x: auto;
    scrollbar-width: none;
}

.cinema-movie-date-tabs::-webkit-scrollbar {
    display: none;
}

.cinema-movie-date-tab {
    flex: 0 0 auto;
    width: 82px;
    min-height: 96px;
    border: 1px solid rgba(255, 255, 255, 0.13);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.055);
    color: rgba(245, 245, 247, 0.76);
    display: grid;
    place-items: center;
    padding: 10px 8px;
    cursor: pointer;
    transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.cinema-movie-date-tab span,
.cinema-movie-date-tab small {
    font-size: 0.66rem;
    font-weight: 950;
    letter-spacing: 0.16em;
    line-height: 1;
}

.cinema-movie-date-tab strong {
    color: #f5f5f7;
    font-size: 1.72rem;
    font-weight: 950;
    line-height: 1;
    letter-spacing: -0.04em;
}

.cinema-movie-date-tab:hover,
.cinema-movie-date-tab:focus-visible {
    transform: translateY(-2px);
    border-color: rgba(255, 204, 0, 0.42);
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.32);
}

.cinema-movie-date-tab.active {
    background: #ffcc00;
    border-color: #ffcc00;
    color: #221b00;
    box-shadow: 0 16px 32px rgba(255, 204, 0, 0.18);
}

.cinema-movie-date-tab.active strong {
    color: #171300;
}

.cinema-movie-theatre-list {
    margin-top: 8px;
}

.cinema-theatre-showtime-row {
    grid-template-columns: 92px minmax(0, 1fr) !important;
    gap: 22px !important;
    align-items: stretch !important;
    padding: 24px !important;
}

.cinema-theatre-row-media {
    display: flex;
    align-items: flex-start;
    justify-content: center;
}

.cinema-theatre-row-icon {
    width: 76px;
    height: 76px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(255, 159, 10, 0.28);
    background: radial-gradient(circle at 30% 20%, rgba(255, 159, 10, 0.22), rgba(255, 159, 10, 0.07) 55%, rgba(255, 255, 255, 0.04));
    color: #ff9f0a;
    font-size: 1.35rem;
    object-fit: cover;
}

.cinema-theatre-row-icon.cinema-theatre-image {
    background: rgba(255, 255, 255, 0.06) !important;
}

.cinema-theatre-row-content {
    min-width: 0;
    display: grid;
    gap: 18px;
}

.cinema-theatre-row-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 18px;
}

.cinema-theatre-row-head h3 {
    margin-bottom: 8px !important;
}

.cinema-theatre-row-head p {
    max-width: 520px;
}

.cinema-theatre-showtime-row .cinema-card-times {
    grid-column: auto;
    margin-top: 0;
}

.cinema-theatre-showtime-row .cinema-format-stack {
    gap: 14px;
}

.cinema-theatre-showtime-row .cinema-format-group {
    display: grid;
    grid-template-columns: minmax(92px, 0.18fr) minmax(0, 1fr);
    align-items: start;
    gap: 14px;
}

.cinema-theatre-showtime-row .cinema-format-label {
    margin-top: 15px !important;
}

@media (max-width: 900px) {
    .cinema-detail-hero {
        grid-template-columns: 116px minmax(0, 1fr) !important;
        gap: 15px !important;
        margin-bottom: 18px !important;
    }

    .cinema-detail-hero > img {
        width: 116px !important;
        min-height: 174px;
    }

    .cinema-movie-date-tabs {
        gap: 10px;
        margin-bottom: 18px;
    }

    .cinema-movie-date-tab {
        width: 68px;
        min-height: 82px;
        border-radius: 10px;
    }

    .cinema-movie-date-tab strong {
        font-size: 1.42rem;
    }

    .cinema-theatre-showtime-row {
        display: grid !important;
        grid-template-columns: 62px minmax(0, 1fr) !important;
        gap: 13px !important;
        padding: 15px !important;
    }

    .cinema-theatre-row-icon {
        width: 54px;
        height: 54px;
        border-radius: 12px;
        font-size: 1rem;
    }

    .cinema-theatre-row-head {
        display: block;
    }

    .cinema-theatre-row-head .cinema-action-row {
        margin-top: 10px !important;
    }

    .cinema-theatre-showtime-row .cinema-format-group {
        display: block;
    }

    .cinema-theatre-showtime-row .cinema-format-label {
        margin-top: 0 !important;
    }
}

.cinema-detail-copy .cinema-movie-date-tabs {
    margin: 26px 0 0;
    max-width: min(100%, 760px);
}

.cinema-detail-hero + .cinema-movie-date-tabs {
    display: none;
}

.cinema-format-label {
    display: none !important;
}

.cinema-format-group,
.cinema-theatre-showtime-row .cinema-format-group {
    display: block !important;
}

.cinema-theatre-showtime-row .cinema-showtime-chips {
    margin-top: 0;
}

@media (max-width: 900px) {
    .cinema-detail-copy .cinema-movie-date-tabs {
        grid-column: 1 / -1;
        margin-top: 16px;
        max-width: 100%;
    }
}

.cinema-detail-copy .cinema-quick-stats {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0 !important;
    width: min(100%, 720px);
    margin-top: 22px !important;
    padding: 10px 14px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.08);
    background: linear-gradient(180deg, rgba(82, 18, 53, 0.62), rgba(35, 8, 34, 0.76)), rgba(24, 7, 30, 0.92);
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.055);
    overflow: hidden;
}

.cinema-detail-copy .cinema-quick-stats span {
    position: relative;
    display: grid !important;
    grid-template-columns: 54px minmax(0, 1fr);
    align-items: center;
    gap: 12px !important;
    min-width: 0;
    min-height: 54px !important;
    padding: 0 16px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: rgba(245, 236, 246, 0.78);
    font-size: 0.86rem;
    font-weight: 850;
    line-height: 1.1;
    white-space: nowrap;
}

.cinema-detail-copy .cinema-quick-stats span + span::before {
    content: "";
    position: absolute;
    left: 0;
    top: 8px;
    bottom: 8px;
    width: 1px;
    background: rgba(255, 255, 255, 0.09);
}

.cinema-detail-copy .cinema-quick-stats i {
    display: inline-grid;
    place-items: center;
    width: 54px;
    height: 46px;
    border-radius: 12px;
    color: #ff9500 !important;
    background: rgba(94, 26, 23, 0.88);
    font-size: 1.24rem !important;
}

.cinema-detail-copy .cinema-quick-stats strong {
    display: inline-block;
    margin-right: 5px;
    color: #ffffff;
    font-size: 1.34rem !important;
    font-weight: 950;
    line-height: 1;
}

@media (max-width: 720px) {
    .cinema-detail-copy .cinema-quick-stats {
        width: 100%;
        padding: 8px;
        border-radius: 14px;
    }

    .cinema-detail-copy .cinema-quick-stats span {
        grid-template-columns: 38px minmax(0, 1fr);
        gap: 8px !important;
        min-height: 46px !important;
        padding: 0 8px !important;
        font-size: 0.68rem;
    }

    .cinema-detail-copy .cinema-quick-stats i {
        width: 38px;
        height: 36px;
        border-radius: 10px;
        font-size: 0.98rem !important;
    }

    .cinema-detail-copy .cinema-quick-stats strong {
        display: block;
        margin: 0 0 2px;
        font-size: 1rem !important;
    }
}

.cinema-theatre-showtime-row {
    grid-template-columns: 86px minmax(0, 1fr) !important;
    gap: 18px !important;
    align-items: start !important;
    padding: 16px 18px !important;
}

.cinema-theatre-row-media {
    width: 86px;
}

.cinema-theatre-row-icon {
    width: 76px !important;
    height: 76px !important;
    aspect-ratio: 1;
    border-radius: 16px !important;
    border-color: rgba(255, 159, 10, 0.16) !important;
    background: radial-gradient(circle at 50% 38%, rgba(255, 159, 10, 0.16), rgba(255, 255, 255, 0.045) 60%, rgba(255, 255, 255, 0.025)) !important;
    color: rgba(255, 159, 10, 0.88) !important;
    font-size: 1.18rem !important;
}

.cinema-theatre-row-icon.cinema-theatre-image {
    display: block !important;
    object-fit: cover;
    object-position: center;
    background: rgba(255, 255, 255, 0.06) !important;
}

.cinema-theatre-showtime-row .cinema-card-times {
    border-top: 1px solid rgba(255, 255, 255, 0.075);
    padding-top: 9px;
}

.cinema-theatre-row-head .cinema-action-row.compact {
    gap: 8px;
}

.cinema-theatre-row-head .cinema-action-row.compact a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 34px;
    padding: 0 16px;
    border-radius: 999px;
    color: rgba(255, 255, 255, 0.86);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.035));
    border: 1px solid rgba(255, 255, 255, 0.105);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.055);
    font-size: 0.78rem;
    font-weight: 850;
    letter-spacing: 0;
}

.cinema-theatre-row-head .cinema-action-row.compact a:hover,
.cinema-theatre-row-head .cinema-action-row.compact a:focus-visible {
    background: linear-gradient(180deg, rgba(255, 159, 10, 0.22), rgba(255, 159, 10, 0.10));
    border-color: rgba(255, 159, 10, 0.34);
    outline: none;
}

.cinema-theatre-showtime-row .cinema-theatre-row-content {
    gap: 8px;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head {
    min-height: 66px;
    align-items: center;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head h3 {
    margin-bottom: 6px !important;
    font-size: clamp(1.02rem, 1.45vw, 1.34rem);
    letter-spacing: -0.02em;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head p {
    color: rgba(235, 229, 245, 0.48);
    font-size: 0.88rem;
}

.cinema-theatre-showtime-row .cinema-showtime-chips {
    gap: 8px;
}

.cinema-theatre-showtime-row .cinema-showtime-chip {
    min-width: 0;
    min-height: 34px !important;
    height: 34px !important;
    padding: 0 15px !important;
    border-radius: 10px !important;
    color: rgba(255, 255, 255, 0.86);
    background: rgba(255, 255, 255, 0.07);
    border-color: rgba(255, 255, 255, 0.12);
    font-size: 0.8rem !important;
    font-weight: 850;
}

@media (max-width: 720px) {
    .cinema-theatre-showtime-row {
        grid-template-columns: 72px minmax(0, 1fr) !important;
        gap: 12px !important;
        padding: 13px !important;
    }

    .cinema-theatre-row-media {
        width: 72px;
    }

    .cinema-theatre-row-icon {
        width: 64px !important;
        height: 64px !important;
        border-radius: 14px !important;
    }

    .cinema-theatre-showtime-row .cinema-card-times {
        padding-top: 10px;
    }

    .cinema-theatre-row-head .cinema-action-row.compact a {
        min-height: 36px;
        padding: 0 14px;
        font-size: 0.78rem;
    }

    .cinema-theatre-showtime-row .cinema-theatre-row-head {
        min-height: 58px;
        align-items: flex-start;
    }

    .cinema-theatre-showtime-row .cinema-showtime-chip {
        min-height: 34px;
        padding: 0 13px;
    }
}

.cinema-title-badges {
    gap: 10px !important;
    margin: 0 0 16px !important;
}

.cinema-title-badges span {
    min-height: 36px !important;
    padding: 0 16px !important;
    border-radius: 8px !important;
    color: #ffd166 !important;
    background: linear-gradient(180deg, rgba(255, 159, 10, 0.24), rgba(255, 159, 10, 0.11)) !important;
    border: 1px solid rgba(255, 159, 10, 0.26);
    font-size: 0.88rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.18em !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row {
    grid-template-columns: 116px minmax(0, 1fr) !important;
    gap: 22px !important;
    padding: 18px 20px !important;
    border-radius: 14px !important;
}

.cinema-theatre-row-media {
    width: 116px !important;
}

.cinema-theatre-row-icon {
    width: 104px !important;
    height: 104px !important;
    border-radius: 16px !important;
}

.cinema-theatre-row-icon.cinema-theatre-image {
    object-fit: cover !important;
    object-position: center !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head {
    min-height: 104px !important;
}

.cinema-theatre-row-head .cinema-action-row.compact a {
    min-height: 38px !important;
    padding: 0 20px !important;
    border-radius: 12px !important;
    font-size: 0.84rem !important;
    font-weight: 900 !important;
}

.cinema-theatre-showtime-row .cinema-showtime-chip {
    border-radius: 10px !important;
}

@media (max-width: 720px) {
    .cinema-title-badges span {
        min-height: 32px !important;
        padding: 0 12px !important;
        font-size: 0.76rem !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row {
        grid-template-columns: 82px minmax(0, 1fr) !important;
        gap: 13px !important;
        padding: 14px !important;
        border-radius: 12px !important;
    }

    .cinema-theatre-row-media {
        width: 82px !important;
    }

    .cinema-theatre-row-icon {
        width: 76px !important;
        height: 76px !important;
        border-radius: 14px !important;
    }

    .cinema-theatre-showtime-row .cinema-theatre-row-head {
        min-height: 76px !important;
    }

    .cinema-theatre-row-head .cinema-action-row.compact a {
        min-height: 34px !important;
        padding: 0 14px !important;
        border-radius: 10px !important;
        font-size: 0.76rem !important;
    }
}

.cinema-showtime-card.cinema-theatre-showtime-row {
    grid-template-columns: 156px minmax(0, 1fr) !important;
    align-items: stretch !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
    align-self: stretch;
    display: flex;
    width: 156px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
    width: 100% !important;
    height: 100% !important;
    min-height: 154px;
    border-radius: 14px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon.cinema-theatre-image {
    object-fit: cover !important;
    object-position: center !important;
}

@media (max-width: 720px) {
    .cinema-showtime-card.cinema-theatre-showtime-row {
        grid-template-columns: 88px minmax(0, 1fr) !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
        width: 88px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
        min-height: 88px;
        border-radius: 12px !important;
    }
}

.cinema-browse-shell {
    --cinema-radius-panel: 14px;
    --cinema-radius-card: 12px;
    --cinema-radius-control: 10px;
    --cinema-space-xs: 8px;
    --cinema-space-sm: 12px;
    --cinema-space-md: 16px;
    --cinema-space-lg: 22px;
}

.cinema-browser-grid {
    gap: var(--cinema-space-md) !important;
}

.cinema-list-panel,
.cinema-detail-panel,
.cinema-empty-state {
    border-radius: var(--cinema-radius-panel) !important;
}

.cinema-list-panel {
    padding: var(--cinema-space-xs) !important;
    gap: var(--cinema-space-xs) !important;
}

.cinema-list-item {
    min-height: 76px !important;
    padding: 10px !important;
    border-radius: var(--cinema-radius-card) !important;
}

.cinema-list-item img,
.cinema-list-item .cinema-theatre-icon {
    border-radius: var(--cinema-radius-control) !important;
}

.cinema-detail-panel {
    padding: 20px !important;
}

.cinema-detail-hero {
    gap: 28px !important;
    align-items: start !important;
}

.cinema-detail-hero > img {
    border-radius: var(--cinema-radius-control) !important;
}

.cinema-title-badges {
    margin: 0 0 var(--cinema-space-md) !important;
}

.cinema-title-badges span {
    border-radius: var(--cinema-radius-control) !important;
}

.cinema-detail-panel h2 {
    margin: 0 0 18px !important;
}

.cinema-detail-meta {
    margin-top: 0 !important;
}

.cinema-detail-copy .cinema-quick-stats {
    margin-top: 18px !important;
    border-radius: var(--cinema-radius-card) !important;
    padding: 9px 12px !important;
}

.cinema-detail-copy .cinema-quick-stats i {
    border-radius: var(--cinema-radius-control) !important;
}

.cinema-detail-copy .cinema-movie-date-tabs {
    margin: var(--cinema-space-lg) 0 0 !important;
    gap: var(--cinema-space-sm) !important;
}

.cinema-movie-date-tab {
    border-radius: var(--cinema-radius-control) !important;
}

.cinema-section-heading {
    margin: var(--cinema-space-lg) 0 var(--cinema-space-sm) !important;
}

.cinema-showtime-list {
    gap: var(--cinema-space-sm) !important;
}

.cinema-movie-theatre-list {
    margin-top: var(--cinema-space-lg) !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row {
    grid-template-columns: 148px minmax(0, 1fr) !important;
    gap: 20px !important;
    align-items: stretch !important;
    padding: var(--cinema-space-md) !important;
    border-radius: var(--cinema-radius-card) !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
    align-self: stretch !important;
    width: 148px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
    width: 100% !important;
    height: 100% !important;
    min-height: 148px !important;
    border-radius: var(--cinema-radius-control) !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-content {
    gap: 10px !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head {
    min-height: 92px !important;
    align-items: center !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head h3 {
    margin: 0 0 6px !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head p {
    margin: 0 !important;
}

.cinema-theatre-showtime-row .cinema-card-times {
    padding-top: 10px !important;
}

.cinema-theatre-row-head .cinema-action-row.compact {
    gap: var(--cinema-space-xs) !important;
    margin-top: 0 !important;
}

.cinema-theatre-row-head .cinema-action-row.compact a,
.cinema-theatre-showtime-row .cinema-showtime-chip {
    border-radius: var(--cinema-radius-control) !important;
}

@media (max-width: 720px) {
    .cinema-detail-panel {
        padding: 14px !important;
    }

    .cinema-detail-hero {
        gap: 14px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row {
        grid-template-columns: 88px minmax(0, 1fr) !important;
        gap: 12px !important;
        padding: 12px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
        width: 88px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
        min-height: 88px !important;
    }

    .cinema-theatre-showtime-row .cinema-theatre-row-head {
        min-height: 76px !important;
        align-items: start !important;
    }
}

.cinema-showtime-card.cinema-theatre-showtime-row {
    grid-template-columns: 118px minmax(0, 1fr) !important;
    padding: 14px !important;
    gap: 18px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
    width: 118px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
    min-height: 118px !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head {
    min-height: 72px !important;
}

.cinema-theatre-detail-hero {
    grid-template-columns: minmax(190px, 285px) minmax(0, 1fr) !important;
}

.cinema-theatre-detail-hero .cinema-theatre-large-icon {
    width: 100% !important;
    max-width: 285px;
    aspect-ratio: 2 / 3;
    height: auto !important;
    border-radius: var(--cinema-radius-control) !important;
    object-fit: cover;
}

.theatre-mode .cinema-showtime-card.movie-row {
    padding: 14px !important;
    border-radius: var(--cinema-radius-card) !important;
}

.theatre-mode .cinema-showtime-card.movie-row .cinema-movie-row-head {
    margin-bottom: 10px;
}

.theatre-mode .cinema-showtime-card.movie-row .cinema-format-stack {
    border-top: 1px solid rgba(255, 255, 255, 0.075);
    padding-top: 10px;
}

@media (max-width: 720px) {
    .cinema-showtime-card.cinema-theatre-showtime-row {
        grid-template-columns: 82px minmax(0, 1fr) !important;
        padding: 12px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
        width: 82px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
        min-height: 82px !important;
    }

    .cinema-theatre-showtime-row .cinema-theatre-row-head {
        min-height: 62px !important;
    }

    .cinema-theatre-detail-hero {
        grid-template-columns: 86px minmax(0, 1fr) !important;
    }
}

.cinema-showtime-card.cinema-theatre-showtime-row {
    grid-template-columns: 112px minmax(0, 1fr) !important;
    gap: 16px !important;
    padding: 12px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
    width: 112px !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
    min-height: 112px !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head {
    min-height: 64px !important;
}

.theatre-mode .cinema-detail-hero.cinema-theatre-detail-hero {
    grid-template-columns: 190px minmax(0, 1fr) !important;
    gap: 28px !important;
    align-items: start !important;
}

.theatre-mode .cinema-theatre-detail-hero .cinema-theatre-large-icon {
    width: 190px !important;
    height: 190px !important;
    max-width: 190px !important;
    aspect-ratio: 1;
}

.theatre-mode .cinema-detail-panel h2 {
    max-width: 18ch !important;
    font-size: clamp(2.25rem, 4.6vw, 4.5rem) !important;
    line-height: 0.98 !important;
    margin-bottom: 14px !important;
}

.theatre-mode .cinema-detail-meta {
    margin-bottom: 12px !important;
}

.theatre-mode .cinema-action-row.compact {
    margin: 0 0 16px !important;
}

@media (max-width: 720px) {
    .cinema-showtime-card.cinema-theatre-showtime-row {
        grid-template-columns: 76px minmax(0, 1fr) !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
        width: 76px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
        min-height: 76px !important;
    }

    .theatre-mode .cinema-detail-hero.cinema-theatre-detail-hero {
        grid-template-columns: 82px minmax(0, 1fr) !important;
        gap: 14px !important;
    }

    .theatre-mode .cinema-theatre-detail-hero .cinema-theatre-large-icon {
        width: 82px !important;
        height: 82px !important;
    }

    .theatre-mode .cinema-detail-panel h2 {
        font-size: clamp(1.45rem, 6vw, 2.2rem) !important;
    }
}

.cinema-browse-shell {
    --cinema-radius-sm: 8px;
    --cinema-radius-md: 16px;
    --cinema-radius-lg: 24px;
    --cinema-transition: 220ms ease;
}

.cinema-list-panel {
    gap: 14px !important;
}

.cinema-list-item {
    border-radius: var(--cinema-radius-lg) !important;
    padding: 14px 16px !important;
    transition: transform var(--cinema-transition), background var(--cinema-transition), border-color var(--cinema-transition), box-shadow var(--cinema-transition), opacity var(--cinema-transition) !important;
}

.cinema-list-item img,
.cinema-list-item .cinema-theatre-icon {
    opacity: 0.65;
    filter: grayscale(14%) saturate(0.9);
    transition: opacity var(--cinema-transition), filter var(--cinema-transition), transform var(--cinema-transition) !important;
}

.cinema-list-item.active img,
.cinema-list-item.active .cinema-theatre-icon,
.cinema-list-item:hover img,
.cinema-list-item:focus-visible img,
.cinema-list-item:hover .cinema-theatre-icon,
.cinema-list-item:focus-visible .cinema-theatre-icon {
    opacity: 1;
    filter: none;
}

.cinema-list-item:hover,
.cinema-list-item:focus-visible {
    transform: scale(1.02) !important;
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.38), 0 0 24px rgba(255, 159, 10, 0.08) !important;
}

.cinema-list-copy strong {
    color: rgba(245, 245, 247, 0.82) !important;
    font-weight: 850 !important;
    letter-spacing: -0.018em;
}

.cinema-list-copy small {
    color: rgba(235, 235, 245, 0.48) !important;
    font-weight: 700 !important;
}

.cinema-list-item.active .cinema-list-copy strong {
    color: #ffffff !important;
    font-weight: 950 !important;
}

.cinema-list-item.active .cinema-list-copy small {
    color: rgba(245, 245, 247, 0.68) !important;
}

.cinema-detail-panel h2 {
    max-width: min(100%, 12.5ch) !important;
    font-size: clamp(1.95rem, 3.68vw, 3.78rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.055em !important;
}

.cinema-synopsis {
    max-width: 720px !important;
    line-height: 1.58 !important;
}

.cinema-detail-copy .cinema-quick-stats {
    display: inline-flex !important;
    align-items: center !important;
    gap: 0 !important;
    width: auto !important;
    max-width: 100%;
    min-height: 42px;
    margin-top: 18px !important;
    padding: 4px 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.095) !important;
    border-radius: var(--cinema-radius-md) !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.055), rgba(255, 255, 255, 0.025)) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.035) !important;
}

.cinema-detail-copy .cinema-quick-stats span {
    position: relative;
    min-height: 34px !important;
    padding: 6px 14px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    color: rgba(235, 235, 245, 0.74) !important;
    white-space: nowrap;
}

.cinema-detail-copy .cinema-quick-stats span + span::before {
    content: '';
    position: absolute;
    left: 0;
    top: 7px;
    bottom: 7px;
    width: 1px;
    background: rgba(255, 255, 255, 0.11);
}

.cinema-detail-copy .cinema-quick-stats i {
    width: 15px;
    text-align: center;
    color: rgba(255, 190, 72, 0.9) !important;
    font-size: 0.9rem !important;
}

.cinema-detail-copy .cinema-quick-stats strong {
    color: #ffffff !important;
    font-size: 1.02rem !important;
    line-height: 1;
}

.cinema-detail-copy .cinema-movie-date-tabs {
    gap: 10px !important;
    margin-top: 20px !important;
}

.cinema-movie-date-tab {
    width: 74px !important;
    min-height: 86px !important;
    border-radius: var(--cinema-radius-md) !important;
    border-color: rgba(255, 255, 255, 0.12) !important;
    background: rgba(255, 255, 255, 0.045) !important;
    color: rgba(235, 235, 245, 0.62) !important;
    transition: transform var(--cinema-transition), background var(--cinema-transition), border-color var(--cinema-transition), box-shadow var(--cinema-transition), color var(--cinema-transition) !important;
}

.cinema-movie-date-tab strong {
    font-size: 1.48rem !important;
    color: rgba(245, 245, 247, 0.82) !important;
}

.cinema-movie-date-tab:hover,
.cinema-movie-date-tab:focus-visible {
    transform: translateY(-2px) !important;
    border-color: rgba(255, 159, 10, 0.42) !important;
    background: rgba(255, 159, 10, 0.08) !important;
    box-shadow: 0 12px 28px rgba(0, 0, 0, 0.28), 0 0 18px rgba(255, 159, 10, 0.07) !important;
}

.cinema-movie-date-tab.active {
    background: linear-gradient(180deg, rgba(255, 204, 0, 0.86), rgba(255, 167, 16, 0.78)) !important;
    border-color: rgba(255, 204, 0, 0.7) !important;
    color: rgba(26, 20, 0, 0.82) !important;
    box-shadow: 0 12px 24px rgba(255, 159, 10, 0.16) !important;
}

.cinema-movie-date-tab.active strong {
    color: #171300 !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    gap: 16px !important;
    padding: 16px 18px !important;
    border-radius: var(--cinema-radius-md) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.022) !important;
    transition: border-color var(--cinema-transition), background var(--cinema-transition), box-shadow var(--cinema-transition) !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row:hover {
    border-color: rgba(255, 255, 255, 0.09) !important;
    background: linear-gradient(180deg, rgba(23, 23, 25, 0.94), rgba(12, 12, 14, 0.97)) !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-media {
    align-items: center !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
    width: 58px !important;
    height: 58px !important;
    border-radius: var(--cinema-radius-md) !important;
    opacity: 0.68;
    filter: grayscale(15%) saturate(0.78) brightness(0.74);
    box-shadow: inset 0 0 0 999px rgba(0, 0, 0, 0.34), 0 10px 22px rgba(0, 0, 0, 0.28) !important;
}

.cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon.cinema-theatre-image {
    opacity: 0.72;
    filter: grayscale(15%) saturate(0.72) brightness(0.72);
}

.cinema-theatre-showtime-row .cinema-theatre-row-content {
    gap: 10px !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head {
    align-items: flex-start !important;
    gap: 12px !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head h3 {
    margin-bottom: 4px !important;
    font-size: 1.05rem !important;
    line-height: 1.08 !important;
    color: rgba(245, 245, 247, 0.92) !important;
}

.cinema-theatre-showtime-row .cinema-theatre-row-head p {
    font-size: 0.73rem !important;
    line-height: 1.28 !important;
    color: rgba(235, 235, 245, 0.44) !important;
}

.cinema-theatre-showtime-row .cinema-card-times {
    margin-top: 0 !important;
}

.cinema-theatre-showtime-row .cinema-showtime-chips {
    gap: 8px !important;
    margin-top: 0 !important;
}

.cinema-theatre-showtime-row .cinema-showtime-chip {
    min-width: 68px !important;
    min-height: 36px !important;
    padding: 7px 12px !important;
    border-radius: var(--cinema-radius-sm) !important;
    font-size: 0.78rem !important;
    font-weight: 850 !important;
    transition: transform var(--cinema-transition), background var(--cinema-transition), border-color var(--cinema-transition), box-shadow var(--cinema-transition), color var(--cinema-transition) !important;
}

.cinema-theatre-showtime-row .cinema-showtime-chip:hover,
.cinema-theatre-showtime-row .cinema-showtime-chip:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 10px 20px rgba(255, 127, 115, 0.14) !important;
}

.cinema-theatre-row-head .cinema-action-row.compact {
    align-self: flex-start !important;
    margin-top: 0 !important;
    gap: 8px !important;
}

.cinema-theatre-row-head .cinema-action-row.compact a {
    min-height: 32px !important;
    padding: 7px 11px !important;
    border-radius: var(--cinema-radius-sm) !important;
    font-size: 0.72rem !important;
    transition: background var(--cinema-transition), border-color var(--cinema-transition), color var(--cinema-transition), box-shadow var(--cinema-transition), transform var(--cinema-transition) !important;
}

.cinema-theatre-row-head .cinema-action-row.compact a:hover,
.cinema-theatre-row-head .cinema-action-row.compact a:focus-visible {
    transform: translateY(-1px);
    background: rgba(255, 255, 255, 0.085) !important;
    border-color: rgba(255, 159, 10, 0.38) !important;
    box-shadow: 0 0 18px rgba(255, 159, 10, 0.08) !important;
}

@media (max-width: 900px) {
    .cinema-list-panel {
        gap: 12px !important;
    }

    .cinema-list-item:hover,
    .cinema-list-item:focus-visible {
        transform: none !important;
    }

    .cinema-detail-panel h2 {
        max-width: 100% !important;
        font-size: clamp(1.38rem, 6.2vw, 2.08rem) !important;
        line-height: 1.06 !important;
    }

    .cinema-detail-copy .cinema-quick-stats {
        width: 100% !important;
        overflow-x: auto;
        padding: 4px 6px !important;
    }

    .cinema-detail-copy .cinema-quick-stats span {
        padding: 6px 10px !important;
        font-size: 0.68rem !important;
    }

    .cinema-detail-copy .cinema-movie-date-tabs {
        gap: 8px !important;
    }

    .cinema-movie-date-tab {
        width: 62px !important;
        min-height: 76px !important;
        border-radius: 12px !important;
    }

    .cinema-movie-date-tab strong {
        font-size: 1.28rem !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row {
        grid-template-columns: 50px minmax(0, 1fr) !important;
        gap: 10px !important;
        padding: 12px !important;
    }

    .cinema-showtime-card.cinema-theatre-showtime-row .cinema-theatre-row-icon {
        width: 44px !important;
        height: 44px !important;
        border-radius: 12px !important;
    }

    .cinema-theatre-showtime-row .cinema-theatre-row-head {
        display: block !important;
    }

    .cinema-theatre-row-head .cinema-action-row.compact {
        margin-top: 8px !important;
    }

    .cinema-theatre-showtime-row .cinema-showtime-chip {
        min-width: 62px !important;
        min-height: 34px !important;
        padding: 6px 10px !important;
    }
}

.cinema-structured-row {
    --cinema-row-media-w: 82px;
    --cinema-row-media-h: 104px;
    display: grid !important;
    grid-template-columns: var(--cinema-row-media-w) minmax(0, 1fr) !important;
    align-items: start !important;
    gap: 16px !important;
    min-height: calc(var(--cinema-row-media-h) + 28px) !important;
    padding: 14px 16px !important;
}

.cinema-structured-row .cinema-row-media {
    width: var(--cinema-row-media-w) !important;
    height: var(--cinema-row-media-h) !important;
    display: flex !important;
    align-items: stretch !important;
    justify-content: center !important;
    align-self: start !important;
    flex: 0 0 var(--cinema-row-media-w) !important;
}

.cinema-structured-row .cinema-theatre-row-icon,
.cinema-structured-row .cinema-movie-row-poster {
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    object-fit: cover !important;
    border-radius: 14px !important;
}

.cinema-structured-row .cinema-row-content {
    min-height: var(--cinema-row-media-h) !important;
    height: var(--cinema-row-media-h) !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    gap: 8px !important;
    min-width: 0 !important;
}

.cinema-structured-row .cinema-row-top {
    display: flex !important;
    align-items: flex-start !important;
    justify-content: space-between !important;
    gap: 12px !important;
    min-width: 0 !important;
}

.cinema-structured-row .cinema-row-top > div:first-child {
    min-width: 0 !important;
}

.cinema-structured-row .cinema-row-top h3 {
    margin: 0 0 4px !important;
    max-width: 34ch !important;
    line-height: 1.12 !important;
    text-wrap: balance;
}

.cinema-structured-row .cinema-row-top p {
    margin: 0 !important;
    line-height: 1.25 !important;
}

.cinema-structured-row .cinema-row-divider {
    width: 100% !important;
    height: 1px !important;
    flex: 0 0 1px !important;
    background: rgba(255, 255, 255, 0.075) !important;
    box-shadow: none !important;
    opacity: 1 !important;
}

.cinema-structured-row .cinema-row-bottom {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

.cinema-structured-row .cinema-showtime-chips {
    align-items: flex-end !important;
    gap: 7px !important;
    margin: 0 !important;
}

.cinema-structured-row .cinema-showtime-chip {
    min-height: 34px !important;
    min-width: 64px !important;
    padding: 6px 11px !important;
}

.cinema-structured-row .cinema-action-row.compact {
    align-self: flex-start !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
}

.theatre-mode .cinema-showtime-card.movie-row .cinema-movie-row-head {
    display: flex !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

.theatre-mode .cinema-showtime-card.movie-row .cinema-format-stack,
.theatre-mode .cinema-showtime-card.movie-row .cinema-card-times {
    margin-top: 0 !important;
}

@media (max-width: 900px) {
    .cinema-structured-row {
        --cinema-row-media-w: 62px;
        --cinema-row-media-h: 82px;
        gap: 12px !important;
        min-height: calc(var(--cinema-row-media-h) + 24px) !important;
        padding: 12px !important;
    }

    .cinema-structured-row .cinema-row-content {
        min-height: var(--cinema-row-media-h) !important;
        height: var(--cinema-row-media-h) !important;
        gap: 6px !important;
    }

    .cinema-structured-row .cinema-row-top {
        gap: 8px !important;
    }

    .cinema-structured-row .cinema-row-top h3 {
        max-width: 24ch !important;
        font-size: 0.92rem !important;
        line-height: 1.12 !important;
    }

    .cinema-structured-row .cinema-row-top p {
        font-size: 0.68rem !important;
    }

    .cinema-structured-row .cinema-showtime-chips {
        gap: 6px !important;
    }

    .cinema-structured-row .cinema-showtime-chip {
        min-width: 58px !important;
        min-height: 32px !important;
        padding: 5px 9px !important;
        font-size: 0.72rem !important;
    }

    .cinema-structured-row .cinema-action-row.compact a {
        min-height: 30px !important;
        padding: 6px 9px !important;
    }
}

.cinema-showtime-card.cinema-structured-row {
    grid-template-columns: var(--cinema-row-media-w) minmax(0, 1fr) !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-row-media,
.cinema-showtime-card.cinema-structured-row .cinema-theatre-row-media,
.cinema-showtime-card.cinema-structured-row .cinema-movie-row-media {
    width: var(--cinema-row-media-w) !important;
    height: var(--cinema-row-media-h) !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-theatre-row-icon,
.cinema-showtime-card.cinema-structured-row .cinema-theatre-row-icon.cinema-theatre-image,
.cinema-showtime-card.cinema-structured-row .cinema-movie-row-poster {
    width: 100% !important;
    height: 100% !important;
}

.cinema-showtime-card.cinema-structured-row {
    --cinema-row-media-w: 64px;
    --cinema-row-media-h: 92px;
    gap: 14px !important;
    min-height: calc(var(--cinema-row-media-h) + 24px) !important;
    padding: 12px 14px !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-row-content {
    height: var(--cinema-row-media-h) !important;
    min-height: var(--cinema-row-media-h) !important;
    gap: 6px !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-row-top h3 {
    max-width: 30ch !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.cinema-showtime-card.cinema-structured-row .cinema-row-top p {
    display: -webkit-box !important;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.cinema-showtime-card.cinema-structured-row .cinema-row-divider {
    background: rgba(255, 255, 255, 0.055) !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-showtime-chip {
    min-height: 31px !important;
    min-width: 58px !important;
    padding: 5px 10px !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-movie-row-head img.cinema-movie-row-poster,
.theatre-mode .cinema-showtime-card.cinema-structured-row .cinema-movie-row-head img.cinema-movie-row-poster {
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    border-radius: 12px !important;
}

.cinema-showtime-card.cinema-structured-row .cinema-theatre-row-icon {
    border-radius: 12px !important;
}

@media (max-width: 900px) {
    .cinema-showtime-card.cinema-structured-row {
        --cinema-row-media-w: 56px;
        --cinema-row-media-h: 78px;
        gap: 10px !important;
        min-height: calc(var(--cinema-row-media-h) + 20px) !important;
        padding: 10px !important;
    }

    .cinema-showtime-card.cinema-structured-row .cinema-row-content {
        height: var(--cinema-row-media-h) !important;
        min-height: var(--cinema-row-media-h) !important;
        gap: 5px !important;
    }

    .cinema-showtime-card.cinema-structured-row .cinema-showtime-chip {
        min-height: 29px !important;
        min-width: 52px !important;
        padding: 4px 8px !important;
    }
}

.cinema-showtime-card.cinema-structured-row .cinema-theatre-row-icon,
.cinema-showtime-card.cinema-structured-row .cinema-theatre-row-icon.cinema-theatre-image {
    min-height: 0 !important;
    max-height: var(--cinema-row-media-h) !important;
}

@media (max-width: 900px) {
    .cinema-showtime-card.cinema-structured-row {
        --cinema-row-media-w: 64px;
        --cinema-row-media-h: 112px;
        min-height: calc(var(--cinema-row-media-h) + 20px) !important;
    }

    .cinema-showtime-card.cinema-structured-row .cinema-row-content {
        height: var(--cinema-row-media-h) !important;
        min-height: var(--cinema-row-media-h) !important;
    }

    .cinema-showtime-card.cinema-structured-row .cinema-action-row.compact {
        gap: 6px !important;
    }

    .cinema-showtime-card.cinema-structured-row .cinema-action-row.compact a {
        min-height: 28px !important;
        padding: 5px 8px !important;
        font-size: 0.66rem !important;
    }

    .cinema-showtime-card.cinema-structured-row .cinema-showtime-chip {
        min-height: 30px !important;
    }
}

.mobile-results .results-list.cinema-browser-active {
    display: block !important;
    width: 100% !important;
    max-width: calc(100vw - 18px) !important;
    margin: 0 auto !important;
    padding: 8px 0 calc(96px + env(safe-area-inset-bottom)) !important;
}

.cinema-browse-shell.cinema-reboot {
    display: flex !important;
    flex-direction: column !important;
}

.feed-card,
.listing-card,
.sub-cat-btn,
.featured-card-flyer,
.search-result-thumb,
.card-image,
.feed-card-image,
.card-bg-img,
.card-image img,
.featured-card-flyer .flyer-image,
.featured-image-box-mobile img,
.search-result-thumb img,
.cinema-l2-movie-card,
.cinema-reboot-movie-card,
.cinema-reboot-movie-card img,
.cinema-reboot-detail-head img,
.cinema-detail-hero img,
.details-hero img,
#listingDetailsModal .details-header img,
.cinema-movie-row-poster,
.cinema-showtime-card.cinema-structured-row .cinema-movie-row-poster,
.cinema-theatre-image,
.cinema-reboot-theatre-image,
.cinema-theatre-row-icon.cinema-theatre-image {
    box-shadow: none !important;
    filter: none !important;
    text-shadow: none !important;
}

.feed-card:active,
.listing-card:active,
.sub-cat-btn:active,
.featured-card-flyer:active,
.cinema-reboot-movie-card:hover,
.cinema-reboot-movie-card:focus-visible,
.cinema-reboot-movie-card.active,
.cinema-l2-movie-card:active {
    box-shadow: none !important;
}

.feed-card *,
.sub-cat-btn *,
.featured-card-flyer *,
.cinema-l2-movie-card *,
.cinema-reboot-movie-card *,
.card-image *,
.details-hero *,
.cinema-reboot-detail-head *,
.cinema-showtime-card.cinema-structured-row .cinema-row-media * {
    text-shadow: none !important;
}

.cinema-l2-language-label,
.card-sub-text,
.card-type-badge,
.playing-today-badge,
.listing-actions-overlay .listing-image-action {
    box-shadow: none !important;
    text-shadow: none !important;
}

body,
body *,
body *::before,
body *::after {
    box-shadow: none !important;
    text-shadow: none !important;
}

img,
picture,
video,
canvas,
.feed-card-image,
.card-bg-img,
.card-image img,
.featured-card-flyer .flyer-image,
.search-result-thumb img,
.cinema-reboot-movie-card img,
.cinema-reboot-detail-head img,
.cinema-detail-hero img,
.details-hero img,
.cinema-movie-row-poster,
.cinema-theatre-image,
.cinema-reboot-theatre-image {
    filter: none !important;
}

.feed-card::after,
.card-image::after,
.listing-card::after,
.search-placeholder::after,
.ticker-item::after,
.active-search-results .search-result-thumb::after,
.cinema-list-item::before,
#listingDetailsModal .modal-content.listing-card-vibe::before {
    background: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
    filter: none !important;
}

.search-overlay .search-placeholder {
    min-height: calc(100vh - 210px - env(safe-area-inset-bottom)) !important;
    margin: 0 !important;
    padding: 24px 22px !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
}

.search-overlay .search-placeholder p {
    color: rgba(248, 245, 255, 0.70) !important;
    font-size: 0.95rem !important;
    line-height: 1.45 !important;
    font-weight: 650 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
    max-width: 340px !important;
}

.search-overlay .mobile-search-discovery {
    justify-content: flex-start !important;
    align-items: stretch !important;
    min-height: auto !important;
    gap: 0 !important;
    padding: 2px 0 0 !important;
}

.search-overlay .mobile-search-quick-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: flex-start !important;
    align-content: flex-start !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
}

.search-overlay .mobile-search-quick-pill {
    --quick-accent: var(--cd-theme-solid, var(--mobile-primary));
    appearance: none !important;
    min-width: 0 !important;
    min-height: 34px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 13px !important;
    border: 1px solid color-mix(in srgb, var(--quick-accent) 22%, transparent) !important;
    border-radius: 999px !important;
    background: color-mix(in srgb, var(--quick-accent) 13%, transparent) !important;
    color: var(--cd-secondary, var(--quick-accent)) !important;
    box-shadow: none !important;
    font: inherit !important;
    font-size: 0.76rem !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    line-height: 1.1 !important;
    text-align: center !important;
    cursor: pointer !important;
    -webkit-tap-highlight-color: transparent !important;
}

body.light-mode .search-overlay .mobile-search-quick-pill {
    color: var(--cd-accent-readable, var(--quick-accent)) !important;
}

.search-overlay .mobile-search-quick-pill span {
    min-width: 0 !important;
    white-space: nowrap !important;
}

.search-overlay .mobile-search-quick-pill:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--quick-accent) 70%, transparent) !important;
    outline-offset: 2px !important;
}

.search-overlay .mobile-search-quick-pill:active {
    transform: translateY(1px) !important;
}

.feed-card-overlay,
.card-content-overlay,
.featured-card-flyer .flyer-overlay,
.details-hero-overlay,
.premium-header-overlay,
#listingDetailsModal .details-hero-overlay {
    background: transparent !important;
    box-shadow: none !important;
    filter: none !important;
}

.feed-card:active,
.listing-card:active,
.sub-cat-btn:active,
.feed-card:active .feed-card-image,
.listing-card:active .card-image img,
.sub-cat-btn:active .card-bg-img {
    box-shadow: none !important;
    filter: none !important;
}

.brand-group h1,
.logo-text {
    display: inline-flex !important;
    align-items: baseline !important;
    justify-content: center !important;
    gap: 0 !important;
    background: none !important;
    -webkit-background-clip: initial !important;
    background-clip: initial !important;
    -webkit-text-fill-color: initial !important;
    color: #ffffff !important;
}

.brand-group h1 .logo-chicago,
.logo-text .logo-chicago {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
    background: none !important;
}

.brand-group h1 .logo-desi,
.logo-text .logo-desi {
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%)) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
}

.mobile-results:not(.hidden) {
    padding-top: calc(72px + env(safe-area-inset-top)) !important;
}

.mobile-results:not(.hidden) .results-list {
    padding-top: 12px !important;
}

.mobile-results.mobile-event-results:not(.hidden) {
    padding: env(safe-area-inset-top) 0.5rem 100px !important;
}

.mobile-results.mobile-event-results:not(.hidden) .results-list {
    gap: 1rem !important;
    padding-top: 0 !important;
}

.mobile-results.mobile-news-results {
    padding: 12px 0.5rem 100px !important;
}

.mobile-results.mobile-news-results .results-list {
    padding-top: 0 !important;
}

.mobile-results .results-list.cinema-browser-active {
    padding-top: 0 !important;
}

.mobile-results.cinema-l3-results,
.mobile-results:has(.cinema-l3-mode) {
    background: #0d1419 !important;
    padding-left: 8px !important;
    padding-right: 8px !important;
}

.mobile-results.cinema-l3-results .results-list.cinema-browser-active,
.mobile-results:has(.cinema-l3-mode) .results-list.cinema-browser-active {
    max-width: 100vw !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    background: #0d1419 !important;
}

.cinema-browse-shell.cinema-reboot.cinema-l3-mode {
    --cinema-reboot-bg: #0d1419;
    --cinema-reboot-panel: #151c22;
    --cinema-reboot-panel-2: #192026;
    --cinema-reboot-border: rgba(255, 255, 255, 0.14);
    --cinema-reboot-orange: #ff6b00;
    --cinema-reboot-orange-2: #ffb693;
    --cinema-reboot-red: #ff4b4b;
    --cinema-reboot-muted: rgba(220, 227, 235, 0.68);
    background: #0d1419 !important;
    color: #ffffff !important;
    width: 100% !important;
    max-width: none !important;
}

.cinema-l3-mode .cinema-reboot-detail-panel {
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    padding: 0 6px 18px !important;
}

.cinema-l3-mode .cinema-reboot-detail-head {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    align-items: stretch !important;
    padding: 0 !important;
    background: #151c22 !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}

.cinema-l3-mode .cinema-reboot-detail-head > img {
    width: 100% !important;
    aspect-ratio: 16 / 10 !important;
    border-radius: 0 !important;
    object-fit: cover !important;
    object-position: center top !important;
}

.cinema-l3-mode .cinema-reboot-eyebrow {
    color: #ff9f0a !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.08em !important;
}

.cinema-l3-mode .cinema-reboot-title-row h2 {
    font-size: clamp(1.55rem, 7vw, 2.2rem) !important;
    line-height: 1.06 !important;
}

.cinema-l3-mode .cinema-reboot-detail-copy,
.cinema-l3-mode .cinema-reboot-title-row {
    height: auto !important;
}

.cinema-l3-mode .cinema-reboot-detail-copy {
    padding: 14px !important;
}

.cinema-l3-mode .cinema-reboot-title-row {
    align-content: start !important;
}

.cinema-l3-mode .cinema-reboot-movie-meta-row {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 13px !important;
}

.cinema-l3-mode .cinema-reboot-date-tab.active {
    background: linear-gradient(135deg, #ffb000 0%, #ff7a00 46%, #ff5e00 100%) !important;
    border-color: transparent !important;
    box-shadow: 0 12px 26px rgba(255, 122, 24, 0.22) !important;
}

.cinema-l3-mode .cinema-reboot-language-pill {
    min-height: 34px !important;
    padding: 0 13px !important;
    border-radius: 999px !important;
    font-size: 0.76rem !important;
    color: #ffffff !important;
}

.cinema-l3-mode .cinema-reboot-fact-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 34px !important;
    padding: 0 12px !important;
    border: 1px solid rgba(255, 157, 80, 0.34) !important;
    border-radius: 999px !important;
    background: rgba(255, 106, 0, 0.08) !important;
    color: #ffc08a !important;
    font-size: 0.68rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.cinema-l3-mode .cinema-reboot-date-strip {
    margin-top: 16px !important;
}

.cinema-l3-mode .cinema-reboot-date-label {
    display: block !important;
    margin: 0 2px 10px !important;
    color: rgba(220, 227, 235, 0.88) !important;
    font-size: 0.72rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.08em !important;
    text-transform: uppercase !important;
}

.cinema-l3-mode .cinema-reboot-date-tabs {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    width: 100% !important;
    gap: 8px !important;
    margin-top: 0 !important;
    padding: 0 !important;
    overflow: visible !important;
}

.cinema-l3-mode .cinema-reboot-date-tab:nth-child(n+6) {
    display: none !important;
}

.cinema-l3-mode .cinema-reboot-date-tab {
    flex: initial !important;
    min-width: 0 !important;
    min-height: 72px !important;
    border-radius: 8px !important;
    background: #192026 !important;
    border-color: rgba(255, 255, 255, 0.08) !important;
}

.cinema-l3-mode .cinema-reboot-showtimes {
    gap: 12px !important;
    margin-top: 16px !important;
}

.cinema-l3-mode .cinema-reboot-theatre-row {
    position: relative !important;
    background: #151c22 !important;
    border: 1px solid rgba(255, 255, 255, 0.10) !important;
    border-radius: 12px !important;
    padding: 14px !important;
    overflow: hidden !important;
}

.cinema-l3-mode .cinema-reboot-theatre-row:focus-within {
    border-color: rgba(255, 106, 0, 0.72) !important;
}

.cinema-l3-mode .cinema-reboot-theatre-info {
    grid-template-columns: 72px minmax(0, 1fr) !important;
    gap: 13px !important;
    align-items: start !important;
    padding-right: 0 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-row.has-distance .cinema-reboot-theatre-info {
    padding-right: 82px !important;
}

.cinema-l3-mode .cinema-reboot-theatre-media {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 9px !important;
}

.cinema-l3-mode .cinema-reboot-theatre-image {
    width: 72px !important;
    height: 72px !important;
    min-height: 0 !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 10px !important;
    object-fit: cover !important;
    background: #2a2131 !important;
    border: 1px solid rgba(255, 106, 0, 0.34) !important;
}

.cinema-l3-mode .cinema-reboot-theatre-title-line {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 0 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-title-line h3 {
    font-size: clamp(1.08rem, 5vw, 1.28rem) !important;
    line-height: 1.12 !important;
}

.cinema-l3-mode .cinema-reboot-distance {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    min-height: 32px !important;
    padding: 0 11px !important;
    border-radius: 999px !important;
    background: rgba(255, 107, 0, 0.10) !important;
    border: 0 !important;
    color: #ffc18a !important;
    font-size: 0.74rem !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
}

.cinema-l3-mode .cinema-reboot-theatre-distance-slot {
    position: absolute !important;
    top: 18px !important;
    right: 14px !important;
    z-index: 1 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head {
    gap: 7px !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head p {
    display: flex !important;
    align-items: flex-start !important;
    gap: 7px !important;
    padding: 0 !important;
    color: rgba(231, 226, 238, 0.7) !important;
    font-size: 0.79rem !important;
    line-height: 1.28 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head p i {
    margin-right: 0 !important;
    margin-top: 2px !important;
}

.cinema-l3-mode .cinema-reboot-row-actions {
    display: flex !important;
    flex-wrap: nowrap !important;
    justify-content: stretch !important;
    gap: 8px !important;
    margin-top: 14px !important;
    margin-left: 85px !important;
}

.cinema-l3-mode .cinema-reboot-row-actions a {
    background: rgba(255, 106, 0, 0.07) !important;
    border-color: rgba(255, 106, 0, 0.28) !important;
    color: #ffc48c !important;
}

.cinema-l3-mode .cinema-reboot-row-actions a {
    flex: 1 1 0 !important;
    min-height: 36px !important;
    padding: 0 12px !important;
    border-radius: 14px !important;
    gap: 6px !important;
    font-size: 0.74rem !important;
    font-weight: 850 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-shows {
    margin-left: 85px !important;
    margin-top: 16px !important;
}

.cinema-l3-mode .cinema-reboot-section-label {
    display: block !important;
    margin-bottom: 9px !important;
    color: rgba(230, 226, 238, 0.62) !important;
    font-size: 0.74rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.cinema-l3-mode .cinema-reboot-format-label {
    display: block !important;
    margin: 0 0 8px !important;
    color: rgba(220, 227, 235, 0.7) !important;
    font-size: 0.68rem !important;
    font-weight: 900 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
}

.cinema-l3-mode .cinema-reboot-format-group + .cinema-reboot-format-group {
    margin-top: 16px !important;
}

.cinema-l3-mode .cinema-reboot-time-chips {
    gap: 9px !important;
    padding-top: 0 !important;
    justify-content: flex-start !important;
}

.cinema-l3-mode .cinema-reboot-time-chips::before {
    display: none !important;
}

.cinema-l3-mode .cinema-reboot-theatre-shows::before {
    content: '' !important;
    display: block !important;
    width: 100% !important;
    height: 1px !important;
    margin-bottom: 12px !important;
    background: rgba(255, 255, 255, 0.10) !important;
}

.cinema-l3-mode .cinema-reboot-time-chip {
    flex: 1 1 86px !important;
    min-width: 0 !important;
    max-width: 124px !important;
    min-height: 46px !important;
    border-radius: 8px !important;
    background: linear-gradient(135deg, #ff5e00, #ff7a00) !important;
    border-color: transparent !important;
    color: #ffffff !important;
    font-size: 0.84rem !important;
    font-weight: 950 !important;
}

@media (max-width: 430px) {
    .cinema-l3-mode .cinema-reboot-detail-head {
        grid-template-columns: none !important;
        gap: 0 !important;
        padding: 0 !important;
        border-radius: 12px !important;
    }

    .cinema-l3-mode .cinema-reboot-detail-head > img {
        width: 100% !important;
    }

    .cinema-l3-mode .cinema-reboot-theatre-info {
        grid-template-columns: 72px minmax(0, 1fr) !important;
        gap: 12px !important;
        padding-right: 0 !important;
    }

    .cinema-l3-mode .cinema-reboot-theatre-row.has-distance .cinema-reboot-theatre-info {
        padding-right: 76px !important;
    }

    .cinema-l3-mode .cinema-reboot-theatre-image {
        width: 72px !important;
        height: 72px !important;
    }

    .cinema-l3-mode .cinema-reboot-row-actions,
    .cinema-l3-mode .cinema-reboot-theatre-shows {
        margin-left: 84px !important;
    }

    .cinema-l3-mode .cinema-reboot-date-tab {
        min-height: 72px !important;
    }

    .cinema-l3-mode .cinema-reboot-date-tab span,
    .cinema-l3-mode .cinema-reboot-date-tab small {
        font-size: 0.54rem !important;
    }

    .cinema-l3-mode .cinema-reboot-date-tab strong {
        font-size: 1rem !important;
    }
}

.menu-overlay {
    background: rgba(0, 0, 0, 0.52) !important;
    backdrop-filter: blur(8px) saturate(135%) !important;
    -webkit-backdrop-filter: blur(8px) saturate(135%) !important;
    z-index: 6400 !important;
}

.side-menu,
body.light-mode .side-menu {
    position: fixed !important;
    top: auto !important;
    left: 10px !important;
    right: 10px !important;
    bottom: calc(86px + env(safe-area-inset-bottom)) !important;
    width: auto !important;
    max-width: none !important;
    height: auto !important;
    max-height: min(76vh, 660px) !important;
    padding: 0 !important;
    border-radius: 28px !important;
    transform: translateY(calc(100% + 120px)) !important;
    opacity: 0 !important;
    visibility: hidden !important;
    overflow: hidden !important;
    transition: transform 0.42s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.24s ease, visibility 0.24s ease !important;
    z-index: 7000 !important;
}

.side-menu.active,
body.light-mode .side-menu.active {
    transform: translateY(0) !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.side-menu::before {
    content: '';
    width: 42px;
    height: 4px;
    border-radius: 999px;
    background: rgba(248, 245, 255, 0.22);
    margin: 10px auto 0;
    display: block;
    flex: 0 0 auto;
}

.side-menu-header,
body.light-mode .side-menu-header {
    padding: 12px 16px 12px !important;
}

.side-menu-content {
    max-height: calc(min(76vh, 660px) - 76px) !important;
    padding: 8px 12px 14px !important;
}

.mobile-menu-link,
body.light-mode .mobile-menu-link {
    min-height: 46px !important;
}

.mobile-results.cinema-l3-results,
.mobile-results:has(.cinema-l3-mode),
.mobile-results.cinema-l3-results .results-list.cinema-browser-active,
.mobile-results:has(.cinema-l3-mode) .results-list.cinema-browser-active {
    background: transparent !important;
}

.cinema-browse-shell.cinema-reboot.cinema-l3-mode {
    --cinema-reboot-bg: var(--mobile-bg) !important;
    --cinema-reboot-panel: rgba(33, 24, 45, 0.92) !important;
    --cinema-reboot-panel-2: rgba(33, 24, 45, 0.92) !important;
    --cinema-reboot-border: rgba(255, 255, 255, 0.12) !important;
    --cinema-reboot-muted: rgba(236, 226, 245, 0.68) !important;
    background: transparent !important;
    font-family: -apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", Helvetica, Arial, sans-serif !important;
}

.cinema-l3-mode .cinema-reboot-detail-head,
.cinema-l3-mode .cinema-reboot-theatre-row {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    background: var(--cd-surface-gradient) !important;
    border-color: rgba(255, 255, 255, 0.12) !important;
}

.cinema-l3-mode .cinema-reboot-detail-head {
    border-radius: 24px !important;
}

.cinema-l3-mode .cinema-reboot-detail-head > img {
    width: 100% !important;
    aspect-ratio: 3 / 4 !important;
    max-height: none !important;
    border-radius: 0 !important;
    object-fit: cover !important;
    object-position: center top !important;
}

.cinema-l3-mode .cinema-reboot-date-tabs {
    display: flex !important;
    width: 100% !important;
    gap: 8px !important;
    overflow-x: auto !important;
    padding: 0 0 2px !important;
    scrollbar-width: none !important;
}

.cinema-l3-mode .cinema-reboot-date-tabs::-webkit-scrollbar {
    display: none !important;
}

.cinema-l3-mode .cinema-reboot-date-tab {
    flex: 0 0 66px !important;
    width: 66px !important;
    min-width: 66px !important;
    min-height: 82px !important;
    border-radius: 14px !important;
    background: linear-gradient(180deg, rgba(48, 35, 67, 0.92), rgba(24, 17, 35, 0.96)) !important;
    border: 1px solid rgba(255, 255, 255, 0.13) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05), 0 10px 24px rgba(0, 0, 0, 0.22) !important;
}

.cinema-l3-mode .cinema-reboot-theatre-row {
    padding: 12px !important;
    border-radius: 24px !important;
}

.cinema-l3-mode .cinema-reboot-theatre-info,
.cinema-l3-mode .cinema-reboot-theatre-row.has-distance .cinema-reboot-theatre-info {
    display: grid !important;
    grid-template-columns: 62px minmax(0, 1fr) !important;
    gap: 12px !important;
    align-items: center !important;
    padding-right: 0 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-media {
    align-items: stretch !important;
    gap: 0 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-image {
    width: 62px !important;
    height: 62px !important;
    border-radius: 10px !important;
}

.cinema-l3-mode .cinema-reboot-theatre-content {
    justify-content: center !important;
    gap: 0 !important;
    width: 100% !important;
    min-width: 0 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head {
    gap: 4px !important;
    width: 100% !important;
    min-width: 0 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-title-line h3 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: clamp(1.06rem, 4.8vw, 1.24rem) !important;
    font-weight: 950 !important;
    line-height: 1.12 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head p {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin-top: 4px !important;
    color: rgba(220, 227, 235, 0.58) !important;
    font-size: 0.76rem !important;
    font-weight: 650 !important;
    line-height: 1.3 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head p i {
    flex: 0 0 auto !important;
    margin: 0 !important;
    color: #ff7a00 !important;
}

.cinema-l3-mode .cinema-reboot-theatre-head p span {
    display: block !important;
    min-width: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

.cinema-l3-mode .cinema-reboot-theatre-shows {
    width: 100% !important;
    margin: 12px 0 0 !important;
    padding-top: 12px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.10) !important;
}

.cinema-l3-mode .cinema-reboot-theatre-shows::before,
.cinema-l3-mode .cinema-reboot-section-label,
.cinema-l3-mode .cinema-reboot-format-label {
    display: none !important;
}

.cinema-l3-mode .cinema-reboot-showtime-stack,
.cinema-l3-mode .cinema-reboot-format-group {
    width: 100% !important;
}

.cinema-l3-mode .cinema-reboot-time-chips {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
    width: 100% !important;
    padding-top: 0 !important;
}

.cinema-l3-mode .cinema-reboot-time-chip {
    width: 78px !important;
    min-width: 78px !important;
    max-width: 78px !important;
    min-height: 40px !important;
    padding: 0 8px !important;
    border-radius: 12px !important;
    background: linear-gradient(90deg, #ffb000 0%, #ff7a00 46%, #ff5e00 100%) !important;
    border: 0 !important;
    color: #ffffff !important;
    font-size: 0.76rem !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    justify-self: center !important;
    box-shadow: 0 10px 22px rgba(255, 122, 24, 0.18) !important;
}

.cinema-l3-mode .cinema-reboot-row-actions {
    display: grid !important;
    grid-template-columns: 42px minmax(0, 1fr) 42px !important;
    align-items: center !important;
    justify-items: center !important;
    gap: 14px !important;
    width: 100% !important;
    margin: 12px 0 0 !important;
    padding-top: 14px !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}

.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-icon-action {
    width: 42px !important;
    height: 42px !important;
    min-width: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    color: rgba(255, 255, 255, 0.8) !important;
    font-size: 1.1rem !important;
    box-shadow: none !important;
}

.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-icon-action.disabled {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0.5 !important;
    color: rgba(255, 255, 255, 0.9) !important;
    pointer-events: none !important;
}

.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-icon-action:hover,
.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-icon-action:focus-visible {
    background: rgba(255, 255, 255, 0.12) !important;
    color: #ffffff !important;
    outline: none !important;
}

.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-distance {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    justify-self: center !important;
    width: auto !important;
    min-width: 0 !important;
    min-height: 36px !important;
    padding: 0 14px 0 12px !important;
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 999px !important;
    color: rgba(255, 255, 255, 0.8) !important;
    font-size: 0.74rem !important;
    font-weight: 800 !important;
    box-shadow: none !important;
}

.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-distance i {
    color: rgba(255, 255, 255, 0.7) !important;
    font-size: 0.94rem !important;
}

.cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-distance.is-empty {
    visibility: hidden !important;
}

@media (max-width: 430px) {
    .cinema-l3-mode .cinema-reboot-theatre-info,
    .cinema-l3-mode .cinema-reboot-theatre-row.has-distance .cinema-reboot-theatre-info {
        grid-template-columns: 56px minmax(0, 1fr) !important;
        gap: 10px !important;
    }

    .cinema-l3-mode .cinema-reboot-theatre-image {
        width: 56px !important;
        height: 56px !important;
    }

    .cinema-l3-mode .cinema-reboot-time-chips {
        gap: 7px !important;
    }

    .cinema-l3-mode .cinema-reboot-time-chip {
        width: 74px !important;
        min-width: 74px !important;
        max-width: 74px !important;
        min-height: 38px !important;
    }

    .cinema-l3-mode .cinema-reboot-row-actions {
        grid-template-columns: 38px minmax(0, 1fr) 38px !important;
        gap: 12px !important;
    }

    .cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-icon-action {
        width: 38px !important;
        height: 38px !important;
        min-width: 38px !important;
        min-height: 38px !important;
    }

    .cinema-l3-mode .cinema-reboot-row-actions .cinema-reboot-distance {
        width: auto !important;
        min-height: 32px !important;
    }

    .cinema-l3-mode .cinema-reboot-date-tab {
        flex-basis: 62px !important;
        width: 62px !important;
        min-width: 62px !important;
        min-height: 82px !important;
    }
}

.listing-card-l3-row {
    justify-content: flex-start !important;
    margin-top: 10px !important;
}

.listing-profile-link,
.listing-l3-empty-state a,
.search-profile-link {
    min-height: 34px !important;
    padding: 0 12px !important;
    border-radius: 999px !important;
    background: rgba(255, 122, 24, 0.12) !important;
    border: 1px solid rgba(255, 122, 24, 0.22) !important;
    color: #ffd9bd !important;
    box-shadow: none !important;
    font-size: 0.72rem !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    line-height: 1 !important;
}

.listing-profile-link i,
.search-profile-link i {
    font-size: 0.72rem !important;
}

.search-profile-link {
    align-self: flex-start !important;
}

.cinema-browse-shell.cinema-reboot.cinema-l3-mode {
    gap: 12px !important;
}

.cinema-l3-mode .cinema-reboot-detail-panel {
    border-radius: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
}

.cinema-l3-mode .cinema-reboot-detail-head,
.cinema-l3-mode .cinema-reboot-detail-panel .cinema-reboot-detail-head {
    display: grid !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 13px !important;
    align-items: center !important;
    padding: 12px !important;
    border-radius: 24px !important;
    background: var(--cd-surface-gradient) !important;
    border: 1px solid rgba(255, 255, 255, 0.12) !important;
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.24) !important;
}

.cinema-l3-mode .cinema-reboot-detail-head > img,
.cinema-l3-mode .cinema-reboot-detail-panel .cinema-reboot-detail-head > img {
    width: 104px !important;
    min-width: 104px !important;
    height: 138px !important;
    aspect-ratio: auto !important;
    border-radius: 16px !important;
    object-fit: cover !important;
    object-position: center top !important;
    background: #130d1f !important;
}

.cinema-l3-mode .cinema-reboot-detail-copy {
    min-width: 0 !important;
    padding: 0 !important;
}

.cinema-l3-mode .cinema-reboot-title-row {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 12px !important;
    min-width: 0 !important;
}

.cinema-l3-mode .cinema-reboot-title-row h2 {
    margin: 0 !important;
    color: #ffffff !important;
    font-size: clamp(1.34rem, 7vw, 1.8rem) !important;
    line-height: 1.02 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 3 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
}

.cinema-l3-mode .cinema-reboot-movie-meta-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 0 !important;
}

.cinema-l3-mode .cinema-reboot-date-strip {
    padding: 0 2px !important;
}

.cinema-l3-mode .cinema-reboot-showtimes {
    margin-top: 12px !important;
}

@media (max-width: 390px) {
    .cinema-l3-mode .cinema-reboot-detail-head,
    .cinema-l3-mode .cinema-reboot-detail-panel .cinema-reboot-detail-head {
        grid-template-columns: 88px minmax(0, 1fr) !important;
        gap: 11px !important;
        padding: 10px !important;
        border-radius: 20px !important;
    }

    .cinema-l3-mode .cinema-reboot-detail-head > img,
    .cinema-l3-mode .cinema-reboot-detail-panel .cinema-reboot-detail-head > img {
        width: 88px !important;
        min-width: 88px !important;
        height: 118px !important;
        border-radius: 14px !important;
    }

    .cinema-l3-mode .cinema-reboot-title-row h2 {
        font-size: clamp(1.18rem, 7vw, 1.54rem) !important;
    }

    .listing-profile-link,
    .search-profile-link {
        min-height: 32px !important;
        font-size: 0.68rem !important;
    }
}

.feed-card-footer .footer-action-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 0 0 auto !important;
    min-height: 40px !important;
    padding: 0 18px !important;
    border-radius: 999px !important;
    background: var(--cd-accent-gradient) !important;
    color: var(--cd-text-on-accent) !important;
    -webkit-text-fill-color: var(--cd-text-on-accent) !important;
    border: 1px solid rgba(255, 255, 255, 0.48) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.56), 0 10px 22px rgba(255, 94, 0, 0.28) !important;
    font-size: 0.76rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.08em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
    white-space: nowrap !important;
}

body.light-mode .feed-card-footer .footer-title,
body.light-mode .feed-card-footer .footer-subtitle {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
}

.cinema-l2-footer-stack {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
    width: 100% !important;
}

.cinema-l2-status-pill {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 28px !important;
    padding: 7px 11px !important;
    border-radius: 10px !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.42) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.42), 0 10px 22px rgba(0, 0, 0, 0.22) !important;
    font-size: 0.68rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.08em !important;
    line-height: 1 !important;
    text-transform: none !important;
    text-shadow: none !important;
}

.cinema-l2-status-pill.now-playing {
    background: linear-gradient(135deg, #28d66f 0%, #08a85a 48%, #047a3b 100%) !important;
}

.cinema-l2-status-pill.upcoming {
    background: linear-gradient(135deg, #ffb000 0%, #ff7a00 48%, #ff5e00 100%) !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-language-label {
    position: absolute !important;
    top: 18px !important;
    right: 18px !important;
    left: auto !important;
    max-width: calc(50% - 24px) !important;
    margin: 0 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-content-overlay {
    justify-content: flex-end !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-status-pill {
    position: absolute !important;
    top: 18px !important;
    left: 18px !important;
    right: auto !important;
    max-width: calc(50% - 24px) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.cinema-l2-language-label,
.cinema-search-language-pill,
.cinema-reboot-language-pill,
.movie-l3-language-pill,
.mobile-home-movie-language {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

body.light-mode .mobile-sub-grid.mobile-l2-grid .card-sub-text,
body.light-mode .mobile-sub-grid.owners-actions-grid .card-sub-text {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: rgba(0, 0, 0, 0.08) !important;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.12) !important;
}

body.light-mode .mobile-sub-grid.mobile-l2-grid .card-sub-title,
body.light-mode .mobile-sub-grid.owners-actions-grid .card-sub-title {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
}

body.light-mode .mobile-results .results-list .card-info,
body.light-mode .mobile-results .results-list .card-info h3,
body.light-mode .mobile-results .results-list .listing-card h3,
body.light-mode .mobile-results .results-list .trust-row,
body.light-mode .mobile-results .results-list .card-header-row,
body.light-mode .mobile-results .results-list .card-distance,
body.light-mode .mobile-results .results-list .contact-link,
body.light-mode .mobile-results .results-list .contact-link.event-highlight span,
body.light-mode .mobile-results .results-list .contact-text span {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
}

body.light-mode .mobile-results .results-list .contact-text label {
    color: var(--text-muted) !important;
    -webkit-text-fill-color: var(--text-muted) !important;
}

body.light-mode .mobile-results .results-list .contact-link.event-highlight label {
    color: var(--mobile-primary) !important;
    -webkit-text-fill-color: var(--mobile-primary) !important;
}

body.light-mode .mobile-results .results-list .trust-row,
body.light-mode .mobile-results .results-list .card-header-row,
body.light-mode .mobile-results .results-list .trust-row.card-meta-bottom {
    border-color: var(--mobile-border) !important;
}

body.light-mode .mobile-menu-link {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
}

.mobile-menu-link i,
body.light-mode .mobile-menu-link i {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

body.light-mode .side-menu-header {
    border-bottom-color: var(--mobile-border) !important;
}

body.light-mode .side-menu::before {
    background: rgba(23, 23, 28, 0.18) !important;
}

body.light-mode .close-menu-btn {
    background: rgba(23, 23, 28, 0.06) !important;
    border: 1px solid rgba(23, 23, 28, 0.12) !important;
    color: var(--text-white) !important;
}

body.light-mode .mobile-menu-link:active {
    background: rgba(23, 23, 28, 0.07) !important;
}

body.light-mode .active-search-results .search-result-card,
body.light-mode .active-search-results .cinema-search-result-card {
    background: var(--cd-surface-gradient) !important;
    border-color: var(--mobile-border) !important;
    color: var(--text-white) !important;
}

body.light-mode .active-search-results :is(.search-result-content, .cinema-search-result-content),
body.light-mode .active-search-results :is(.search-result-card h3, .cinema-search-result-card h3),
body.light-mode .active-search-results :is(.search-grid-item, .search-grid-item span),
body.light-mode .active-search-results :is(.search-result-meta, .search-meta-item),
body.light-mode .active-search-results .search-result-topline > span:not(.card-type-badge),
body.light-mode .active-search-results :is(.cinema-search-result-summary, .cinema-search-result-footer, .cinema-search-result-footer strong) {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
}

body.light-mode .active-search-results :is(.search-result-role, .search-result-location) {
    color: var(--text-muted) !important;
    -webkit-text-fill-color: var(--text-muted) !important;
}

body.light-mode .active-search-results .search-meta-open {
    color: #0f9f50 !important;
    -webkit-text-fill-color: #0f9f50 !important;
}

body.light-mode .active-search-results .search-meta-closed {
    color: #d93a48 !important;
    -webkit-text-fill-color: #d93a48 !important;
}

body.light-mode .active-search-results .search-result-thumb-fallback {
    color: rgba(23, 23, 28, 0.55) !important;
}

body.light-mode .active-search-results .search-grid-item i {
    color: var(--search-grid-color, var(--mobile-primary)) !important;
    -webkit-text-fill-color: var(--search-grid-color, var(--mobile-primary)) !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-sub-text {
    background: linear-gradient(135deg, var(--cinema-language-1, #ffd700), var(--cinema-language-2, #ff5e00)) !important;
    border-color: rgba(255, 255, 255, 0.38) !important;
    box-shadow: 0 10px 22px var(--cinema-language-glow, rgba(255, 94, 0, 0.28)) !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-sub-title {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    aspect-ratio: auto !important;
    gap: 8px !important;
    overflow: visible !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card:nth-child(n + 3) {
    padding-top: 14px !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card:nth-child(2n + 3)::before {
    content: "" !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: calc(200% + 6px) !important;
    height: 1px !important;
    background: color-mix(in srgb, var(--mobile-border) 78%, var(--text-white)) !important;
    pointer-events: none !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-poster-frame {
    flex: none !important;
    position: relative !important;
    width: 100% !important;
    aspect-ratio: 2 / 3 !important;
    overflow: hidden !important;
    border-radius: 18px !important;
    background: #130f1b !important;
    border: 1px solid var(--mobile-border) !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-bg-img {
    position: static !important;
    inset: auto !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    object-position: center center !important;
    background: #130f1b !important;
    border-radius: 0 !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-content-overlay {
    position: static !important;
    inset: auto !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 7px !important;
    width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-meta-row {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    width: 100% !important;
    min-width: 0 !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-language-label,
.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-status-pill {
    position: static !important;
    inset: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 24px !important;
    margin: 0 !important;
    padding: 6px 8px !important;
    border-radius: 9px !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
    font-size: 0.56rem !important;
    letter-spacing: 0.04em !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-language-label {
    position: absolute !important;
    top: 8px !important;
    left: 8px !important;
    right: auto !important;
    bottom: auto !important;
    z-index: 2 !important;
    flex: none !important;
    max-width: calc(100% - 16px) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-status-pill {
    position: absolute !important;
    left: 8px !important;
    right: auto !important;
    top: auto !important;
    bottom: 8px !important;
    z-index: 2 !important;
    width: auto !important;
    max-width: calc(100% - 16px) !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-footer-row,
.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-sub-info,
.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-sub-text {
    width: 100% !important;
    max-width: 100% !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-sub-text {
    padding: 8px 10px !important;
    border-radius: 12px !important;
    gap: 5px !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .card-sub-title {
    display: -webkit-box !important;
    -webkit-line-clamp: 1 !important;
    -webkit-box-orient: vertical !important;
    text-align: center !important;
    white-space: normal !important;
    overflow: hidden !important;
    font-size: 0.86rem !important;
    line-height: 1.14 !important;
}

.mobile-sub-grid.cinema-l2-grid .cinema-l2-movie-card .cinema-l2-card-cta {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    color: rgba(255, 255, 255, 0.94) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, 0.94) !important;
    font-size: 0.68rem !important;
    font-weight: 850 !important;
    letter-spacing: 0 !important;
    line-height: 1.1 !important;
    overflow: hidden !important;
    text-align: center !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
}

.mobile-sub-grid-container.mobile-utility-button-container {
    width: 100%;
    margin-left: 0;
    overflow-x: hidden;
    overflow-y: visible;
    padding-bottom: 6px;
}

.mobile-sub-grid.mobile-utility-button-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px !important;
    padding: 0 0 4px;
    scroll-snap-type: none;
}

.mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn {
    --mobile-utility-button-gradient: var(--cd-accent-gradient, linear-gradient(135deg, #f59e0b 0%, #fb7185 45%, #e11d48 100%));
    flex: none;
    width: 100%;
    min-height: 50px;
    height: auto;
    aspect-ratio: auto;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    flex-direction: row;
    gap: 6px;
    padding: 7px 8px;
    border-radius: 16px;
    border: 1px solid rgba(255, 255, 255, 0.42);
    background: var(--mobile-utility-button-gradient);
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-align: center;
    overflow: hidden;
    scroll-snap-align: none;
    outline: 2px solid transparent;
    outline-offset: -4px;
    box-shadow: none !important;
}

.mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn:focus-visible {
    outline-color: rgba(255, 255, 255, 0.92);
    outline-offset: 2px;
}

.mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn.active {
    border-color: rgba(255, 255, 255, 0.96);
    background: var(--mobile-utility-button-gradient);
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    outline: 2px solid rgba(255, 255, 255, 0.62);
    box-shadow: none !important;
}

.mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-icon {
    flex: 0 0 26px;
    width: 26px;
    height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.2);
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    border: 1px solid rgba(255, 255, 255, 0.26);
    font-size: 0.72rem;
    line-height: 1;
    box-shadow: none !important;
}

.mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn.active .mobile-utility-sub-icon {
    background: rgba(255, 255, 255, 0.96);
    color: var(--cd-theme-solid, var(--mobile-primary)) !important;
    -webkit-text-fill-color: var(--cd-theme-solid, var(--mobile-primary)) !important;
    border-color: rgba(255, 255, 255, 0.96);
    box-shadow: none !important;
}

.mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-label {
    flex: 1 1 auto;
    min-width: 0;
    max-width: 100%;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: clamp(0.82rem, 2.55vw, 0.94rem);
    font-weight: 900;
    line-height: 1.1;
    letter-spacing: 0.03em;
    margin-top: 0 !important;
    text-align: left;
    text-transform: uppercase !important;
    overflow-wrap: anywhere;
}

body.dark-mode .mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn {
    box-shadow: none !important;
}

body.dark-mode .mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn.active {
    outline-color: rgba(255, 255, 255, 0.58);
    box-shadow: none !important;
}

@media (max-width: 340px) {
    .mobile-sub-grid.mobile-utility-button-grid {
        gap: 8px !important;
    }

    .mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-btn {
        min-height: 46px;
        padding: 7px 6px;
        gap: 5px;
    }

    .mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-icon {
        flex-basis: 24px;
        width: 24px;
        height: 24px;
        font-size: 0.68rem;
    }

    .mobile-sub-grid.mobile-utility-button-grid .mobile-utility-sub-label {
        font-size: 0.76rem;
    }
}

.mobile-results.mobile-utility-inline-results:not(.hidden) {
    padding-top: 0 !important;
}

.mobile-results.mobile-utility-inline-results .results-list {
    padding-top: 0 !important;
    gap: 0 !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card,
.mobile-results.mobile-utility-inline-results .mobile-community-news-card {
    min-height: 0 !important;
    padding: 13px 0 !important;
    border: 0 !important;
    border-bottom: 1px solid var(--mobile-border) !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card {
    grid-template-columns: 104px minmax(0, 1fr) !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card .search-result-thumb {
    width: 104px !important;
    min-height: 104px !important;
    height: 100% !important;
    border-radius: 0 !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card .search-result-content {
    padding: 2px 0 2px 13px !important;
    gap: 8px !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="event"] {
    display: block !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="event"] .search-result-thumb {
    width: 100% !important;
    min-height: 0 !important;
    height: auto !important;
    margin: 0 0 12px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: transparent !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="event"] .search-result-thumb img {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    max-height: none !important;
    border-radius: 8px !important;
    object-fit: contain !important;
    object-position: center top !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="event"] .search-result-thumb:has(img) .search-result-thumb-fallback {
    display: none !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="event"] .search-result-thumb:not(:has(img)) .search-result-thumb-fallback {
    position: relative !important;
    min-height: 168px !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="event"] .search-result-content {
    padding: 0 !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="movie_screening"] {
    grid-template-columns: 92px minmax(0, 1fr) !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="movie_screening"] .search-result-thumb {
    width: 86px !important;
    min-height: 128px !important;
    height: 128px !important;
    align-self: start !important;
    border-radius: 8px !important;
    overflow: hidden !important;
    background: transparent !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="movie_screening"] .search-result-thumb img {
    border-radius: 8px !important;
    object-fit: cover !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="movie_screening"] .search-result-content {
    justify-content: flex-start !important;
}

.mobile-results.mobile-utility-inline-results .mobile-utility-card[data-mobile-utility-type="movie_screening"] .search-card-grid {
    grid-template-columns: 1fr !important;
    gap: 6px !important;
}

#listingDetailsModal.event-mode .details-header {
    width: 100% !important;
    height: auto !important;
    max-height: none !important;
    margin: 0 !important;
    border-radius: 30px 30px 0 0 !important;
    background: #050505 !important;
    box-shadow: none !important;
}

#listingDetailsModal.event-mode .details-header #detailsModalImg {
    width: 100% !important;
    height: auto !important;
    max-height: min(44vh, 360px) !important;
    object-fit: contain !important;
    object-position: center top !important;
    transform: none !important;
}

#listingDetailsModal.event-mode .details-hero-overlay {
    display: none !important;
}

#listingDetailsModal.event-mode .event-detail-heading {
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
}

#listingDetailsModal.event-mode .event-detail-heading .details-cat-tag {
    margin-bottom: 10px !important;
}

#listingDetailsModal.event-mode .event-detail-heading #detailsModalTitle {
    display: block !important;
    -webkit-line-clamp: initial !important;
    overflow: visible !important;
    text-shadow: none !important;
}

#listingDetailsModal.event-mode .event-detail-heading .details-subtitle {
    max-width: 100% !important;
    text-shadow: none !important;
}

#listingDetailsModal.event-mode .event-detail-meta-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0 !important;
}

#listingDetailsModal.event-mode .event-detail-meta-wide {
    grid-column: auto !important;
}

#listingDetailsModal .detail-summary-item,
#listingDetailsModal .info-item-box,
#listingDetailsModal .detail-section {
    min-height: 0 !important;
    padding: 12px 0 !important;
    border: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12) !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
}

#listingDetailsModal .detail-summary-strip,
#listingDetailsModal .detail-info-list,
#listingDetailsModal .details-info-grid {
    gap: 0 !important;
}

body.light-mode .mobile-results .mobile-utility-card {
    color: var(--text-white) !important;
}

body.light-mode .mobile-results .mobile-utility-card h3,
body.light-mode .mobile-results .mobile-utility-card .search-result-content,
body.light-mode .mobile-results .mobile-utility-card .search-grid-item,
body.light-mode .mobile-results .mobile-utility-card .search-grid-item span,
body.light-mode .mobile-results .mobile-utility-card .mobile-utility-action-button,
body.light-mode .mobile-results .mobile-utility-card .mobile-utility-action-button span {
    color: var(--text-white) !important;
    -webkit-text-fill-color: var(--text-white) !important;
}

body.light-mode .mobile-results .mobile-utility-card .search-result-summary,
body.light-mode .mobile-results .mobile-utility-card .mobile-utility-paid-disclosure {
    color: var(--text-muted) !important;
    -webkit-text-fill-color: var(--text-muted) !important;
}

.mobile-menu-link,
.mobile-menu-link:visited,
.mobile-menu-link:hover,
.mobile-menu-link:focus-visible,
.mobile-menu-link i {
    text-decoration: none !important;
}

.feed-card-content {
    padding-bottom: 12px !important;
}

.home-feed-cards .card-glass-title {
    border-radius: 12px !important;
}

.feed-card-footer,
body.light-mode .feed-card-footer {
    padding: 4px 6px !important;
    gap: 8px !important;
    border-radius: 16px !important;
}

.home-feed-cards .feed-card-footer,
body.light-mode .home-feed-cards .feed-card-footer {
    width: fit-content !important;
    max-width: 100% !important;
    padding: 7px 10px !important;
    border-radius: 12px !important;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.058) 0%, rgba(255, 255, 255, 0.032) 100%) !important;
    border-color: rgba(255, 255, 255, 0.14) !important;
    color: #ffffff !important;
}

.home-feed-cards .feed-card-footer .footer-text {
    flex: 0 1 auto !important;
    min-width: 0 !important;
}

.home-feed-cards .feed-card-footer .footer-subtitle,
body.light-mode .home-feed-cards .feed-card-footer .footer-subtitle {
    color: rgba(255, 255, 255, 0.9) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, 0.9) !important;
}

.feed-card-footer .footer-action-btn {
    min-height: 34px !important;
    padding: 0 15px !important;
}

.logo-desi,
.brand-group h1 .logo-desi,
.logo-text .logo-desi {
    background: var(--cd-accent-gradient) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    color: transparent !important;
    -webkit-text-fill-color: transparent !important;
}

body.dark-mode .logo-chicago,
.dark-mode .logo-chicago {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

body.light-mode .logo-chicago,
.light-mode .logo-chicago {
    color: #0a3f86 !important;
    -webkit-text-fill-color: #0a3f86 !important;
}

.mobile-results .results-list .listing-card:not(.event-card):not(.cinema-card) .card-image {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: 1.65 / 1 !important;
}

.mobile-results .results-list.event-mode .listing-card.event-card .card-image,
.mobile-results .results-list .listing-card.event-card .card-image {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    aspect-ratio: auto !important;
    overflow: visible !important;
    background: #050505 !important;
}

.mobile-results .results-list.event-mode .listing-card.event-card .card-image img,
.mobile-results .results-list .listing-card.event-card .card-image img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-height: none !important;
    animation: none !important;
    transform: none !important;
    object-fit: contain !important;
    object-position: center top !important;
}

.mobile-results .results-list .listing-card.event-card:active .card-image img {
    transform: none !important;
}

.mobile-results.mobile-directory-results:not(.hidden) {
    padding: env(safe-area-inset-top) 0.5rem 100px !important;
}

.mobile-results.mobile-directory-results:not(.hidden) .results-list.directory-mode {
    gap: 1rem !important;
    padding-top: 0 !important;
}

.mobile-directory-results-summary {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    min-height: 28px;
    padding: 0 2px 2px;
    color: var(--text-muted);
    -webkit-text-fill-color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 760;
    line-height: 1.25;
}

.mobile-directory-results-summary strong {
    color: var(--text-white);
    -webkit-text-fill-color: var(--text-white);
    font-weight: 900;
}

.mobile-directory-results-summary span {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    min-width: 0;
    text-align: right;
}

.mobile-directory-results-summary i {
    color: var(--mobile-primary);
    -webkit-text-fill-color: var(--mobile-primary);
    font-size: 0.68rem;
}

body.light-mode .mobile-directory-results-summary strong {
    color: var(--text-dark);
    -webkit-text-fill-color: var(--text-dark);
}

@media (max-width: 340px) {
    .mobile-directory-results-summary {
        align-items: flex-start;
        flex-direction: column;
        gap: 4px;
    }

    .mobile-directory-results-summary span {
        justify-content: flex-start;
        text-align: left;
    }
}

.mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .card-image {
    aspect-ratio: 1.75 / 1 !important;
}

.mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .card-info {
    padding: 0.9rem 0.9rem 0.95rem !important;
}

.mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .card-header-row {
    margin-bottom: 10px !important;
    padding-bottom: 10px !important;
}

.mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .contact-stack {
    gap: 8px !important;
}

.mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .contact-link {
    gap: 12px !important;
    padding: 8px 10px !important;
    border-radius: 15px !important;
}

.mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .contact-link i {
    width: 40px !important;
    height: 40px !important;
    border-radius: 11px !important;
    font-size: 1.02rem !important;
}

@media (max-width: 390px) {
    .mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .card-info {
        padding: 0.8rem 0.8rem 0.85rem !important;
    }

    .mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .contact-link {
        gap: 10px !important;
        padding: 7px 9px !important;
    }

    .mobile-results.mobile-directory-results .results-list.directory-mode .listing-card:not(.event-card):not(.cinema-card) .contact-link i {
        width: 38px !important;
        height: 38px !important;
    }
}

.mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .card-info {
    padding: 0.9rem 0.9rem 0.95rem !important;
}

.mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .card-header-row {
    margin-bottom: 10px !important;
    padding-bottom: 10px !important;
}

.mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .contact-stack {
    gap: 8px !important;
}

.mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .contact-link.event-highlight {
    gap: 12px !important;
    padding: 8px 10px !important;
    border-radius: 15px !important;
}

.mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .contact-link.event-highlight i {
    width: 40px !important;
    height: 40px !important;
    border-radius: 11px !important;
    font-size: 1.02rem !important;
}

@media (max-width: 390px) {
    .mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .card-info {
        padding: 0.8rem 0.8rem 0.85rem !important;
    }

    .mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .contact-link.event-highlight {
        gap: 10px !important;
        padding: 7px 9px !important;
    }

    .mobile-results.mobile-event-results .results-list.event-mode .listing-card.event-card .contact-link.event-highlight i {
        width: 38px !important;
        height: 38px !important;
    }
}

/* Temple Community (Hindu Priests + Temple Events) native mobile views. */
.mobile-results.mobile-temple-community-results:not(.hidden) {
    padding: env(safe-area-inset-top) 0.5rem 100px !important;
}

.mobile-results.mobile-temple-community-results.mobile-event-results:not(.hidden) {
    padding-top: calc(68px + env(safe-area-inset-top)) !important;
}

.mobile-results.mobile-temple-community-results .results-list {
    gap: 1rem !important;
}

.mobile-temple-community-card .card-header-row {
    align-items: flex-start !important;
    flex-direction: column !important;
    gap: 4px !important;
}

.mobile-temple-community-card .card-header-row h3 {
    margin: 0 !important;
}

.mobile-temple-community-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 12px;
}

.mobile-temple-community-chip {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(255, 94, 0, 0.10);
    border: 1px solid rgba(255, 94, 0, 0.28);
    color: #ff7a1a;
    font-size: 0.74rem;
    font-weight: 850;
    line-height: 1.15;
}

body.light-mode .mobile-temple-community-chip {
    background: rgba(255, 94, 0, 0.08);
    color: var(--mobile-primary);
    -webkit-text-fill-color: var(--mobile-primary);
}

.mobile-results.mobile-temple-community-detail-results:not(.hidden) {
    padding: 0 0 calc(112px + env(safe-area-inset-bottom)) !important;
}

.mobile-results.mobile-temple-community-detail-results .results-list {
    gap: 0 !important;
    width: min(100%, 520px) !important;
    margin: 0 auto !important;
}

.mobile-temple-community-detail-card {
    --mobile-l3-bg: var(--cd-app-bg, #f8f7f4);
    --mobile-l3-text: var(--cd-text-main, #1d1d1f);
    --mobile-l3-muted: var(--cd-text-muted, rgba(29, 29, 31, 0.66));
    --mobile-l3-card: var(--cd-card-bg, rgba(255, 255, 255, 0.92));
    --mobile-l3-border: var(--cd-border, rgba(29, 29, 31, 0.10));
    --mobile-l3-accent: var(--mobile-primary, #ff5e00);
    width: 100% !important;
    margin: 0 !important;
    padding: 0 14px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    overflow: visible !important;
    box-sizing: border-box !important;
}

.mobile-temple-community-detail-card .mobile-temple-community-detail-hero {
    position: relative !important;
    height: auto !important;
    aspect-ratio: 1.45 / 1 !important;
    margin: 0 -14px 18px !important;
    border-radius: 0 !important;
    overflow: hidden !important;
    background: color-mix(in srgb, var(--mobile-l3-accent) 10%, transparent) !important;
}

.mobile-temple-community-detail-card .mobile-temple-community-detail-hero img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

.mobile-temple-community-detail-card .mobile-l3-image-badge {
    position: absolute !important;
    left: 18px !important;
    bottom: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    min-height: 38px !important;
    max-width: calc(100% - 36px) !important;
    padding: 0 16px !important;
    border-radius: 999px !important;
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffb000, #ff5e00)) !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 0.78rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.1em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
}

.mobile-temple-community-detail-card .details-body,
.mobile-temple-community-detail-card .details-body-content {
    margin-top: 0 !important;
    padding: 0 0 12px !important;
    background: transparent !important;
    color: var(--mobile-l3-text) !important;
}

.mobile-temple-community-detail-card .mobile-l3-title-block {
    padding: 0 4px 18px !important;
}

.mobile-temple-community-detail-card .mobile-l3-eyebrow {
    margin: 0 0 8px !important;
    color: var(--mobile-l3-accent) !important;
    -webkit-text-fill-color: var(--mobile-l3-accent) !important;
    font-size: 0.78rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.12em !important;
    line-height: 1.1 !important;
    text-transform: uppercase !important;
}

.mobile-temple-community-detail-card .mobile-l3-title {
    display: block !important;
    margin: 0 !important;
    color: var(--mobile-l3-text) !important;
    -webkit-text-fill-color: var(--mobile-l3-text) !important;
    font-size: clamp(1.75rem, 8vw, 2.45rem) !important;
    line-height: 1.04 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
    overflow: visible !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance !important;
}

.mobile-temple-community-detail-card .mobile-l3-subtitle {
    display: block !important;
    margin: 10px 0 0 !important;
    max-width: 100% !important;
    color: var(--mobile-l3-muted) !important;
    -webkit-text-fill-color: var(--mobile-l3-muted) !important;
    font-size: 0.98rem !important;
    line-height: 1.42 !important;
    font-weight: 650 !important;
    overflow-wrap: anywhere !important;
}

.mobile-temple-community-detail-card .mobile-l3-action-row {
    display: flex !important;
    gap: 10px !important;
    overflow-x: auto !important;
    padding: 2px 0 16px !important;
    scrollbar-width: none !important;
}

.mobile-temple-community-detail-card .mobile-l3-action-row::-webkit-scrollbar {
    display: none !important;
}

.mobile-temple-community-detail-card .mobile-l3-action {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 9px !important;
    flex: 0 0 auto !important;
    min-height: 44px !important;
    min-width: 0 !important;
    padding: 0 16px !important;
    border-radius: 999px !important;
    border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 32%, transparent) !important;
    background: color-mix(in srgb, var(--mobile-l3-accent) 12%, var(--mobile-l3-card)) !important;
    color: var(--mobile-l3-text) !important;
    -webkit-text-fill-color: var(--mobile-l3-text) !important;
    text-decoration: none !important;
    font-size: 0.86rem !important;
    font-weight: 900 !important;
    white-space: nowrap !important;
}

.mobile-temple-community-detail-card .mobile-l3-action.primary {
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffb000, #ff5e00)) !important;
    border-color: transparent !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.mobile-temple-community-detail-card .mobile-l3-action:active {
    transform: scale(0.96) !important;
}

.mobile-temple-community-detail-card .detail-summary-strip {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin: 0 0 18px !important;
}

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

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

.mobile-temple-community-detail-card .detail-summary-item small,
.mobile-temple-community-detail-card .detail-info-row span {
    display: block !important;
    margin: 0 0 4px !important;
    color: var(--mobile-l3-accent) !important;
    -webkit-text-fill-color: var(--mobile-l3-accent) !important;
    font-size: 0.72rem !important;
    font-weight: 950 !important;
    letter-spacing: 0.12em !important;
    line-height: 1 !important;
    text-transform: uppercase !important;
}

.mobile-temple-community-detail-card .detail-summary-item strong {
    display: block !important;
    color: var(--mobile-l3-text) !important;
    -webkit-text-fill-color: var(--mobile-l3-text) !important;
    font-size: 1.08rem !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    overflow-wrap: anywhere !important;
}

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

.mobile-temple-community-detail-card .detail-section-heading h3 {
    margin: 0 0 12px !important;
    color: var(--mobile-l3-text) !important;
    -webkit-text-fill-color: var(--mobile-l3-text) !important;
    font-size: 1.18rem !important;
    line-height: 1.18 !important;
    font-weight: 950 !important;
    letter-spacing: 0 !important;
}

.mobile-temple-community-detail-card .detail-rich-text {
    margin: 0 !important;
    color: var(--mobile-l3-muted) !important;
    -webkit-text-fill-color: var(--mobile-l3-muted) !important;
    font-size: 0.98rem !important;
    line-height: 1.58 !important;
}

.mobile-temple-community-detail-card .detail-chip-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
}

.mobile-temple-community-detail-card .detail-chip {
    display: inline-flex !important;
    align-items: center !important;
    min-height: 30px !important;
    padding: 6px 12px !important;
    border-radius: 999px !important;
    background: color-mix(in srgb, var(--mobile-l3-accent) 8%, #ffffff) !important;
    border: 1px solid color-mix(in srgb, var(--mobile-l3-accent) 22%, transparent) !important;
    color: var(--mobile-l3-text) !important;
    -webkit-text-fill-color: var(--mobile-l3-text) !important;
    font-size: 0.82rem !important;
    font-weight: 900 !important;
}

.mobile-temple-community-detail-card .detail-chip-row.accent .detail-chip {
    background: color-mix(in srgb, var(--mobile-l3-accent) 11%, #ffffff) !important;
    border-color: color-mix(in srgb, var(--mobile-l3-accent) 28%, transparent) !important;
}

.mobile-results .results-list.event-mode .mobile-event-filter-bar {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    width: 100%;
    margin: 0 0 -0.55rem;
    padding: 6px;
    border: 1px solid var(--mobile-border);
    border-radius: 18px;
    background: var(--cd-inner-bg);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.045);
}

.mobile-results.mobile-event-results .results-list.event-mode .mobile-event-results-header {
    width: 100%;
    margin: 0 0 -1rem;
    padding: 1rem 0;
    text-align: center;
}

.mobile-results.mobile-event-results .results-list.event-mode .mobile-event-results-header .mobile-event-logo-text {
    display: inline-flex;
    align-items: baseline;
    justify-content: center;
    gap: 0;
    margin: 0;
    background: none;
    color: var(--text-white);
    font-size: 1.85rem;
    font-weight: 800;
    line-height: 1;
    letter-spacing: 0;
    text-wrap: balance;
    -webkit-background-clip: initial;
    background-clip: initial;
    -webkit-text-fill-color: initial;
}

.mobile-results .results-list.event-mode .mobile-event-filter-btn {
    min-width: 0;
    min-height: 40px;
    padding: 0 8px;
    border: 1px solid color-mix(in srgb, var(--mobile-primary) 16%, var(--mobile-border));
    border-radius: 14px;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.025)),
        color-mix(in srgb, var(--mobile-primary) 5%, transparent);
    color: color-mix(in srgb, var(--text-white) 88%, var(--mobile-primary));
    -webkit-text-fill-color: color-mix(in srgb, var(--text-white) 88%, var(--mobile-primary));
    font: inherit;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
    white-space: nowrap;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.mobile-results .results-list.event-mode .mobile-event-filter-btn.active {
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%));
    border-color: color-mix(in srgb, var(--mobile-primary) 42%, transparent);
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    box-shadow: var(--cd-soft-glow, 0 10px 24px rgba(255, 94, 0, 0.30), 0 0 16px rgba(255, 215, 0, 0.14));
}

.mobile-results .results-list .trust-row.card-meta-bottom .verified-badge,
.trust-row.card-meta-bottom .verified-badge {
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    background-image: none !important;
    box-shadow: none !important;
    color: inherit !important;
    -webkit-text-fill-color: inherit !important;
    font-size: 0.95rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-transform: none !important;
}

.mobile-results .results-list .trust-row.card-meta-bottom .verified-badge i,
.trust-row.card-meta-bottom .verified-badge i {
    color: currentColor !important;
    -webkit-text-fill-color: currentColor !important;
    font-size: 0.95rem !important;
}

.mobile-results .results-list .trust-row.card-meta-bottom .card-rating-row,
.mobile-results .results-list .trust-row.card-meta-bottom .card-distance,
.trust-row.card-meta-bottom .card-rating-row,
.trust-row.card-meta-bottom .card-distance {
    font-size: 0.95rem !important;
    font-weight: 800 !important;
}

:root {
    --cd-cat-trending-1: #f44369;
    --cd-cat-trending-2: #3e3b92;
    --cd-cat-trending-3: #ff8da4;
}

.mobile-results.mobile-trending-results {
    padding-left: 10px !important;
    padding-right: 10px !important;
    padding-top: 16px !important;
}

.mobile-results.mobile-trending-results.mobile-trending-empty-results {
    margin-top: -88px !important;
}

.mobile-results .results-list.trending-mode {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    padding: 0 0 calc(96px + env(safe-area-inset-bottom)) !important;
}

.mobile-results.mobile-trending-results .results-list.trending-mode {
    padding-top: 0 !important;
}

.mobile-trending-shell {
    width: 100%;
}

.mobile-trending-empty-results .mobile-trending-shell > .cd-empty-state {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.mobile-trending-empty-results .mobile-trending-grid > .cd-empty-state {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.mobile-trending-actions button,
.mobile-trending-actions a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    border: 1px solid var(--mobile-border);
    border-radius: 999px;
    background: #ffffff;
    color: #17171c;
    font: inherit;
    font-size: 0.78rem;
    font-weight: 900;
    line-height: 1;
    text-decoration: none;
    cursor: pointer;
}

.mobile-trending-cta-row {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    margin: 0 0 24px;
    text-align: center;
}

.mobile-trending-whatsapp {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    text-decoration: none;
}

.mobile-trending-primary-cta {
    display: block;
    max-width: 100%;
    margin: 0;
    color: color-mix(in srgb, var(--text-white) 84%, var(--cd-cat-trending-1));
    font-size: 0.88rem;
    font-weight: 950;
    line-height: 1.35;
}

.mobile-trending-primary-cta span {
    color: inherit;
}

.mobile-trending-primary-cta-secondary {
    display: inline;
}

.mobile-trending-primary-cta-secondary .fa-whatsapp {
    vertical-align: middle;
    margin-right: 4px;
}

.mobile-trending-whatsapp {
    margin: 0;
    color: var(--cd-cat-trending-1);
    font-size: 1.02rem;
    font-weight: 950;
    line-height: 1.22;
}

.mobile-trending-category-tabs {
    display: flex;
    gap: 8px;
    overflow-x: auto;
    padding: 0 0 8px;
    margin: 0 0 12px;
    scrollbar-width: none;
}

.mobile-trending-category-tabs::-webkit-scrollbar {
    display: none;
}

.mobile-trending-category-tabs button {
    flex: 0 0 auto;
    min-height: 36px;
    padding: 0 12px;
    border: 1px solid var(--mobile-border);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--text-muted);
    font: inherit;
    font-size: 0.76rem;
    font-weight: 900;
    letter-spacing: 0;
}

.mobile-trending-category-tabs button.active,
.mobile-trending-category-tabs button:focus-visible {
    border-color: color-mix(in srgb, var(--cd-cat-trending-1) 56%, #ffffff);
    background: color-mix(in srgb, var(--cd-cat-trending-1) 16%, transparent);
    color: var(--text-white);
    outline: none;
}

.mobile-trending-filter-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin: 0 0 18px;
}

.mobile-trending-filter-grid label {
    display: flex;
    min-width: 0;
    flex-direction: column;
    gap: 8px;
}

.mobile-trending-filter-grid label > span {
    color: var(--text-muted);
    font-size: 0.62rem;
    font-weight: 950;
    letter-spacing: 0.08em;
    line-height: 1;
    text-transform: uppercase;
}

.mobile-trending-filter-grid select {
    width: 100%;
    min-height: 54px;
    min-width: 0;
    padding: 10px 12px;
    border: 1px solid var(--mobile-border);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.06);
    color: var(--text-white);
    font: inherit;
    font-size: 0.82rem;
    font-weight: 850;
    letter-spacing: 0;
}

body.light-mode .mobile-trending-filter-grid select {
    background: rgba(255, 255, 255, 0.74);
    color: #1d1d1f;
}

body.light-mode .mobile-trending-category-tabs button {
    background: rgba(255, 255, 255, 0.78);
    color: #5f6368;
}

body.light-mode .mobile-trending-category-tabs button.active,
body.light-mode .mobile-trending-category-tabs button:focus-visible {
    background: color-mix(in srgb, var(--cd-cat-trending-1) 12%, #ffffff);
    color: #9f183d;
}

body.light-mode .mobile-trending-category-heading h2 {
    color: #1d1d1f;
}

.mobile-trending-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.mobile-trending-category-section {
    display: grid;
    gap: 10px;
}

.mobile-trending-category-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 2px 2px 0;
}

.mobile-trending-category-heading h2 {
    margin: 0;
    color: var(--text-white);
    font-size: 0.98rem;
    font-weight: 950;
    letter-spacing: 0;
}

.mobile-trending-category-heading span {
    min-width: 28px;
    min-height: 26px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 9px;
    border: 1px solid var(--mobile-border);
    border-radius: 999px;
    color: var(--text-muted);
    font-size: 0.72rem;
    font-weight: 950;
}

.mobile-trending-category-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
}

.mobile-trending-card {
    min-width: 0;
    overflow: hidden;
    border: 1px solid var(--mobile-border);
    border-radius: 16px;
    background: var(--mobile-card-bg);
    box-shadow: none;
    cursor: pointer;
    padding: 8px;
}

.mobile-trending-two-col {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
}

.mobile-trending-card-simple {
    min-width: 0;
    overflow: hidden;
    border: 1px solid var(--mobile-border);
    border-radius: 12px;
    background: var(--mobile-card-bg);
    box-shadow: none;
    cursor: pointer;
    padding: 4px;
}

.mobile-trending-card-simple.is-vertical-flyer {
    grid-row: span 1;
}

.mobile-trending-media-simple {
    position: relative;
    aspect-ratio: auto;
    overflow: hidden;
    border-radius: 10px;
    background: #111113;
}

.mobile-trending-media-simple img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    object-position: top center;
    border-radius: 10px;
    background: #111113;
}

.mobile-trending-media-simple .mobile-trending-category-label {
    position: absolute;
    left: 6px;
    right: 6px;
    bottom: 6px;
    width: fit-content;
    max-width: calc(100% - 12px);
    min-height: 20px;
    display: inline-flex;
    align-items: center;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.72);
    color: #ffffff;
    font-size: 0.58rem;
    font-weight: 900;
    line-height: 1;
    z-index: 2;
}

.mobile-trending-media-simple .mobile-trending-status-label,
.mobile-trending-media .mobile-trending-status-label {
    position: absolute;
    left: 6px;
    right: auto;
    top: 6px;
    bottom: auto;
    width: fit-content;
    max-width: calc(100% - 12px);
    min-height: 20px;
    display: inline-flex;
    align-items: center;
    padding: 0 6px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.72);
    color: #ffffff;
    font-size: 0.58rem;
    font-weight: 900;
    line-height: 1;
    z-index: 3;
}

.mobile-trending-whatsapp-inline {
    color: var(--cd-cat-trending-1);
    font-weight: 950;
    white-space: nowrap;
    text-decoration: none;
}

.mobile-trending-load-more {
    min-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    color: var(--text-muted);
    font-size: 0.82rem;
    font-weight: 800;
}

@media (max-width: 360px) {
    .mobile-trending-two-col {
        gap: 8px;
    }
}

@media (min-width: 560px) {
    .mobile-trending-cta-row {
        grid-template-columns: minmax(0, 1.5fr) minmax(190px, 0.75fr);
    }
}

.mobile-trending-main {
    width: 100%;
    display: grid;
    grid-template-columns: minmax(112px, 42%) minmax(0, 1fr);
    align-items: stretch;
    gap: 12px;
    padding: 0;
    border: 0;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
}

.mobile-trending-media {
    position: relative;
    aspect-ratio: auto;
    overflow: visible;
    border-radius: 12px;
    background: #111113;
}

.mobile-trending-media img {
    width: 100%;
    height: auto;
    display: block;
    object-fit: contain;
    object-position: top center;
    border-radius: 12px;
    background: #111113;
}

.mobile-trending-modal-media img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
}

.mobile-trending-placeholder {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    color: var(--cd-cat-trending-1);
    font-size: 1.8rem;
}

.mobile-trending-media > span {
    position: absolute;
    left: 8px;
    right: 8px;
    bottom: 8px;
    width: fit-content;
    max-width: calc(100% - 16px);
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.72);
    color: #ffffff;
    font-size: 0.66rem;
    font-weight: 900;
    line-height: 1;
}

.mobile-trending-category-label {
    z-index: 2;
}

.mobile-trending-modal-body > .mobile-trending-status-label {
    width: fit-content;
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    padding: 0 8px;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.72);
    color: #ffffff;
    font-size: 0.66rem;
    font-weight: 900;
    line-height: 1;
}

.mobile-trending-copy {
    min-width: 0;
    display: grid;
    grid-auto-rows: max-content;
    align-content: start;
    row-gap: 8px;
    padding: 4px 4px 4px 0;
}

.mobile-trending-card.is-vertical-flyer .mobile-trending-copy {
    align-content: space-evenly;
    row-gap: 0;
    padding-top: 8px;
    padding-bottom: 8px;
}

.mobile-trending-copy small,
.mobile-trending-modal-body > span {
    display: block;
    color: var(--cd-cat-trending-1);
    line-height: 1.1;
    text-transform: uppercase;
}

.mobile-trending-copy small {
    font-size: 0.72rem;
    font-weight: 950;
    letter-spacing: 0.075em;
}

.mobile-trending-modal-body > span {
    font-size: 0.66rem;
    font-weight: 900;
    letter-spacing: 0.06em;
}

.mobile-trending-copy h3 {
    margin: 0;
    color: var(--text-white);
    font-size: clamp(1rem, 4vw, 1.14rem);
    font-weight: 950;
    line-height: 1.07;
    letter-spacing: 0;
    overflow-wrap: anywhere;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-trending-copy p {
    margin: 0;
    color: color-mix(in srgb, var(--text-white) 46%, var(--text-muted));
    font-size: 0.82rem;
    font-weight: 720;
    line-height: 1.34;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-trending-meta {
    display: contents;
    margin-top: 0;
    color: color-mix(in srgb, var(--text-white) 54%, var(--text-muted));
    font-size: 0.78rem;
    font-weight: 850;
    line-height: 1.18;
}

.mobile-trending-meta span {
    min-width: 0;
    display: grid;
    grid-template-columns: 16px minmax(0, 1fr);
    align-items: start;
    gap: 6px;
    overflow-wrap: anywhere;
}

.mobile-trending-meta i {
    width: 16px;
    padding-top: 1px;
    color: var(--cd-cat-trending-1);
    font-size: 0.9rem;
    text-align: center;
}

.mobile-trending-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
    padding: 0 10px 10px;
}

.mobile-trending-actions button,
.mobile-trending-actions a {
    width: 100%;
    min-width: 0;
    min-height: 34px;
    padding: 0 8px;
    background: color-mix(in srgb, var(--cd-cat-trending-1) 8%, #ffffff);
    color: var(--text-white);
}

.mobile-trending-actions.modal-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 7px;
    padding: 0;
}

.mobile-trending-actions.modal-actions button,
.mobile-trending-actions.modal-actions a {
    min-height: 38px;
    padding: 0 6px;
    gap: 5px;
    font-size: 0.76rem;
    white-space: nowrap;
    color: #17171c !important;
    -webkit-text-fill-color: #17171c !important;
}

.mobile-trending-actions.modal-actions i,
.mobile-trending-actions.modal-actions span {
    color: #17171c !important;
    -webkit-text-fill-color: #17171c !important;
}

.mobile-trending-modal {
    position: fixed;
    inset: 0;
    z-index: 60000;
    display: none;
}

.mobile-trending-modal.active {
    display: block;
}

.mobile-trending-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.58);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

.mobile-trending-modal-panel {
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: calc(10px + env(safe-area-inset-bottom));
    max-height: min(86vh, 720px);
    overflow: auto;
    border: 1px solid var(--mobile-border);
    border-radius: 22px;
    background: var(--modal-bg);
    color: var(--text-white);
}

.mobile-trending-modal-close {
    position: sticky;
    top: 12px;
    z-index: 3;
    width: 44px;
    height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 12px 12px -56px auto;
    border: 1px solid color-mix(in srgb, var(--mobile-primary) 46%, transparent);
    border-radius: 50%;
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%));
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 1.2rem;
    box-shadow: var(--cd-soft-glow, 0 10px 24px rgba(255, 94, 0, 0.30), 0 0 16px rgba(255, 215, 0, 0.14));
}

.mobile-trending-modal-close i {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
}

.mobile-trending-modal-media {
    aspect-ratio: auto;
    background: #111113;
}

.mobile-trending-modal-media img {
    width: 100%;
    height: auto;
    max-height: none;
    object-fit: contain;
    object-position: top center;
    background: #111113;
}

.mobile-trending-modal-media .mobile-trending-placeholder {
    min-height: 220px;
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-modal-layout {
    display: block;
    max-height: none;
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-modal-media {
    min-height: 0;
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-modal-media img {
    height: auto;
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-modal-body {
    max-height: none;
    overflow: visible;
    padding: 16px;
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-modal-body h2 {
    font-size: clamp(1rem, 4.5vw, 1.35rem);
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-modal-body p {
    font-size: 0.82rem;
}

.mobile-trending-modal-panel.is-vertical-flyer .mobile-trending-facts {
    grid-template-columns: 1fr;
    gap: 7px;
    margin: 12px 0;
}

.mobile-trending-modal-body {
    padding: 16px;
}

.mobile-trending-modal-body h2 {
    margin: 7px 0 0;
    color: var(--text-white);
    font-size: 1.5rem;
    font-weight: 950;
    line-height: 1.06;
    letter-spacing: 0;
}

.mobile-trending-modal-body p {
    margin: 9px 0 0;
    color: var(--text-muted);
    font-size: 0.92rem;
    font-weight: 650;
    line-height: 1.45;
}

.mobile-trending-facts {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin: 14px 0;
}

.mobile-trending-fact {
    min-width: 0;
    padding: 10px;
    border: 1px solid var(--mobile-border);
    border-radius: 12px;
    background: var(--modal-inner-bg);
}

.mobile-trending-fact label {
    display: block;
    margin-bottom: 5px;
    color: var(--cd-cat-trending-1);
    font-size: 0.62rem;
    font-weight: 900;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.mobile-trending-fact span,
.mobile-trending-fact a {
    color: var(--text-white);
    font-size: 0.82rem;
    font-weight: 800;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.mobile-trending-fact a.mobile-trending-phone-link {
    width: 100%;
    min-height: 38px;
    margin: 2px 0 5px;
    padding: 9px 11px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    border: 1px solid color-mix(in srgb, var(--cd-cat-trending-1) 46%, transparent);
    border-radius: 999px;
    background: var(--cd-accent-gradient, linear-gradient(135deg, #ffd700 0%, #ff5e00 100%));
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    text-decoration: none;
    box-shadow: var(--cd-soft-glow, 0 10px 24px rgba(255, 94, 0, 0.22));
    box-sizing: border-box;
}

.mobile-trending-fact a.mobile-trending-phone-link i,
.mobile-trending-fact a.mobile-trending-phone-link span {
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    line-height: 1;
}

@media (max-width: 340px) {
    .mobile-trending-grid,
    .mobile-trending-facts {
        grid-template-columns: 1fr;
    }
}

.mobile-home-hero-card,
.home-feed-cards .feed-card {
    box-shadow: none !important;
}

.home-feed-cards .feed-card {
    height: 194px !important;
    min-height: 194px !important;
    aspect-ratio: auto !important;
    border-radius: 17px !important;
    background: #071a3b !important;
    overflow: hidden !important;
    isolation: isolate !important;
}

.mobile-home-hero-image,
.home-feed-cards .feed-card-image {
    opacity: 1 !important;
}

.home-feed-cards .feed-card::after {
    background: transparent !important;
    background-image: none !important;
}

.mobile-home-hero-shade,
.home-feed-cards .feed-card-overlay {
    background:
        linear-gradient(90deg, rgba(5, 18, 43, 0.52) 0%, rgba(5, 18, 43, 0.28) 34%, rgba(5, 18, 43, 0) 62%) !important;
}

.mobile-home-hero-copy,
.home-feed-cards .feed-card-content {
    position: absolute !important;
    inset: 0 !important;
    width: 100% !important;
    padding: 28px 19px 20px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    box-sizing: border-box !important;
}

.home-feed-cards .card-top-info {
    display: contents !important;
}

.mobile-home-hero-copy h2,
.home-feed-cards .feed-card-hero-title {
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    color: #ffffff !important;
    -webkit-text-fill-color: #ffffff !important;
    font-size: 1.24rem !important;
    font-weight: 860 !important;
    line-height: 1.22 !important;
    letter-spacing: 0 !important;
    text-align: left !important;
    text-transform: none !important;
    max-width: 56% !important;
}

.mobile-home-hero-copy p,
.home-feed-cards .card-tagline {
    width: fit-content !important;
    max-width: min(60%, 272px) !important;
    margin: auto 0 0 !important;
    padding: 6px 9px !important;
    border: 1px solid rgba(255, 255, 255, 0.13) !important;
    border-radius: 10px !important;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.14) 0%, rgba(255, 255, 255, 0.055) 48%, rgba(4, 18, 42, 0.28) 100%),
        rgba(5, 18, 43, 0.28) !important;
    backdrop-filter: blur(10px) saturate(128%) !important;
    -webkit-backdrop-filter: blur(10px) saturate(128%) !important;
    box-shadow: none !important;
    color: rgba(255, 255, 255, 0.92) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, 0.92) !important;
    font-size: 0.72rem !important;
    font-weight: 660 !important;
    line-height: 1.42 !important;
    text-align: left !important;
}

.home-feed-cards .card-tagline {
    transform: translateY(-6px) !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-content {
    padding: 22px 12px 16px !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-hero-title {
    max-width: 86% !important;
    font-size: 1rem !important;
    line-height: 1.18 !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .card-tagline {
    max-width: 88% !important;
    padding: 5px 7px !important;
    font-size: 0.62rem !important;
}

.mobile-home-hero-copy p {
    transform: translateY(4px) !important;
    max-width: calc(100vw - 58px) !important;
    white-space: nowrap !important;
    font-size: 0.68rem !important;
}

.mobile-home-hero-dots {
    margin-bottom: 16px !important;
}

@media (max-width: 360px) {
    .mobile-home-hero-copy,
    .home-feed-cards .feed-card-content {
        padding: 24px 16px 18px !important;
    }

    .mobile-home-hero-copy h2,
    .home-feed-cards .feed-card-hero-title {
        font-size: 1.12rem !important;
        max-width: 62% !important;
    }

    .mobile-home-hero-copy p,
    .home-feed-cards .card-tagline {
        max-width: 70% !important;
    }

    .mobile-home-hero-copy p {
        max-width: calc(100vw - 50px) !important;
        font-size: 0.62rem !important;
    }

    .home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-content {
        padding: 20px 11px 15px !important;
    }

    .home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-hero-title {
        max-width: 88% !important;
        font-size: 0.94rem !important;
    }

    .home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .card-tagline {
        max-width: 90% !important;
        font-size: 0.58rem !important;
    }
}

.mobile-home-category-panel {
    margin: 0 0.5rem 14px;
    padding: 6px 5px 9px;
    border: 1px solid rgba(20, 25, 34, 0.06);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.94);
}

.mobile-home-category-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    column-gap: 3px;
    row-gap: 9px;
}

.mobile-home-category-card,
.mobile-home-category-card:visited,
.mobile-home-category-card:hover,
.mobile-home-category-card:focus-visible {
    min-width: 0;
    display: grid;
    justify-items: center;
    gap: 3px;
    color: #171b24;
    text-align: center;
    text-decoration: none;
    -webkit-tap-highlight-color: transparent;
}

.mobile-home-category-icon {
    width: 58px;
    height: 58px;
    border-radius: 13px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--mobile-home-icon-fg, #0a3f86);
    background: var(--mobile-home-icon-bg, #eaf2ff);
    overflow: hidden;
    transition: transform 160ms ease;
}

.mobile-home-category-icon.has-image img {
    width: 100%;
    height: 100%;
    border-radius: inherit;
    display: block;
    object-fit: cover;
}

.mobile-home-category-icon i {
    font-size: 1.82rem;
}

.mobile-home-category-card:active .mobile-home-category-icon {
    transform: scale(0.96);
}

.mobile-home-category-card:focus-visible {
    border-radius: 13px;
    outline: 3px solid rgba(255, 94, 0, 0.28);
    outline-offset: 3px;
}

.mobile-home-category-card > span:last-child {
    max-width: 100%;
    min-height: 24px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    color: #151922;
    font-size: 0.6rem;
    font-weight: 760;
    line-height: 1.15;
    letter-spacing: 0;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
}

.mobile-home-category-card[data-home-category="organization"] > span:last-child,
.mobile-home-category-card[data-home-category="classifieds"] > span:last-child,
.mobile-home-category-card[data-home-category="restaurant"] > span:last-child {
    font-size: 0.56rem;
}

body.dark-mode .mobile-home-category-panel {
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(28, 28, 30, 0.94);
}

body.dark-mode .mobile-home-category-card,
body.dark-mode .mobile-home-category-card:visited,
body.dark-mode .mobile-home-category-card:hover,
body.dark-mode .mobile-home-category-card:focus-visible,
body.dark-mode .mobile-home-category-card > span:last-child {
    color: #f5f5f7;
    -webkit-text-fill-color: #f5f5f7;
}

@media (max-width: 340px) {
    .mobile-home-category-grid {
        column-gap: 2px;
    }

    .mobile-home-category-icon {
        width: 54px;
        height: 54px;
    }

    .mobile-home-category-icon i {
        font-size: 1.68rem;
    }

    .mobile-home-category-card > span:last-child {
        font-size: 0.55rem;
    }

    .mobile-home-category-card[data-home-category="organization"] > span:last-child,
    .mobile-home-category-card[data-home-category="classifieds"] > span:last-child,
    .mobile-home-category-card[data-home-category="restaurant"] > span:last-child {
        font-size: 0.52rem;
    }

}

.home-feed-section {
    --home-bg: #faf8f4;
    --home-surface: #ffffff;
    --home-navy: #123A6F;
    --home-coral: #F65373;
    --home-orange: #FF7A32;
    --home-text: #1C1E21;
    --home-muted: #6E737A;
    --home-border: #ECEEF2;
    --home-price: #C23E02;
    --home-soft-shadow: 0 12px 30px rgba(18, 58, 111, 0.07), 0 2px 8px rgba(28, 30, 33, 0.04);
    --home-card-shadow: 0 14px 34px rgba(18, 58, 111, 0.09), 0 1px 0 rgba(255, 255, 255, 0.82) inset;
    --home-card-radius: 22px;
    min-height: 100svh;
    padding: calc(10px + env(safe-area-inset-top)) 0 calc(112px + env(safe-area-inset-bottom));
    background:
        radial-gradient(circle at 50% -80px, rgba(255, 122, 50, 0.1), transparent 280px),
        linear-gradient(180deg, #fffaf5 0%, var(--home-bg) 42%, #f7f7f5 100%);
    color: var(--home-text);
    -webkit-font-smoothing: antialiased;
}

.home-feed-section .header-container.brand-header {
    padding: 7px 18px 5px;
    margin-bottom: 13px;
}

.home-feed-section .brand-group h1 {
    font-size: clamp(1.72rem, 8vw, 2rem);
    font-weight: 880;
    line-height: 1;
    letter-spacing: 0;
}

.home-feed-section .brand-tagline.single-line-tagline {
    margin-top: 4px;
    color: var(--home-muted);
    -webkit-text-fill-color: var(--home-muted);
    font-size: clamp(0.64rem, 2.85vw, 0.72rem);
    font-weight: 680;
    letter-spacing: 0;
}

.mobile-home-hero {
    gap: 10px;
    padding: 0 16px 18px;
}

.mobile-home-hero-card,
.home-feed-cards .feed-card {
    border: 1px solid rgba(255, 255, 255, 0.58);
    border-radius: 24px !important;
    background: #071a3b !important;
    box-shadow: 0 20px 42px rgba(18, 58, 111, 0.15), 0 2px 8px rgba(28, 30, 33, 0.05) !important;
    transition: transform 170ms ease, box-shadow 170ms ease;
}

.mobile-home-hero-card {
    min-height: 212px;
}

.mobile-home-hero-card:active,
.home-feed-cards .feed-card:active {
    transform: scale(0.96) !important;
}

.mobile-home-hero-shade,
.home-feed-cards .feed-card-overlay {
    background:
        linear-gradient(180deg, rgba(6, 14, 30, 0.04) 0%, rgba(6, 14, 30, 0.28) 45%, rgba(6, 14, 30, 0.78) 100%),
        linear-gradient(90deg, rgba(7, 25, 55, 0.82) 0%, rgba(7, 25, 55, 0.46) 44%, rgba(7, 25, 55, 0.02) 78%) !important;
}

.mobile-home-hero-image,
.home-feed-cards .feed-card-image {
    opacity: 0.96 !important;
    filter: saturate(0.98) contrast(1.02);
}

.mobile-home-hero-copy,
.home-feed-cards .feed-card-content {
    padding: 25px 20px 18px !important;
}

.mobile-home-hero-copy h2,
.home-feed-cards .feed-card-hero-title {
    max-width: 74% !important;
    font-size: clamp(1.22rem, 6.1vw, 1.52rem) !important;
    font-weight: 840 !important;
    line-height: 1.14 !important;
    letter-spacing: 0 !important;
    text-wrap: balance;
    text-shadow: 0 2px 16px rgba(0, 0, 0, 0.22);
}

.mobile-home-hero-copy p,
.home-feed-cards .card-tagline {
    width: fit-content !important;
    max-width: calc(100% - 4px) !important;
    margin: auto 0 0 !important;
    padding: 7px 10px !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.14) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18) !important;
    backdrop-filter: blur(14px) saturate(130%) !important;
    -webkit-backdrop-filter: blur(14px) saturate(130%) !important;
    color: rgba(255, 255, 255, 0.94) !important;
    -webkit-text-fill-color: rgba(255, 255, 255, 0.94) !important;
    font-size: 0.7rem !important;
    font-weight: 720 !important;
    line-height: 1.2 !important;
    white-space: normal !important;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.18);
    transform: none !important;
}

.mobile-home-hero-dots {
    margin-bottom: 2px !important;
    gap: 7px;
}

.mobile-home-hero-dot {
    width: 6px;
    height: 6px;
    background: #d9dde5;
    transition: width 160ms ease, background-color 160ms ease, opacity 160ms ease;
}

.mobile-home-hero-dot.is-active {
    width: 20px;
    border-radius: 999px;
    background: linear-gradient(135deg, var(--home-orange), var(--home-coral));
}

.mobile-home-category-panel {
    margin: 0 16px 24px;
    padding: 14px 10px 15px;
    border: 1px solid var(--home-border);
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: var(--home-soft-shadow);
}

.mobile-home-category-grid {
    column-gap: 6px;
    row-gap: 11px;
}

.mobile-home-category-card,
.mobile-home-category-card:visited,
.mobile-home-category-card:hover,
.mobile-home-category-card:focus-visible {
    min-height: 73px;
    gap: 5px;
    color: var(--home-text);
    -webkit-text-fill-color: var(--home-text);
}

.mobile-home-category-icon {
    width: 50px;
    height: 50px;
    border: 1px solid rgba(18, 58, 111, 0.08);
    border-radius: 17px;
    background: color-mix(in srgb, var(--mobile-home-icon-bg, #eef4ff) 34%, #ffffff 66%);
    box-shadow: 0 8px 18px rgba(18, 58, 111, 0.06);
    color: color-mix(in srgb, var(--mobile-home-icon-fg, var(--home-navy)) 82%, var(--home-navy));
    transition: transform 160ms ease, box-shadow 160ms ease;
}

.mobile-home-category-icon.has-image img {
    width: 39px;
    height: 39px;
    border-radius: 12px;
    object-fit: contain;
    filter: saturate(0.82) contrast(0.98) brightness(1.02);
}

.mobile-home-category-icon i {
    font-size: 1.42rem;
}

.mobile-home-category-card:active .mobile-home-category-icon {
    transform: scale(0.96);
    box-shadow: 0 4px 10px rgba(18, 58, 111, 0.07);
}

.mobile-home-category-card > span:last-child,
.mobile-home-category-card[data-home-category="organization"] > span:last-child,
.mobile-home-category-card[data-home-category="classifieds"] > span:last-child,
.mobile-home-category-card[data-home-category="restaurant"] > span:last-child {
    min-height: 21px;
    color: var(--home-text);
    -webkit-text-fill-color: var(--home-text);
    font-size: clamp(0.54rem, 2.55vw, 0.61rem);
    font-weight: 720;
    line-height: 1.13;
}

.mobile-home-event-section {
    margin: 0 0 24px;
}

.mobile-home-section-heading {
    min-height: 40px;
    margin: 0 18px 10px;
}

.mobile-home-section-heading h2 {
    color: var(--home-text);
    -webkit-text-fill-color: var(--home-text);
    font-size: 1.08rem;
    font-weight: 840;
    line-height: 1.12;
    text-wrap: balance;
}

.mobile-home-section-heading a {
    min-height: 36px;
    padding: 0 2px 0 10px;
    color: var(--home-coral);
    -webkit-text-fill-color: var(--home-coral);
    font-size: 0.74rem;
    font-weight: 760;
}

.mobile-home-section-heading a i {
    font-size: 0.64rem;
}

.mobile-home-event-rail,
.mobile-home-classified-rail,
.mobile-home-news-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-movie-rail,
.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    width: 100%;
    margin-left: 0;
    gap: 12px;
    padding: 0 18px 5px;
    scroll-padding-inline: 18px;
}

.mobile-home-event-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-news-rail,
.mobile-home-classified-rail {
    grid-auto-columns: calc((100% - 30px) / 1.2);
}

.mobile-home-movie-rail {
    grid-auto-columns: minmax(166px, 46vw);
}

.mobile-home-event-card,
.mobile-home-classified-card,
.mobile-home-news-card,
.mobile-home-featured-business-card,
.mobile-home-movie-card,
.mobile-home-event-skeleton,
.mobile-home-classified-skeleton,
.mobile-home-news-skeleton,
.mobile-home-featured-business-skeleton,
.mobile-home-movie-skeleton {
    border: 1px solid var(--home-border);
    border-radius: var(--home-card-radius);
    background: var(--home-surface);
    box-shadow: var(--home-card-shadow);
    color: var(--home-text);
    transition: transform 170ms ease, box-shadow 170ms ease, border-color 170ms ease;
}

.mobile-home-event-card:active,
.mobile-home-classified-card:active,
.mobile-home-news-card:active,
.mobile-home-featured-business-card:active,
.mobile-home-movie-card:active {
    transform: scale(0.96);
}

.mobile-home-event-card,
.mobile-home-featured-business-card,
.mobile-home-featured-business-skeleton {
    min-height: 290px;
}

.mobile-home-event-media,
.mobile-home-featured-business-media,
.mobile-home-news-media {
    background:
        linear-gradient(135deg, rgba(255, 122, 50, 0.11), rgba(18, 58, 111, 0.07)),
        #f6f7f9;
}

.mobile-home-event-media,
.mobile-home-featured-business-media {
    height: 165px;
}

.mobile-home-event-media img,
.mobile-home-news-media img,
.mobile-home-featured-business-media img,
.mobile-home-movie-poster img {
    outline: 1px solid rgba(0, 0, 0, 0.08);
    filter: saturate(0.96) contrast(1.01);
}

.mobile-home-event-date {
    top: 14px;
    right: 14px;
    width: 44px;
    min-height: 50px;
    border: 1px solid rgba(18, 58, 111, 0.06);
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.96);
    color: var(--home-navy);
    box-shadow: 0 8px 20px rgba(18, 58, 111, 0.12);
}

.mobile-home-event-date small {
    color: var(--home-coral);
    -webkit-text-fill-color: var(--home-coral);
    font-size: 0.68rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    line-height: 1.2;
}

.mobile-home-event-date strong {
    font-size: 1.15rem;
    font-weight: 800;
    line-height: 1.1;
    margin-top: 1px;
}

.mobile-home-event-body {
    display: grid;
    align-content: start;
    gap: 8px;
    padding: 16px 18px 18px;
}

.mobile-home-event-body h3,
.mobile-home-classified-card h3,
.mobile-home-news-card h3,
.mobile-home-featured-business-card h3 {
    color: var(--home-text);
    -webkit-text-fill-color: var(--home-text);
    font-weight: 790;
    letter-spacing: 0;
}

.mobile-home-event-body h3 {
    min-height: auto;
    margin-bottom: 6px;
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
}

.mobile-home-event-meta,
.mobile-home-classified-meta,
.mobile-home-business-meta,
.mobile-home-news-card p {
    color: var(--home-muted);
    -webkit-text-fill-color: var(--home-muted);
}

.mobile-home-event-meta {
    gap: 8px;
    font-size: 0.84rem;
    font-weight: 620;
}

.mobile-home-event-meta i {
    width: 12px;
    color: #9ba2ad;
    -webkit-text-fill-color: #9ba2ad;
}

.mobile-home-classified-card {
    position: relative;
    min-height: 168px;
    padding: 11px;
    gap: 10px;
    background:
        linear-gradient(180deg, rgba(246, 83, 115, 0.07) 0%, rgba(255, 255, 255, 0) 38%),
        var(--home-surface);
}

.mobile-home-classified-card::after,
.mobile-home-news-card.no-image::after,
.mobile-home-featured-business-card.no-image .mobile-home-featured-business-media::after {
    content: "";
    position: absolute;
    inset: auto 12px 12px auto;
    width: 42px;
    height: 42px;
    border-radius: 16px;
    background: linear-gradient(135deg, rgba(246, 83, 115, 0.13), rgba(255, 122, 50, 0.12));
    pointer-events: none;
}

.mobile-home-classified-tag,
.mobile-home-business-tag,
.mobile-home-movie-language {
    border: 1px solid rgba(246, 83, 115, 0.14);
    border-radius: 999px;
    background: rgba(246, 83, 115, 0.1);
    box-shadow: none;
    color: var(--home-coral);
    -webkit-text-fill-color: var(--home-coral);
    font-size: 0.54rem;
    font-weight: 760;
    letter-spacing: 0;
    text-transform: none;
    padding: 5px 8px;
}

.mobile-home-classified-card h3 {
    position: relative;
    z-index: 1;
    font-size: 0.76rem;
    line-height: 1.22;
}

.mobile-home-classified-meta {
    position: relative;
    z-index: 1;
    gap: 5px;
    font-size: 0.6rem;
    font-weight: 640;
}

.mobile-home-business-meta {
    position: relative;
    z-index: 1;
    gap: 6px;
    font-size: 0.84rem;
    font-weight: 620;
}

.mobile-home-featured-business-media {
    height: 165px;
}

.mobile-home-featured-business-card.no-image .mobile-home-featured-business-media {
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 18% 18%, rgba(255, 122, 50, 0.18), transparent 52px),
        linear-gradient(135deg, rgba(18, 58, 111, 0.08), rgba(246, 83, 115, 0.08));
}

.mobile-home-business-fallback-icon {
    width: 64px;
    height: 64px;
    border: 1px solid rgba(18, 58, 111, 0.08);
    border-radius: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.72);
    color: var(--home-navy);
    -webkit-text-fill-color: var(--home-navy);
    box-shadow: 0 10px 24px rgba(18, 58, 111, 0.08);
}

.mobile-home-business-fallback-icon i {
    font-size: 1.6rem;
}

.mobile-home-featured-business-body {
    display: grid;
    align-content: start;
    gap: 8px;
    padding: 16px 18px 18px;
}

.mobile-home-featured-business-card h3 {
    min-height: auto;
    margin: 0 0 6px 0;
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
}

.mobile-home-business-tag {
    top: 14px;
    left: 14px;
    padding: 6px 12px;
    font-size: 0.68rem;
    font-weight: 760;
}

.mobile-home-news-column {
    scroll-snap-align: start;
    display: grid;
    grid-template-rows: auto auto;
    gap: 8px;
}

.mobile-home-news-card {
    min-height: 135px;
    height: 135px;
    display: grid;
    border-radius: 12px;
}

.mobile-home-news-card.has-image {
    grid-template-columns: 100px 1fr;
    grid-template-rows: 1fr;
}

.mobile-home-news-card.no-image {
    position: relative;
    min-height: 135px;
    height: 135px;
    padding: 0;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
    background:
        linear-gradient(135deg, rgba(18, 58, 111, 0.06), rgba(246, 83, 115, 0.07)),
        var(--home-surface);
}

.mobile-home-news-media {
    width: 100px;
    height: 100%;
}

.mobile-home-news-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mobile-home-news-body {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 4px;
    padding: 12px 14px;
    box-sizing: border-box;
    overflow: hidden;
    min-height: 0;
}

.mobile-home-news-card.no-image .mobile-home-news-body {
    position: relative;
    z-index: 1;
    padding: 12px 14px;
}

.mobile-home-news-date {
    color: var(--home-coral);
    -webkit-text-fill-color: var(--home-coral);
    font-size: 0.56rem;
    font-weight: 760;
    letter-spacing: 0;
    text-transform: none;
}

.mobile-home-news-card h3 {
    margin: 0;
    font-size: 0.88rem;
    line-height: 1.25;
    font-weight: 780;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-home-news-card p {
    margin: 0;
    font-size: 0.74rem;
    line-height: 1.2;
    color: var(--text-muted);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-home-news-read {
    display: none;
}

.mobile-home-movie-card {
    aspect-ratio: 2 / 3;
    min-height: 166px;
    background: #ffffff;
}

.mobile-home-movie-poster {
    border-radius: inherit;
}

.mobile-home-movie-language {
    top: 8px;
    left: 8px;
    max-width: calc(100% - 16px);
    background: rgba(18, 58, 111, 0.82);
    border-color: rgba(255, 255, 255, 0.18);
    color: #ffffff;
    -webkit-text-fill-color: #ffffff;
    font-size: 0.5rem;
}

.home-feed-cards {
    gap: 14px;
    padding: 0 16px;
    margin-bottom: 0;
}

.home-feed-cards .feed-card {
    height: 188px !important;
    min-height: 188px !important;
}

.home-feed-cards .feed-card[data-home-feed-category="owners"] {
    height: 178px !important;
    min-height: 178px !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-content {
    padding: 20px 13px 14px !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-hero-title {
    max-width: 92% !important;
    font-size: 1.02rem !important;
    line-height: 1.16 !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .card-tagline {
    max-width: 94% !important;
    padding: 6px 8px !important;
    font-size: 0.58rem !important;
}

body.dark-mode .home-feed-section {
    --home-bg: #0d0f13;
    --home-surface: #181b21;
    --home-text: rgba(255, 255, 255, 0.94);
    --home-muted: rgba(255, 255, 255, 0.66);
    --home-border: rgba(255, 255, 255, 0.11);
    --home-price: #FF7A32;
    background:
        radial-gradient(circle at 50% -80px, rgba(246, 83, 115, 0.12), transparent 280px),
        linear-gradient(180deg, #11141a 0%, #0d0f13 100%);
}

body.dark-mode .mobile-home-category-panel,
body.dark-mode .mobile-home-event-card,
body.dark-mode .mobile-home-classified-card,
body.dark-mode .mobile-home-news-card,
body.dark-mode .mobile-home-featured-business-card,
body.dark-mode .mobile-home-movie-card,
body.dark-mode .mobile-home-flyer-card,
body.dark-mode .mobile-home-deals-card,
body.dark-mode .mobile-home-exclusive-deals-card,
body.dark-mode .mobile-home-business-promos-card {
    background: var(--home-surface);
    border-color: var(--home-border);
}

@media (max-width: 360px) {
    .mobile-home-hero {
        padding-inline: 12px;
    }

    .mobile-home-hero-copy,
    .home-feed-cards .feed-card-content {
        padding: 22px 16px 16px !important;
    }

    .mobile-home-hero-copy h2,
    .home-feed-cards .feed-card-hero-title {
        max-width: 78% !important;
        font-size: 1.12rem !important;
    }

    .mobile-home-category-panel {
        margin-inline: 12px;
        padding-inline: 8px;
    }

    .mobile-home-category-icon {
        border-radius: 12px;
    }

    .mobile-home-event-rail,
    .mobile-home-classified-rail,
    .mobile-home-news-rail,
    .mobile-home-featured-business-rail,
    .mobile-home-featured-restaurant-rail,
    .mobile-home-movie-rail {
        padding-inline: 14px;
        scroll-padding-inline: 14px;
    }

    .mobile-home-event-rail,
    .mobile-home-featured-business-rail,
    .mobile-home-featured-restaurant-rail,
    .mobile-home-news-rail,
    .mobile-home-classified-rail {
        grid-auto-columns: calc((100% - 26px) / 1.2);
    }

    .mobile-home-movie-rail {
        grid-auto-columns: minmax(158px, 46vw);
    }

    .home-feed-cards {
        padding-inline: 12px;
    }
}

.home-feed-section {
    --home-bg: #F8F6F1;
    --home-surface: #FFFFFF;
    --home-border: #E9ECF2;
    --home-price: #C23E02;
    --home-soft-shadow: 0 8px 22px rgba(18, 38, 63, 0.06), 0 1px 2px rgba(18, 38, 63, 0.04);
    --home-card-shadow: 0 10px 24px rgba(18, 38, 63, 0.075), 0 1px 2px rgba(18, 38, 63, 0.035);
    --home-card-radius: 20px;
    padding-top: calc(6px + env(safe-area-inset-top));
    padding-bottom: calc(100px + env(safe-area-inset-bottom));
    background:
        linear-gradient(180deg, #fbfaf7 0%, var(--home-bg) 52%, #f6f4ef 100%);
}

.home-feed-section .header-container.brand-header {
    padding: 10px 18px 3px;
    margin-bottom: 14px;
}

.home-feed-section .brand-group h1 {
    font-size: clamp(1.6rem, 7.2vw, 1.9rem);
    font-weight: 860;
}

.home-feed-section .brand-tagline.single-line-tagline {
    margin-top: 6px;
    font-size: clamp(0.58rem, 2.55vw, 0.66rem);
    font-weight: 640;
    color: #747A83;
    -webkit-text-fill-color: #747A83;
}

.mobile-home-hero {
    gap: 8px;
    padding: 0 16px 16px;
}

.mobile-home-hero-card,
.home-feed-cards .feed-card {
    border-color: rgba(233, 236, 242, 0.74) !important;
    border-radius: 20px !important;
    box-shadow: 0 12px 28px rgba(18, 38, 63, 0.12), 0 1px 2px rgba(18, 38, 63, 0.04) !important;
}

.mobile-home-hero-card {
    min-height: 202px;
}

.mobile-home-hero-image,
.home-feed-cards .feed-card-image {
    opacity: 1 !important;
    filter: saturate(0.88) contrast(1.04) brightness(0.92);
}

.mobile-home-hero-shade,
.home-feed-cards .feed-card-overlay {
    background:
        linear-gradient(180deg, rgba(4, 13, 27, 0.14) 0%, rgba(4, 13, 27, 0.42) 52%, rgba(4, 13, 27, 0.82) 100%),
        linear-gradient(90deg, rgba(5, 19, 44, 0.84) 0%, rgba(5, 19, 44, 0.54) 44%, rgba(5, 19, 44, 0.08) 84%) !important;
}

.mobile-home-hero-card[data-mobile-home-event-hero] .mobile-home-hero-shade,
.mobile-home-hero-card[data-mobile-home-event-hero] .mobile-home-hero-copy {
    display: none !important;
}

.mobile-home-hero-card[data-mobile-home-event-hero] .mobile-home-hero-image {
    opacity: 1 !important;
    filter: none !important;
}

.mobile-home-hero-copy,
.home-feed-cards .feed-card-content {
    padding: 22px 18px 16px !important;
}

.mobile-home-hero-copy h2,
.home-feed-cards .feed-card-hero-title {
    max-width: 76% !important;
    font-size: clamp(1.16rem, 5.6vw, 1.36rem) !important;
    font-weight: 810 !important;
    line-height: 1.14 !important;
}

.mobile-home-hero-copy p,
.home-feed-cards .card-tagline {
    padding: 6px 9px !important;
    border-color: rgba(255, 255, 255, 0.18) !important;
    background: rgba(13, 22, 38, 0.34) !important;
    font-size: 0.64rem !important;
    font-weight: 660 !important;
    line-height: 1.24 !important;
}

.mobile-home-hero-dots {
    gap: 6px;
}

.mobile-home-hero-dot {
    width: 5px;
    height: 5px;
    background: #DDE2EA;
}

.mobile-home-hero-dot.is-active {
    width: 16px;
    background: var(--home-coral);
}

.mobile-home-category-panel {
    margin: 0 14px 18px;
    padding: 8px 0 12px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
}

.mobile-home-category-grid {
    --mobile-home-category-gap: clamp(3px, 1.5vw, 6px);
    --mobile-home-category-col-size: calc((100% - (var(--mobile-home-category-gap) * 4)) / 5);
    display: grid;
    grid-template-columns: repeat(5, var(--mobile-home-category-col-size));
    grid-auto-columns: var(--mobile-home-category-col-size);
    grid-template-rows: repeat(3, minmax(70px, auto));
    column-gap: var(--mobile-home-category-gap);
    row-gap: clamp(6px, 2vw, 10px);
    overflow-x: auto;
    overflow-y: hidden;
    overscroll-behavior-x: contain;
    scroll-snap-type: x proximity;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}

.mobile-home-category-grid::-webkit-scrollbar {
    display: none;
}

.mobile-home-category-card,
.mobile-home-category-card:visited,
.mobile-home-category-card:hover,
.mobile-home-category-card:focus-visible {
    width: 100%;
    min-height: 86px;
    gap: 3px;
    scroll-snap-align: start;
}

.mobile-home-category-icon {
    width: clamp(46px, 15.5vw, 60px);
    height: clamp(46px, 15.5vw, 60px);
    max-width: 100%;
    margin-inline: auto;
    aspect-ratio: 1;
    border: 0;
    border-radius: clamp(11px, 3.2vw, 14px);
    background: transparent;
    box-shadow: none;
}

.mobile-home-category-icon.has-image img {
    width: 100%;
    height: 100%;
    border-radius: inherit;
    object-fit: contain;
    filter: saturate(0.86) contrast(0.98) brightness(1.02);
}

.mobile-home-category-icon i {
    font-size: 2.05rem;
}

.mobile-home-category-card:active .mobile-home-category-icon {
    box-shadow: none;
}

.mobile-home-category-card > span:last-child,
.mobile-home-category-card[data-home-category="organization"] > span:last-child,
.mobile-home-category-card[data-home-category="classifieds"] > span:last-child,
.mobile-home-category-card[data-home-category="restaurant"] > span:last-child {
    width: 100%;
    max-width: 100%;
    padding-inline: 1px;
    box-sizing: border-box;
    min-height: 22px;
    font-size: clamp(0.50rem, 2.15vw, 0.56rem);
    font-weight: 720;
    line-height: 1.15;
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
}

.mobile-home-category-card > .mobile-home-category-label {
    display: flex;
}

body.dark-mode .mobile-home-category-panel {
    background: transparent;
    border-color: transparent;
}

.mobile-home-event-section {
    margin-bottom: 21px;
}

.mobile-home-section-heading {
    min-height: 34px;
    margin: 0 16px 8px;
}

.mobile-home-section-heading h2 {
    font-size: 1rem;
    font-weight: 790;
}

.mobile-home-section-heading a {
    min-height: 34px;
    color: #F65373;
    -webkit-text-fill-color: #F65373;
    font-size: 0.7rem;
    font-weight: 720;
}

.mobile-home-event-rail,
.mobile-home-classified-rail,
.mobile-home-news-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-movie-rail {
    gap: 11px;
    padding: 0 16px 4px;
    scroll-padding-inline: 16px;
}

.mobile-home-event-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-news-rail,
.mobile-home-classified-rail {
    grid-auto-columns: calc((100% - 27px) / 1.2);
}

.mobile-home-movie-rail {
    grid-auto-columns: minmax(166px, 46vw);
}

.mobile-home-event-card,
.mobile-home-classified-card,
.mobile-home-news-card,
.mobile-home-featured-business-card,
.mobile-home-movie-card,
.mobile-home-event-skeleton,
.mobile-home-classified-skeleton,
.mobile-home-news-skeleton,
.mobile-home-featured-business-skeleton,
.mobile-home-movie-skeleton {
    border-color: var(--home-border);
    border-radius: var(--home-card-radius);
    background: #FFFFFF;
    box-shadow: var(--home-card-shadow);
}

.mobile-home-event-card,
.mobile-home-featured-business-card,
.mobile-home-featured-business-skeleton {
    min-height: 285px;
}

.mobile-home-event-media,
.mobile-home-featured-business-media,
.mobile-home-news-media {
    background: #F5F7FA;
}

.mobile-home-event-media,
.mobile-home-featured-business-media {
    height: 160px;
}

.mobile-home-event-date {
    top: 14px;
    right: 14px;
    width: 44px;
    min-height: 50px;
    border-radius: 12px;
    box-shadow: 0 8px 18px rgba(18, 38, 63, 0.1);
}

.mobile-home-event-date small {
    font-size: 0.68rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    line-height: 1.2;
}

.mobile-home-event-date strong {
    font-size: 1.15rem;
    font-weight: 850;
    line-height: 1.1;
    margin-top: 1px;
}
.mobile-home-event-body {
    display: grid;
    align-content: start;
    gap: 6px;
    padding: 16px 18px 18px;
}

.mobile-home-event-body h3 {
    min-height: auto;
    margin-bottom: 6px;
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
}

.mobile-home-event-meta {
    gap: 8px;
    font-size: 0.84rem;
    font-weight: 620;
}

.mobile-home-event-meta i {
    width: 12px;
    color: #A1A8B3;
    -webkit-text-fill-color: #A1A8B3;
}

.mobile-home-classified-card::after,
.mobile-home-news-card.no-image::after,
.mobile-home-featured-business-card.no-image .mobile-home-featured-business-media::after {
    display: none;
}

.mobile-home-classified-column {
    scroll-snap-align: start;
    display: grid;
    grid-template-rows: auto auto;
    gap: 8px;
}

.mobile-home-classified-card {
    min-height: 132px;
    height: 132px;
    padding: 12px 14px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 4px;
    background: #FFFFFF;
}

.mobile-home-classified-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
    min-width: 0;
}

.mobile-home-classified-lane {
    min-width: 0;
    max-width: 100%;
    padding: 4px 7px;
    border: 1px solid #E7EBF1;
    border-radius: 999px;
    background: #F7F8FA;
    color: #475467;
    -webkit-text-fill-color: #475467;
    font-size: 0.52rem;
    font-weight: 650;
    line-height: 1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-classified-tag {
    border-color: rgba(18, 58, 111, 0.12);
    background: #F4F7FB;
    color: var(--home-navy);
    -webkit-text-fill-color: var(--home-navy);
    font-size: 0.5rem;
    font-weight: 680;
    padding: 4px 7px;
    border-radius: 999px;
}

.mobile-home-business-tag,
.mobile-home-movie-language {
    border-color: rgba(18, 58, 111, 0.12);
    background: #F4F7FB;
    color: var(--home-navy);
    -webkit-text-fill-color: var(--home-navy);
    font-size: 0.5rem;
    font-weight: 680;
    padding: 4px 7px;
}

.mobile-home-classified-card h3 {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 720;
    line-height: 1.25;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-home-classified-price {
    display: block;
    color: var(--home-navy);
    -webkit-text-fill-color: var(--home-navy);
    font-size: 0.8rem;
    font-weight: 760;
    line-height: 1.1;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-classified-meta {
    gap: 4px;
    font-size: 0.74rem;
    font-weight: 540;
    color: #6E737A;
    -webkit-text-fill-color: #6E737A;
}

.mobile-home-business-meta {
    gap: 6px;
    font-size: 0.84rem;
    font-weight: 620;
    color: var(--home-muted);
    -webkit-text-fill-color: var(--home-muted);
}

.mobile-home-news-card {
    min-height: 172px;
    grid-template-rows: 86px minmax(86px, auto);
}

.mobile-home-news-card.no-image {
    min-height: 168px;
    padding: 0;
    background: #FFFFFF;
}

.mobile-home-news-media {
    height: 86px;
}

.mobile-home-news-body {
    display: grid;
    grid-template-rows: auto auto minmax(0, 1fr) auto;
    gap: 6px;
    min-height: 0;
    padding: 11px;
}

.mobile-home-news-kicker {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    color: #7A8089;
    -webkit-text-fill-color: #7A8089;
    font-size: 0.76rem;
    font-weight: 650;
    line-height: 1.2;
}

.mobile-home-news-kicker span {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.mobile-home-news-kicker span + span::before {
    content: "";
    display: inline-block;
    width: 3px;
    height: 3px;
    margin: 0 6px 1px 0;
    border-radius: 50%;
    background: #C6CBD4;
}

.mobile-home-news-card h3 {
    font-size: 0.78rem;
    font-weight: 720;
    line-height: 1.22;
    -webkit-line-clamp: 3;
    line-clamp: 3;
}

.mobile-home-news-card p {
    font-size: 0.6rem;
    font-weight: 520;
    line-height: 1.28;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.mobile-home-news-read {
    justify-self: end;
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #F65373;
    -webkit-text-fill-color: #F65373;
    font-size: 0.76rem;
    font-weight: 720;
    line-height: 1;
}

.mobile-home-news-read i {
    font-size: 0.68rem;
}

.mobile-home-business-tag {
    top: 8px;
    left: 8px;
}

.mobile-home-featured-business-media img {
    object-position: center;
}

.mobile-home-featured-business-card.no-image .mobile-home-featured-business-media {
    background:
        linear-gradient(135deg, #F7F8FA, #EEF2F7);
}

.mobile-home-business-fallback-icon {
    width: 60px;
    height: 60px;
    border-color: #E3E8EF;
    border-radius: 20px;
    background: #FFFFFF;
    box-shadow: 0 6px 14px rgba(18, 38, 63, 0.07);
}

.mobile-home-business-fallback-icon i {
    font-size: 1.5rem;
}

.mobile-home-featured-business-body {
    display: grid;
    align-content: start;
    gap: 6px;
    padding: 16px 18px 18px;
}

.mobile-home-featured-business-card h3 {
    min-height: auto;
    margin: 0 0 6px 0;
    font-size: 1.05rem;
    font-weight: 780;
    line-height: 1.3;
    -webkit-line-clamp: 2;
    line-clamp: 2;
}

.mobile-home-business-tag {
    top: 14px;
    left: 14px;
    padding: 6px 12px;
    font-size: 0.68rem;
    font-weight: 700;
}

.mobile-home-movie-card {
    min-height: 164px;
    border-radius: 18px;
}

.mobile-home-movie-poster::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 52%;
    background: linear-gradient(180deg, transparent 0%, rgba(7, 16, 31, 0.78) 100%);
    pointer-events: none;
}

.mobile-home-movie-language {
    top: 11px;
    left: 11px;
    z-index: 2;
    max-width: calc(100% - 22px);
    border: none;
    background: linear-gradient(135deg, var(--cinema-language-1, #ff8a00), var(--cinema-language-2, #f23673));
    box-shadow: 0 8px 18px var(--cinema-language-glow, rgba(255, 94, 0, 0.22));
    color: #FFFFFF;
    -webkit-text-fill-color: #FFFFFF;
    font-size: 0.58rem;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 5px 8px;
}

.mobile-home-movie-title {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 12px;
    z-index: 2;
    display: -webkit-box;
    overflow: hidden;
    color: #FFFFFF;
    -webkit-text-fill-color: #FFFFFF;
    font-size: 0.74rem;
    font-weight: 720;
    line-height: 1.18;
    text-shadow: 0 1px 10px rgba(0, 0, 0, 0.4);
    -webkit-line-clamp: 2;
    line-clamp: 2;
    -webkit-box-orient: vertical;
}

.home-feed-cards {
    gap: 20px 12px;
    padding: 0 16px;
}

.home-feed-cards .feed-card {
    height: 172px !important;
    min-height: 172px !important;
    box-shadow: 0 10px 22px rgba(18, 38, 63, 0.12) !important;
}

.home-feed-cards .feed-card[data-home-feed-category="owners"] {
    height: 178px !important;
    min-height: 178px !important;
    margin-top: 12px !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .feed-card-hero-title {
    font-size: 0.94rem !important;
    font-weight: 760 !important;
}

.home-feed-cards .feed-card:not([data-home-feed-category="owners"]) .card-tagline {
    font-size: 0.54rem !important;
}

.home-feed-cards .feed-card[data-home-feed-category="deals"] .card-tagline,
.home-feed-cards .feed-card[data-home-feed-category="flyers"] .card-tagline {
    font-size: 0.64rem !important;
}

.home-feed-cards .feed-card[data-home-feed-category="owners"] .feed-card-image {
    object-position: center;
    filter: saturate(0.82) contrast(1.02) brightness(0.94) !important;
}

.home-feed-cards .feed-card[data-home-feed-category="owners"] .feed-card-overlay {
    background:
        linear-gradient(180deg, rgba(4, 13, 27, 0.04) 0%, rgba(4, 13, 27, 0.18) 46%, rgba(4, 13, 27, 0.56) 100%),
        linear-gradient(90deg, rgba(5, 19, 44, 0.76) 0%, rgba(5, 19, 44, 0.26) 48%, rgba(5, 19, 44, 0.02) 100%) !important;
}

@media (max-width: 360px) {
    .mobile-home-category-icon {
        border-radius: 12px;
    }

    .mobile-home-category-icon.has-image img {
        width: 100%;
        height: 100%;
    }

    .mobile-home-category-card > span:last-child,
    .mobile-home-category-card[data-home-category="organization"] > span:last-child,
    .mobile-home-category-card[data-home-category="classifieds"] > span:last-child,
    .mobile-home-category-card[data-home-category="restaurant"] > span:last-child {
        font-size: clamp(0.44rem, 1.8vw, 0.50rem);
    }

    .mobile-home-event-rail,
    .mobile-home-featured-business-rail,
    .mobile-home-featured-restaurant-rail,
    .mobile-home-news-rail,
    .mobile-home-classified-rail {
        grid-auto-columns: calc((100% - 27px) / 1.2);
    }

    .mobile-home-flyer-rail,
    .mobile-home-deals-rail,
    .mobile-home-exclusive-deals-rail,
    .mobile-home-business-promos-rail {
        grid-auto-columns: calc((100% - 24px) / 2.5);
    }

    .mobile-home-movie-rail {
        grid-auto-columns: minmax(160px, 45vw);
    }
}

.mobile-home-news-rail,
.mobile-home-classified-rail,
.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    gap: 12px;
    padding-inline: 16px;
    scroll-padding-inline: 16px;
}

.mobile-home-news-rail,
.mobile-home-classified-rail {
    grid-auto-columns: calc((100% - 27px) / 1.2);
}

.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    grid-auto-columns: calc((100% - 24px) / 2.5);
}

.mobile-home-news-card,
.mobile-home-classified-card,
.mobile-home-flyer-card,
.mobile-home-deals-card,
.mobile-home-exclusive-deals-card,
.mobile-home-business-promos-card {
    border-color: #E9ECF2;
    background: #FFFFFF;
    box-shadow: 0 9px 22px rgba(18, 38, 63, 0.07), 0 1px 2px rgba(18, 38, 63, 0.035);
}

.mobile-home-flyer-card,
.mobile-home-deals-card,
.mobile-home-exclusive-deals-card,
.mobile-home-business-promos-card {
    display: block;
    aspect-ratio: 3 / 4;
    border-radius: 12px;
    overflow: hidden;
    text-decoration: none;
}

.mobile-home-flyer-card img,
.mobile-home-deals-card img,
.mobile-home-exclusive-deals-card img,
.mobile-home-business-promos-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mobile-home-news-column {
    scroll-snap-align: start;
    display: grid;
    grid-template-rows: auto auto;
    gap: 8px;
}

.mobile-home-news-card {
    min-height: 120px;
    height: auto;
    display: grid;
    border-radius: 16px;
}

.mobile-home-news-card.has-image {
    grid-template-columns: 100px 1fr;
    grid-template-rows: 1fr;
}

.mobile-home-news-card.no-image {
    position: relative;
    min-height: 120px;
    height: auto;
    padding: 0;
    grid-template-columns: 1fr;
    grid-template-rows: 1fr;
}

.mobile-home-news-media {
    width: 100px;
    height: 100%;
}

.mobile-home-news-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.mobile-home-news-body,
.mobile-home-news-card.no-image .mobile-home-news-body {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    gap: 8px;
    padding: 14px 16px 16px;
    box-sizing: border-box;
    overflow: visible;
    min-height: 0;
}

.mobile-home-news-kicker {
    min-height: 13px;
    max-width: 100%;
    gap: 8px;
    overflow: hidden;
    color: #7A8089;
    -webkit-text-fill-color: #7A8089;
    font-size: 0.76rem;
    font-weight: 640;
    line-height: 1.22;
}

.mobile-home-news-kicker span:first-child {
    flex: 1 1 auto;
    max-width: calc(100% - 54px);
}

.mobile-home-news-kicker span:last-child {
    flex: 0 0 auto;
}

.mobile-home-news-kicker span + span::before {
    width: 3px;
    height: 3px;
    margin: 0 5px 1px 0;
    background: #B9C0CB;
}

.mobile-home-news-section .mobile-home-section-heading {
    flex-wrap: wrap;
}

.mobile-home-news-status {
    display: inline-flex;
    align-items: center;
    min-height: 23px;
    margin-left: auto;
    padding: 0 8px;
    border: 1px solid rgba(246, 83, 115, 0.20);
    border-radius: 999px;
    background: rgba(246, 83, 115, 0.10);
    color: #F65373;
    -webkit-text-fill-color: #F65373;
    font-size: 0.58rem;
    font-weight: 760;
    line-height: 1;
    white-space: nowrap;
}

.mobile-home-news-note {
    width: 100%;
    margin: -2px 0 8px;
    color: #6E737A;
    -webkit-text-fill-color: #6E737A;
    font-size: 0.68rem;
    font-weight: 620;
    line-height: 1.3;
}

.mobile-home-news-card h3 {
    align-self: start;
    display: block;
    overflow: visible;
    margin: 0;
    color: #1C1E21;
    -webkit-text-fill-color: #1C1E21;
    font-size: 1rem;
    font-weight: 780;
    line-height: 1.3;
    text-wrap: pretty;
}

.mobile-home-news-read {
    display: none;
}

.mobile-home-classified-column {
    scroll-snap-align: start;
    display: grid;
    grid-template-rows: auto auto;
    gap: 8px;
}

.mobile-home-classified-card {
    position: relative;
    height: 148px;
    min-height: 148px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    gap: 4px;
    padding: 16px 18px 18px;
    border-radius: 16px;
    overflow: hidden;
}

.mobile-home-classified-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}

.mobile-home-classified-lane {
    padding: 4px 10px;
    border-radius: 999px;
    border: 1px solid rgba(255, 94, 0, 0.15);
    background: #FFF5ED;
    color: var(--home-price);
    -webkit-text-fill-color: var(--home-price);
    font-size: 0.58rem;
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.03em;
    text-transform: uppercase;
}

body.dark-mode .mobile-home-classified-lane {
    background: rgba(255, 122, 50, 0.08);
    border-color: rgba(255, 122, 50, 0.18);
}

.mobile-home-classified-tag {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    border: 1px solid rgba(255, 94, 0, 0.18);
    background: #FFF6F0;
    color: #FF5E00;
    -webkit-text-fill-color: #FF5E00;
    border-radius: 50%;
    box-sizing: border-box;
}

.mobile-home-classified-tag i {
    font-size: 0.58rem;
    line-height: 1;
}

.mobile-home-classified-card h3 {
    margin: 0;
    color: #1C1E21;
    -webkit-text-fill-color: #1C1E21;
    font-size: 0.98rem;
    font-weight: 780;
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mobile-home-classified-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    gap: 8px;
}

.mobile-home-classified-price {
    color: var(--home-price);
    -webkit-text-fill-color: var(--home-price);
    font-size: 0.95rem;
    font-weight: 900;
    line-height: 1.1;
}

.mobile-home-classified-meta {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    color: #6E737A;
    -webkit-text-fill-color: #6E737A;
    font-size: 0.76rem;
    font-weight: 600;
    line-height: 1.15;
}

@media (max-width: 360px) {
    .mobile-home-news-body,
    .mobile-home-news-card.no-image .mobile-home-news-body {
        padding-inline: 11px;
    }
}

/* Home feed + mobile chrome: shared horizontal rhythm */
:root {
    --home-edge: 5px;
    --home-rail-gap: 6px;
}

.home-feed-section {
    --home-edge: 5px;
    --home-rail-gap: 6px;
}

.home-feed-section .header-container.brand-header {
    padding-inline: var(--home-edge);
}

.mobile-home-hero {
    padding-inline: 0;
}

.mobile-home-hero-card {
    border-radius: 0 !important;
    border-inline: 0 !important;
    box-shadow: none !important;
}

.mobile-home-category-panel {
    margin-inline: var(--home-edge);
    padding-inline: 0;
}

.mobile-home-category-grid {
    column-gap: var(--home-rail-gap);
}

.mobile-home-section-heading {
    margin-inline: var(--home-edge);
}

.mobile-home-event-rail,
.mobile-home-classified-rail,
.mobile-home-news-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-movie-rail,
.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    width: 100%;
    margin-left: 0;
    gap: var(--home-rail-gap);
    padding-inline: var(--home-edge);
    scroll-padding-inline: var(--home-edge);
}

.mobile-home-event-rail,
.mobile-home-featured-business-rail,
.mobile-home-featured-restaurant-rail,
.mobile-home-news-rail,
.mobile-home-classified-rail {
    grid-auto-columns: calc((100% - var(--home-rail-gap)) / 1.2);
}

.mobile-home-flyer-rail,
.mobile-home-deals-rail,
.mobile-home-exclusive-deals-rail,
.mobile-home-business-promos-rail {
    grid-auto-columns: calc((100% - calc(var(--home-rail-gap) * 2)) / 2.5);
}

.mobile-home-news-column,
.mobile-home-classified-column {
    gap: var(--home-rail-gap);
}

.home-feed-cards {
    gap: var(--home-rail-gap) !important;
    padding-inline: var(--home-edge);
    margin-bottom: 0 !important;
}

.home-feed-cards .feed-card[data-home-feed-category="owners"] {
    margin-top: var(--home-rail-gap);
}

.mobile-home-event-section,
.home-feed-cards {
    --home-edge: 10px;
    --home-rail-gap: 10px;
}
