/**
 * Reviews Archive - Wide Layout with Sticky Sidebar
 * @since 1.0.0
 */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ==========================================================================
   DESIGN TOKENS
   ========================================================================== */
.ipx-reviews {
    --ipx-bg: #000;
    --ipx-surface: #16181c;
    --ipx-surface-2: #1d1f23;
    --ipx-surface-3: #2f3336;
    --ipx-text: #e7e9ea;
    --ipx-text-2: #71767b;
    --ipx-text-3: #536471;
    /* Use the global Indie Portal brand color (defined in public.css) */
    --ipx-accent: var(--ip-primary, var(--ip-primary));
    --ipx-border: #2f3336;
    --ipx-hover: rgba(255, 255, 255, 0.03);
    
    /* Recommendation colors */
    --ipx-rec-skip: #9d9d9d;
    --ipx-rec-play: #1eff00;
    --ipx-rec-complete: #ff8000;
    
    /* Interaction colors */
    --ipx-helpful: #00ba7c;
    --ipx-unhelpful: #f91880;
    --ipx-comment: #1d9bf0;
    
    --ipx-radius: 16px;
    --ipx-radius-sm: 12px;
    --ipx-transition: 0.15s ease;
    
    /* Layout */
    --ipx-sidebar-width: 280px;
    --ipx-max-width: 1200px;
    /* One sticky offset used across the /reviews page.
       Accounts for the fixed site header and provides predictable stacking.
       (We intentionally avoid JS-driven sticky toggles.) */
    --ipx-sticky-top: 88px;
}

/* Admin bar increases the effective top offset */
.admin-bar .ipx-reviews {
    --ipx-sticky-top: 120px;
}

/* ==========================================================================
   BASE
   ========================================================================== */
.ipx-reviews {
    background: var(--ipx-bg);
    color: var(--ipx-text);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
}

.ipx-reviews *, .ipx-reviews *::before, .ipx-reviews *::after {
    box-sizing: border-box;
}

.ipx-reviews a {
    color: inherit;
    text-decoration: none;
}

/* ==========================================================================
   HEADER
   ========================================================================== */
.ipx-reviews-header {
    border-bottom: 1px solid var(--ipx-border);
    background: rgba(0, 0, 0, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    /* Stabilization (7.8): the /reviews header is no longer sticky.
       Sticky stacking is handled by the sidebar (and only that), avoiding overlap.
    */
    position: relative;
    top: auto;
    z-index: 1;
}

.ipx-reviews-header-inner {
    max-width: var(--ipx-max-width);
    margin: 0 auto;
    padding: 20px 32px;
}

.ipx-reviews-title {
    font-size: 28px;
    font-weight: 700;
    margin: 0;
    color: var(--ipx-text);
}

.ipx-reviews-subtitle {
    font-size: 14px;
    color: var(--ipx-text-2);
    margin: 4px 0 0;
}

/* ==========================================================================
   LAYOUT - Two Column
   ========================================================================== */
.ipx-reviews-layout {
    max-width: var(--ipx-max-width);
    margin: 0 auto;
    display: flex;
    gap: 32px;
    padding: 0 32px;
}

/* ==========================================================================
   SIDEBAR - Sticky Filters
   ========================================================================== */
.ipx-sidebar {
    width: var(--ipx-sidebar-width);
    flex-shrink: 0;
}

.ipx-sidebar-backdrop {
    display: none;
}

.ipx-sidebar-inner {
    /* Stabilization (7.8): sticky is handled by .ipx-sidebar, not the inner wrapper. */
    position: relative;
    top: auto;
    padding: 24px 0;
}

.ipx-sidebar-section {
    margin-bottom: 28px;
}

.ipx-sidebar-title {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--ipx-text-2);
    margin: 0 0 12px;
    padding: 0 8px;
}

/* Sort Options */
.ipx-sort-options {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ipx-sort-option {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ipx-text-2);
    border-radius: var(--ipx-radius-sm);
    transition: var(--ipx-transition);
}

.ipx-sort-option:hover {
    background: var(--ipx-surface);
    color: var(--ipx-text);
}

.ipx-sort-option.active {
    background: rgba(200, 42, 239, 0.12);
    color: var(--ip-primary, #C82AEF);
}

.ipx-sort-option.active::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 3px;
    height: 24px;
    background: var(--ip-primary, #C82AEF);
    border-radius: 0 3px 3px 0;
}

.ipx-sort-option.active svg {
    color: var(--ip-primary, #C82AEF);
}

.ipx-sort-option {
    position: relative;
}

/* Filter Options */
.ipx-filter-options {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.ipx-filter-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ipx-text-2);
    border-radius: var(--ipx-radius-sm);
    transition: var(--ipx-transition);
}

.ipx-filter-option:hover {
    background: var(--ipx-surface);
    color: var(--ipx-text);
}

.ipx-filter-option.active {
    background: rgba(200, 42, 239, 0.12);
    color: var(--ip-primary, #C82AEF);
    border-left: 3px solid var(--ip-primary, #C82AEF);
    padding-left: 9px;
}

.ipx-opt-icon {
    font-size: 14px;
}

.ipx-opt-complete.active { color: var(--ipx-rec-complete); }
.ipx-opt-play.active { color: var(--ipx-rec-play); }
.ipx-opt-skip.active { color: var(--ipx-rec-skip); }

/* Sidebar Select */
.ipx-sidebar-select {
    width: 100%;
    background: var(--ipx-surface);
    border: 1px solid var(--ipx-border);
    border-radius: var(--ipx-radius-sm);
    padding: 12px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ipx-text);
    cursor: pointer;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2371767b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 14px center;
}

.ipx-sidebar-select:hover {
    background-color: var(--ipx-surface-2);
    border-color: var(--ipx-text-3);
}

.ipx-sidebar-select:focus {
    outline: none;
    border-color: var(--ipx-accent);
}

.ipx-sidebar-select option {
    background: var(--ipx-surface);
}

/* Clear Filters */
.ipx-clear-filters {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ipx-unhelpful);
    border: 1px solid rgba(249, 24, 128, 0.3);
    border-radius: var(--ipx-radius-sm);
    transition: var(--ipx-transition);
}

.ipx-clear-filters:hover {
    background: rgba(249, 24, 128, 0.1);
    border-color: var(--ipx-unhelpful);
}

/* ==========================================================================
   MAIN FEED
   ========================================================================== */
.ipx-reviews-feed {
    flex: 1;
    min-width: 0;
    padding: 24px 0;
}

/* Mobile Filters - Hidden on Desktop */
.ipx-mobile-filters {
    display: none;
}

/* Reviews List */
.ipx-reviews-list {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* ==========================================================================
   REVIEW CARD - Large, Inviting, Uniform
   ========================================================================== */
.ipx-review-card {
    display: flex;
    background: var(--ipx-surface);
    border: 1px solid var(--ipx-border);
    border-radius: var(--ipx-radius);
    overflow: hidden;
    transition: border-color var(--ipx-transition), transform var(--ipx-transition), box-shadow var(--ipx-transition);
}

.ipx-review-card:hover {
    border-color: var(--ipx-text-3);
    transform: translateY(-3px);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

/* Card Poster - Full card height, image not stretched */
.ipx-card-poster {
    flex-shrink: 0;
    width: 220px;
    background: linear-gradient(135deg, var(--ipx-surface-2) 0%, var(--ipx-surface-3) 100%);
    display: flex;
    align-items: center;
    justify-content: center;
}

.ipx-card-poster img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 16px;
}

.ipx-review-card:hover .ipx-card-poster img {
    transform: scale(1.02);
    transition: transform var(--ipx-transition);
}

.ipx-card-poster .ipx-poster-placeholder {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 56px;
    color: var(--ipx-text-3);
}

/* Card Content */
.ipx-card-content {
    flex: 1;
    min-width: 0;
    padding: 24px 28px;
    display: flex;
    flex-direction: column;
    position: relative;
}

/* Rating Badge - Top Right */
.ipx-card-rating {
    position: absolute;
    top: 24px;
    right: 28px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 16px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 700;
}

.ipx-rating-icon {
    font-size: 16px;
}

.ipx-rating-label {
    letter-spacing: -0.01em;
}

.ipx-rating-skip {
    background: rgba(157, 157, 157, 0.15);
    color: var(--ipx-rec-skip);
    border: 1px solid rgba(157, 157, 157, 0.25);
}

.ipx-rating-play {
    background: rgba(30, 255, 0, 0.12);
    color: var(--ipx-rec-play);
    border: 1px solid rgba(30, 255, 0, 0.25);
}

.ipx-rating-complete {
    background: rgba(255, 128, 0, 0.12);
    color: var(--ipx-rec-complete);
    border: 1px solid rgba(255, 128, 0, 0.25);
}

/* Card Header */
.ipx-card-header {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    margin-bottom: 16px;
    padding-right: 160px; /* Space for rating badge */
}

.ipx-card-avatar {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    flex-shrink: 0;
}

.ipx-card-meta {
    flex: 1;
    min-width: 0;
    line-height: 1.4;
}

.ipx-card-author {
    font-weight: 700;
    font-size: 16px;
    color: var(--ipx-text);
}

.ipx-card-context {
    font-size: 15px;
    color: var(--ipx-text-2);
    display: block;
    margin-top: 2px;
}

/* Game link in PINK */
.ipx-game-link {
    color: var(--ipx-accent) !important;
    font-weight: 600;
}

.ipx-game-link:hover {
    text-decoration: underline;
}

.ipx-card-time {
    color: var(--ipx-text-3);
}

/* Headline */
.ipx-card-headline {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 12px;
    color: var(--ipx-text);
}

.ipx-card-headline a:hover {
    text-decoration: underline;
}

/* Review Text - Show 4 lines before truncating */
.ipx-card-text {
    font-size: 15px;
    line-height: 1.6;
    color: var(--ipx-text);
    flex: 1;
}

.ipx-card-text p {
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.ipx-read-more {
    display: block;
    margin-top: 10px;
    color: var(--ipx-accent);
    font-weight: 600;
    font-size: 14px;
    padding: 4px 0;
    position: relative;
    z-index: 1;
}

.ipx-read-more:hover {
    text-decoration: underline;
    color: var(--ipx-accent);
}

/* Play Stats */
.ipx-card-stats {
    display: flex;
    gap: 20px;
    margin-top: auto;
    padding-top: 12px;
}

.ipx-stat {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: var(--ipx-text-2);
}

.ipx-stat svg {
    opacity: 0.7;
}

/* ==========================================================================
   ACTION BAR
   ========================================================================== */
.ipx-card-actions {
    display: flex;
    align-items: center;
    gap: 4px;
    margin: 16px -10px 0;
    padding-top: 16px;
    border-top: 1px solid var(--ipx-border);
}

.ipx-action-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 12px;
    font-size: 13px;
    color: var(--ipx-text-2);
    background: transparent;
    border: none;
    border-radius: 9999px;
    cursor: pointer;
    transition: var(--ipx-transition);
}

.ipx-action-btn:hover {
    background: rgba(255, 255, 255, 0.08);
}

.ipx-action-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
}

.ipx-action-btn svg {
    transition: var(--ipx-transition);
}

.ipx-action-count {
    font-weight: 500;
    min-width: 16px;
}

/* Actions: Brand-synced (match single game section navigator) */
.ipx-action-btn:hover{background: var(--ip-primary-light); color: var(--ip-primary);}
.ipx-action-btn:hover svg{stroke: var(--ip-primary);}
.ipx-action-helpful.active, .ipx-action-unhelpful.active{color: var(--ip-primary);}
.ipx-action-helpful.active svg, .ipx-action-unhelpful.active svg{fill: var(--ip-primary); stroke: var(--ip-primary);}
.ipx-action-comment:hover, .ipx-action-share:hover{color: var(--ip-primary);}
.ipx-action-comment:hover svg, .ipx-action-share:hover svg{stroke: var(--ip-primary);}

/* ==========================================================================
   EMPTY STATE
   ========================================================================== */
.ipx-reviews-empty {
    text-align: center;
    padding: 80px 20px;
    color: var(--ipx-text-2);
}

.ipx-reviews-empty svg {
    margin-bottom: 16px;
    opacity: 0.4;
}

.ipx-reviews-empty h3 {
    font-size: 20px;
    font-weight: 700;
    color: var(--ipx-text);
    margin: 0 0 8px;
}

.ipx-reviews-empty p {
    font-size: 15px;
    margin: 0;
}

.ipx-reviews-empty-actions {
    margin-top: 18px;
}

.ipx-clear-filters {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 14px;
    border-radius: 9999px;
    border: 1px solid var(--ipx-border);
    background: var(--ipx-surface);
    color: var(--ipx-text);
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

.ipx-clear-filters:hover {
    background: var(--ipx-surface-2);
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */
.ipx-pagination {
    margin-top: 32px;
    padding-top: 24px;
    border-top: 1px solid var(--ipx-border);
}

.ipx-pagination ul {
    display: flex;
    justify-content: center;
    gap: 4px;
    list-style: none;
    margin: 0;
    padding: 0;
}

.ipx-pagination li a,
.ipx-pagination li span {
    display: block;
    padding: 10px 16px;
    font-size: 14px;
    font-weight: 500;
    color: var(--ipx-text);
    background: var(--ipx-surface);
    border: 1px solid var(--ipx-border);
    border-radius: 9999px;
    transition: var(--ipx-transition);
}

.ipx-pagination li a:hover {
    background: var(--ipx-surface-2);
    border-color: var(--ipx-text-3);
}

.ipx-pagination li span.current {
    background: var(--ipx-accent);
    border-color: var(--ipx-accent);
}

/* Share modal is handled globally via assets/js/public.js (.ipx-share-btn). */

/* ==========================================================================
   RESPONSIVE - Tablet
   ========================================================================== */
@media (max-width: 1024px) {
    .ipx-reviews-layout {
        padding: 0 20px;
        gap: 24px;
    }
    
    .ipx-sidebar {
        width: 220px;
    }
    
    .ipx-card-poster {
        width: 180px;
    }
    
    .ipx-card-content {
        padding: 20px 24px;
    }
    
    .ipx-card-header {
        padding-right: 140px;
    }
    
    .ipx-card-headline {
        font-size: 18px;
    }
    
    .ipx-card-text p {
        -webkit-line-clamp: 3;
    }
}

/* ==========================================================================
   RESPONSIVE - Mobile
   ========================================================================== */
@media (max-width: 768px) {
    .ipx-reviews-header-inner {
        padding: 16px 20px;
    }
    
    .ipx-reviews-title {
        font-size: 22px;
    }
    
    .ipx-reviews-layout {
        flex-direction: column;
        padding: 0;
    }
    
    /* Hide sidebar on mobile */
    .ipx-sidebar {
        display: none;
    }

    .ipx-sidebar-backdrop.is-open {
        display: block;
        position: fixed;
        inset: 0;
        background: rgba(0, 0, 0, 0.55);
        z-index: 199;
    }

    .ipx-sidebar.is-open {
        display: block;
        position: fixed;
        top: 0;
        right: 0;
        height: 100vh;
        width: min(86vw, 360px);
        background: var(--ipx-surface);
        z-index: 200;
        overflow-y: auto;
        border-left: 1px solid var(--ipx-border);
    }

    .ipx-sidebar.is-open .ipx-sidebar-inner {
        position: static;
        top: auto;
        padding: 20px 16px 24px;
    }
    
    /* Show mobile filters */
    .ipx-mobile-filters {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        padding: 12px 20px;
        background: var(--ipx-surface);
        border-bottom: 1px solid var(--ipx-border);
        position: sticky;
        top: 72px;
        z-index: 90;
    }
    
    .ipx-mobile-filter-btn {
        display: flex;
        align-items: center;
        gap: 8px;
        padding: 10px 16px;
        font-size: 14px;
        font-weight: 500;
        color: var(--ipx-text);
        background: var(--ipx-surface-2);
        border: 1px solid var(--ipx-border);
        border-radius: 9999px;
        cursor: pointer;
    }
    
    .ipx-mobile-sort select {
        background: var(--ipx-surface-2);
        border: 1px solid var(--ipx-border);
        border-radius: 9999px;
        padding: 10px 32px 10px 16px;
        font-size: 14px;
        font-weight: 500;
        color: var(--ipx-text);
        appearance: none;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2371767b' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: right 12px center;
    }
    
    .ipx-reviews-feed {
        padding: 16px;
    }
    
    .ipx-reviews-list {
        gap: 12px;
    }
    
    /* Mobile Card - horizontal, smaller poster */
    .ipx-review-card {
        flex-direction: row;
    }
    
    .ipx-card-poster {
        width: 100px;
    }
    
    .ipx-card-poster img {
        padding: 10px;
    }
    
    .ipx-card-content {
        padding: 12px 14px;
    }
    
    .ipx-card-rating {
        position: static;
        margin-bottom: 10px;
        align-self: flex-start;
        padding: 6px 10px;
        font-size: 11px;
    }
    
    .ipx-rating-icon {
        font-size: 12px;
    }
    
    .ipx-card-header {
        padding-right: 0;
    }
    
    .ipx-card-avatar {
        width: 28px;
        height: 28px;
    }
    
    .ipx-card-author {
        font-size: 13px;
    }
    
    .ipx-card-context {
        font-size: 12px;
    }
    
    .ipx-card-headline {
        font-size: 14px;
    }
    
    .ipx-card-text {
        font-size: 13px;
    }
    
    .ipx-card-text p {
        -webkit-line-clamp: 2;
    }
    
    .ipx-card-actions {
        margin: 8px -6px 0;
        padding-top: 8px;
    }
    
    .ipx-action-btn {
        padding: 6px 8px;
    }
    
    .ipx-action-btn svg {
        width: 16px;
        height: 16px;
    }
}

@media (max-width: 480px) {
    .ipx-card-poster {
        width: 80px;
    }
    
    .ipx-card-poster img {
        padding: 8px;
    }
    
    .ipx-card-content {
        padding: 10px 12px;
    }
    
    .ipx-card-avatar {
        width: 24px;
        height: 24px;
    }
    
    .ipx-card-author {
        font-size: 12px;
    }
    
    .ipx-card-context {
        font-size: 11px;
    }
    
    .ipx-card-headline {
        font-size: 13px;
    }
    
    .ipx-card-text {
        font-size: 12px;
    }
    
    .ipx-action-btn {
        padding: 5px 6px;
    }
    
    .ipx-action-btn svg {
        width: 14px;
        height: 14px;
    }
    
    .ipx-action-count {
        font-size: 11px;
    }
}


/* Reviews Feed: New items banner (Phase 6)
   Stabilization (7.8): keep it in normal flow (non-sticky) to avoid stacking conflicts. */
.ipx-feed-new-banner{position:relative;top:auto;z-index:1;padding:10px 0;}
.ipx-feed-new-button{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;border-radius:14px;border:1px solid rgba(200,42,239,.35);background:rgba(200,42,239,.10);backdrop-filter:blur(8px);font-weight:800;cursor:pointer;color:var(--ip-primary);box-shadow:0 10px 30px rgba(0,0,0,.25)}
.ipx-feed-new-button:hover{background:rgba(200,42,239,.16);border-color:rgba(200,42,239,.55);transform:translateY(-1px)}


/* --------------------------------------------------------------------------
   Reviews Feed Card (Phase 7.1)
   Full visual overhaul: compact, scan-first, no dead columns, consistent with /games UI.
   -------------------------------------------------------------------------- */

/* Ensure legacy archive card layout does not bleed into feed cards */
.ipx-review-card.ipx-review-feed-card{
    display:block !important;
    padding:16px !important;
    border-radius:18px;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(255,255,255,.035);
    backdrop-filter:blur(6px);
    margin-bottom:14px;
    transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}

.ipx-review-card.ipx-review-feed-card:hover{
    border-color: rgba(200, 42, 239, 0.35);
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.25), 0 0 0 1px rgba(200, 42, 239, 0.15);
    transform: translateY(-2px);
}

/* Layout: featured image column + content column (Phase 7.3) */
.ipx-review-card.ipx-review-feed-card .ipx-rf-layout{
    display:flex;
    align-items:flex-start;
    gap:20px;
    flex-wrap: wrap;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-body{flex:1;min-width:0;}

.ipx-review-card.ipx-review-feed-card .ipx-rf-header{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:14px;
    flex-wrap: wrap;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-cover{
    /* Match dashboard styling: smaller, square-ish cover */
    width:140px;
    flex-shrink: 0;
    aspect-ratio:3/4;
    border-radius:12px;
    overflow:hidden;
    display:block;
    border:1px solid rgba(255,255,255,.12);
    background:rgba(0,0,0,.22);
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-cover img{
    width:100%;
    height:100%;
    object-fit:cover;
    display:block;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-cover-fallback{
    width:100%;
    height:100%;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:28px;
    opacity:.85;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-head-main{flex:1;min-width:0;}

/* Status/badge area (top right) */
.ipx-review-card.ipx-review-feed-card .ipx-rf-head-aside {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    flex-shrink: 0;
}

/* Style the recommendation badge on /reviews */
.ipx-review-card.ipx-review-feed-card .ip-rc-recommendation {
    padding: 6px 12px;
    border-radius: 16px;
    font-size: 12px;
    font-weight: 700;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-game-row{
    display:flex;
    align-items:center;
    gap:10px;
    flex-wrap:wrap;
    margin-bottom: 6px;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-game-title{
    font-weight:700;
    letter-spacing:-.01em;
    text-decoration:none;
    line-height:1.3;
    font-size:15px;
    /* Allow title to wrap instead of truncating */
    white-space: normal;
    word-break: break-word;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-chip{
    padding:6px 10px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.14);
    background:rgba(255,255,255,.04);
    font-size:12px;
    opacity:.92;
    white-space:nowrap;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-chip-muted{
    opacity:.8;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-reviewer-row{
    display:flex;
    align-items:center;
    gap:8px;
    margin-top:8px;
    opacity:.92;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-avatar{
    width:28px;
    height:28px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.18);
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-author{
    font-weight:800;
    font-size:13px;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-dot{opacity:.65}
.ipx-review-card.ipx-review-feed-card .ipx-rf-time{opacity:.75;font-size:13px}

.ipx-review-card.ipx-review-feed-card .ipx-rf-verdict{
    flex:0 0 auto;
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:8px 12px;
    border-radius:999px;
    border:1px solid rgba(255,255,255,.16);
    background:rgba(0,0,0,.25);
    font-weight:900;
    font-size:12px;
    white-space:nowrap;
}

/* Optional subtle tints by verdict */
.ipx-review-card.ipx-review-feed-card .ipx-rf-verdict-play{border-color:rgba(46,204,113,.35)}
.ipx-review-card.ipx-review-feed-card .ipx-rf-verdict-complete{border-color:rgba(46,204,113,.45)}
.ipx-review-card.ipx-review-feed-card .ipx-rf-verdict-skip{border-color:rgba(231,76,60,.35)}

/* Recommendation badge emoji (Phase 7.3) */
.ip-rc-recommendation .ip-rc-emoji{margin-right:6px;}

.ipx-review-card.ipx-review-feed-card .ipx-rf-content{
    margin-top:12px;
}

/* Expanded state shows full inline text */
.ipx-review-card.ipx-review-feed-card.ipx-rf-expanded .ipx-rf-excerpt{
    display:block;
    -webkit-line-clamp:unset;
    overflow:visible;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-headline{
    margin:0 0 8px;
    font-size:16px;
    font-weight: 700;
    line-height:1.35;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-headline a,
.ipx-review-card.ipx-review-feed-card .ipx-rf-headline button{
    text-decoration:none;
    color:inherit;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-toggle{
    appearance:none;
    background:transparent;
    border:0;
    padding:0;
    font:inherit;
    text-align:left;
    cursor:pointer;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-toggle:hover{
    opacity:.92;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-excerpt{
    margin:0;
    color: rgba(255,255,255,0.75);
    font-size:14px;
    line-height:1.6;
    display:-webkit-box;
    -webkit-line-clamp:3;
    -webkit-box-orient:vertical;
    overflow:hidden;
}

/* Expand state: show full text inline without clamping (Phase 7.3) */
.ipx-review-card.ipx-review-feed-card.ipx-rf-expanded .ipx-rf-excerpt{
    display:block;
    -webkit-line-clamp:unset;
    overflow:visible;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-readfull{
    margin-top:10px;
    padding:0;
    border:0;
    background:transparent;
    color: var(--ip-primary, #C82AEF);
    font-weight:800;
    font-size:13px;
    cursor:pointer;
    transition: color 0.15s ease;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-readfull:hover{
    color: #d64ff2;
    text-decoration: underline;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-full{
    margin-top:12px;
    padding-top:12px;
    border-top:1px solid rgba(255,255,255,.10);
    opacity:.95;
}

.ipx-review-card.ipx-review-feed-card.ipx-rf-expanded .ipx-rf-excerpt{
    -webkit-line-clamp:initial;
    overflow:visible;
}

/* Actions footer - FULL WIDTH at bottom of card (outside ipx-rf-body) */
.ipx-review-card.ipx-review-feed-card .ipx-rf-actions{
    display:flex;
    align-items:center;
    gap:12px;
    margin-top:16px;
    padding-top:16px;
    border-top: 1px solid rgba(255,255,255,0.08);
    width: 100%;
    flex-basis: 100%;
}

/* Phase 7.87: make blank card space clickable + add View Full Review CTA */
.ipx-review-card.ipx-review-feed-card{cursor:pointer;}
.ipx-review-card.ipx-review-feed-card a,
.ipx-review-card.ipx-review-feed-card button{cursor:auto;}
.ipx-review-card.ipx-review-feed-card .ipx-rf-view-full{margin-left:auto;}

/* Make the "View Full Review" CTA prominent with purple accent. */
.ipx-review-card.ipx-review-feed-card .ipx-rf-view-full.ipx-btn-primary{
    background: linear-gradient(135deg, var(--ip-primary, #C82AEF), #9333ea) !important;
    background-image: linear-gradient(135deg, var(--ip-primary, #C82AEF), #9333ea) !important;
    border: 1px solid var(--ip-primary, #C82AEF);
    color: #fff;
    box-shadow: 0 4px 15px rgba(200, 42, 239, 0.3) !important;
    transform: none !important;
    font-weight: 700;
}

.ipx-review-card.ipx-review-feed-card .ipx-rf-view-full.ipx-btn-primary:hover{
    background: linear-gradient(135deg, #d64ff2, #a855f7) !important;
    background-image: linear-gradient(135deg, #d64ff2, #a855f7) !important;
    box-shadow: 0 6px 20px rgba(200, 42, 239, 0.4) !important;
    transform: translateY(-2px) !important;
}

/* Phase 7.87: smooth feed transitions when filters are applied (avoid footer jump) */
#ipx-reviews-feed.ipx-feed-is-loading{
    transition: opacity .18s ease, transform .18s ease;
    will-change: opacity, transform;
}

#ipx-reviews-feed.ipx-feed-is-loading.ipx-feed-fadeout{
    opacity: 0;
    transform: translateY(8px);
}

/* Phase 7.88: empty state for AJAX filter results */
.ipx-feed-empty{
    padding: 22px;
    border: 1px solid rgba(255,255,255,.10);
    border-radius: 18px;
    background: rgba(0,0,0,.35);
    color: rgba(255,255,255,.80);
    font-weight: 700;
}

.ipx-review-card.ipx-review-feed-card .ipx-action-btn{
    padding:8px 10px;
    border-radius:12px;
    opacity:.88;
    border: 1px solid transparent;
    transition: all 0.15s ease;
}

.ipx-review-card.ipx-review-feed-card .ipx-action-btn:hover{
    opacity:1;
    background: rgba(200, 42, 239, 0.12);
    border-color: rgba(200, 42, 239, 0.25);
    color: var(--ip-primary, #C82AEF);
}

.ipx-review-card.ipx-review-feed-card .ipx-action-btn:hover svg{
    stroke: var(--ip-primary, #C82AEF);
}

.ipx-review-card.ipx-review-feed-card .ipx-action-btn.active{
    color: var(--ip-primary, #C82AEF);
    background: rgba(200, 42, 239, 0.12);
}

.ipx-review-card.ipx-review-feed-card .ipx-action-btn.active svg{
    fill: var(--ip-primary, #C82AEF);
    stroke: var(--ip-primary, #C82AEF);
}

@media (max-width: 768px) {
    .ipx-review-card.ipx-review-feed-card{padding:14px !important;}
    .ipx-review-card.ipx-review-feed-card .ipx-rf-cover{width:120px;flex-basis:120px}
    .ipx-review-card.ipx-review-feed-card .ipx-rf-game-title{font-size:15px}
}

@media (max-width: 480px) {
    .ipx-review-card.ipx-review-feed-card .ipx-rf-header{gap:12px}
    .ipx-review-card.ipx-review-feed-card .ipx-rf-cover{width:104px;flex-basis:104px}
    .ipx-review-card.ipx-review-feed-card .ipx-rf-headline{font-size:16px}
    .ipx-review-card.ipx-review-feed-card .ipx-rf-excerpt{font-size:12px}
}

/* Phase 7.4 header tightening */
.ipx-reviews-header{padding:24px 0 10px;}
.ipx-reviews-header-inner{max-width:1200px;margin:0 auto;padding:0 24px;}
.ipx-reviews-title{margin:0 0 6px;}
.ipx-reviews-subtitle{margin:0;}

/* Phase 7.5 sidebar: tabbed panels that do not shift the feed
   Stabilization (7.8): sidebar stickiness is pure CSS using a single shared offset.
   No JS toggles and no layout overlap. */
.ipx-sidebar{position:sticky;top:var(--ipx-sticky-top);align-self:flex-start;}
.ipx-sidebar-inner{position:relative;padding:12px 10px;overflow:visible;max-height:none;}
.ipx-filter-tabs{display:flex;gap:8px;margin:0 0 10px;}
.ipx-filter-tab{
    flex:1;
    appearance:none;
    border:1px solid rgba(255,255,255,.10);
    background:rgba(255,255,255,.04);
    color:rgba(255,255,255,.86);
    border-radius:14px;
    padding:10px 10px;
    font-weight:800;
    font-size:13px;
    cursor:pointer;
    transition:transform .12s ease, background .12s ease, border-color .12s ease, box-shadow .12s ease;
}
.ipx-filter-tab:hover{transform:translateY(-1px);background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.16);}
.ipx-filter-tab.active{
    background:var(--ip-primary, #C82AEF);
    border-color:var(--ip-primary, #C82AEF);
    color:#fff;
    box-shadow:0 4px 14px rgba(200,42,239,.35);
}

.ipx-filter-panels{position:relative;}
.ipx-filter-panel{
    display:none;
    padding:10px 6px 6px;
    border-radius:16px;
    background:rgba(255,255,255,.02);
}
.ipx-filter-panel.active{display:block;}

/* Allow long platform lists without forcing sidebar scrollbars:
   only the platform panel can scroll internally when needed. */
.ipx-filter-panel[data-ipx-panel="platform"]{
    overflow-y:auto;
    max-height:420px;
    padding-right:6px;
}
.ipx-sidebar-title{font-size:12px;letter-spacing:.08em;text-transform:uppercase;margin:0 0 10px;opacity:.75;}
.ipx-sort-option,.ipx-filter-option{padding:9px 10px;border-radius:14px;font-size:13px;line-height:1.15;}
/* Phase 7.7: Platform search removed (buttons-only UI) */

/* Fix 5: platform buttons should never truncate labels.
   Use a 2-column wrap layout (more room per button than 3-column grids). */
.ipx-platform-grid{
    display:flex;
    flex-wrap:wrap;
    gap:6px;
    align-items:stretch;
}
.ipx-platform-grid .ipx-filter-option{
    flex: 1 1 calc(50% - 6px);
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
    word-break:break-word;
}


/* Phase 7.4: Reviews hero (mirrors /games hero) */
.ipx-reviews .ipx-directory-hero{position:relative;border-radius:22px;overflow:hidden;margin:10px auto 18px;max-width:1200px;min-height:360px;background:#0b0b0d;border:1px solid rgba(255,255,255,.08);} 
.ipx-reviews .ipx-hero-media{position:absolute;inset:0;} 
.ipx-reviews .ipx-hero-video,.ipx-reviews .ipx-hero-fallback,.ipx-reviews .ipx-hero-youtube{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;} 
.ipx-reviews .ipx-hero-fallback{object-position:center;} 
.ipx-reviews .ipx-hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.35) 55%, rgba(0,0,0,.15) 100%);} 
.ipx-reviews .ipx-hero-content{position:relative;z-index:2;padding:42px 40px;max-width:720px;} 
.ipx-reviews .ipx-hero-kicker{display:inline-block;font-weight:800;letter-spacing:.08em;text-transform:uppercase;font-size:12px;color:rgba(255,255,255,.72);} 
.ipx-reviews .ipx-hero-title{margin:10px 0 10px;font-size:44px;line-height:1.05;} 
.ipx-reviews .ipx-hero-desc{margin:0 0 18px;color:rgba(255,255,255,.78);font-size:16px;line-height:1.45;} 
.ipx-reviews .ipx-hero-cta{display:inline-flex;align-items:center;justify-content:center;padding:12px 16px;border-radius:14px;font-weight:800;} 
@media (max-width: 900px){.ipx-reviews .ipx-directory-hero{min-height:300px;margin:8px 12px 12px;} .ipx-reviews .ipx-hero-content{padding:28px 22px;} .ipx-reviews .ipx-hero-title{font-size:34px;}}
