/**
 * Mobile Listing Page - Editorial Happy Hour Magazine Design
 * Bold, distinctive mobile-first layout with condensed typography
 */

@import url('https://fonts.googleapis.com/css2?family=Fjalla+One&family=IBM+Plex+Sans:wght@400;500;600&display=swap');

@media (max-width: 768px) {

    /* ========================================
       CSS VARIABLES - EDITORIAL SYSTEM
       ======================================== */

    .single-listing {
        --color-bg-dark: #1a2332;
        --color-bg-medium: #2C3E50;
        --color-card: rgba(27, 40, 56, 0.6);
        --color-card-border: rgba(255, 255, 255, 0.1);
        --color-text-dark: #1a2332;
        --color-text-medium: #495057;
        --color-text-light: rgba(255, 255, 255, 0.95);
        --color-text-medium-light: rgba(255, 255, 255, 0.75);
        --color-accent: #FF6B00;
        --color-accent-light: #FF8C42;
        --color-accent-glow: rgba(255, 107, 0, 0.15);

        --font-display: 'Fjalla One', 'Impact', sans-serif;
        --font-body: 'IBM Plex Sans', -apple-system, sans-serif;

        --radius-card: 16px;
        --radius-button: 8px;
        --shadow-card: 0 4px 20px rgba(0, 0, 0, 0.12);
        --shadow-elevated: 0 8px 32px rgba(0, 0, 0, 0.16);
    }

    /* ========================================
       1. FOUNDATION - BACKGROUND & STRUCTURE
       ======================================== */

    body.single-listing,
    body.single-listing #page,
    .single-listing .listing-detail-page,
    .single-listing .page-container,
    .single-listing #lp-single-detail-page {
        background: linear-gradient(180deg, var(--color-bg-dark) 0%, var(--color-bg-medium) 100%) !important;
        background-attachment: fixed !important;
    }

    /* Remove competing backgrounds */
    .single-listing .app-view-content,
    .single-listing .lp-details-page,
    .single-listing section,
    .single-listing .listing-content-area {
        background: transparent !important;
    }

    /* ========================================
       2. HERO - CLEAN FEATURED IMAGE
       ======================================== */

    .single-listing .hh-hero-full {
        height: 240px !important;
        max-height: 240px !important;
        min-height: 240px !important;
        margin: 0 0 20px 0 !important;
        position: relative !important;
        overflow: hidden !important;
        border-radius: 0 !important;
    }

    /* Hero image - clean, no overlay */
    .single-listing .hh-hero-full img,
    .single-listing .hh-hero-full .hero-image,
    .single-listing .hh-hero-full [class*="image"] {
        width: 100% !important;
        height: 240px !important;
        object-fit: cover !important;
        object-position: center !important;
    }

    /* Remove dark gradient overlay */
    .single-listing .hh-hero-full::before {
        display: none !important;
    }

    /* Show ONLY featured image - hide all others completely */
    .single-listing .hh-hero-full .slick-slider,
    .single-listing .hh-hero-full [class*="slider"] {
        pointer-events: none !important;
        overflow: hidden !important;
    }

    /* Hide all slides except the active one */
    .single-listing .hh-hero-full .slick-slide {
        display: none !important;
        visibility: hidden !important;
        opacity: 0 !important;
        position: absolute !important;
        left: -9999px !important;
    }

    /* Only show the current/active slide */
    .single-listing .hh-hero-full .slick-slide.slick-current,
    .single-listing .hh-hero-full .slick-slide.slick-active {
        display: block !important;
        visibility: visible !important;
        opacity: 1 !important;
        position: relative !important;
        left: 0 !important;
        width: 100% !important;
    }

    /* Force slider track to show only one image */
    .single-listing .hh-hero-full .slick-track {
        transform: none !important;
        width: 100% !important;
    }

    /* Hide slider navigation completely */
    .single-listing .hh-hero-full .slick-prev,
    .single-listing .hh-hero-full .slick-next,
    .single-listing .hh-hero-full .slick-dots {
        display: none !important;
    }

    /* Title moves BELOW hero image */
    .single-listing .hh-hero-full .hh-title-info,
    .single-listing .hh-hero-full [class*="title"] {
        position: static !important;
        background: var(--color-bg-medium) !important;
        padding: 20px 20px 16px 20px !important;
        margin: 0 !important;
    }

    /* Override: SEE MORE button stays with hero (not fixed on scroll) */
    body.single-listing .hh-see-more-link,
    body.single-listing [class*="see-more"].image-popup {
        position: absolute !important;
        top: auto !important;
        bottom: 10px !important;
        right: 10px !important;
        left: auto !important;
        z-index: 999 !important;
    }

    .single-listing .hh-hero-full h1,
    .single-listing .hh-hero-full .listing-title {
        font-family: var(--font-display) !important;
        font-size: 28px !important;
        font-weight: 900 !important;
        line-height: 1.2 !important;
        letter-spacing: -0.02em !important;
        text-transform: uppercase !important;
        color: #FFFFFF !important;
        margin: 0 0 10px 0 !important;
        text-shadow: none !important;
    }

    /* Rating badge - inline below title */
    .single-listing .hh-hero-full .rating,
    .single-listing .hh-hero-full [class*="stars"] {
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
        background: transparent !important;
        backdrop-filter: none !important;
        padding: 0 !important;
        border-radius: 0 !important;
        font-size: 14px !important;
        font-weight: 500 !important;
        color: rgba(255, 255, 255, 0.8) !important;
        text-shadow: none !important;
        box-shadow: none !important;
    }

    .single-listing .hh-hero-full .rating i,
    .single-listing .hh-hero-full [class*="stars"] i {
        color: var(--color-accent) !important;
    }

    /* ========================================
       3. CONTENT WRAPPER - CARD SYSTEM
       ======================================== */

    .single-listing .hh-content-wrapper {
        padding: 0 !important;
        margin-top: 0 !important;
        position: relative !important;
        z-index: 10 !important;
    }

    /* Dark semi-transparent content cards */
    .single-listing .hh-section,
    .single-listing .hh-about-content,
    .single-listing .hh-sidebar-widget {
        background: var(--color-card) !important;
        backdrop-filter: blur(10px) !important;
        border: 1px solid var(--color-card-border) !important;
        border-radius: var(--radius-card) !important;
        padding: 24px 20px !important;
        margin: 0 12px 18px 12px !important;
        box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3) !important;
        position: relative !important;
        overflow: hidden !important;
    }

    /* Card elevation system - creates visual hierarchy */
    .single-listing .hh-section,
    .single-listing .hh-sidebar-widget {
        box-shadow: var(--shadow-card) !important;
    }

    /* Alternate cards get slightly elevated shadow */
    .single-listing .hh-section:nth-child(even),
    .single-listing .hh-sidebar-widget:nth-child(even) {
        box-shadow: 0 6px 24px rgba(0, 0, 0, 0.14) !important;
    }

    /* Important cards (verification, hours) get maximum elevation */
    .single-listing .hh-verification-section,
    .single-listing .hh-hours-widget,
    .single-listing .hh-sidebar-widget:nth-of-type(2) {
        box-shadow: var(--shadow-elevated) !important;
    }

    /* First card after hero */
    .single-listing .hh-content-wrapper > .hh-section:first-child {
        margin-top: 0 !important;
    }

    /* Last card before footer */
    .single-listing .hh-section:last-child,
    .single-listing .hh-sidebar-widget:last-child {
        margin-bottom: 40px !important;
    }

    /* Happy Hour Times widget uses standard dark card (matching desktop) */

    /* First card gets elevated treatment with rounded top corners */
    .single-listing .hh-section:first-child,
    .single-listing .hh-content-wrapper > *:first-child {
        border-top-left-radius: 24px !important;
        border-top-right-radius: 24px !important;
    }

    /* Remove card styling from title-info if it's in content wrapper */
    .single-listing .hh-content-wrapper .hh-title-info {
        background: transparent !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* ========================================
       4. HAPPY HOUR DEALS - STAR TREATMENT
       ======================================== */

    .single-listing .hh-section.hh-hours,
    .single-listing .hh-section.hh-deals,
    .single-listing [class*="happy-hour"],
    .single-listing [class*="deal-times"] {
        background: linear-gradient(135deg, var(--color-accent) 0%, var(--color-accent-light) 100%) !important;
        padding: 28px 24px !important;
        margin: 0 12px 20px 12px !important;
        box-shadow:
            var(--shadow-elevated),
            0 0 0 4px var(--color-accent-glow),
            inset 0 1px 0 rgba(255, 255, 255, 0.2) !important;
        position: relative !important;
        overflow: visible !important;
    }

    /* Accent stripe on left edge */
    .single-listing .hh-section.hh-hours::before,
    .single-listing [class*="happy-hour"]::before {
        content: '' !important;
        position: absolute !important;
        left: 0 !important;
        top: 0 !important;
        bottom: 0 !important;
        width: 6px !important;
        background: rgba(255, 255, 255, 0.4) !important;
    }

    /* Deal card typography */
    .single-listing .hh-section.hh-hours h2,
    .single-listing .hh-section.hh-hours h3,
    .single-listing [class*="happy-hour"] h2,
    .single-listing [class*="happy-hour"] h3 {
        font-family: var(--font-display) !important;
        font-size: 26px !important;
        font-weight: 900 !important;
        text-transform: uppercase !important;
        letter-spacing: -0.01em !important;
        color: #FFFFFF !important;
        margin: 0 0 12px 0 !important;
        text-shadow: 0 2px 4px rgba(0, 0, 0, 0.15) !important;
    }

    .single-listing .hh-section.hh-hours p,
    .single-listing .hh-section.hh-hours span,
    .single-listing [class*="happy-hour"] p,
    .single-listing [class*="happy-hour"] span {
        color: rgba(255, 255, 255, 0.95) !important;
        font-size: 15px !important;
        line-height: 1.6 !important;
    }

    /* ========================================
       5. TYPOGRAPHY - EDITORIAL HIERARCHY
       ======================================== */

    /* Section headlines - condensed display with light text */
    .single-listing .hh-section h2,
    .single-listing .hh-about-content h2 {
        font-family: var(--font-display) !important;
        font-size: 22px !important;
        font-weight: 900 !important;
        text-transform: uppercase !important;
        letter-spacing: -0.01em !important;
        color: var(--color-text-light) !important;
        margin: 0 0 16px 0 !important;
        position: relative !important;
        padding-bottom: 12px !important;
    }

    /* Accent underline for headings */
    .single-listing .hh-section h2::after,
    .single-listing .hh-about-content h2::after {
        content: '' !important;
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 40px !important;
        height: 3px !important;
        background: var(--color-accent) !important;
        border-radius: 2px !important;
    }

    /* Widget headings - editorial style with light text */
    .single-listing .hh-sidebar-widget h2,
    .single-listing .hh-sidebar-widget h3,
    .single-listing .hh-sidebar-widget h4 {
        font-family: var(--font-display) !important;
        font-size: 20px !important;
        font-weight: 900 !important;
        text-transform: uppercase !important;
        letter-spacing: -0.01em !important;
        color: var(--color-text-light) !important;
        margin: 0 0 16px 0 !important;
        position: relative !important;
        padding-bottom: 12px !important;
    }

    /* Orange underline for widget headings */
    .single-listing .hh-sidebar-widget h2::after,
    .single-listing .hh-sidebar-widget h3::after,
    .single-listing .hh-sidebar-widget h4::after {
        content: '' !important;
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        width: 40px !important;
        height: 3px !important;
        background: var(--color-accent) !important;
        border-radius: 2px !important;
    }

    /* Subheadings with light text */
    .single-listing .hh-section h3,
    .single-listing .hh-about-content h3 {
        font-family: var(--font-body) !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        color: var(--color-text-light) !important;
        margin: 16px 0 8px 0 !important;
    }

    /* Body text */
    .single-listing .hh-section p,
    .single-listing .hh-section span,
    .single-listing .hh-section div,
    .single-listing .hh-about-content p,
    .single-listing .hh-about-content span {
        font-family: var(--font-body) !important;
        font-size: 15px !important;
        line-height: 1.7 !important;
        color: var(--color-text-medium) !important;
    }

    /* List styling - clean and readable */
    .single-listing .hh-section ul,
    .single-listing .hh-section ol,
    .single-listing .hh-sidebar-widget ul,
    .single-listing .hh-sidebar-widget ol {
        padding-left: 20px !important;
        margin: 16px 0 !important;
    }

    .single-listing .hh-section li,
    .single-listing .hh-sidebar-widget li {
        font-family: var(--font-body) !important;
        font-size: 15px !important;
        line-height: 1.6 !important;
        color: var(--color-text-medium-light) !important;
        margin-bottom: 10px !important;
    }

    /* Custom bullet points */
    .single-listing .hh-section ul li::marker,
    .single-listing .hh-sidebar-widget ul li::marker {
        color: var(--color-accent) !important;
    }

    /* Ordered list numbers */
    .single-listing .hh-section ol li::marker,
    .single-listing .hh-sidebar-widget ol li::marker {
        color: var(--color-accent) !important;
        font-weight: 600 !important;
    }

    /* Body text - optimal readability with light text */
    .single-listing .hh-section p,
    .single-listing .hh-sidebar-widget p {
        font-family: var(--font-body) !important;
        font-size: 15px !important;
        line-height: 1.65 !important;
        color: var(--color-text-medium-light) !important;
        margin-bottom: 12px !important;
    }

    /* Last paragraph in card */
    .single-listing .hh-section p:last-child,
    .single-listing .hh-sidebar-widget p:last-child {
        margin-bottom: 0 !important;
    }

    /* Text links within content */
    .single-listing .hh-section a,
    .single-listing .hh-sidebar-widget a {
        color: var(--color-accent) !important;
        text-decoration: none !important;
        border-bottom: 1px solid var(--color-accent) !important;
        transition: opacity 0.2s ease !important;
    }

    .single-listing .hh-section a:active,
    .single-listing .hh-sidebar-widget a:active {
        opacity: 0.7 !important;
    }

    /* ========================================
       6. BUTTONS & INTERACTIVE ELEMENTS
       ======================================== */

    /* Primary CTA - FORCE orange background with pure white text */
    html body.single-listing .claim-btn,
    html body.single-listing .contact-owner-btn,
    html body.single-listing .write-review-btn,
    html body.single-listing [class*="cta-btn"],
    html body.single-listing button[class*="primary"],
    html body.single-listing .hh-verification-section button,
    html body.single-listing .hh-verification-section a.button,
    html body.single-listing .hh-verification-section a[class*="button"],
    html body.single-listing button[class*="claim"],
    html body.single-listing a[class*="claim"] {
        font-family: var(--font-body) !important;
        font-size: 16px !important;
        font-weight: 800 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.03em !important;
        background: #FF6B00 !important;
        background-color: #FF6B00 !important;
        color: #FFFFFF !important;
        border: none !important;
        border-radius: var(--radius-button) !important;
        padding: 16px 32px !important;
        box-shadow: 0 4px 12px rgba(255, 107, 0, 0.4) !important;
        transition: all 0.2s ease !important;
        cursor: pointer !important;
        text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5) !important;
    }

    /* FORCE all text inside buttons to pure white with strong shadow */
    html body.single-listing .claim-btn,
    html body.single-listing .claim-btn *,
    html body.single-listing .contact-owner-btn,
    html body.single-listing .contact-owner-btn *,
    html body.single-listing [class*="cta-btn"],
    html body.single-listing [class*="cta-btn"] *,
    html body.single-listing button[class*="primary"],
    html body.single-listing button[class*="primary"] *,
    html body.single-listing button[class*="claim"],
    html body.single-listing button[class*="claim"] *,
    html body.single-listing a[class*="claim"],
    html body.single-listing a[class*="claim"] *,
    html body.single-listing .hh-verification-section button,
    html body.single-listing .hh-verification-section button *,
    html body.single-listing .hh-verification-section a.button,
    html body.single-listing .hh-verification-section a.button *,
    html body.single-listing .hh-verification-section a[class*="button"],
    html body.single-listing .hh-verification-section a[class*="button"] * {
        color: #FFFFFF !important;
        text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5) !important;
    }

    /* FORCE icon inside button to pure white */
    html body.single-listing button[class*="claim"] i,
    html body.single-listing a[class*="claim"] i,
    html body.single-listing .hh-verification-section button i,
    html body.single-listing .hh-verification-section a i {
        color: #FFFFFF !important;
    }

    .single-listing .claim-btn:active,
    .single-listing .contact-owner-btn:active,
    .single-listing button[class*="primary"]:active {
        transform: translateY(1px) !important;
        box-shadow: 0 2px 8px var(--color-accent-glow) !important;
    }

    /* Share and Favorite buttons - below title */
    .single-listing .hh-title-info .lpshare-wrapper,
    .single-listing .hh-title-info .lpfavorite-wrapper {
        display: inline-flex !important;
        gap: 10px !important;
        margin-top: 12px !important;
    }

    .single-listing .lpshare-btn,
    .single-listing .lpfavorite-btn,
    .single-listing .share-btn,
    .single-listing .favorite-btn,
    .single-listing button[class*="secondary"],
    .single-listing [class*="lpshare-"],
    .single-listing [class*="lpfavorite-"] {
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
        background: rgba(255, 255, 255, 0.15) !important;
        backdrop-filter: blur(8px) !important;
        color: #FFFFFF !important;
        border: 1px solid rgba(255, 255, 255, 0.25) !important;
        border-radius: 20px !important;
        padding: 8px 14px !important;
        font-size: 12px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.04em !important;
        transition: all 0.2s ease !important;
        font-family: var(--font-body) !important;
    }

    .single-listing .lpshare-btn:active,
    .single-listing .lpfavorite-btn:active,
    .single-listing .share-btn:active,
    .single-listing .favorite-btn:active {
        background: rgba(255, 255, 255, 0.25) !important;
        transform: scale(0.97) !important;
    }

    .single-listing .lpshare-btn i,
    .single-listing .lpfavorite-btn i,
    .single-listing .share-btn i,
    .single-listing .favorite-btn i,
    .single-listing [class*="lpshare-"] i,
    .single-listing [class*="lpfavorite-"] i {
        color: var(--color-accent) !important;
        font-size: 14px !important;
    }

    /* Favorited state */
    .single-listing .lpfavorite-btn.favorited,
    .single-listing .favorite-btn.favorited {
        background: var(--color-accent) !important;
        border-color: var(--color-accent) !important;
    }

    .single-listing .lpfavorite-btn.favorited i,
    .single-listing .favorite-btn.favorited i {
        color: #FFFFFF !important;
    }

    /* ========================================
       7. CONTACT INFO - ICON LIST DESIGN
       ======================================== */

    .single-listing .hh-section.hh-contact,
    .single-listing [class*="contact-info"] {
        background: var(--color-card) !important;
    }

    /* Contact information - icon-based layout with light text */
    .single-listing .hh-sidebar-widget a[href^="tel"],
    .single-listing .hh-sidebar-widget a[href^="mailto"],
    .single-listing .hh-sidebar-widget a[href^="http"] {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        padding: 12px 0 !important;
        border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
        text-decoration: none !important;
        color: var(--color-text-medium-light) !important;
        transition: background-color 0.2s ease !important;
    }

    .single-listing .hh-sidebar-widget a[href^="tel"]:last-child,
    .single-listing .hh-sidebar-widget a[href^="mailto"]:last-child,
    .single-listing .hh-sidebar-widget a[href^="http"]:last-child {
        border-bottom: none !important;
    }

    /* Icon styling */
    .single-listing .hh-sidebar-widget a i,
    .single-listing .hh-sidebar-widget .icon {
        color: var(--color-accent) !important;
        font-size: 18px !important;
        width: 28px !important;
        height: 28px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        background: rgba(255, 107, 0, 0.1) !important;
        border-radius: 50% !important;
        flex-shrink: 0 !important;
    }

    /* Clickable area feedback */
    .single-listing .hh-sidebar-widget a:active {
        background-color: rgba(0, 0, 0, 0.03) !important;
    }

    /* Icon-based list items (legacy support) */
    .single-listing .hh-contact-item,
    .single-listing [class*="contact"] a,
    .single-listing [class*="contact"] .info-row {
        display: flex !important;
        align-items: center !important;
        gap: 12px !important;
        padding: 12px 0 !important;
        border-bottom: 1px solid #e9ecef !important;
        text-decoration: none !important;
    }

    .single-listing [class*="contact"] a:last-child,
    .single-listing [class*="contact"] .info-row:last-child {
        border-bottom: none !important;
    }

    /* Icons get accent color (legacy support) */
    .single-listing [class*="contact"] i,
    .single-listing [class*="contact"] .icon {
        color: var(--color-accent) !important;
        font-size: 18px !important;
        width: 24px !important;
        flex-shrink: 0 !important;
    }

    /* ========================================
       8. COMMUNITY VERIFICATION - TRUST BADGE
       ======================================== */

    /* Community Verification - dark card with orange accent */
    .single-listing .hh-verification-section,
    .single-listing .hh-section.hh-verification,
    .single-listing [class*="verification"] {
        background: var(--color-card) !important;
        border-left: 4px solid var(--color-accent) !important;
    }

    /* Large emoji in Community Verification */
    .single-listing .hh-verification-section .emoji,
    .single-listing [class*="verification"] .emoji,
    .single-listing .hh-verification-section [role="img"],
    .single-listing [class*="verification"] [role="img"] {
        font-size: 64px !important;
        line-height: 1 !important;
        display: block !important;
        margin: 16px auto !important;
        text-align: center !important;
    }

    /* Verification badge - orange to match brand */
    .single-listing .hh-verification-badge {
        display: inline-flex !important;
        align-items: center !important;
        gap: 8px !important;
        background: var(--color-accent) !important;
        color: #FFFFFF !important;
        padding: 10px 16px !important;
        border-radius: 20px !important;
        font-size: 13px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.05em !important;
        margin-bottom: 16px !important;
        box-shadow: 0 2px 8px var(--color-accent-glow) !important;
    }

    .single-listing .hh-verification-badge i {
        font-size: 16px !important;
    }

    /* Voting buttons - light style on dark background */
    .single-listing .hh-vote-button {
        display: inline-flex !important;
        align-items: center !important;
        gap: 6px !important;
        padding: 10px 16px !important;
        border-radius: 8px !important;
        border: 1px solid rgba(255, 255, 255, 0.2) !important;
        background: rgba(255, 255, 255, 0.1) !important;
        color: var(--color-text-light) !important;
        font-size: 14px !important;
        font-weight: 600 !important;
        transition: all 0.2s ease !important;
    }

    .single-listing .hh-vote-button:active {
        transform: scale(0.97) !important;
        border-color: var(--color-accent) !important;
    }

    .single-listing .hh-vote-button.voted {
        background: var(--color-accent) !important;
        color: #FFFFFF !important;
        border-color: var(--color-accent) !important;
    }

    /* ========================================
       9. REVIEWS - CARD STACK
       ======================================== */

    /* Write Review Section - dark card */
    .single-listing .hh-review-section {
        background: var(--color-card) !important;
    }

    /* Star rating input - accent color stars */
    .single-listing .star-rating,
    .single-listing [class*="rating"] {
        display: flex !important;
        gap: 8px !important;
        margin: 16px 0 !important;
    }

    .single-listing .star-rating i,
    .single-listing .star-rating .fa,
    .single-listing .star-rating .fa-star,
    .single-listing [class*="rating"] i,
    .single-listing [class*="rating"] .fa,
    .single-listing [class*="rating"] .fa-star,
    .single-listing .hh-review-section i[class*="star"] {
        font-size: 32px !important;
        color: var(--color-accent) !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
        opacity: 0.3 !important;
    }

    .single-listing .star-rating i.selected,
    .single-listing .star-rating i:hover,
    .single-listing .star-rating .fa-star.selected,
    .single-listing .star-rating .fa-star:hover,
    .single-listing [class*="rating"] i.selected,
    .single-listing [class*="rating"] i:hover,
    .single-listing .hh-review-section i[class*="star"]:hover,
    .single-listing .hh-review-section i[class*="star"].selected {
        color: var(--color-accent) !important;
        opacity: 1 !important;
    }

    /* FORCE all review section text to be light colored for readability */
    html body.single-listing .hh-review-section label,
    html body.single-listing .hh-review-section span:not([class*="star"]):not(.fa):not(.far):not(.fas),
    html body.single-listing [class*="review"] label,
    html body.single-listing [class*="review"] span:not([class*="star"]):not(.fa):not(.far):not(.fas),
    html body.single-listing .review-label,
    html body.single-listing .rating-label,
    html body.single-listing section[class*="review"] label,
    html body.single-listing section[class*="review"] span:not([class*="star"]):not(.fa):not(.far):not(.fas),
    html body.single-listing div[class*="review"] label,
    html body.single-listing div[class*="review"] span:not([class*="star"]):not(.fa):not(.far):not(.fas) {
        color: rgba(255, 255, 255, 0.95) !important;
        font-weight: 500 !important;
    }

    /* CATCH-ALL: Force any remaining dark gray text in review sections to be light */
    html body.single-listing .hh-review-section *,
    html body.single-listing section[class*="review"] *,
    html body.single-listing div[class*="review"] *,
    html body.single-listing .hh-section[class*="review"] *,
    html body.single-listing *[class*="review-"] * {
        color: rgba(255, 255, 255, 0.9) !important;
    }

    /* Keep stars orange (higher specificity to override catch-all) */
    html body.single-listing .star-rating i,
    html body.single-listing [class*="star"] i,
    html body.single-listing i[class*="star"],
    html body.single-listing .fa-star {
        color: var(--color-accent) !important;
    }

    /* Review textarea - large dark style */
    .single-listing .hh-review-textarea,
    .single-listing textarea[placeholder*="experience"],
    .single-listing textarea[placeholder*="review"],
    .single-listing .review-form textarea,
    .single-listing textarea {
        width: 100% !important;
        min-height: 120px !important;
        padding: 16px !important;
        background: rgba(0, 0, 0, 0.4) !important;
        color: var(--color-text-light) !important;
        border: 2px solid rgba(255, 255, 255, 0.2) !important;
        border-radius: 12px !important;
        font-family: var(--font-body) !important;
        font-size: 15px !important;
        line-height: 1.6 !important;
        resize: vertical !important;
        transition: border-color 0.2s ease, background-color 0.2s ease !important;
    }

    .single-listing .hh-review-textarea::placeholder,
    .single-listing textarea::placeholder {
        color: rgba(255, 255, 255, 0.4) !important;
    }

    .single-listing .hh-review-textarea:focus,
    .single-listing textarea:focus {
        outline: none !important;
        border-color: var(--color-accent) !important;
        background: rgba(0, 0, 0, 0.5) !important;
    }

    /* Submit review button */
    .single-listing .hh-submit-review {
        background: var(--color-accent) !important;
        color: #FFFFFF !important;
        border: none !important;
        border-radius: 8px !important;
        padding: 14px 32px !important;
        font-family: var(--font-body) !important;
        font-size: 15px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.03em !important;
        box-shadow: 0 4px 12px var(--color-accent-glow) !important;
        cursor: pointer !important;
        transition: all 0.2s ease !important;
    }

    .single-listing .hh-submit-review:active {
        transform: translateY(1px) !important;
        box-shadow: 0 2px 8px var(--color-accent-glow) !important;
    }

    /* Review display cards - dark style */
    .single-listing .review-box,
    .single-listing .single-review {
        background: rgba(0, 0, 0, 0.2) !important;
        border-radius: 12px !important;
        padding: 16px !important;
        margin-bottom: 12px !important;
        border-left: 3px solid var(--color-accent) !important;
        box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2) !important;
    }

    .single-listing .review-author {
        font-weight: 600 !important;
        color: var(--color-text-light) !important;
        margin-bottom: 6px !important;
    }

    .single-listing .review-text {
        font-size: 14px !important;
        line-height: 1.6 !important;
        color: var(--color-text-medium-light) !important;
    }

    /* ========================================
       10. GALLERY CONTROLS - REFINED
       ======================================== */

    /* SEE MORE button - 20px height */
    .single-listing .hh-hero-full .hh-see-more-link,
    .single-listing .hh-hero-full [class*="see-more"],
    .single-listing .hh-hero-full [class*="view-gallery"] {
        position: absolute !important;
        bottom: 10px !important;
        right: 10px !important;
        top: auto !important;
        left: auto !important;
        background: rgba(0, 0, 0, 0.7) !important;
        backdrop-filter: blur(8px) !important;
        color: #FFFFFF !important;
        font-family: var(--font-body) !important;
        font-size: 10px !important;
        font-weight: 600 !important;
        text-transform: uppercase !important;
        letter-spacing: 0.02em !important;
        padding: 5px 8px !important;
        border-radius: 3px !important;
        border: none !important;
        z-index: 3 !important;
        transition: all 0.2s ease !important;
        text-decoration: none !important;
        box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3) !important;
        line-height: 1 !important;
        height: 20px !important;
        display: inline-flex !important;
        align-items: center !important;
        white-space: nowrap !important;
    }

    .single-listing .hh-see-more-link:hover,
    .single-listing .hh-see-more-link:active {
        background: rgba(0, 0, 0, 0.8) !important;
        transform: scale(0.98) !important;
    }

    /* Gallery arrows */
    .single-listing .hh-hero-full .slick-arrow,
    .single-listing .hh-hero-full [class*="arrow"] {
        background: rgba(255, 255, 255, 0.95) !important;
        backdrop-filter: blur(8px) !important;
        color: var(--color-text-dark) !important;
        width: 40px !important;
        height: 40px !important;
        border-radius: 50% !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
        z-index: 3 !important;
        border: none !important;
        font-size: 14px !important;
    }

    .single-listing .hh-hero-full .slick-prev {
        left: 16px !important;
    }

    .single-listing .hh-hero-full .slick-next {
        right: 16px !important;
    }

    /* Dots - minimal and elegant */
    .single-listing .hh-hero-full .slick-dots {
        bottom: 16px !important;
        z-index: 3 !important;
        display: flex !important;
        justify-content: center !important;
        gap: 8px !important;
    }

    .single-listing .hh-hero-full .slick-dots li button {
        background: rgba(255, 255, 255, 0.4) !important;
        width: 8px !important;
        height: 8px !important;
        border-radius: 50% !important;
        transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
        border: none !important;
    }

    .single-listing .hh-hero-full .slick-dots li.slick-active button {
        background: #FFFFFF !important;
        width: 24px !important;
        border-radius: 4px !important;
    }

    /* ========================================
       GALLERY MODAL / LIGHTBOX FIXES
       ======================================== */

    /* PhotoSwipe / Lightbox modal */
    .pswp,
    .photoswipe,
    [class*="lightbox"],
    [class*="gallery-modal"] {
        z-index: 99999 !important;
    }

    /* Ensure body doesn't lose styles when modal opens */
    body.single-listing.modal-open,
    body.single-listing.pswp-open {
        background: linear-gradient(180deg, var(--color-bg-dark) 0%, var(--color-bg-medium) 100%) !important;
    }

    /* Prevent layout shift when modal closes */
    .single-listing .hh-content-wrapper,
    .single-listing .hh-section {
        will-change: auto !important;
    }

    /* Gallery modal close button */
    .pswp__button--close,
    [class*="lightbox"] .close,
    [class*="gallery-modal"] .close {
        background: rgba(0, 0, 0, 0.8) !important;
        color: #FFFFFF !important;
        width: 44px !important;
        height: 44px !important;
        border-radius: 50% !important;
        backdrop-filter: blur(8px) !important;
    }

    /* ========================================
       11. SPACING & RHYTHM
       ======================================== */

    /* Content wrapper gets proper padding */
    .single-listing .hh-content-wrapper {
        padding-bottom: 60px !important;
    }

    /* ========================================
       12. HIDE CLUTTER
       ======================================== */

    /* Hide unwanted buttons */
    body.single-listing .see-filters-btn,
    body.single-listing [class*="see-filters"],
    body.single-listing .hh-mobile-filters-trigger,
    body.single-listing .hh-open-filters,
    body.single-listing #hh-open-filters,
    body.single-listing .expand-all-btn,
    body.single-listing [class*="expand-all"],
    body.single-listing [class*="expand-details"],
    body.single-listing .hh-expand-details,
    body.single-listing button[class*="expand"] {
        display: none !important;
    }

    /* Remove jarring borders */
    .single-listing .detail-section,
    .single-listing .content-section {
        border: none !important;
    }

    /* Remove separator lines */
    .single-listing hr,
    .single-listing .separator {
        display: none !important;
    }

    /* Hide empty transparent boxes and internal containers */
    .single-listing [class*="empty"],
    .single-listing .placeholder:empty {
        display: none !important;
    }

    /* Hide empty nested containers in About section */
    .single-listing .hh-about-content > div:empty,
    .single-listing .hh-about-content > .inner:empty,
    .single-listing .hh-about-content > [class*="content"]:empty,
    .single-listing .hh-about-content > [class*="text"]:empty,
    .single-listing .hh-section > div:empty {
        display: none !important;
    }

    /* Remove borders from nested boxes in About section */
    .single-listing .hh-about-content > div,
    .single-listing .hh-about-content > [class*="inner"],
    .single-listing .hh-section > div[class*="inner"] {
        border: none !important;
        background: transparent !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
    }

    /* CRITICAL FIX: Remove ALL card styling from .hh-about-content
     * The parent .hh-section already provides the card container
     * This prevents the "box within a box" appearance
     */
    .single-listing .hh-about-content {
        background: transparent !important;
        border: none !important;
        box-shadow: none !important;
        padding: 0 !important;
        margin: 0 !important;
        min-height: 0 !important;
        border-radius: 0 !important;
    }

    /* Fix About This Venue empty state - remove internal box appearance */
    .single-listing .hh-about-content {
        min-height: 0 !important;
    }

    .single-listing .hh-about-content:empty {
        padding: 12px !important;
        min-height: 40px !important;
    }

    /* Remove any pseudo-elements that might create boxes */
    .single-listing .hh-about-content::before,
    .single-listing .hh-about-content::after {
        display: none !important;
    }

    /* ========================================
       13. SMOOTH ANIMATIONS & FINAL POLISH
       ======================================== */

    /* Smooth card entrance animations */
    .single-listing .hh-section,
    .single-listing .hh-sidebar-widget,
    .single-listing .hh-about-content {
        animation: slideUpFade 0.4s cubic-bezier(0.4, 0, 0.2, 1) backwards !important;
    }

    /* Staggered animation delays */
    .single-listing .hh-section:nth-child(1),
    .single-listing .hh-sidebar-widget:nth-child(1) {
        animation-delay: 0.05s !important;
    }

    .single-listing .hh-section:nth-child(2),
    .single-listing .hh-sidebar-widget:nth-child(2) {
        animation-delay: 0.1s !important;
    }

    .single-listing .hh-section:nth-child(3),
    .single-listing .hh-sidebar-widget:nth-child(3) {
        animation-delay: 0.15s !important;
    }

    .single-listing .hh-section:nth-child(4),
    .single-listing .hh-sidebar-widget:nth-child(4) {
        animation-delay: 0.2s !important;
    }

    .single-listing .hh-section:nth-child(5),
    .single-listing .hh-sidebar-widget:nth-child(5) {
        animation-delay: 0.25s !important;
    }

    @keyframes slideUpFade {
        from {
            opacity: 0;
            transform: translateY(20px);
        }
        to {
            opacity: 1;
            transform: translateY(0);
        }
    }

    /* Button press feedback */
    .single-listing button,
    .single-listing a.button,
    .single-listing .btn {
        -webkit-tap-highlight-color: transparent !important;
        user-select: none !important;
    }

    /* Reduce motion for accessibility */
    @media (prefers-reduced-motion: reduce) {
        .single-listing * {
            animation-duration: 0.01ms !important;
            animation-iteration-count: 1 !important;
            transition-duration: 0.01ms !important;
        }
    }

}
