/**
 * Credit Score Demo Styles
 * Extracted from ormeo.lens CompanyCreditScoreView
 */

/* ========================================
   Layout
   ======================================== */
.creditscore-demo {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: var(--spacing-lg);
    height: 100%;
    overflow-y: auto;
    background: var(--bg-primary);

    /* Custom scrollbar for macOS visibility */
    scrollbar-width: thin;
    scrollbar-color: var(--border-secondary, #c4c4c4) var(--bg-primary, #fafafa);
}

.creditscore-demo::-webkit-scrollbar {
    width: 8px;
}

.creditscore-demo::-webkit-scrollbar-track {
    background: var(--bg-primary);
    border-radius: 4px;
}

.creditscore-demo::-webkit-scrollbar-thumb {
    background: var(--border-secondary, #c4c4c4);
    border-radius: 4px;
    border: 2px solid var(--bg-primary);
}

.creditscore-demo::-webkit-scrollbar-thumb:hover {
    background: var(--text-quaternary, #a3a3a3);
}

/* ========================================
   Sections
   ======================================== */
.cs-section {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}

.cs-section-header {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.cs-section-title {
    font-size: 1rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

/* ========================================
   Credit Score Card (Main Gauge)
   ======================================== */
.cs-credit-score-card {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    padding: 1.25rem;
}

.cs-credit-score-gauge {
    width: 100%;
    position: relative;
}

.cs-gauge-bar {
    width: 100%;
    height: 60px;
    border-radius: var(--radius-md);
    overflow: hidden;
    position: relative;
    background-color: var(--bg-tertiary);
    border: 1px solid var(--border-primary);
}

.cs-gauge-bar--undetermined {
    background: repeating-linear-gradient(
        -45deg,
        var(--bg-tertiary),
        var(--bg-tertiary) 8px,
        var(--bg-secondary) 8px,
        var(--bg-secondary) 16px
    );
}

.cs-gauge-fill {
    height: 100%;
    border-radius: var(--radius-sm) 0 0 var(--radius-sm);
    transition: width 0.5s ease;
}

.cs-gauge-fill--low {
    background: linear-gradient(90deg, #CF2020, #e53935);
}

.cs-gauge-fill--medium {
    background: linear-gradient(90deg, #FFBB10, #ffc107);
}

.cs-gauge-fill--high {
    background: linear-gradient(90deg, #42B74A, #4caf50);
}

.cs-gauge-text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.25rem;
    font-weight: 700;
    color: white;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
    white-space: nowrap;
    z-index: 1;
}

.cs-gauge-text--undetermined {
    color: var(--text-tertiary);
    text-shadow: none;
    font-size: 0.875rem;
    font-weight: 500;
}

/* Score Descriptions */
.cs-score-descriptions {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border-primary);
}

.cs-description-list {
    margin: 0;
    padding-left: 1.25rem;
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
}

.cs-description-list li {
    font-size: 0.875rem;
    color: var(--text-secondary);
    line-height: 1.4;
}

/* ========================================
   Risk Gauges Grid (Semi-circle gauges)
   ======================================== */
.cs-risk-gauges-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}

@media (max-width: 640px) {
    .cs-risk-gauges-grid {
        grid-template-columns: 1fr;
    }
}

.cs-risk-gauge-card {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    display: flex;
    justify-content: center;
    align-items: center;
}

.cs-risk-gauge {
    display: flex;
    flex-direction: column;
    align-items: center;
    user-select: none;
}

.cs-risk-gauge svg {
    display: block;
}

.cs-risk-gauge__title {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--text-secondary);
    text-align: center;
    margin-top: 0.25rem;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
}

/* ========================================
   Two Column Grid (Real-Time & Network)
   ======================================== */
.cs-two-column-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
}

@media (max-width: 900px) {
    .cs-two-column-grid {
        grid-template-columns: 1fr;
    }
}

/* ========================================
   Risk Card
   ======================================== */
.cs-risk-card {
    background-color: var(--bg-secondary);
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-md);
    padding: 1.25rem;
    display: flex;
    flex-direction: column;
}

.cs-risk-card__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.75rem;
}

.cs-risk-card__title {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--text-primary);
    margin: 0;
}

.cs-header-link {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--accent-primary);
    text-decoration: none;
}

.cs-header-link:hover {
    text-decoration: underline;
}

.cs-details-description {
    font-size: 0.8125rem;
    color: var(--text-secondary);
    margin: 0.75rem 0;
    line-height: 1.4;
}

.cs-no-data {
    text-align: center;
    padding: 1.5rem;
    color: var(--text-tertiary);
    font-size: 0.875rem;
}

/* ========================================
   Real-Time Risk Gauge (Linear Bar)
   ======================================== */
.cs-realtime-risk {
    width: 100%;
}

.cs-realtime-risk__header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.375rem;
}

.cs-realtime-risk__title {
    font-size: 0.625rem;
    font-weight: 600;
    color: var(--text-tertiary);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.cs-realtime-risk__value {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--text-primary);
}

.cs-realtime-risk__gauge {
    margin-bottom: 0.25rem;
}

.cs-realtime-risk__svg {
    width: 100%;
    height: auto;
    display: block;
}

.cs-realtime-risk__labels {
    display: flex;
    justify-content: space-between;
    padding: 0 0.125rem;
}

.cs-realtime-risk__label {
    font-size: 0.625rem;
    font-weight: 500;
    text-align: center;
    flex: 1;
    white-space: nowrap;
}

.cs-realtime-risk__label--low {
    color: var(--accent-green, #42B74A);
}

.cs-realtime-risk__label--moderate {
    color: var(--accent-yellow, #FFBB10);
}

.cs-realtime-risk__label--high {
    color: var(--accent-orange, #FF7A00);
}

.cs-realtime-risk__label--very-high {
    color: var(--accent-red, #CF2020);
}

/* ========================================
   Network Risk Gauge
   ======================================== */
.cs-network-risk {
    width: 100%;
}

.cs-network-risk__gauge {
    margin-bottom: 0.75rem;
}

.cs-network-risk__svg {
    width: 100%;
    height: auto;
    display: block;
}

/* Network Stats Grid */
.cs-network-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.5rem;
}

.cs-stat-card {
    background-color: var(--bg-tertiary);
    border-radius: var(--radius-md);
    padding: 0.75rem;
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
}

.cs-stat-card--warning {
    background-color: color-mix(in srgb, var(--accent-yellow, #FFBB10) 15%, var(--bg-tertiary));
}

.cs-stat-card__value {
    font-size: 1.25rem;
    font-weight: 700;
    color: var(--text-primary);
}

.cs-stat-card__label {
    font-size: 0.6875rem;
    color: var(--text-secondary);
}

.cs-stat-card__percent {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-tertiary);
}

/* ========================================
   Intelligence Table
   ======================================== */
.cs-table-container {
    max-height: 200px;
    overflow-y: auto;
    border: 1px solid var(--border-primary);
    border-radius: var(--radius-sm);

    /* Custom scrollbar for macOS visibility */
    scrollbar-width: thin;
    scrollbar-color: var(--border-secondary, #c4c4c4) var(--bg-secondary, #ffffff);
}

.cs-table-container::-webkit-scrollbar {
    width: 6px;
}

.cs-table-container::-webkit-scrollbar-track {
    background: var(--bg-secondary);
}

.cs-table-container::-webkit-scrollbar-thumb {
    background: var(--border-secondary, #c4c4c4);
    border-radius: 3px;
}

.cs-table-container::-webkit-scrollbar-thumb:hover {
    background: var(--text-quaternary, #a3a3a3);
}

.cs-risk-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.8125rem;
}

.cs-risk-table thead {
    position: sticky;
    top: 0;
    background-color: var(--bg-tertiary);
}

.cs-risk-table th {
    text-align: left;
    padding: 0.5rem 0.75rem;
    font-weight: 600;
    color: var(--text-secondary);
    border-bottom: 1px solid var(--border-primary);
    font-size: 0.75rem;
}

.cs-risk-table td {
    padding: 0.5rem 0.75rem;
    color: var(--text-primary);
    border-bottom: 1px solid var(--border-secondary);
}

.cs-risk-table tbody tr:last-child td {
    border-bottom: none;
}

.cs-risk-table tbody tr:hover {
    background-color: var(--bg-hover, rgba(0, 0, 0, 0.02));
}

.cs-score-column {
    width: 50px;
}

.cs-date-column {
    width: 100px;
}

.cs-score-cell {
    text-align: center;
}

.cs-score-indicator {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.cs-date-cell {
    white-space: nowrap;
    color: var(--text-secondary);
}
