/* =============================================
   CONSULTA REPORT V2 - VeículoSeguro
   Design System VS TOTAL - Redesign 2026
   Baseado no layout iconesvslayout/LAYOUT.md
   ============================================= */

/* =========== 1. VARIÁVEIS E TOKENS V2 =========== */
:root {
    /* Cores Principais V2 */
    --vs2-primary: #1B3A5C;
    --vs2-primary-dark: #0F2640;
    --vs2-primary-light: #2A5580;
    --vs2-white: #FFFFFF;

    /* Grays */
    --vs2-gray-50: #F8FAFC;
    --vs2-gray-100: #F1F5F9;
    --vs2-gray-200: #E2E8F0;
    --vs2-gray-300: #CBD5E1;
    --vs2-gray-400: #94A3B8;
    --vs2-gray-500: #64748B;
    --vs2-gray-600: #475569;
    --vs2-gray-700: #334155;

    /* Status */
    --vs2-success: #16A34A;
    --vs2-success-bg: #F0FDF4;
    --vs2-success-border: #BBF7D0;

    --vs2-danger: #DC2626;
    --vs2-danger-bg: #FEF2F2;
    --vs2-danger-border: #FECACA;

    --vs2-warning: #D97706;
    --vs2-warning-bg: #FFFBEB;
    --vs2-warning-border: #FDE68A;

    --vs2-info-bg: #EFF6FF;
    --vs2-info-border: #BFDBFE;
}

/* =========== 2. SUMMARY GRID V2 =========== */
.vs2-summary-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    padding: 20px 24px;
    background: var(--vs2-gray-50);
    border-bottom: 1px solid var(--vs2-gray-200);
}

@media (max-width: 768px) {
    .vs2-summary-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 10px;
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .vs2-summary-grid {
        grid-template-columns: 1fr;
        gap: 8px;
        padding: 12px;
    }
}

/* =========== 3. SUMMARY CARD V2 =========== */
.vs2-summary-card {
    border-radius: 10px;
    padding: 16px 14px;
    text-align: center;
    border: 1.5px solid;
    position: relative;
    cursor: pointer;
    transition: all 0.2s ease;
}

.vs2-summary-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.vs2-summary-card .vs2-card-icon {
    width: 28px;
    height: 28px;
    margin: 0 auto 6px;
    display: block;
}

.vs2-summary-card .vs2-card-title {
    font-size: 0.65rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    margin-bottom: 4px;
}

.vs2-summary-card .vs2-card-value {
    font-size: 0.85rem;
    font-weight: 700;
}

.vs2-summary-card .vs2-card-status {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    margin-top: 4px;
}

.vs2-summary-card .vs2-card-status img {
    width: 16px;
    height: 16px;
}

/* Variantes de cor */
.vs2-summary-card.green {
    background: var(--vs2-success-bg);
    border-color: var(--vs2-success-border);
    color: var(--vs2-success);
}

.vs2-summary-card.red {
    background: var(--vs2-danger-bg);
    border-color: var(--vs2-danger-border);
    color: var(--vs2-danger);
}

.vs2-summary-card.orange {
    background: var(--vs2-warning-bg);
    border-color: var(--vs2-warning-border);
    color: var(--vs2-warning);
}

.vs2-summary-card.blue {
    background: var(--vs2-info-bg);
    border-color: var(--vs2-info-border);
    color: var(--vs2-primary);
}

/* =========== 4. SECTION HEADER V2 =========== */
.vs2-section-header {
    background: var(--vs2-primary);
    color: var(--vs2-white);
    padding: 10px 24px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 0.85rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}

.vs2-section-header.danger {
    background: var(--vs2-danger);
}

.vs2-section-header.warning {
    background: var(--vs2-warning);
}

.vs2-section-header.secondary {
    background: var(--vs2-primary-light);
}

.vs2-section-header img.vs2-section-icon {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
    filter: brightness(0) invert(1);
}

.vs2-section-header .vs2-section-date {
    margin-left: auto;
    font-size: 0.7rem;
    font-weight: 400;
    opacity: 0.7;
}

.vs2-section-header .vs2-source-tag {
    font-size: 0.6rem;
    font-weight: 600;
    padding: 2px 8px;
    border-radius: 3px;
    background: rgba(255, 255, 255, 0.2);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    white-space: nowrap;
}

/* =========== 5. SECTION BODY V2 =========== */
.vs2-section-body {
    padding: 20px 24px;
}

.vs2-section-body.alert-body {
    background: var(--vs2-danger-bg);
    border-left: 4px solid var(--vs2-danger);
}

.vs2-section-body.warn-body {
    background: var(--vs2-warning-bg);
    border-left: 4px solid var(--vs2-warning);
}

/* Alert / Warn Banners */
.vs2-alert-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--vs2-danger);
    color: var(--vs2-white);
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.vs2-alert-banner img,
.vs2-warn-banner img {
    width: 18px;
    height: 18px;
    filter: brightness(0) invert(1);
    flex-shrink: 0;
}

.vs2-warn-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--vs2-warning);
    color: var(--vs2-white);
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

/* =========== 6. DATA GRID V2 =========== */
.vs2-data-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
}

.vs2-data-grid.cols-2 {
    grid-template-columns: repeat(2, 1fr);
}

.vs2-data-grid.cols-4 {
    grid-template-columns: repeat(4, 1fr);
}

.vs2-data-item {
    padding: 12px 16px;
    border-bottom: 1px solid var(--vs2-gray-100);
    border-right: 1px solid var(--vs2-gray-100);
}

/* Border-right reset para última coluna */
.vs2-data-grid .vs2-data-item:nth-child(3n) {
    border-right: none;
}

.vs2-data-grid.cols-2 .vs2-data-item:nth-child(2n) {
    border-right: none;
}

.vs2-data-grid.cols-2 .vs2-data-item:nth-child(3n) {
    border-right: 1px solid var(--vs2-gray-100);
}

.vs2-data-grid.cols-4 .vs2-data-item:nth-child(3n) {
    border-right: 1px solid var(--vs2-gray-100);
}

.vs2-data-grid.cols-4 .vs2-data-item:nth-child(4n) {
    border-right: none;
}

.vs2-data-item .vs2-label {
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--vs2-gray-400);
    margin-bottom: 3px;
}

.vs2-data-item .vs2-value {
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--vs2-primary);
    word-break: break-all;
}

.vs2-data-item.full-width {
    grid-column: 1 / -1;
    border-right: none;
}

@media (max-width: 768px) {
    .vs2-data-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .vs2-data-grid .vs2-data-item:nth-child(3n) {
        border-right: 1px solid var(--vs2-gray-100);
    }

    .vs2-data-grid .vs2-data-item:nth-child(2n) {
        border-right: none;
    }
}

@media (max-width: 480px) {
    .vs2-data-grid,
    .vs2-data-grid.cols-2,
    .vs2-data-grid.cols-4 {
        grid-template-columns: 1fr;
    }

    .vs2-data-grid .vs2-data-item {
        border-right: none;
    }
}

/* =========== 7. STATUS BADGES V2 =========== */
.vs2-badge {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 10px;
    border-radius: 20px;
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.vs2-badge img {
    width: 12px;
    height: 12px;
}

.vs2-badge.ok {
    background: var(--vs2-success-bg);
    color: var(--vs2-success);
    border: 1px solid var(--vs2-success-border);
}

.vs2-badge.alert {
    background: var(--vs2-danger-bg);
    color: var(--vs2-danger);
    border: 1px solid var(--vs2-danger-border);
}

.vs2-badge.warn {
    background: var(--vs2-warning-bg);
    color: var(--vs2-warning);
    border: 1px solid var(--vs2-warning-border);
}

.vs2-badge.pending {
    background: var(--vs2-gray-100);
    color: var(--vs2-gray-500);
    border: 1px solid var(--vs2-gray-200);
}

/* =========== 8. RESTRICTION GRID V2 =========== */
.vs2-restriction-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
}

.vs2-restriction-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--vs2-gray-50);
    border-radius: 8px;
    border: 1px solid var(--vs2-gray-200);
}

.vs2-restriction-item .vs2-r-label {
    font-size: 0.8rem;
    font-weight: 600;
    color: var(--vs2-gray-600);
}

.vs2-restriction-item.has-alert {
    background: var(--vs2-danger-bg);
    border-color: var(--vs2-danger-border);
}

.vs2-restriction-item.has-alert .vs2-r-label {
    color: var(--vs2-danger);
    font-weight: 700;
}

/* Fix: badge alert dentro de restriction-item com alert precisa contraste */
.vs2-restriction-item.has-alert .vs2-badge.alert {
    background: var(--vs2-danger);
    color: var(--vs2-white);
    border-color: var(--vs2-danger);
}
.vs2-restriction-item.has-alert .vs2-badge.alert img {
    filter: brightness(0) invert(1);
}

/* Badge dentro de restriction items: tamanho legível */
.vs2-restriction-item .vs2-badge {
    font-size: 0.75rem;
    padding: 4px 12px;
    min-width: 80px;
    justify-content: center;
}

@media (max-width: 576px) {
    .vs2-restriction-grid {
        grid-template-columns: 1fr;
    }
}

/* =========== 8B. SUB-SECTION HEADER & VALORES COLORIDOS =========== */
.vs2-subsection-header {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 8px 16px;
    margin-top: 20px;
    margin-bottom: 12px;
    background: var(--vs2-gray-100);
    border-left: 3px solid var(--vs2-primary);
    font-size: 0.78rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--vs2-primary);
}
.vs2-subsection-header img {
    width: 16px;
    height: 16px;
    opacity: 0.7;
}

/* Valor com alerta (restrição ativa) */
.vs2-value.vs2-valor-alerta {
    color: var(--vs2-danger);
    font-weight: 700;
}

/* Valor limpo (nada consta) */
.vs2-value.vs2-valor-ok {
    color: var(--vs2-success);
    font-weight: 600;
}

/* =========== 9. DÉBITOS V2 =========== */
.vs2-debito-highlight {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    background: var(--vs2-warning-bg);
    border: 1px solid var(--vs2-warning-border);
    border-radius: 8px;
    margin-bottom: 8px;
}

.vs2-debito-highlight .vs2-d-label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--vs2-gray-600);
}

.vs2-debito-highlight .vs2-d-value {
    font-size: 0.9rem;
    font-weight: 800;
    color: var(--vs2-warning);
}

.vs2-debito-highlight.has-debt .vs2-d-value {
    color: var(--vs2-danger);
}

.vs2-debito-total {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 14px 16px;
    background: var(--vs2-warning);
    color: var(--vs2-white);
    border-radius: 8px;
    margin-top: 8px;
    font-weight: 700;
}

.vs2-debito-total .vs2-d-label {
    font-size: 0.8rem;
    text-transform: uppercase;
}

.vs2-debito-total .vs2-d-value {
    font-size: 1.1rem;
    font-weight: 800;
}

/* =========== 9.5 ALERT/WARN BANNERS =========== */
.vs2-section-alert-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--vs2-danger);
    color: #FFFFFF;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.vs2-section-alert-banner img {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

.vs2-section-alert-banner div {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.vs2-section-alert-banner strong {
    font-size: 0.85rem;
}

.vs2-section-alert-banner span {
    font-size: 0.75rem;
    font-weight: 400;
    opacity: 0.9;
}

.vs2-section-warn-banner {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px 16px;
    background: var(--vs2-warning);
    color: #FFFFFF;
    border-radius: 8px;
    margin-bottom: 16px;
    font-size: 0.8rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.vs2-section-warn-banner img {
    width: 18px;
    height: 18px;
    flex-shrink: 0;
}

/* =========== 10. AUCTION V2 =========== */
.vs2-auction-base {
    border: 1px solid var(--vs2-danger-border);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 14px;
}

.vs2-auction-base:last-child {
    margin-bottom: 0;
}

.vs2-auction-base-header {
    background: var(--vs2-danger);
    color: var(--vs2-white);
    padding: 8px 16px;
    font-size: 0.75rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.vs2-auction-card {
    border: 1px solid var(--vs2-gray-200);
    border-radius: 8px;
    overflow: hidden;
    margin-bottom: 12px;
}

.vs2-auction-card:last-child {
    margin-bottom: 0;
}

.vs2-auction-card-header {
    background: var(--vs2-gray-50);
    padding: 10px 16px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 1px solid var(--vs2-gray-200);
}

.vs2-auction-card-header strong {
    font-size: 0.8rem;
    color: var(--vs2-primary);
}

.vs2-auction-date-badge {
    background: var(--vs2-primary);
    color: var(--vs2-white);
    padding: 2px 10px;
    border-radius: 4px;
    font-size: 0.7rem;
    font-weight: 600;
}

/* Cards dentro de auction-base */
.vs2-auction-base .vs2-auction-card {
    border: none;
    border-radius: 0;
    margin-bottom: 0;
    border-bottom: 1px solid var(--vs2-danger-border);
}

.vs2-auction-base .vs2-auction-card:last-child {
    border-bottom: none;
}

/* Alert body auction overrides */
.vs2-section-body.alert-body .vs2-auction-card {
    border-color: var(--vs2-danger-border);
}

.vs2-section-body.alert-body .vs2-auction-card-header {
    background: var(--vs2-danger-bg);
    border-bottom-color: var(--vs2-danger-border);
}

.vs2-section-body.alert-body .vs2-auction-card-header strong {
    color: var(--vs2-danger);
}

/* =========== 11. FIPE VALUE V2 =========== */
.vs2-fipe-box {
    text-align: center;
    padding: 20px;
}

.vs2-fipe-value {
    font-size: 2rem;
    font-weight: 800;
    color: var(--vs2-primary);
    letter-spacing: -0.02em;
}

.vs2-fipe-ref {
    font-size: 0.75rem;
    color: var(--vs2-gray-400);
    margin-top: 4px;
}

/* =========== 12. EMPTY STATE V2 =========== */
.vs2-empty-state {
    text-align: center;
    padding: 20px;
    color: var(--vs2-gray-400);
    font-size: 0.85rem;
    font-style: italic;
}

/* =========== 13. SECTION CONTAINER V2 =========== */
.vs2-section {
    border-bottom: 1px solid var(--vs2-gray-200);
}

.vs2-section:last-child {
    border-bottom: none;
}

/* =========== 14. PARECER TÉCNICO V2 =========== */
.vs2-parecer-card {
    display: flex;
    align-items: center;
    gap: 20px;
    border: 2px solid;
    border-radius: 10px;
    padding: 20px 24px;
    margin-bottom: 16px;
}

.vs2-parecer-card.verde {
    background: var(--vs2-success-bg);
    border-color: var(--vs2-success-border);
}

.vs2-parecer-card.amarelo {
    background: var(--vs2-warning-bg);
    border-color: var(--vs2-warning-border);
}

.vs2-parecer-card.vermelho {
    background: var(--vs2-danger-bg);
    border-color: var(--vs2-danger-border);
}

.vs2-parecer-card img.vs2-semaforo {
    width: 56px;
    height: 56px;
    flex-shrink: 0;
}

.vs2-parecer-info {
    flex: 1;
}

.vs2-parecer-info .vs2-parecer-label {
    font-size: 0.8rem;
    color: var(--vs2-gray-600);
}

.vs2-parecer-info .vs2-parecer-semaforo {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-top: 6px;
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-dot {
    display: inline-block;
    width: 12px;
    height: 12px;
    border-radius: 50%;
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-dot.verde {
    background: var(--vs2-success);
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-dot.amarelo {
    background: var(--vs2-warning);
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-dot.vermelho {
    background: var(--vs2-danger);
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-text {
    font-size: 0.95rem;
    font-weight: 800;
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-text.verde {
    color: var(--vs2-success);
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-text.amarelo {
    color: var(--vs2-warning);
}

.vs2-parecer-info .vs2-parecer-semaforo .vs2-semaforo-text.vermelho {
    color: var(--vs2-danger);
}

.vs2-parecer-info .vs2-parecer-interpretacao {
    font-size: 0.8rem;
    color: var(--vs2-gray-600);
    margin-top: 8px;
}

.vs2-parecer-obs {
    background: var(--vs2-gray-50);
    border: 1px solid var(--vs2-gray-200);
    border-radius: 8px;
    padding: 16px 20px;
}

.vs2-parecer-obs .vs2-parecer-obs-title {
    font-size: 0.7rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--vs2-gray-400);
    margin-bottom: 8px;
}

.vs2-parecer-obs .vs2-parecer-obs-text {
    font-size: 0.75rem;
    color: var(--vs2-gray-600);
    line-height: 1.7;
}

/* =========== 15. RECALL V2 =========== */
.vs2-recall-obs {
    background: var(--vs2-warning-bg);
    border: 1px solid var(--vs2-warning-border);
    border-radius: 8px;
    padding: 12px 16px;
    margin-bottom: 16px;
    font-size: 0.75rem;
    color: var(--vs2-gray-600);
    line-height: 1.6;
}

.vs2-recall-obs strong {
    color: var(--vs2-warning);
}

/* =========== 16. CONSULT BAR V2 =========== */
.vs2-consult-bar {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    border-bottom: 1px solid var(--vs2-gray-200);
}

.vs2-consult-bar .vs2-bar-item {
    padding: 16px 20px;
    text-align: center;
    border-right: 1px solid var(--vs2-gray-200);
}

.vs2-consult-bar .vs2-bar-item:last-child {
    border-right: none;
}

.vs2-consult-bar .vs2-bar-label {
    font-size: 0.65rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--vs2-gray-400);
    margin-bottom: 4px;
}

.vs2-consult-bar .vs2-bar-value {
    font-size: 0.95rem;
    font-weight: 700;
    color: var(--vs2-primary);
}

.vs2-plate-badge {
    display: inline-block;
    background: var(--vs2-primary);
    color: var(--vs2-white);
    padding: 4px 14px;
    border-radius: 4px;
    font-weight: 800;
    letter-spacing: 2px;
    font-size: 1rem;
}

@media (max-width: 576px) {
    .vs2-consult-bar {
        grid-template-columns: repeat(2, 1fr);
    }

    .vs2-consult-bar .vs2-bar-item:nth-child(2) {
        border-right: none;
    }
}

/* =========== 17. FOOTER V2 =========== */
.vs2-report-footer {
    background: var(--vs2-gray-50);
    border-top: 1px solid var(--vs2-gray-200);
    padding: 20px 24px;
    font-size: 0.65rem;
    color: var(--vs2-gray-400);
    line-height: 1.6;
}

.vs2-report-footer strong {
    color: var(--vs2-gray-500);
}

.vs2-report-footer p {
    margin-bottom: 8px;
}

.vs2-report-footer p:last-child {
    margin-bottom: 0;
}

.vs2-footer-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 24px;
    background: var(--vs2-primary);
    color: var(--vs2-white);
    font-size: 0.7rem;
    opacity: 0.9;
}

/* =========== 18. PRINT STYLES V2 =========== */
@media print {
    * {
        -webkit-print-color-adjust: exact !important;
        color-adjust: exact !important;
    }

    .vs2-section {
        page-break-inside: avoid;
    }

    .vs2-summary-card {
        page-break-inside: avoid;
    }

    .vs2-auction-card {
        page-break-inside: avoid;
    }

    .vs2-section-header {
        background: var(--vs2-primary) !important;
        color: white !important;
    }

    .vs2-section-header.danger {
        background: var(--vs2-danger) !important;
    }

    .vs2-section-header.warning {
        background: var(--vs2-warning) !important;
    }
}

/* =========== 19. UTILITY CLASSES V2 =========== */
.vs2-mt-16 {
    margin-top: 16px;
}

.vs2-mt-20 {
    margin-top: 20px;
}

.vs2-mb-16 {
    margin-bottom: 16px;
}

/* =========== 20. SCORE GAUGE (CRÉDITO) =========== */
.vs2-score-gauge {
    margin: 18px 0 8px;
    width: 100%;
}

.vs2-score-track {
    position: relative;
    display: flex;
    width: 100%;
    height: 14px;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.08);
}

.vs2-score-segment {
    height: 100%;
}

.vs2-score-segment.red {
    background: linear-gradient(90deg, #DC2626 0%, #EF4444 100%);
    flex: 0 0 30%;
}

.vs2-score-segment.orange {
    background: linear-gradient(90deg, #F59E0B 0%, #FBBF24 100%);
    flex: 0 0 20%;
}

.vs2-score-segment.blue {
    background: linear-gradient(90deg, #3B82F6 0%, #60A5FA 100%);
    flex: 0 0 20%;
}

.vs2-score-segment.green {
    background: linear-gradient(90deg, #10B981 0%, #34D399 100%);
    flex: 0 0 30%;
}

.vs2-score-marker {
    position: absolute;
    top: -4px;
    width: 4px;
    height: 22px;
    background: #0F2A47;
    border-radius: 2px;
    box-shadow: 0 0 0 2px white, 0 1px 4px rgba(0, 0, 0, 0.25);
    transform: translateX(-50%);
    transition: left 0.3s ease;
}

.vs2-score-scale {
    display: flex;
    justify-content: space-between;
    margin-top: 8px;
    font-size: 0.7rem;
    color: #6B7280;
    font-weight: 600;
    letter-spacing: 0.03em;
}

.vs2-score-scale span {
    flex: 1;
    text-align: center;
}

.vs2-score-scale span:first-child {
    text-align: left;
}

.vs2-score-scale span:last-child {
    text-align: right;
}

.vs2-score-value {
    display: flex;
    align-items: baseline;
    gap: 8px;
    margin-bottom: 6px;
}

.vs2-score-value .vs2-score-number {
    font-size: 2.2rem;
    font-weight: 800;
    color: #0F2A47;
    line-height: 1;
}

.vs2-score-value .vs2-score-max {
    font-size: 1rem;
    color: #6B7280;
    font-weight: 600;
}

.vs2-score-value .vs2-score-faixa {
    margin-left: auto;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 12px;
    background: #F3F4F6;
    color: #1B3A5C;
}

/* =========== 21. COLLAPSIBLE DETAILS =========== */
.vs2-collapsible {
    margin-top: 14px;
    border: 1px solid #E5E7EB;
    border-radius: 8px;
    overflow: hidden;
    background: #FAFBFC;
}

.vs2-collapsible > summary {
    list-style: none;
    cursor: pointer;
    padding: 10px 14px;
    font-size: 0.82rem;
    font-weight: 600;
    color: #1B3A5C;
    background: #F3F4F6;
    user-select: none;
    display: flex;
    align-items: center;
    gap: 8px;
    transition: background 0.15s ease;
}

.vs2-collapsible > summary::-webkit-details-marker {
    display: none;
}

.vs2-collapsible > summary::before {
    content: "▸";
    font-size: 0.75rem;
    color: #6B7280;
    transition: transform 0.2s ease;
    display: inline-block;
}

.vs2-collapsible[open] > summary::before {
    transform: rotate(90deg);
}

.vs2-collapsible > summary:hover {
    background: #E5E7EB;
}

.vs2-collapsible > .vs2-collapsible-body {
    padding: 14px;
    background: white;
}

/* =========== 22. GENERIC TABLE =========== */
.vs2-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.82rem;
    background: white;
}

.vs2-table thead {
    background: #F3F4F6;
}

.vs2-table thead th {
    text-align: left;
    padding: 10px 12px;
    font-size: 0.72rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #1B3A5C;
    border-bottom: 1px solid #D1D5DB;
}

.vs2-table tbody td {
    padding: 9px 12px;
    border-bottom: 1px solid #F3F4F6;
    color: #374151;
    vertical-align: top;
}

.vs2-table tbody tr:last-child td {
    border-bottom: none;
}

.vs2-table tbody tr:hover {
    background: #F9FAFB;
}

.vs2-table tbody td.numeric {
    text-align: right;
    font-variant-numeric: tabular-nums;
    font-weight: 600;
}

.vs2-table tbody td.alert-value {
    color: #DC2626;
    font-weight: 700;
}

/* =========== 23. FEATURES GRID (OPTIONAL FEATURES) =========== */
.vs2-features-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin: 0 0 16px 0;
}

@media (max-width: 768px) {
    .vs2-features-grid {
        grid-template-columns: 1fr;
        gap: 12px;
    }
}

.vs2-features-grid .vs2-section {
    margin-bottom: 0;
}

/* =========== 24. CREDITO — HIGHLIGHT VALUES =========== */
.vs2-valor-alerta {
    color: #DC2626;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.vs2-valor-positivo {
    color: #047857;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
}

.vs2-valor-numerico {
    font-variant-numeric: tabular-nums;
    font-weight: 600;
}

.vs2-data-item .vs2-value.vs2-valor-alerta,
.vs2-data-item .vs2-value.vs2-valor-positivo {
    font-size: 0.95rem;
}

/* =========== 25.1 CREDITO — SCORE CARD (ScoreCardBase) =========== */
.vs2-credito-score-card {
    padding: 18px 22px;
    border-radius: 10px;
    border: 1px solid #E5E7EB;
    background: linear-gradient(180deg, #FAFBFC 0%, #FFFFFF 100%);
}

.vs2-credito-score-card--blue {
    border-left: 4px solid #3B82F6;
    background: linear-gradient(180deg, #F0F9FF 0%, #FFFFFF 100%);
}

.vs2-credito-score-card--green {
    border-left: 4px solid #10B981;
    background: linear-gradient(180deg, #F0FFF4 0%, #FFFFFF 100%);
}

.vs2-credito-score-card--orange {
    border-left: 4px solid #F59E0B;
    background: linear-gradient(180deg, #FFFBF0 0%, #FFFFFF 100%);
}

.vs2-credito-score-card--red {
    border-left: 4px solid #DC2626;
    background: linear-gradient(180deg, #FEF2F2 0%, #FFFFFF 100%);
}

.vs2-credito-score-card--yellow {
    border-left: 4px solid #EAB308;
    background: linear-gradient(180deg, #FEFCE8 0%, #FFFFFF 100%);
}

.vs2-credito-score-primary .vs2-label {
    margin-bottom: 6px;
}

.vs2-credito-score-display {
    display: flex;
    align-items: baseline;
    gap: 8px;
    flex-wrap: wrap;
}

.vs2-credito-score-number {
    font-size: 2.2rem;
    font-weight: 800;
    color: #0F2A47;
    line-height: 1;
    font-variant-numeric: tabular-nums;
}

.vs2-credito-score-max {
    font-size: 1rem;
    color: #6B7280;
    font-weight: 600;
}

.vs2-credito-score-sublabel {
    margin-left: auto;
    font-size: 0.85rem;
    font-weight: 700;
    padding: 4px 12px;
    border-radius: 12px;
    background: #F3F4F6;
    color: #1B3A5C;
}

.vs2-credito-score-message {
    margin-top: 14px;
    padding: 10px 14px;
    background: #F9FAFB;
    border-left: 3px solid #9CA3AF;
    border-radius: 4px;
    font-size: 0.85rem;
    color: #4B5563;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.5;
}

.vs2-credito-score-message span {
    flex: 1;
}

/* =========== 25. CREDITO — TIMELINE (HISTÓRICO/SUCESSÃO) =========== */
.vs2-timeline {
    position: relative;
    padding-left: 24px;
    margin-top: 8px;
}

.vs2-timeline::before {
    content: "";
    position: absolute;
    left: 8px;
    top: 6px;
    bottom: 6px;
    width: 2px;
    background: #E5E7EB;
}

.vs2-timeline-item {
    position: relative;
    margin-bottom: 14px;
}

.vs2-timeline-item::before {
    content: "";
    position: absolute;
    left: -20px;
    top: 6px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #1B3A5C;
    box-shadow: 0 0 0 2px white;
}

.vs2-timeline-date {
    font-size: 0.75rem;
    font-weight: 700;
    color: #6B7280;
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.vs2-timeline-content {
    margin-top: 4px;
    font-size: 0.85rem;
    color: #374151;
}
