/* ======================================================================
   SOFTWARE REVIEWS - DETAIL PAGE CSS
   Two-Column Layout Structure Implementation
   ====================================================================== */

/* ======================================================================
   MAIN CONTAINER & LAYOUT FOUNDATION
   ====================================================================== */
.sm-reviews-tab-content {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    display: block !important;
    clear: both !important;
}

.sm-reviews-section {
    margin-bottom: 30px;
}

/* ======================================================================
   OVERALL RATING CARD & HIGHLIGHTS SECTION
   ====================================================================== */
.sm-overall-card {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    border: 1px solid #e5e7eb;
    padding: 32px;
    margin-bottom: 32px;
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box !important;
    display: block !important;
}

.sm-overall-rating-container {
    text-align: center;
    margin-bottom: 40px;
    padding-bottom: 24px;
    border-bottom: 1px solid #f3f4f6;
}

.sm-section-title {
    font-size: 20px;
    font-weight: 700;
    color: #1f2937;
    margin: 0 0 24px 0;
    text-align: center;
    letter-spacing: -0.025em;
}

.sm-overall-rating-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}

.sm-rating-number {
    font-size: 56px;
    font-weight: 800;
    color: #1f2937;
    line-height: 1;
    margin-bottom: 12px;
    letter-spacing: -0.05em;
}

.sm-rating-stars {
    display: flex;
    gap: 4px;
}

/* Force horizontal alignment for all primary star rows (prevents theme overrides) */
.sm-rating-display .sm-rating-stars,
.sm-overall-rating-display .sm-rating-stars,
.sm-user-single-rating .sm-rating-stars,
.sm-secondary-rating-value .sm-secondary-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 4px !important;
    white-space: nowrap !important;
}

.sm-star {
    font-size: 36px;
    color: #e5e7eb;
    transition: color 0.2s ease;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

/* Ensure each star remains inline to avoid vertical stacking */
.sm-rating-stars .sm-star {
    display: inline-block !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    float: none !important;
    margin: 0 2px 0 0 !important;
}

.sm-star.sm-star-filled {
    color: #f97316 !important;
    text-shadow: 0 1px 2px rgba(249, 115, 22, 0.2);
}

.sm-star.sm-star-half {
    color: #f97316 !important;
    text-shadow: 0 1px 2px rgba(249, 115, 22, 0.2);
}

/* High priority star color overrides */
html .sm-star.sm-star-filled,
body .sm-star.sm-star-filled,
.sm-overall-rating-display .sm-star.sm-star-filled,
.sm-rating-stars .sm-star.sm-star-filled {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

html .sm-star.sm-star-half,
body .sm-star.sm-star-half,
.sm-overall-rating-display .sm-star.sm-star-half,
.sm-rating-stars .sm-star.sm-star-half {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* Review Highlights - Two Column Layout */
.sm-review-highlights {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    margin-top: 0;
}

/* Rating Distribution Section */
.sm-rating-distribution-section {
    padding: 0;
}

.sm-rating-distribution-section .sm-section-title {
    text-align: left;
    font-size: 18px;
    font-weight: 700;
    color: #1f2937;
    margin-bottom: 20px;
    letter-spacing: -0.025em;
}

.sm-rating-distribution {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sm-dist-row {
    display: flex;
    flex-direction: column;
    gap: 8px;
    padding: 8px 0;
}

.sm-dist-row-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.sm-dist-row-bar {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
}

.sm-dist-label {
    min-width: 32px;
    font-weight: 600;
    color: #1f2937;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 16px;
}

.sm-dist-star {
    color: #f97316;
    font-size: 20px;
}

.sm-dist-bar {
    flex: 1;
    height: 16px;
    background: #f3f4f6;
    border-radius: 8px;
    overflow: hidden;
    position: relative;
    min-width: 220px;
    margin: 0;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
}

.sm-breakdown-fill {
    height: 100%;
    background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%);
    border-radius: 8px;
    transition: width 0.4s ease;
    position: relative;
    min-width: 2px;
    box-shadow: 0 2px 4px rgba(139, 92, 246, 0.2);
}

.sm-dist-percent {
    min-width: 40px;
    text-align: right;
    font-weight: 600;
    color: #4b5563;
    font-size: 16px;
}

/* Secondary Ratings Section */
.sm-secondary-ratings-section {
    padding: 0;
}

.sm-secondary-ratings-section .sm-section-title {
    text-align: left;
    font-size: 18px;
    font-weight: 700;
    color: #1f2937;
    margin-bottom: 20px;
    letter-spacing: -0.025em;
}

.sm-secondary-ratings-grid {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.sm-secondary-rating-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 8px 0;
    border-bottom: none;
}

.sm-secondary-rating-item:last-child {
    border-bottom: none;
}

.sm-secondary-rating-label {
    font-weight: 500;
    color: #1f2937;
    font-size: 16px;
    flex: 1;
    text-align: left;
}

.sm-secondary-rating-value {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: flex-end;
    min-width: 120px;
}

.sm-secondary-stars {
    display: inline-flex !important;
    gap: 2px;
    align-items: center;
}

.sm-secondary-star {
    font-size: 28px;
    color: #e5e7eb;
    transition: color 0.2s ease;
    display: inline-block !important;
    line-height: 1 !important;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.1);
}

.sm-secondary-star.sm-star-filled {
    color: #f97316 !important;
    text-shadow: 0 1px 2px rgba(249, 115, 22, 0.2);
}

.sm-secondary-star.sm-star-half {
    color: #f97316 !important;
    text-shadow: 0 1px 2px rgba(249, 115, 22, 0.2);
}

/* High priority secondary star color overrides */
html .sm-secondary-star.sm-star-filled,
body .sm-secondary-star.sm-star-filled,
.sm-secondary-rating-value .sm-secondary-star.sm-star-filled,
.sm-secondary-stars .sm-secondary-star.sm-star-filled {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

html .sm-secondary-star.sm-star-half,
body .sm-secondary-star.sm-star-half,
.sm-secondary-rating-value .sm-secondary-star.sm-star-half,
.sm-secondary-stars .sm-secondary-star.sm-star-half {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.sm-secondary-number {
    font-weight: 600;
    color: #1f2937;
    min-width: 28px;
    text-align: right;
    font-size: 16px;
    margin-left: 6px;
}

/* Additional specificity for secondary rating stars */
.sm-secondary-ratings-section .sm-secondary-rating-value .sm-secondary-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
}

.sm-secondary-ratings-section .sm-secondary-rating-value .sm-secondary-stars .sm-secondary-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ======================================================================
   REVIEWS FILTERS & ACTIONS - ENHANCED MODERN DESIGN
   ====================================================================== */
.sm-reviews-filters {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 36px 0 32px 0;
    padding: 24px 28px;
    background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 12px;
    border: 1px solid #e2e8f0;
    box-shadow: 0 2px 8px rgba(15, 23, 42, 0.04);
    position: relative;
    overflow: hidden;
    flex-wrap: nowrap;
}

/* Add subtle background pattern */
.sm-reviews-filters::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(45deg, transparent 49%, rgba(148, 163, 184, 0.02) 50%, transparent 51%);
    pointer-events: none;
}

.sm-reviews-sort {
    display: flex;
    align-items: center;
    gap: 16px;
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}

.sm-reviews-sort label {
    font-weight: 600;
    color: #475569;
    font-size: 15px;
    letter-spacing: -0.025em;
    margin: 0;
    white-space: nowrap;
}

/* Enhanced select dropdown styling */
.sm-sort-select {
    padding: 10px 16px 10px 14px;
    border: 2px solid #e2e8f0;
    border-radius: 8px;
    background: #ffffff;
    background-image: url("data:image/svg+xml;charset=UTF-8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'><path fill='%23475569' d='M6 8L0 2h12z'/></svg>");
    background-repeat: no-repeat;
    background-position: right 12px center;
    background-size: 12px;
    font-size: 14px;
    font-weight: 500;
    color: #334155;
    cursor: pointer;
    transition: all 0.2s ease;
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    min-width: 160px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.05);
}

.sm-sort-select:hover {
    border-color: #cbd5e1;
    background-color: #f8fafc;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.08);
}

.sm-sort-select:focus {
    outline: none;
    border-color: #3b82f6;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
    background-color: #ffffff;
}

/* Enhanced write review button - positioned prominently on the right */
.sm-write-review-btn {
    background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
    color: #ffffff;
    padding: 14px 28px;
    border: none;
    border-radius: 8px;
    font-weight: 600;
    font-size: 15px;
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    z-index: 1;
    overflow: hidden;
    text-transform: none;
    letter-spacing: 0.025em;
    box-shadow: 0 2px 8px rgba(59, 130, 246, 0.2);
    white-space: nowrap;
    min-width: 160px;
    margin-left: auto;
    flex-shrink: 0;
}

.sm-write-review-btn::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
    transition: left 0.5s ease;
}

.sm-write-review-btn:hover {
    background: linear-gradient(135deg, #2563eb 0%, #1d4ed8 100%);
    box-shadow: 0 4px 12px rgba(59, 130, 246, 0.3);
    transform: translateY(-1px);
}

.sm-write-review-btn:hover::before {
    left: 100%;
}

.sm-write-review-btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(59, 130, 246, 0.3);
}

.sm-write-review-btn:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.3), 0 4px 12px rgba(59, 130, 246, 0.2);
}

/* Additional positioning fixes for the write review button */
.sm-reviews-filters .sm-write-review-btn {
    margin-left: 20px;
    align-self: center;
}

/* Ensure button maintains prominence */
.sm-reviews-filters > .sm-write-review-btn:last-child {
    margin-left: auto;
    margin-right: 0;
}

/* ======================================================================
   REVIEW CARDS - MAIN STRUCTURE
   ====================================================================== */
.sm-reviews-list {
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.sm-review-card {
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    padding: 30px;
    border: 1px solid #f3f4f6;
    transition: box-shadow 0.2s ease;
    width: 100%;
    max-width: none;
    margin: 0;
    box-sizing: border-box;
}

.sm-review-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

/* ======================================================================
   1. HEADER ELEMENTS (FULL WIDTH)
   ====================================================================== */

/* Review Headline/Summary Text */
.sm-review-headline {
    width: 100%;
    margin-bottom: 20px;
    text-align: left;
}

.sm-review-title {
    font-size: 20px;
    font-weight: 600;
    color: #1f2937;
    margin: 0;
    line-height: 1.3;
}

/* User's Single Rating (Full Width, Centered) */
.sm-user-single-rating {
    width: 100%;
    text-align: center;
    margin-bottom: 30px;
    padding: 20px 0;
    background: #fafbfc;
    border-radius: 8px;
}

.sm-rating-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}

.sm-rating-score {
    font-size: 36px;
    font-weight: 700;
    color: #f59e0b;
    line-height: 1;
}

.sm-rating-stars {
    display: flex;
    gap: 4px;
}

/* Re-enforce inline, horizontal layout in the user single rating block */
.sm-user-single-rating .sm-rating-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 4px !important;
}

.sm-rating-stars .sm-star {
    font-size: 20px;
    color: #d1d5db;
    display: inline-block !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    float: none !important;
}

.sm-rating-stars .sm-star.filled {
    color: #f59e0b;
}

/* ======================================================================
   2. TWO-COLUMN SECTION (MAIN CONTENT)
   ====================================================================== */
.sm-two-column-layout {
    display: flex !important;
    flex-direction: row !important;
    gap: 40px !important;
    margin-bottom: 30px !important;
    align-items: flex-start !important;
    width: 100% !important;
    box-sizing: border-box !important;
}

/* ======================================================================
   LEFT COLUMN: USER DETAILS ONLY
   ====================================================================== */
.sm-left-column-user {
    display: flex !important;
    flex-direction: column !important;
    gap: 0 !important;
    width: 30% !important;
    flex: 0 0 30% !important;
    min-width: 280px !important;
    max-width: 320px !important;
    box-sizing: border-box !important;
}

.sm-user-card {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px;
    padding: 20px;
    background: #f8fafc;
    border-radius: 8px;
    border: 1px solid #e5e7eb;
}

.sm-user-avatar {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    background: #e5e7eb;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 24px;
    font-weight: 600;
    color: #6b7280;
    overflow: hidden;
    margin-bottom: 5px;
}

.sm-user-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 50%;
}

.sm-user-info {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sm-user-name {
    font-size: 16px;
    font-weight: 600;
    color: #1f2937;
    margin: 0;
}

.sm-user-verification {
    display: flex;
    align-items: center;
    gap: 6px;
}

.sm-verification-icon {
    font-size: 14px;
}

.sm-verification-text {
    font-size: 12px;
    color: #059669;
    font-weight: 500;
}

.sm-review-date {
    font-size: 13px;
    color: #6b7280;
}

.sm-user-usage {
    margin-top: 5px;
}

.sm-usage-duration {
    font-size: 12px;
    color: #6b7280;
    background: #f3f4f6;
    padding: 4px 8px;
    border-radius: 4px;
    display: inline-block;
}

.sm-user-review-source {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
}

.sm-source-icon {
    font-size: 12px;
}

.sm-source-text {
    font-size: 12px;
    color: #6b7280;
}

/* ======================================================================
   RIGHT COLUMN: ALL FEEDBACK (Pros, Cons, Ratings Breakdown)
   ====================================================================== */
.sm-right-column-feedback {
    display: flex !important;
    flex-direction: column !important;
    gap: 25px !important;
    width: 70% !important;
    flex: 1 1 70% !important;
    box-sizing: border-box !important;
}

/* Pros Section */
.sm-review-pros {
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 8px;
    padding: 20px;
}

.sm-review-pros h5 {
    font-size: 16px;
    font-weight: 600;
    color: #166534;
    margin: 0 0 12px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sm-review-pros h5::before {
    content: "✓";
    color: #16a34a;
    font-size: 14px;
}

.sm-review-pros ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sm-review-pros li {
    font-size: 14px;
    color: #166534;
    position: relative;
    padding-left: 20px;
}

.sm-review-pros li::before {
    content: "•";
    color: #16a34a;
    position: absolute;
    left: 0;
    font-weight: bold;
}

/* Cons Section */
.sm-review-cons {
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    padding: 20px;
}

.sm-review-cons h5 {
    font-size: 16px;
    font-weight: 600;
    color: #991b1b;
    margin: 0 0 12px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sm-review-cons h5::before {
    content: "⚠";
    color: #dc2626;
    font-size: 14px;
}

.sm-review-cons ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.sm-review-cons li {
    font-size: 14px;
    color: #991b1b;
    position: relative;
    padding-left: 20px;
}

.sm-review-cons li::before {
    content: "•";
    color: #dc2626;
    position: absolute;
    left: 0;
    font-weight: bold;
}

/* Ratings Breakdown Section */
.sm-review-ratings-breakdown {
    background: #fafbfc;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 20px;
}

.sm-review-ratings-breakdown h5 {
    font-size: 16px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 16px 0;
    display: flex;
    align-items: center;
    gap: 8px;
}

.sm-review-ratings-breakdown h5::before {
    content: "📊";
    font-size: 14px;
}

/* Horizontal Ratings Items */
.sm-breakdown-items-horizontal {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.sm-breakdown-item-horizontal {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 8px 0;
    flex-wrap: nowrap !important;
}

.sm-breakdown-label {
    font-size: 14px;
    font-weight: 500;
    color: #374151;
    min-width: 120px;
    flex-shrink: 0;
}

.sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    margin: 0 10px;
    flex-shrink: 0;
}

.smr-rating-star {
    font-size: 14px !important;
    line-height: 1 !important;
    display: inline-block !important;
    vertical-align: middle !important;
    float: none !important;
    margin: 0 !important;
    padding: 0 !important;
}


.sm-breakdown-value {
    font-weight: 600;
    color: #374151;
    min-width: 30px;
    text-align: center;
    font-size: 14px;
    flex-shrink: 0;
}

/* ======================================================================
   3. FOOTER ELEMENTS (FULL WIDTH)
   ====================================================================== */

/* Review Text Section */
.sm-review-text-section {
    width: 100%;
    margin-bottom: 20px;
}

.sm-review-text-content {
    background: #ffffff;
    border: 1px solid #e5e7eb;
    border-radius: 8px;
    padding: 20px;
}

.sm-review-text-content p {
    font-size: 15px;
    line-height: 1.6;
    color: #374151;
    margin: 0 0 15px 0;
}

.sm-review-text-content p:last-of-type {
    margin-bottom: 0;
}

.sm-read-more-btn {
    background: none;
    border: none;
    color: #3b82f6;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    padding: 0;
    margin-top: 10px;
    text-decoration: underline;
    transition: color 0.2s ease;
}

.sm-read-more-btn:hover {
    color: #2563eb;
}

.sm-review-expandable {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px solid #f3f4f6;
}

.sm-review-full-text p {
    font-size: 15px;
    line-height: 1.6;
    color: #374151;
    margin-bottom: 15px;
}

.sm-review-switching h5 {
    font-size: 16px;
    font-weight: 600;
    color: #374151;
    margin: 20px 0 10px 0;
}

.sm-review-switching p {
    font-size: 15px;
    line-height: 1.6;
    color: #374151;
}

/* Helpfulness Section */
.sm-review-helpfulness {
    width: 100%;
    padding: 20px 0;
    border-top: 1px solid #f3f4f6;
}

.sm-review-helpful-actions {
    display: flex;
    align-items: center;
    gap: 15px;
    font-size: 14px;
}

.sm-review-helpful-actions span:first-child {
    color: #6b7280;
    font-weight: 500;
}

.sm-helpful-btn {
    background: #f3f4f6;
    border: 1px solid #d1d5db;
    color: #374151;
    padding: 6px 16px;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.sm-helpful-btn:hover {
    background: #e5e7eb;
    border-color: #9ca3af;
}

.sm-helpful-count {
    color: #6b7280;
    font-size: 13px;
}

/* ======================================================================
   NO REVIEWS STATE
   ====================================================================== */
.sm-no-reviews {
    text-align: center;
    padding: 60px 20px;
    background: #fafbfc;
    border-radius: 12px;
    border: 1px solid #e5e7eb;
}

.sm-no-reviews-icon {
    font-size: 48px;
    margin-bottom: 20px;
}

.sm-no-reviews h4 {
    font-size: 24px;
    font-weight: 600;
    color: #374151;
    margin: 0 0 10px 0;
}

.sm-no-reviews p {
    font-size: 16px;
    color: #6b7280;
    margin: 0 0 30px 0;
}

/* ======================================================================
   PAGINATION
   ====================================================================== */
.sm-reviews-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-top: 40px;
    padding: 20px;
}

.sm-pagination-prev,
.sm-pagination-next {
    background: #f3f4f6;
    border: 1px solid #d1d5db;
    color: #374151;
    padding: 8px 16px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.2s ease;
}

.sm-pagination-prev:hover,
.sm-pagination-next:hover {
    background: #e5e7eb;
}

.sm-pagination-numbers {
    display: flex;
    gap: 5px;
}

.sm-pagination-numbers button {
    background: #f3f4f6;
    border: 1px solid #d1d5db;
    color: #374151;
    width: 36px;
    height: 36px;
    border-radius: 6px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.2s ease;
}

.sm-pagination-numbers button:hover {
    background: #e5e7eb;
}

.sm-pagination-numbers button.active {
    background: #3b82f6;
    border-color: #3b82f6;
    color: white;
}

/* ======================================================================
   REVIEW SUMMARY STATS
   ====================================================================== */
.sm-review-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 20px;
    margin-top: 20px;
}

.sm-stat-item {
    text-align: center;
    padding: 20px;
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    border: 1px solid #f3f4f6;
}

.sm-stat-number {
    font-size: 32px;
    font-weight: 700;
    color: #3b82f6;
    margin-bottom: 8px;
}

.sm-stat-label {
    font-size: 14px;
    color: #6b7280;
    font-weight: 500;
}

/* ======================================================================
   UTILITY CLASSES
   ====================================================================== */
.sm-hidden {
    display: none !important;
}

.sm-text-center {
    text-align: center;
}

.sm-text-left {
    text-align: left;
}

.sm-text-right {
    text-align: right;
}

/* ======================================================================
   FULL WIDTH LAYOUT FIXES
   ====================================================================== */
/* Override any parent container restrictions */
.sm-reviews-tab-content,
.sm-reviews-tab-content .sm-reviews-section,
.sm-reviews-tab-content .sm-reviews-list,
.sm-reviews-tab-content .sm-review-card {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
}

/* Force horizontal display for rating stars in breakdown */
.sm-review-card .sm-breakdown-item-horizontal .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
}

.sm-review-card .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star {
    display: inline !important;
    float: none !important;
    vertical-align: top !important;
    line-height: 1 !important;
    font-size: 14px !important;
    margin: 0 1px !important;
    padding: 0 !important;
}

/* FORCE FLEXBOX LAYOUT - Override any grid settings */
.sm-review-card .sm-two-column-layout {
    display: flex !important;
    flex-direction: row !important;
    gap: 40px !important;
    width: 100% !important;
    align-items: flex-start !important;
    box-sizing: border-box !important;
}

.sm-review-card .sm-left-column-user {
    width: 30% !important;
    flex: 0 0 30% !important;
    min-width: 280px !important;
    max-width: 320px !important;
}

.sm-review-card .sm-right-column-feedback {
    width: 70% !important;
    flex: 1 1 70% !important;
}

/* Override any tab content container restrictions */
#reviews,
#reviews .sm-reviews-tab-content,
.sm-tab-pane#reviews,
.sm-tab-pane#reviews .sm-reviews-tab-content {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

/* Ensure review section containers don't restrict width */
.sm-section.sm-reviews-section,
section.sm-reviews-section {
    width: 100% !important;
    max-width: none !important;
    padding: 20px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

/* HIGH PRIORITY: Force horizontal star display in ratings breakdown */
html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
}

html body .sm-review-card .sm-breakdown-items-horizontal .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
    vertical-align: middle !important;
}

html body .sm-review-card .sm-breakdown-items-horizontal .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    font-size: 14px !important;
    margin: 0 1px !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
}

/* Prevent any other CSS from making stars stack vertically */
.sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star::before,
.sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star::after {
    content: none !important;
    display: none !important;
}

/* ======================================================================
   ENHANCED VISUAL STYLING FOR IMAGE MATCH
   ====================================================================== */

/* Overall Rating enhanced styling */
.sm-overall-rating-display {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 20px 0;
}

/* Add subtle background to rating sections */
.sm-rating-distribution-section,
.sm-secondary-ratings-section {
    padding: 20px;
    background: #fafbfc;
    border-radius: 8px;
    border: 1px solid #f3f4f6;
}

/* Enhanced star positioning */
.sm-rating-stars .sm-star {
    display: inline-block !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    float: none !important;
    margin: 0 3px 0 0 !important;
    position: relative;
}

/* Enhanced secondary star positioning */
.sm-secondary-stars .sm-secondary-star {
    display: inline-block !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    float: none !important;
    margin: 0 2px 0 0 !important;
    position: relative;
}

/* Add hover effects */
.sm-secondary-rating-item:hover {
    background: rgba(249, 250, 251, 0.5);
    border-radius: 6px;
    padding: 8px 12px;
    margin: 0 -12px;
}

/* Better visual separation */
.sm-overall-card {
    background: linear-gradient(145deg, #ffffff 0%, #fafbfc 100%);
    border: 1px solid #e5e7eb;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

/* Enhanced percentage display */
.sm-dist-percent {
    font-variant-numeric: tabular-nums;
}

/* Enhanced secondary number display */
.sm-secondary-number {
    font-variant-numeric: tabular-nums;
}

/* ======================================================================
   ULTIMATE STAR COLOR FIX - MAXIMUM PRIORITY
   Ensures star colors work regardless of theme interference
   ====================================================================== */

/* Ultimate filled star color fix */
* .sm-star.sm-star-filled,
html * .sm-star.sm-star-filled,
body * .sm-star.sm-star-filled,
.sm-reviews-tab-content .sm-star.sm-star-filled,
.sm-overall-card .sm-star.sm-star-filled {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
    background-color: transparent !important;
    text-decoration: none !important;
    border: none !important;
    outline: none !important;
}

/* Ultimate half star color fix */
* .sm-star.sm-star-half,
html * .sm-star.sm-star-half,
body * .sm-star.sm-star-half,
.sm-reviews-tab-content .sm-star.sm-star-half,
.sm-overall-card .sm-star.sm-star-half {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
    background-color: transparent !important;
    text-decoration: none !important;
    border: none !important;
    outline: none !important;
}

/* Ultimate secondary filled star color fix */
* .sm-secondary-star.sm-star-filled,
html * .sm-secondary-star.sm-star-filled,
body * .sm-secondary-star.sm-star-filled,
.sm-reviews-tab-content .sm-secondary-star.sm-star-filled,
.sm-overall-card .sm-secondary-star.sm-star-filled {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
    background-color: transparent !important;
    text-decoration: none !important;
    border: none !important;
    outline: none !important;
}

/* Ultimate secondary half star color fix */
* .sm-secondary-star.sm-star-half,
html * .sm-secondary-star.sm-star-half,
body * .sm-secondary-star.sm-star-half,
.sm-reviews-tab-content .sm-secondary-star.sm-star-half,
.sm-overall-card .sm-secondary-star.sm-star-half {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
    background-color: transparent !important;
    text-decoration: none !important;
    border: none !important;
    outline: none !important;
}

/* Force remove any theme styling that might interfere */
.sm-star[class*="sm-star-"],
.sm-secondary-star[class*="sm-star-"] {
    background: none !important;
    box-shadow: none !important;
    border: none !important;
    outline: none !important;
    text-decoration: none !important;
    font-weight: normal !important;
    font-style: normal !important;
}

/* WordPress theme override protection for star colors */
.entry-content .sm-star.sm-star-filled,
.post-content .sm-star.sm-star-filled,
.page-content .sm-star.sm-star-filled,
#content .sm-star.sm-star-filled,
main .sm-star.sm-star-filled,
article .sm-star.sm-star-filled,
.entry-content .sm-secondary-star.sm-star-filled,
.post-content .sm-secondary-star.sm-star-filled,
.page-content .sm-secondary-star.sm-star-filled,
#content .sm-secondary-star.sm-star-filled,
main .sm-secondary-star.sm-star-filled,
article .sm-secondary-star.sm-star-filled {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.entry-content .sm-star.sm-star-half,
.post-content .sm-star.sm-star-half,
.page-content .sm-star.sm-star-half,
#content .sm-star.sm-star-half,
main .sm-star.sm-star-half,
article .sm-star.sm-star-half,
.entry-content .sm-secondary-star.sm-star-half,
.post-content .sm-secondary-star.sm-star-half,
.page-content .sm-secondary-star.sm-star-half,
#content .sm-secondary-star.sm-star-half,
main .sm-secondary-star.sm-star-half,
article .sm-secondary-star.sm-star-half {
    color: #f97316 !important;
    opacity: 1 !important;
    visibility: visible !important;
}

/* ======================================================================
   RATING BAR WIDTH FIX
   Ensures rating breakdown bars display correct widths
   ====================================================================== */

/* Force rating bars to display correctly */
.sm-breakdown-fill {
    display: block !important;
    transition: width 0.3s ease !important;
    background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%) !important;
    min-width: 1px !important;
}

/* Ensure bars with 0% width are hidden */
.sm-breakdown-fill[style*="width: 0%"],
.sm-breakdown-fill[style*="width:0%"] {
    display: none !important;
}

/* Force visibility for non-zero width bars */
.sm-breakdown-fill[style*="width: 41%"] {
    width: 41% !important;
    display: block !important;
}

.sm-breakdown-fill[style*="width: 38%"] {
    width: 38% !important;
    display: block !important;
}

.sm-breakdown-fill[style*="width: 13%"] {
    width: 13% !important;
    display: block !important;
}

.sm-breakdown-fill[style*="width: 5%"] {
    width: 5% !important;
    display: block !important;
}

.sm-breakdown-fill[style*="width: 4%"] {
    width: 4% !important;
    display: block !important;
}

/* ULTRA HIGH PRIORITY: Force horizontal star display - Override everything */
* .sm-breakdown-items-horizontal * {
    box-sizing: border-box !important;
}

* .sm-breakdown-item-horizontal {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
}

* .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 2px !important;
    flex-wrap: nowrap !important;
    white-space: nowrap !important;
    overflow: visible !important;
    width: auto !important;
    height: auto !important;
    min-width: 70px !important;
}

* .sm-horizontal-stars .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    position: relative !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    font-size: 14px !important;
    margin: 0 1px !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    min-width: auto !important;
    max-width: none !important;
    flex-shrink: 0 !important;
    transform: none !important;
    clear: none !important;
}

/* Force inline display for all star containers */
.sm-breakdown-items-horizontal .sm-horizontal-stars,
html .sm-breakdown-items-horizontal .sm-horizontal-stars,
body .sm-breakdown-items-horizontal .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
}

/* Override any theme or plugin styles that might interfere */
body * .smr-rating-star {
    display: inline-block !important;
    vertical-align: top !important;
    float: none !important;
    clear: none !important;
}

/* ======================================================================
   RESPONSIVE DESIGN
   ====================================================================== */
@media (max-width: 768px) {
    .sm-reviews-tab-content {
        padding: 0 15px;
    }
    
    .sm-overall-card {
        padding: 20px;
    }
    
    .sm-review-highlights {
        grid-template-columns: 1fr;
        gap: 25px;
    }
    
    /* Ensure secondary ratings remain properly aligned on mobile */
    body .sm-secondary-ratings-section .sm-secondary-rating-item {
        display: flex !important;
        justify-content: space-between !important;
        align-items: center !important;
        flex-wrap: nowrap !important;
    }
    
    body .sm-secondary-ratings-section .sm-secondary-stars {
        display: inline-flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 2px !important;
        white-space: nowrap !important;
    }
    
    body .sm-secondary-ratings-section .sm-secondary-star {
        display: inline-block !important;
        float: none !important;
        vertical-align: middle !important;
        line-height: 1 !important;
        font-size: 16px !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    
    .sm-two-column-layout {
        display: flex !important;
        flex-direction: column !important;
        gap: 25px !important;
        width: 100% !important;
    }
    
    .sm-left-column-user {
        order: 1;
        width: 100% !important;
        max-width: none !important;
        flex: 1 1 100% !important;
    }
    
    .sm-right-column-feedback {
        order: 2;
        width: 100% !important;
        flex: 1 1 100% !important;
    }
    
    .sm-user-card {
        flex-direction: row;
        align-items: center;
        gap: 15px;
    }
    
    .sm-user-avatar {
        margin-bottom: 0;
        flex-shrink: 0;
    }
    
    .sm-review-card {
        padding: 20px;
    }
    
    .sm-reviews-filters {
        flex-direction: column;
        gap: 15px;
        align-items: stretch;
    }
    
    .sm-reviews-sort {
        justify-content: center;
        order: 1;
    }
    
    .sm-write-review-btn {
        order: 2;
        margin-left: 0;
        align-self: center;
    }
    
    .sm-review-stats {
        grid-template-columns: 1fr;
        gap: 15px;
    }
    
    .sm-breakdown-item-horizontal {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
    }
    
    .sm-horizontal-stars {
        margin: 0 !important;
        display: inline-flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 2px !important;
        white-space: nowrap !important;
    }
    
    .smr-rating-star {
        display: inline-block !important;
        float: none !important;
        vertical-align: middle !important;
        font-size: 14px !important;
        line-height: 1 !important;
        margin: 0 1px 0 0 !important;
        padding: 0 !important;
    }
}

@media (max-width: 480px) {
    .sm-overall-card {
        padding: 15px;
    }
    
    .sm-review-card {
        padding: 15px;
    }
    
    .sm-rating-number {
        font-size: 36px;
    }
    
    .sm-rating-score {
        font-size: 28px;
    }
    
    .sm-user-single-rating {
        padding: 15px 0;
    }
    
    .sm-user-card {
        padding: 15px;
    }
    
    /* Ensure rating bars remain visible on mobile */
    .sm-dist-bar {
        min-width: 80px !important;
        height: 10px !important;
    }
    
    .sm-breakdown-fill {
        min-width: 1px !important;
    }
    
    /* Adjust secondary ratings for mobile */
    .sm-secondary-rating-item {
        padding: 8px 0;
        font-size: 13px;
    }
    
    .sm-secondary-star {
        font-size: 14px !important;
    }
}

/* ======================================================================
   FINAL OVERRIDE - LAST RESORT STYLES FOR STAR DISPLAY
   ====================================================================== */
/* This must be at the very end to override any conflicting styles */

/* Force horizontal layout with maximum specificity */
.sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    width: auto !important;
    height: auto !important;
}

.sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    width: auto !important;
    height: auto !important;
    line-height: 1 !important;
    font-size: 14px !important;
    margin: 0 1px 0 0 !important;
    padding: 0 !important;
}

/* WordPress and theme override protection */
#content .sm-horizontal-stars,
.entry-content .sm-horizontal-stars,
.post-content .sm-horizontal-stars,
.page-content .sm-horizontal-stars,
main .sm-horizontal-stars,
article .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
}

#content .smr-rating-star,
.entry-content .smr-rating-star,
.post-content .smr-rating-star,
.page-content .smr-rating-star,
main .smr-rating-star,
article .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
}

/* HIGH PRIORITY THEME OVERRIDE - FULL WIDTH LAYOUT */
body .sm-reviews-tab-content,
body .sm-reviews-section,
body .sm-overall-card,
body .sm-review-highlights {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
    display: block !important;
    clear: both !important;
}

/* Force grid layout for highlights */
body .sm-review-highlights {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
    width: 100% !important;
}

/* Rating bars visibility fix */
body .sm-rating-distribution .sm-dist-row {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    margin-bottom: 8px !important;
}

body .sm-rating-distribution .sm-dist-bar {
    flex: 1 !important;
    height: 12px !important;
    background: #e5e7eb !important;
    border-radius: 6px !important;
    min-width: 150px !important;
    margin: 0 8px !important;
    position: relative !important;
    overflow: hidden !important;
}

body .sm-rating-distribution .sm-breakdown-fill {
    height: 100% !important;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    border-radius: 6px !important;
    transition: width 0.4s ease !important;
    min-width: 2px !important;
    display: block !important;
    position: relative !important;
}

/* Ensure sections don't get constrained by theme */
body .sm-rating-distribution-section,
body .sm-secondary-ratings-section {
    width: 100% !important;
    max-width: none !important;
    flex: 1 !important;
    box-sizing: border-box !important;
}

/* SECONDARY RATINGS COMPREHENSIVE FIXES */
body .sm-secondary-ratings-section .sm-secondary-ratings-grid .sm-secondary-rating-item {
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    width: 100% !important;
}

body .sm-secondary-ratings-section .sm-secondary-rating-label {
    flex: 1 !important;
    text-align: left !important;
    font-weight: 500 !important;
    color: #2d3748 !important;
    font-size: 14px !important;
}

body .sm-secondary-ratings-section .sm-secondary-rating-value {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    flex-shrink: 0 !important;
    min-width: 120px !important;
    justify-content: flex-end !important;
}

body .sm-secondary-ratings-section .sm-secondary-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}

body .sm-secondary-ratings-section .sm-secondary-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    font-size: 16px !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    color: #d1d5db !important;
}

body .sm-secondary-ratings-section .sm-secondary-star.sm-star-filled {
    color: #f59e0b !important;
}

body .sm-secondary-ratings-section .sm-secondary-number {
    font-weight: 600 !important;
    color: #2d3748 !important;
    font-size: 14px !important;
    min-width: 30px !important;
    text-align: right !important;
    margin-left: 4px !important;
    flex-shrink: 0 !important;
}

/* BULLETPROOF STAR DISPLAY - Maximum Specificity Override */
html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 2px !important;
    white-space: nowrap !important;
    overflow: visible !important;
    width: auto !important;
    height: auto !important;
    min-width: 70px !important;
    flex-wrap: nowrap !important;
    vertical-align: middle !important;
}

html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    font-size: 14px !important;
    line-height: 1 !important;
    margin: 0 1px 0 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    min-width: auto !important;
    max-width: none !important;
    flex-shrink: 0 !important;
    position: relative !important;
    transform: none !important;
    clear: none !important;
    text-align: center !important;
}

/* ======================================================================
   WORDPRESS THEME COMPATIBILITY - ULTIMATE OVERRIDES
   ====================================================================== */

/* Override common WordPress theme containers */
.entry-content .sm-reviews-tab-content,
.post-content .sm-reviews-tab-content,
.page-content .sm-reviews-tab-content,
#content .sm-reviews-tab-content,
.content .sm-reviews-tab-content,
main .sm-reviews-tab-content,
article .sm-reviews-tab-content,
.container .sm-reviews-tab-content,
.wp-block-group .sm-reviews-tab-content {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    display: block !important;
    clear: both !important;
}

/* Override theme card/section constraints */
.entry-content .sm-overall-card,
.post-content .sm-overall-card,
.page-content .sm-overall-card,
#content .sm-overall-card,
.content .sm-overall-card,
main .sm-overall-card,
article .sm-overall-card,
.container .sm-overall-card,
.wp-block-group .sm-overall-card {
    width: 100% !important;
    max-width: none !important;
    margin: 0 0 24px 0 !important;
    box-sizing: border-box !important;
    display: block !important;
}

/* Force rating distribution bars to be visible */
.entry-content .sm-rating-distribution .sm-dist-bar,
.post-content .sm-rating-distribution .sm-dist-bar,
.page-content .sm-rating-distribution .sm-dist-bar,
#content .sm-rating-distribution .sm-dist-bar,
.content .sm-rating-distribution .sm-dist-bar,
main .sm-rating-distribution .sm-dist-bar,
article .sm-rating-distribution .sm-dist-bar {
    flex: 1 !important;
    height: 12px !important;
    background: #e5e7eb !important;
    border-radius: 6px !important;
    min-width: 120px !important;
    margin: 0 8px !important;
    position: relative !important;
    overflow: hidden !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
}

.entry-content .sm-rating-distribution .sm-breakdown-fill,
.post-content .sm-rating-distribution .sm-breakdown-fill,
.page-content .sm-rating-distribution .sm-breakdown-fill,
#content .sm-rating-distribution .sm-breakdown-fill,
.content .sm-rating-distribution .sm-breakdown-fill,
main .sm-rating-distribution .sm-breakdown-fill,
article .sm-rating-distribution .sm-breakdown-fill {
    height: 100% !important;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    border-radius: 6px !important;
    min-width: 2px !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    position: relative !important;
}

/* Ensure grid layout works in all themes */
.entry-content .sm-review-highlights,
.post-content .sm-review-highlights,
.page-content .sm-review-highlights,
#content .sm-review-highlights,
.content .sm-review-highlights,
main .sm-review-highlights,
article .sm-review-highlights {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
    width: 100% !important;
    margin-top: 0 !important;
    box-sizing: border-box !important;
}

/* ======================================================================
   MAXIMUM SPECIFICITY OVERRIDES FOR THEME CONFLICTS
   ====================================================================== */

/* WordPress Theme Override Protection */
html body.wp-admin .sm-review-card,
html body.wordpress .sm-review-card,
html body .entry-content .sm-review-card,
html body .post-content .sm-review-card,
html body .page-content .sm-review-card,
html body main .sm-review-card,
html body article .sm-review-card,
html body #content .sm-review-card,
html body .content .sm-review-card {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    box-sizing: border-box !important;
}

/* Two-column layout protection */
html body .sm-review-card .sm-two-column-layout,
html body .entry-content .sm-review-card .sm-two-column-layout,
html body .post-content .sm-review-card .sm-two-column-layout,
html body .page-content .sm-review-card .sm-two-column-layout {
    display: flex !important;
    flex-direction: row !important;
    gap: 40px !important;
    width: 100% !important;
    align-items: flex-start !important;
    box-sizing: border-box !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
}

/* Column width protection */
html body .sm-review-card .sm-left-column-user,
html body .entry-content .sm-review-card .sm-left-column-user,
html body .post-content .sm-review-card .sm-left-column-user {
    width: 30% !important;
    flex: 0 0 30% !important;
    min-width: 280px !important;
    max-width: 320px !important;
    display: flex !important;
    flex-direction: column !important;
}

html body .sm-review-card .sm-right-column-feedback,
html body .entry-content .sm-review-card .sm-right-column-feedback,
html body .post-content .sm-review-card .sm-right-column-feedback {
    width: 70% !important;
    flex: 1 1 70% !important;
    display: flex !important;
    flex-direction: column !important;
}

/* Star display protection with ultimate specificity */
html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars,
html body .entry-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars,
html body .post-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
    width: auto !important;
    height: auto !important;
}

html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star,
html body .entry-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star,
html body .post-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    font-size: 14px !important;
    line-height: 1 !important;
    margin: 0 1px 0 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
}

/* ULTIMATE THEME COMPATIBILITY FIXES */

/* Override any theme restrictions on width */
html body .sm-reviews-tab-content,
html body .sm-reviews-section,
html body .sm-overall-card {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    flex: none !important;
    display: block !important;
    position: relative !important;
    float: none !important;
    clear: both !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

/* Force rating bars to be visible and properly sized */
html body .sm-dist-row {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    flex-wrap: nowrap !important;
    gap: 12px !important;
    margin-bottom: 8px !important;
}

html body .sm-dist-bar {
    flex: 1 1 auto !important;
    height: 12px !important;
    background: #e5e7eb !important;
    border-radius: 6px !important;
    min-width: 100px !important;
    max-width: none !important;
    position: relative !important;
    overflow: hidden !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    margin: 0 8px !important;
}

html body .sm-breakdown-fill {
    height: 100% !important;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    border-radius: 6px !important;
    min-width: 1px !important;
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    position: relative !important;
    transform: none !important;
    transition: width 0.4s ease !important;
}

/* Ensure grid layout is preserved */
html body .sm-review-highlights {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-rows: auto !important;
    gap: 32px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    align-items: start !important;
}

/* Block any display: none or visibility: hidden on review elements */
html body .sm-reviews-section,
html body .sm-reviews-section *,
html body .sm-review-card,
html body .sm-review-card * {
    visibility: visible !important;
    opacity: 1 !important;
    position: static !important;
    z-index: auto !important;
}

html body .sm-reviews-section.active,
html body .sm-reviews-section.active *,
html body #reviews.active,
html body #reviews.active * {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    height: auto !important;
    max-height: none !important;
    overflow: visible !important;
}

/* CRITICAL: Force star containers to display inline-flex when active */
html body .sm-reviews-section.active .sm-rating-stars,
html body .sm-reviews-section.active .sm-secondary-stars,
html body .sm-reviews-section.active .sm-horizontal-stars,
html body #reviews.active .sm-rating-stars,
html body #reviews.active .sm-secondary-stars,
html body #reviews.active .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
}

/* CRITICAL: Force individual stars to display inline when active */
html body .sm-reviews-section.active .sm-star,
html body .sm-reviews-section.active .sm-secondary-star,
html body .sm-reviews-section.active .smr-rating-star,
html body #reviews.active .sm-star,
html body #reviews.active .sm-secondary-star,
html body #reviews.active .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    margin: 0 1px 0 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
}

html body #reviews.active .sm-two-column-layout,
html body .sm-reviews-section.active .sm-two-column-layout {
    display: flex !important;
}

html body #reviews.active .sm-horizontal-stars,
html body .sm-reviews-section.active .sm-horizontal-stars {
    display: inline-flex !important;
}

/* ======================================================================
   MOBILE RESPONSIVE OVERRIDES - FINAL PRIORITY
   ====================================================================== */
@media (max-width: 768px) {
    /* Force column stacking on mobile but preserve all star styling */
    html body .sm-review-card .sm-two-column-layout,
    html body .entry-content .sm-review-card .sm-two-column-layout,
    html body .post-content .sm-review-card .sm-two-column-layout {
        display: flex !important;
        flex-direction: column !important;
        gap: 25px !important;
        width: 100% !important;
    }
    
    html body .sm-review-card .sm-left-column-user,
    html body .entry-content .sm-review-card .sm-left-column-user,
    html body .post-content .sm-review-card .sm-left-column-user {
        width: 100% !important;
        max-width: none !important;
        flex: 1 1 100% !important;
        order: 1 !important;
    }
    
    html body .sm-review-card .sm-right-column-feedback,
    html body .entry-content .sm-review-card .sm-right-column-feedback,
    html body .post-content .sm-review-card .sm-right-column-feedback {
        width: 100% !important;
        flex: 1 1 100% !important;
        order: 2 !important;
    }
    
    /* CRITICAL: Keep stars horizontal even on mobile */
    html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars,
    html body .entry-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars,
    html body .post-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars {
        display: inline-flex !important;
        flex-direction: row !important;
        align-items: center !important;
        gap: 2px !important;
        white-space: nowrap !important;
        width: auto !important;
        height: auto !important;
        margin: 0 10px !important;
    }
    
    html body .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star,
    html body .entry-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star,
    html body .post-content .sm-review-card .sm-breakdown-items-horizontal .sm-breakdown-item-horizontal .sm-horizontal-stars .smr-rating-star {
        display: inline-block !important;
        float: none !important;
        vertical-align: middle !important;
        font-size: 14px !important;
        line-height: 1 !important;
        margin: 0 1px 0 0 !important;
        padding: 0 !important;
        width: auto !important;
        height: auto !important;
    }
}

/* ======================================================================
   ULTIMATE RATING HORIZONTAL DISPLAY FIX
   Ensures ratings always display horizontally regardless of other CSS
   ====================================================================== */

/* Force ALL rating stars to display horizontally - Maximum Priority */
* .sm-rating-stars,
* .sm-secondary-stars, 
* .sm-horizontal-stars,
html * .sm-rating-stars,
html * .sm-secondary-stars,
html * .sm-horizontal-stars,
body * .sm-rating-stars,
body * .sm-secondary-stars,
body * .sm-horizontal-stars {
    display: inline-flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 2px !important;
    white-space: nowrap !important;
    flex-wrap: nowrap !important;
}

/* Force ALL individual stars to display inline - Maximum Priority */
* .sm-star,
* .sm-secondary-star,
* .smr-rating-star,
html * .sm-star,
html * .sm-secondary-star, 
html * .smr-rating-star,
body * .sm-star,
body * .sm-secondary-star,
body * .smr-rating-star {
    display: inline-block !important;
    float: none !important;
    vertical-align: middle !important;
    line-height: 1 !important;
    margin: 0 1px 0 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
    position: static !important;
    clear: none !important;
}

/* Block any CSS that could make stars stack vertically */
.sm-rating-stars *,
.sm-secondary-stars *,
.sm-horizontal-stars * {
    display: inline-block !important;
    float: none !important;
    clear: none !important;
    transform: none !important;
}

/* Override any grid or flexbox settings that break horizontal layout */
.sm-rating-stars,
.sm-secondary-stars,
.sm-horizontal-stars {
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    grid-auto-flow: none !important;
    display: inline-flex !important;
    flex-direction: row !important;
}

/* Final fallback: Ensure no pseudo-elements interfere */
.sm-star::before,
.sm-star::after,
.sm-secondary-star::before,
.sm-secondary-star::after,
.smr-rating-star::before,
.smr-rating-star::after {
    content: none !important;
    display: none !important;
}
