/**
 * Betformatics Comparison Box Shortcode Styles
 *
 * Styled comparison table for bookmakers/products.
 *
 * Dependencies: betformatics-variables (loaded via PHP)
 *
 * @package Betformatics
 */

/* =============================================================================
   RESET - Prevent theme interference
   ============================================================================= */
.bf-compare,
.bf-compare * {
    box-sizing: border-box;
}

/* =============================================================================
   ACCESSIBLE DATA TABLE (Visually hidden for screen readers)
   ============================================================================= */
.bf-compare__data-table {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* =============================================================================
   CONTAINER
   ============================================================================= */
.bf-compare {
    position: relative;
    margin: 1.5em 0;
    background: var(--bf-white, #ffffff);
    border: 1px solid var(--bf-border, #e5e7eb);
    border-radius: var(--bf-radius-lg, 12px);
    overflow: hidden;
    font-family: var(--bf-font-family, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif);
}

/* =============================================================================
   HEADER
   ============================================================================= */
.bf-compare__header {
    padding: 16px 20px;
    background: linear-gradient(135deg, var(--bf-gray-50, #f9fafb) 0%, var(--bf-gray-100, #f3f4f6) 100%);
    border-bottom: 1px solid var(--bf-border, #e5e7eb);
}

.bf-compare__title {
    margin: 0;
    font-size: 1.1rem;
    font-weight: var(--bf-font-weight-bold, 700);
    color: var(--bf-text-primary, #1f2937);
}

/* =============================================================================
   LIST
   ============================================================================= */
.bf-compare__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
}

/* =============================================================================
   ITEM ROW
   ============================================================================= */
.bf-compare__item {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr 1fr 120px;
    gap: 12px;
    padding: 14px 20px;
    align-items: center;
    border-bottom: 1px solid var(--bf-gray-100, #f3f4f6);
    transition: background var(--bf-transition-fast, 0.15s ease);
}

.bf-compare__item:last-child {
    border-bottom: none;
}

.bf-compare__item:hover {
    background: var(--bf-gray-50, #f9fafb);
}

/* Featured item (first/top rated) */
.bf-compare__item--featured {
    background: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);
}

.bf-compare__item--featured:hover {
    background: linear-gradient(135deg, #d1fae5 0%, #a7f3d0 100%);
}

/* =============================================================================
   CELLS
   ============================================================================= */
.bf-compare__cell--name {
    display: flex;
    align-items: center;
    gap: 10px;
}

/* #1 Badge */
.bf-compare__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    background: var(--bf-success, #10b981);
    color: var(--bf-white, #ffffff);
    font-size: 0.7rem;
    font-weight: var(--bf-font-weight-bold, 700);
    border-radius: var(--bf-radius-md, 6px);
    flex-shrink: 0;
}

.bf-compare__name {
    font-weight: var(--bf-font-weight-semibold, 600);
    color: var(--bf-text-primary, #1f2937);
}

/* Rating cell */
.bf-compare__cell--rating {
    display: flex;
    align-items: center;
    gap: 8px;
}

.bf-compare__stars {
    display: flex;
    gap: 2px;
}

.bf-star {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.bf-star--full {
    color: var(--bf-star, #f59e0b);
}

.bf-star--half {
    color: var(--bf-star, #f59e0b);
}

.bf-compare__rating-value {
    font-size: 0.85rem;
    font-weight: var(--bf-font-weight-semibold, 600);
    color: var(--bf-text-muted, #6b7280);
}

/* Odds cell */
.bf-compare__odds {
    font-weight: var(--bf-font-weight-bold, 700);
    color: var(--bf-success, #10b981);
    font-size: 1rem;
}

/* Bonus cell */
.bf-compare__bonus {
    font-weight: var(--bf-font-weight-semibold, 600);
    color: #3b82f6;
}

/* =============================================================================
   ACTION BUTTON
   ============================================================================= */
.bf-compare__btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 8px 16px;
    background: var(--bf-success, #10b981);
    color: var(--bf-white, #ffffff) !important;
    font-size: 0.85rem;
    font-weight: var(--bf-font-weight-semibold, 600);
    text-decoration: none !important;
    border-radius: var(--bf-radius-md, 6px);
    transition: background var(--bf-transition-fast, 0.15s ease), transform var(--bf-transition-fast, 0.15s ease);
    white-space: nowrap;
}

.bf-compare__btn:hover {
    background: var(--bf-success-dark, #059669);
    color: var(--bf-white, #ffffff) !important;
    text-decoration: none !important;
    transform: translateY(-1px);
}

.bf-compare__btn:visited {
    color: var(--bf-white, #ffffff) !important;
}

.bf-compare__btn svg {
    flex-shrink: 0;
}

/* =============================================================================
   MOBILE RESPONSIVE
   ============================================================================= */
@media (max-width: 768px) {
    .bf-compare__item {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 16px;
    }

    .bf-compare__cell {
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    /* Mobile labels */
    .bf-compare__cell--rating::before,
    .bf-compare__cell--odds::before,
    .bf-compare__cell--bonus::before {
        font-size: 0.75rem;
        font-weight: var(--bf-font-weight-semibold, 600);
        text-transform: uppercase;
        color: var(--bf-text-muted, #6b7280);
    }

    .bf-compare__cell--rating::before {
        content: "Bedømmelse";
    }

    .bf-compare__cell--odds::before {
        content: "Odds";
    }

    .bf-compare__cell--bonus::before {
        content: "Bonus";
    }

    .bf-compare__cell--name {
        border-bottom: 1px solid var(--bf-border, #e5e7eb);
        padding-bottom: 10px;
        margin-bottom: 4px;
    }

    .bf-compare__cell--action {
        margin-top: 8px;
    }

    .bf-compare__btn {
        width: 100%;
    }
}

/* =============================================================================
   PAGE BUILDER COMPATIBILITY
   ============================================================================= */
.elementor-widget-container .bf-compare,
.elementor-element .bf-compare,
.wp-block .bf-compare {
    margin-left: 0;
    margin-right: 0;
    max-width: 100%;
}

/* =============================================================================
   ACCESSIBILITY
   ============================================================================= */
@media (prefers-reduced-motion: reduce) {
    .bf-compare__item,
    .bf-compare__btn {
        transition: none !important;
    }
}
