/**
 * SiteRooster Competition Landscape Styles
 */

/* ==========================================
   Stat Row
   ========================================== */
.sr-comp-stat-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}

.sr-comp-stat-card {
    background: white;
    border-radius: 10px;
    border: 1px solid var(--gray-200, #e5e7eb);
    padding: 18px 20px;
    position: relative;
    overflow: hidden;
}

.sr-comp-stat-card::after {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
}

.sr-comp-stat-emerald::after { background: var(--emerald-600, #059669); }
.sr-comp-stat-blue::after { background: #2563eb; }
.sr-comp-stat-amber::after { background: #f59e0b; }
.sr-comp-stat-red::after { background: #ef4444; }

.sr-comp-stat-value {
    font-size: 28px;
    font-weight: 700;
    line-height: 1.2;
}

.sr-comp-stat-emerald .sr-comp-stat-value { color: var(--emerald-600, #059669); }
.sr-comp-stat-blue .sr-comp-stat-value { color: #2563eb; }
.sr-comp-stat-amber .sr-comp-stat-value { color: #f59e0b; }
.sr-comp-stat-red .sr-comp-stat-value { color: #ef4444; }

.sr-comp-stat-label {
    font-size: 12px;
    color: var(--gray-500, #6b7280);
    margin-top: 2px;
    font-weight: 500;
}

.sr-comp-stat-detail {
    font-size: 11px;
    color: var(--gray-400, #9ca3af);
    margin-top: 6px;
}

.sr-comp-subtitle {
    font-size: 12px;
    color: var(--gray-400, #9ca3af);
    font-weight: 400;
    margin-left: 8px;
}

/* ==========================================
   Leaderboard Table
   ========================================== */
.sr-comp-table-wrap { overflow-x: auto; }

.sr-comp-leaderboard {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}

.sr-comp-leaderboard thead th {
    padding: 10px 14px;
    text-align: left;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray-500, #6b7280);
    background: var(--gray-50, #f9fafb);
    border-bottom: 1px solid var(--gray-200, #e5e7eb);
    white-space: nowrap;
}

.sr-comp-th-center { text-align: center !important; }
.sr-comp-center { text-align: center; }

.sr-comp-leaderboard tbody tr {
    border-bottom: 1px solid var(--gray-100, #f3f4f6);
    transition: background 0.15s;
}

.sr-comp-leaderboard tbody tr:hover {
    background: var(--gray-50, #f9fafb);
}

.sr-comp-your-row {
    background: rgba(5, 150, 105, 0.04) !important;
}
.sr-comp-your-row:hover {
    background: rgba(5, 150, 105, 0.08) !important;
}

.sr-comp-leaderboard tbody td {
    padding: 12px 14px;
    vertical-align: middle;
}

/* Competitor info cell */
.sr-comp-info {
    display: flex;
    align-items: center;
    gap: 10px;
}

.sr-comp-rank-badge {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    font-weight: 700;
    font-size: 13px;
    background: var(--gray-100, #f3f4f6);
    color: var(--gray-500, #6b7280);
    flex-shrink: 0;
}

.sr-comp-rank-gold { background: #fef3c7; color: #92400e; }
.sr-comp-rank-silver { background: #f3f4f6; color: #374151; }
.sr-comp-rank-bronze { background: #fed7aa; color: #9a3412; }

.sr-comp-favicon {
    width: 20px;
    height: 20px;
    border-radius: 4px;
    flex-shrink: 0;
}

.sr-comp-name {
    font-weight: 600;
    color: var(--gray-900, #111827);
    font-size: 13px;
}

.sr-comp-domain {
    font-size: 11px;
    color: var(--gray-400, #9ca3af);
}

.sr-comp-you-badge {
    display: inline-flex;
    padding: 1px 5px;
    background: var(--emerald-600, #059669);
    color: white;
    font-size: 10px;
    font-weight: 600;
    border-radius: 3px;
    margin-left: 4px;
    letter-spacing: 0.3px;
    vertical-align: middle;
}

/* Presence dots */
.sr-comp-presence {
    display: flex;
    gap: 4px;
    justify-content: center;
}

.sr-comp-dot {
    width: 20px;
    height: 20px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.sr-comp-dot svg { width: 10px; height: 10px; }

.sr-comp-dot-google { background: rgba(66,133,244,0.12); color: #4285f4; }
.sr-comp-dot-bing { background: rgba(0,120,212,0.12); color: #0078d4; }
.sr-comp-dot-chatgpt { background: rgba(16,163,127,0.12); color: #10a37f; }
.sr-comp-dot-gemini { background: rgba(66,133,244,0.12); color: #4285f4; }
.sr-comp-dot-inactive { background: var(--gray-50, #f9fafb); color: var(--gray-200, #e5e7eb); }

/* Keyword count */
.sr-comp-keyword-count {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 600;
}

/* Avg rank */
.sr-comp-avg-rank {
    font-family: 'JetBrains Mono', monospace;
    font-size: 13px;
    font-weight: 700;
}

/* AI visibility bar */
.sr-comp-vis-bar-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    justify-content: center;
}

.sr-comp-vis-bar {
    width: 70px;
    height: 6px;
    background: var(--gray-100, #f3f4f6);
    border-radius: 3px;
    overflow: hidden;
}

.sr-comp-vis-fill {
    height: 100%;
    border-radius: 3px;
    transition: width 0.5s ease;
}

.sr-comp-vis-fill.high { background: var(--emerald-600, #059669); }
.sr-comp-vis-fill.medium { background: #f59e0b; }
.sr-comp-vis-fill.low { background: #ef4444; }

.sr-comp-vis-score {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 600;
    min-width: 28px;
    color: var(--gray-700, #374151);
}

/* Threat level */
.sr-comp-threat {
    font-size: 12px;
    font-weight: 700;
}

.sr-comp-threat-high { color: #ef4444; }
.sr-comp-threat-medium { color: #f59e0b; }
.sr-comp-threat-low { color: var(--gray-400, #9ca3af); }

/* ==========================================
   Heatmap
   ========================================== */
.sr-comp-heatmap-wrap { overflow-x: auto; }

.sr-comp-heatmap {
    width: 100%;
    border-collapse: collapse;
    font-size: 12px;
}

.sr-comp-heatmap th {
    padding: 8px 10px;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    color: var(--gray-500, #6b7280);
    background: var(--gray-50, #f9fafb);
    border-bottom: 1px solid var(--gray-200, #e5e7eb);
    text-align: center;
    white-space: nowrap;
}

.sr-comp-heatmap th:first-child {
    text-align: left;
    min-width: 280px;
    max-width: 400px;
    position: sticky;
    left: 0;
    z-index: 1;
}

.sr-comp-heatmap td {
    padding: 8px 10px;
    text-align: center;
    border-bottom: 1px solid var(--gray-100, #f3f4f6);
}

.sr-comp-heatmap td:first-child {
    text-align: left;
    font-weight: 600;
    position: sticky;
    left: 0;
    background: white;
    z-index: 1;
    max-width: 400px;
}

.sr-comp-heatmap tr:hover td { background: var(--gray-50, #f9fafb); }
.sr-comp-heatmap tr:hover td:first-child { background: var(--gray-50, #f9fafb); }

.sr-comp-heatmap-kw {
    display: flex;
    align-items: center;
    gap: 6px;
}

.sr-comp-heatmap-kw-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-size: 13px;
}

/* Heat cells */
.sr-comp-heat {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 26px;
    border-radius: 5px;
    font-family: 'JetBrains Mono', monospace;
    font-weight: 600;
    font-size: 11px;
    padding: 0 4px;
}

.sr-comp-heat-1 { background: #bbf7d0; color: #14532d; }
.sr-comp-heat-3 { background: #d1fae5; color: #065f46; }
.sr-comp-heat-5 { background: #fef9c3; color: #854d0e; }
.sr-comp-heat-10 { background: #fed7aa; color: #9a3412; }
.sr-comp-heat-20 { background: #fecaca; color: #991b1b; }
.sr-comp-heat-none { background: var(--gray-50, #f9fafb); color: var(--gray-300, #d1d5db); }

/* ==========================================
   Platform Dominance
   ========================================== */
.sr-comp-platform-compare {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.sr-comp-plat-row {
    display: flex;
    align-items: center;
    gap: 12px;
}

.sr-comp-plat-label {
    width: 100px;
    font-size: 12px;
    font-weight: 600;
    color: var(--gray-700, #374151);
    display: flex;
    align-items: center;
    gap: 6px;
    flex-shrink: 0;
}

.sr-comp-plat-label img, .sr-comp-plat-label svg { width: 16px; height: 16px; }

.sr-comp-bar-track {
    flex: 1;
    height: 32px;
    background: var(--gray-50, #f9fafb);
    border-radius: 6px;
    position: relative;
    overflow: hidden;
    display: flex;
}

.sr-comp-bar-you {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    font-size: 11px;
    font-weight: 600;
    color: white;
    background: var(--emerald-600, #059669);
    border-radius: 6px 0 0 6px;
    transition: width 0.6s ease;
    white-space: nowrap;
    min-width: 0;
}

.sr-comp-bar-them {
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 10px;
    font-size: 11px;
    font-weight: 600;
    color: white;
    background: #6366f1;
    border-radius: 0 6px 6px 0;
    transition: width 0.6s ease;
    white-space: nowrap;
    min-width: 0;
}

.sr-comp-bar-nodata {
    background: var(--gray-100, #f3f4f6) !important;
}
.sr-comp-bar-nodata-label {
    width: 100%;
    text-align: center;
    font-size: 11px;
    font-weight: 500;
    color: var(--gray-400, #9ca3af);
    line-height: 32px;
}

.sr-comp-bar-legend {
    display: flex;
    gap: 16px;
    margin-top: 12px;
    font-size: 11px;
    color: var(--gray-500, #6b7280);
}

.sr-comp-legend-dot {
    width: 10px;
    height: 10px;
    border-radius: 3px;
    display: inline-block;
    margin-right: 4px;
    vertical-align: middle;
}

/* ==========================================
   Insights
   ========================================== */
.sr-comp-insights-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.sr-comp-insight {
    padding: 16px;
    border-radius: 8px;
    border: 1px solid var(--gray-100, #f3f4f6);
}

.sr-comp-insight h4 {
    font-size: 13px;
    font-weight: 700;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    gap: 6px;
}

.sr-comp-insight p {
    font-size: 13px;
    color: var(--gray-500, #6b7280);
    line-height: 1.5;
}

.sr-comp-insight p .hl {
    color: var(--gray-900, #111827);
    font-weight: 600;
}

.sr-comp-insight-icon {
    width: 20px;
    height: 20px;
    border-radius: 5px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.sr-comp-insight-danger { background: #fef2f2; color: #ef4444; }
.sr-comp-insight-opportunity { background: #ecfdf5; color: #059669; }
.sr-comp-insight-warning { background: #fffbeb; color: #f59e0b; }
.sr-comp-insight-info { background: #eff6ff; color: #2563eb; }

/* ==========================================
   Table & Heatmap Footers
   ========================================== */
.sr-comp-table-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-top: 1px solid var(--gray-100, #f3f4f6);
    font-size: 12px;
    color: var(--gray-500, #6b7280);
}

.sr-comp-heatmap-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-top: 1px solid var(--gray-100, #f3f4f6);
    font-size: 12px;
    color: var(--gray-500, #6b7280);
}

/* Search input styling */
.sr-input-sm {
    padding: 6px 10px;
    border: 1px solid var(--gray-200, #e5e7eb);
    border-radius: 6px;
    font-size: 12px;
    font-family: inherit;
    outline: none;
    transition: border-color 0.15s;
}

.sr-input-sm:focus {
    border-color: var(--emerald-600, #059669);
    box-shadow: 0 0 0 2px rgba(5, 150, 105, 0.1);
}

/* ==========================================
   Responsive
   ========================================== */
@media (max-width: 1024px) {
    .sr-comp-stat-row { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
    .sr-comp-stat-row { grid-template-columns: 1fr; }
    .sr-comp-insights-grid { grid-template-columns: 1fr; }
}

/* ==========================================
   Competitor Drill-Down
   ========================================== */

/* Make leaderboard rows clickable (non-you) */
.sr-comp-row:not(.sr-comp-your-row) {
    cursor: pointer;
}
.sr-comp-row:not(.sr-comp-your-row):hover {
    background: var(--gray-50, #f9fafb);
}
/* Back button */
.sr-comp-drill-back-row {
    margin-bottom: 16px;
}
.sr-comp-drill-back-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 14px;
    background: #fff;
    border: 1px solid var(--gray-200, #e5e7eb);
    border-radius: 8px;
    cursor: pointer;
    font-size: 13px;
    font-weight: 500;
    color: var(--gray-700, #374151);
    transition: all 0.15s ease;
}
.sr-comp-drill-back-btn:hover {
    background: var(--gray-50, #f9fafb);
    border-color: var(--gray-300, #d1d5db);
}
/* Header card */
.sr-comp-drill-header {
    position: relative;
    overflow: hidden;
    margin-bottom: 20px;
}
.sr-comp-drill-accent {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: #e5e7eb;
}
.sr-comp-drill-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 16px;
}
.sr-comp-drill-identity {
    display: flex;
    align-items: center;
    gap: 14px;
}
.sr-comp-drill-favicon-wrap {
    width: 48px;
    height: 48px;
    border-radius: 12px;
    background: var(--gray-50, #f9fafb);
    border: 1px solid var(--gray-200, #e5e7eb);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}
.sr-comp-drill-favicon-img {
    width: 28px;
    height: 28px;
}
.sr-comp-drill-name {
    font-size: 20px;
    font-weight: 700;
    color: var(--gray-900, #111827);
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.sr-comp-drill-meta {
    font-size: 13px;
    color: var(--gray-500, #6b7280);
    margin-top: 2px;
}
/* Threat badge in header */
.sr-comp-drill-threat-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
}
.sr-comp-drill-threat-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    display: inline-block;
}
.sr-comp-drill-threat-high {
    background: #fef2f2;
    color: #ef4444;
    border: 1px solid #fecaca;
}
.sr-comp-drill-threat-high .sr-comp-drill-threat-dot { background: #ef4444; }
.sr-comp-drill-threat-medium {
    background: #fffbeb;
    color: #f59e0b;
    border: 1px solid #fde68a;
}
.sr-comp-drill-threat-medium .sr-comp-drill-threat-dot { background: #f59e0b; }
.sr-comp-drill-threat-low {
    background: #ecfdf5;
    color: #10b981;
    border: 1px solid #a7f3d0;
}
.sr-comp-drill-threat-low .sr-comp-drill-threat-dot { background: #10b981; }
/* Platform dots in header */
.sr-comp-drill-platforms {
    display: flex;
    gap: 6px;
}
.sr-comp-drill-plat-dot {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--gray-100, #f3f4f6);
    border: 1px solid var(--gray-200, #e5e7eb);
}
.sr-comp-drill-plat-dot.active {
    background: rgba(5, 150, 105, 0.06);
    border-color: rgba(5, 150, 105, 0.2);
}
/* Stat cards row */
.sr-comp-drill-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 20px;
}
.sr-comp-drill-stat-card {
    background: white;
    border-radius: 10px;
    border: 1px solid var(--gray-200, #e5e7eb);
    padding: 18px 20px;
    position: relative;
    overflow: hidden;
}
.sr-comp-drill-stat-accent {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
}
.sr-comp-drill-stat-value {
    font-size: 26px;
    font-weight: 700;
    line-height: 1.2;
}
.sr-comp-drill-stat-label {
    font-size: 12px;
    color: var(--gray-500, #6b7280);
    margin-top: 2px;
    font-weight: 500;
}
.sr-comp-drill-stat-detail {
    font-size: 11px;
    color: var(--gray-400, #9ca3af);
    margin-top: 6px;
}
/* Export button */
.sr-comp-drill-export-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    background: #fff;
    border: 1px solid var(--gray-200, #e5e7eb);
    border-radius: 6px;
    cursor: pointer;
    font-size: 12px;
    font-weight: 500;
    color: var(--gray-700, #374151);
    transition: all 0.15s ease;
}
.sr-comp-drill-export-btn:hover {
    background: var(--gray-50, #f9fafb);
    border-color: var(--gray-300, #d1d5db);
}
/* Keyword breakdown table */
.sr-comp-drill-kw-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.sr-comp-drill-kw-table thead th {
    padding: 10px 14px;
    text-align: center;
    font-weight: 600;
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: var(--gray-500, #6b7280);
    background: var(--gray-50, #f9fafb);
    border-bottom: 1px solid var(--gray-200, #e5e7eb);
    white-space: nowrap;
}
.sr-comp-drill-kw-th {
    text-align: left !important;
}
.sr-comp-drill-kw-th-result {
    border-left: 2px solid var(--gray-200, #e5e7eb) !important;
}
.sr-comp-drill-kw-subhead th {
    padding: 4px 8px !important;
    font-size: 10px !important;
    color: var(--gray-400, #9ca3af) !important;
    font-weight: 500 !important;
    background: #fafafa !important;
}
.sr-comp-drill-kw-sub {
    text-align: center;
}
/* Platform header icon in table */
.sr-comp-drill-th-plat {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.sr-comp-drill-th-plat img,
.sr-comp-drill-th-plat svg {
    vertical-align: middle;
}
/* Table rows */
.sr-comp-drill-kw-row {
    border-bottom: 1px solid var(--gray-100, #f3f4f6);
    transition: background 0.1s ease;
}
.sr-comp-drill-kw-row:hover {
    background: #fafbfc;
}
.sr-comp-drill-kw-name {
    padding: 10px 14px;
    font-weight: 500;
    color: var(--gray-900, #111827);
    white-space: nowrap;
    text-align: left;
}
.sr-comp-drill-kw-rank {
    padding: 8px 8px;
    text-align: center;
}
.sr-comp-drill-kw-result {
    padding: 8px 14px;
    text-align: center;
    border-left: 2px solid var(--gray-200, #e5e7eb);
}
/* Rank badge */
.sr-comp-drill-rank {
    font-family: 'JetBrains Mono', monospace;
    font-size: 12px;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 4px;
    display: inline-block;
}
.sr-comp-drill-rank-empty {
    color: var(--gray-300, #d1d5db);
}
/* Result badges */
.sr-comp-drill-result-badge {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.3px;
}
.sr-comp-drill-result-win {
    background: #ecfdf5;
    color: var(--emerald-600, #059669);
}
.sr-comp-drill-result-lose {
    background: #fef2f2;
    color: #ef4444;
}
.sr-comp-drill-result-split {
    background: #fffbeb;
    color: #f59e0b;
}
.sr-comp-drill-result-none {
    background: var(--gray-50, #f9fafb);
    color: var(--gray-400, #9ca3af);
}
/* Footer record summary */
.sr-comp-drill-record-summary {
    display: flex;
    gap: 16px;
}
.sr-comp-drill-record-win {
    color: var(--emerald-600, #059669);
    font-weight: 600;
}
.sr-comp-drill-record-lose {
    color: #ef4444;
    font-weight: 600;
}
.sr-comp-drill-record-split {
    color: #f59e0b;
    font-weight: 600;
}
/* ==========================================
   Responsive: Drill-Down
   ========================================== */
@media (max-width: 768px) {
    .sr-comp-drill-stats {
        grid-template-columns: repeat(2, 1fr);
    }
    .sr-comp-drill-header-inner {
        flex-direction: column;
        align-items: flex-start;
    }
    .sr-comp-drill-name {
        font-size: 17px;
    }
    .sr-comp-drill-kw-table {
        font-size: 12px;
    }
    .sr-comp-drill-kw-name {
        max-width: 120px;
        overflow: hidden;
        text-overflow: ellipsis;
    }
}