/**
 * ════════════════════════════════════════════════════════════════
 * 🔬 FINANCIAL DEEP DIVE STYLES - ULTRA PROFESSIONAL
 * ════════════════════════════════════════════════════════════════
 */

/* ═══════════════════════════════════════════════════════════════
   📥 IMPORT BASE STYLES
   ═══════════════════════════════════════════════════════════════ */

   @import url('financial-summary.css');

   /* ═══════════════════════════════════════════════════════════════
      📊 FINANCIAL TABS CONTAINER
      ═══════════════════════════════════════════════════════════════ */
   
   .financial-tabs-container {
       background: white;
       padding: 40px;
       border-radius: 24px;
       margin-bottom: 40px;
       box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
   }
   
   body.dark-mode .financial-tabs-container {
       background: rgba(15, 23, 42, 0.95);
   }
   
   /* ═══════════════════════════════════════════════════════════════
      📋 FINANCIAL STATEMENT TABLES
      ═══════════════════════════════════════════════════════════════ */
   
   .financial-table {
       width: 100%;
       border-collapse: separate;
       border-spacing: 0;
       margin-bottom: 32px;
   }
   
   .financial-table thead th {
       background: linear-gradient(135deg, #667eea, #764ba2);
       color: white;
       padding: 16px 20px;
       text-align: left;
       font-weight: 800;
       font-size: 0.9rem;
       letter-spacing: 0.5px;
       text-transform: uppercase;
       border-right: 1px solid rgba(255, 255, 255, 0.2);
   }
   
   .financial-table thead th:last-child {
       border-right: none;
   }
   
   .financial-table tbody tr {
       transition: all 0.2s ease;
   }
   
   .financial-table tbody tr:nth-child(even) {
       background: rgba(241, 245, 249, 0.5);
   }
   
   .financial-table tbody tr:hover {
       background: rgba(102, 126, 234, 0.08);
       transform: translateX(4px);
   }
   
   .financial-table tbody td {
       padding: 14px 20px;
       border-bottom: 1px solid #e2e8f0;
       font-weight: 600;
       color: var(--text-primary);
   }
   
   .financial-table tbody td:first-child {
       font-weight: 700;
       color: var(--text-primary);
   }
   
   .financial-table tbody td:not(:first-child) {
       text-align: right;
       font-family: 'Courier New', monospace;
   }
   
   /* ═══════════════════════════════════════════════════════════════
      🏷 LINE ITEM CATEGORIES
      ═══════════════════════════════════════════════════════════════ */
   
   .category-header {
       background: linear-gradient(135deg, rgba(102, 126, 234, 0.15), rgba(118, 75, 162, 0.1)) !important;
       font-weight: 900 !important;
       font-size: 1.05rem !important;
       color: #667eea !important;
       text-transform: uppercase;
       letter-spacing: 1px;
   }
   
   .category-header:hover {
       background: linear-gradient(135deg, rgba(102, 126, 234, 0.2), rgba(118, 75, 162, 0.15)) !important;
   }
   
   .subtotal-row {
       background: rgba(102, 126, 234, 0.08) !important;
       font-weight: 800 !important;
       border-top: 2px solid #667eea !important;
       border-bottom: 2px solid #667eea !important;
   }
   
   .total-row {
       background: linear-gradient(135deg, rgba(16, 185, 129, 0.15), rgba(5, 150, 105, 0.1)) !important;
       font-weight: 900 !important;
       font-size: 1.1rem !important;
       color: #10b981 !important;
       border-top: 3px solid #10b981 !important;
       border-bottom: 3px solid #10b981 !important;
   }
   
   /* ═══════════════════════════════════════════════════════════════
      📊 YOY COMPARISON
      ═══════════════════════════════════════════════════════════════ */
   
   .yoy-comparison-card {
       background: white;
       padding: 32px;
       border-radius: 20px;
       box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
       margin-bottom: 32px;
       border-left: 5px solid #667eea;
   }
   
   body.dark-mode .yoy-comparison-card {
       background: rgba(15, 23, 42, 0.95);
   }
   
   .yoy-metric {
       display: flex;
       align-items: center;
       justify-content: space-between;
       padding: 16px 0;
       border-bottom: 1px solid #e2e8f0;
   }
   
   .yoy-metric:last-child {
       border-bottom: none;
   }
   
   .yoy-label {
       font-weight: 700;
       font-size: 1rem;
       color: var(--text-primary);
   }
   
   .yoy-value {
       display: flex;
       align-items: center;
       gap: 12px;
   }
   
   .yoy-change {
       display: inline-flex;
       align-items: center;
       gap: 6px;
       padding: 6px 14px;
       border-radius: 12px;
       font-weight: 800;
       font-size: 0.9rem;
   }
   
   .yoy-change.positive {
       background: rgba(16, 185, 129, 0.1);
       color: #10b981;
   }
   
   .yoy-change.negative {
       background: rgba(239, 68, 68, 0.1);
       color: #ef4444;
   }
   
   .yoy-change.neutral {
       background: rgba(100, 116, 139, 0.1);
       color: #64748b;
   }
   
   /* ═══════════════════════════════════════════════════════════════
      🎯 YEAR SELECTOR
      ═══════════════════════════════════════════════════════════════ */
   
   .year-selector-container {
       background: white;
       padding: 24px 32px;
       border-radius: 20px;
       margin-bottom: 32px;
       box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
       display: flex;
       align-items: center;
       gap: 20px;
       flex-wrap: wrap;
   }
   
   body.dark-mode .year-selector-container {
       background: rgba(15, 23, 42, 0.95);
   }
   
   .year-selector-label {
       font-weight: 800;
       font-size: 1.1rem;
       color: var(--text-primary);
       display: flex;
       align-items: center;
       gap: 10px;
   }
   
   .year-selector-label i {
       color: #667eea;
       font-size: 1.3rem;
   }
   
   #yearSelect {
       padding: 14px 20px;
       border-radius: 14px;
       border: 2px solid #e2e8f0;
       font-size: 1rem;
       font-weight: 700;
       color: var(--text-primary);
       background: white;
       cursor: pointer;
       transition: all 0.3s ease;
       min-width: 200px;
       box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
   }
   
   #yearSelect:hover {
       border-color: #667eea;
       box-shadow: 0 4px 16px rgba(102, 126, 234, 0.2);
   }
   
   #yearSelect:focus {
       outline: none;
       border-color: #667eea;
       box-shadow: 0 0 0 4px rgba(102, 126, 234, 0.1);
   }
   
   body.dark-mode #yearSelect {
       background: rgba(30, 41, 59, 0.95);
       border-color: rgba(255, 255, 255, 0.1);
   }
   
   /* ═══════════════════════════════════════════════════════════════
      📊 DUPONT ANALYSIS
      ═══════════════════════════════════════════════════════════════ */
   
   .dupont-container {
       background: white;
       padding: 40px;
       border-radius: 24px;
       margin-bottom: 40px;
       box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
   }
   
   body.dark-mode .dupont-container {
       background: rgba(15, 23, 42, 0.95);
   }
   
   .dupont-formula {
       display: flex;
       align-items: center;
       justify-content: center;
       gap: 16px;
       padding: 32px;
       background: linear-gradient(135deg, rgba(102, 126, 234, 0.05), rgba(118, 75, 162, 0.05));
       border-radius: 20px;
       margin-bottom: 32px;
       flex-wrap: wrap;
   }
   
   .dupont-component {
       background: white;
       padding: 20px 28px;
       border-radius: 16px;
       box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
       text-align: center;
       min-width: 140px;
       border: 2px solid #e2e8f0;
       transition: all 0.3s ease;
   }
   
   .dupont-component:hover {
       transform: translateY(-4px);
       box-shadow: 0 8px 24px rgba(102, 126, 234, 0.2);
       border-color: #667eea;
   }
   
   body.dark-mode .dupont-component {
       background: rgba(30, 41, 59, 0.95);
       border-color: rgba(255, 255, 255, 0.1);
   }
   
   .dupont-component-label {
       font-size: 0.8rem;
       color: var(--text-tertiary);
       font-weight: 700;
       text-transform: uppercase;
       letter-spacing: 0.5px;
       margin-bottom: 8px;
   }
   
   .dupont-component-value {
       font-size: 1.8rem;
       font-weight: 900;
       color: #667eea;
   }
   
   .dupont-operator {
       font-size: 2rem;
       font-weight: 900;
       color: #64748b;
   }
   
   /* ═══════════════════════════════════════════════════════════════
      💧 WORKING CAPITAL WATERFALL
      ═══════════════════════════════════════════════════════════════ */
   
   .waterfall-container {
       background: white;
       padding: 40px;
       border-radius: 24px;
       margin-bottom: 40px;
       box-shadow: 0 8px 32px rgba(0, 0, 0, 0.08);
   }
   
   body.dark-mode .waterfall-container {
       background: rgba(15, 23, 42, 0.95);
   }
   
   /* ═══════════════════════════════════════════════════════════════
      📈 RATIO GRID
      ═══════════════════════════════════════════════════════════════ */
   
   .ratio-grid {
       display: grid;
       grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
       gap: 24px;
       margin-top: 24px;
   }
   
   .ratio-card {
       background: white;
       padding: 28px;
       border-radius: 18px;
       border-left: 5px solid var(--ratio-color, #667eea);
       box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
       transition: all 0.3s ease;
   }
   
   .ratio-card:hover {
       transform: translateY(-6px);
       box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
   }
   
   body.dark-mode .ratio-card {
       background: rgba(15, 23, 42, 0.95);
   }
   
   .ratio-header {
       display: flex;
       align-items: center;
       gap: 12px;
       margin-bottom: 16px;
   }
   
   .ratio-icon {
       width: 48px;
       height: 48px;
       background: linear-gradient(135deg, var(--ratio-color, #667eea), var(--ratio-color-dark, #5568d3));
       border-radius: 14px;
       display: flex;
       align-items: center;
       justify-content: center;
       box-shadow: 0 4px 12px var(--ratio-color-shadow, rgba(102, 126, 234, 0.4));
   }
   
   .ratio-icon i {
       color: white;
       font-size: 1.3rem;
   }
   
   .ratio-name {
       font-size: 0.85rem;
       color: var(--text-tertiary);
       font-weight: 700;
       text-transform: uppercase;
       letter-spacing: 0.5px;
   }
   
   .ratio-value {
       font-size: 2.2rem;
       font-weight: 900;
       color: var(--text-primary);
       margin-bottom: 8px;
       line-height: 1;
   }
   
   .ratio-interpretation {
       font-size: 0.9rem;
       color: var(--text-secondary);
       line-height: 1.5;
   }
   
   /* ═══════════════════════════════════════════════════════════════
      📊 MULTI-YEAR EVOLUTION CHARTS
      ═══════════════════════════════════════════════════════════════ */
   
   .evolution-charts-grid {
       display: grid;
       grid-template-columns: repeat(auto-fit, minmax(500px, 1fr));
       gap: 28px;
       margin-top: 32px;
   }
   
   .evolution-chart-card {
       background: white;
       padding: 32px;
       border-radius: 20px;
       box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
   }
   
   body.dark-mode .evolution-chart-card {
       background: rgba(15, 23, 42, 0.95);
   }
   
   /* ═══════════════════════════════════════════════════════════════
      🎯 QUALITY OF EARNINGS
      ═══════════════════════════════════════════════════════════════ */
   
   .quality-score-container {
       background: linear-gradient(135deg, rgba(16, 185, 129, 0.1), rgba(5, 150, 105, 0.05));
       padding: 40px;
       border-radius: 24px;
       margin-bottom: 32px;
       border: 2px solid rgba(16, 185, 129, 0.2);
   }
   
   .quality-score-grid {
       display: grid;
       grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
       gap: 20px;
       margin-top: 24px;
   }
   
   .quality-metric {
       background: white;
       padding: 24px;
       border-radius: 16px;
       text-align: center;
       box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
   }
   
   body.dark-mode .quality-metric {
       background: rgba(15, 23, 42, 0.95);
   }
   
   .quality-metric-label {
       font-size: 0.85rem;
       color: var(--text-tertiary);
       font-weight: 700;
       text-transform: uppercase;
       letter-spacing: 0.5px;
       margin-bottom: 12px;
   }
   
   .quality-metric-value {
       font-size: 2rem;
       font-weight: 900;
       margin-bottom: 8px;
   }
   
   .quality-metric-status {
       display: inline-flex;
       align-items: center;
       gap: 6px;
       padding: 6px 14px;
       border-radius: 12px;
       font-weight: 800;
       font-size: 0.85rem;
   }
   
   .quality-metric-status.high {
       background: rgba(16, 185, 129, 0.1);
       color: #10b981;
   }
   
   .quality-metric-status.medium {
       background: rgba(245, 158, 11, 0.1);
       color: #f59e0b;
   }
   
   .quality-metric-status.low {
       background: rgba(239, 68, 68, 0.1);
       color: #ef4444;
   }
   
   /* ═══════════════════════════════════════════════════════════════
      📱 RESPONSIVE ADJUSTMENTS
      ═══════════════════════════════════════════════════════════════ */
   
   @media (max-width: 768px) {
       .financial-tabs-container {
           padding: 24px 20px;
       }
       
       .year-selector-container {
           padding: 20px;
       }
       
       #yearSelect {
           width: 100%;
       }
       
       .dupont-formula {
           flex-direction: column;
           gap: 12px;
       }
       
       .dupont-operator {
           transform: rotate(90deg);
       }
       
       .evolution-charts-grid {
           grid-template-columns: 1fr;
       }
       
       .ratio-grid {
           grid-template-columns: 1fr;
       }
       
       .financial-table {
           font-size: 0.85rem;
       }
       
       .financial-table thead th,
       .financial-table tbody td {
           padding: 10px 12px;
       }
   }
   
   @media (max-width: 480px) {
       .financial-table thead th,
       .financial-table tbody td {
           padding: 8px 10px;
           font-size: 0.8rem;
       }
   }
   
   /* ═══════════════════════════════════════════════════════════════
      🎨 SCROLL IMPROVEMENTS
      ═══════════════════════════════════════════════════════════════ */
   
   .tab-panel {
       max-height: none;
       overflow: visible;
   }
   
   /* Smooth scrolling for tables */
   .table-wrapper {
       overflow-x: auto;
       -webkit-overflow-scrolling: touch;
       scrollbar-width: thin;
       scrollbar-color: #cbd5e1 #f1f5f9;
   }
   
   .table-wrapper::-webkit-scrollbar {
       height: 8px;
   }
   
   .table-wrapper::-webkit-scrollbar-track {
       background: #f1f5f9;
       border-radius: 10px;
   }
   
   .table-wrapper::-webkit-scrollbar-thumb {
       background: #cbd5e1;
       border-radius: 10px;
   }
   
   .table-wrapper::-webkit-scrollbar-thumb:hover {
       background: #94a3b8;
   }

   /* ══════════════════════════════════════════════════════════════
    🏆 COMPETITOR COMPARISON CHARTS
    ══════════════════════════════════════════════════════════════ */

    #competitorProfitabilityChart,
    #competitorLeverageChart {
        min-height: 350px !important;
        width: 100% !important;
    }

    /* Force Highcharts visibility */
    #competitorComparison .highcharts-container {
        width: 100% !important;
        height: auto !important;
    }

    #competitorComparison .highcharts-root {
        font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
    }

    /* ════════════════════════════════════════════════════════════════
   📱 RESPONSIVE MOBILE CORRECTIONS - FINANCIAL DEEP DIVE
   ════════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────────
   🔄 DUPONT ROA ANALYSIS - 1 LIGNE COMPOSANTS + 1 LIGNE RÉSULTAT
   ──────────────────────────────────────────────────────────────── */

   @media (max-width: 768px) {
    .dupont-formula {
        display: grid !important;
        grid-template-columns: repeat(5, auto) !important;
        justify-content: center !important;
        align-items: center !important;
        gap: 8px !important;
        padding: 24px !important;
    }
    
    /* Composants principaux */
    .dupont-component:nth-child(1),
    .dupont-component:nth-child(3),
    .dupont-component:nth-child(5) {
        grid-row: 1 !important;
        min-width: 90px !important;
        max-width: 100px !important;
        padding: 12px 14px !important;
    }
    
    /* Opérateurs × */
    .dupont-operator:nth-child(2),
    .dupont-operator:nth-child(4) {
        grid-row: 1 !important;
        font-size: 1.4rem !important;
    }
    
    /* ✅ MASQUER le signe = sur mobile */
    .dupont-operator:nth-child(6) {
        display: none !important;
    }
    
    /* Résultat ROE sur ligne 2 (sans le =) */
    .dupont-component:nth-child(7) {
        grid-column: 1 / -1 !important;
        grid-row: 2 !important;
        max-width: 180px !important;
        margin: 16px auto 0 !important;
        padding: 16px 20px !important;
    }
    
    .dupont-component-label {
        font-size: 0.7rem !important;
    }
    
    .dupont-component-value {
        font-size: 1.3rem !important;
    }
}

@media (max-width: 480px) {
    .dupont-formula {
        gap: 6px !important;
        padding: 20px !important;
    }
    
    .dupont-component:nth-child(1),
    .dupont-component:nth-child(3),
    .dupont-component:nth-child(5) {
        min-width: 75px !important;
        max-width: 85px !important;
        padding: 10px 12px !important;
    }
    
    .dupont-component-label {
        font-size: 0.65rem !important;
    }
    
    .dupont-component-value {
        font-size: 1.1rem !important;
    }
    
    .dupont-operator:nth-child(2),
    .dupont-operator:nth-child(4) {
        font-size: 1.2rem !important;
    }
    
    /* ✅ Le signe = reste masqué */
    .dupont-operator:nth-child(6) {
        display: none !important;
    }
    
    .dupont-component:nth-child(7) {
        max-width: 160px !important;
        margin: 12px auto 0 !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   📊 VISUAL COMPARISON - GRAPHIQUES HIGHCHARTS RESPONSIVE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 1024px) {
    #competitorComparison [style*="grid-template-columns: repeat(auto-fit, minmax(400px, 1fr))"] {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
}

@media (max-width: 768px) {
    #competitorProfitabilityChart,
    #competitorLeverageChart {
        min-height: 300px !important;
        padding: 16px !important;
    }
    
    #competitorComparison .highcharts-container {
        width: 100% !important;
    }
    
    #competitorComparison .highcharts-title {
        font-size: 0.95rem !important;
    }
    
    #competitorComparison .highcharts-axis-title {
        font-size: 0.8rem !important;
    }
    
    #competitorComparison .highcharts-legend-item text {
        font-size: 0.75rem !important;
    }
    
    #competitorComparison .highcharts-data-label text {
        font-size: 10px !important;
    }
}

@media (max-width: 480px) {
    #competitorProfitabilityChart,
    #competitorLeverageChart {
        min-height: 250px !important;
        padding: 12px !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   📊 FINANCIAL RATIOS - 2 CARDS PAR LIGNE SUR MOBILE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .ratio-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    .ratio-card {
        padding: 16px !important;
    }
    
    .ratio-icon {
        width: 40px !important;
        height: 40px !important;
    }
    
    .ratio-icon i {
        font-size: 1.1rem !important;
    }
    
    .ratio-name {
        font-size: 0.7rem !important;
    }
    
    .ratio-value {
        font-size: 1.6rem !important;
    }
    
    .ratio-interpretation {
        font-size: 0.8rem !important;
        line-height: 1.4 !important;
    }
}

@media (max-width: 480px) {
    .ratio-grid {
        gap: 10px !important;
    }
    
    .ratio-card {
        padding: 12px !important;
    }
    
    .ratio-icon {
        width: 36px !important;
        height: 36px !important;
    }
    
    .ratio-icon i {
        font-size: 1rem !important;
    }
    
    .ratio-name {
        font-size: 0.65rem !important;
    }
    
    .ratio-value {
        font-size: 1.3rem !important;
    }
    
    .ratio-interpretation {
        font-size: 0.75rem !important;
    }
    
    .ratio-card [style*="background: rgba(102, 126, 234, 0.05)"] {
        display: none !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   🎯 QUALITY OF EARNINGS - 2 CARDS PAR LIGNE SUR MOBILE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .quality-score-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    .quality-metric {
        padding: 16px !important;
    }
    
    .quality-metric-label {
        font-size: 0.7rem !important;
        margin-bottom: 8px !important;
    }
    
    .quality-metric-value {
        font-size: 1.5rem !important;
        margin-bottom: 6px !important;
    }
    
    .quality-metric-status {
        font-size: 0.75rem !important;
        padding: 4px 10px !important;
    }
    
    .quality-metric-description {
        display: none !important;
    }
}

@media (max-width: 480px) {
    .quality-score-grid {
        gap: 10px !important;
    }
    
    .quality-metric {
        padding: 12px !important;
    }
    
    .quality-metric-label {
        font-size: 0.65rem !important;
    }
    
    .quality-metric-value {
        font-size: 1.3rem !important;
    }
    
    .quality-metric-status {
        font-size: 0.7rem !important;
        padding: 4px 8px !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   ⏳ SPINNER LOADER - TRAIT FIN ET CONTINU (MODERNE & PRO)
   ──────────────────────────────────────────────────────────────── */

#loadingState {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 60vh;
    padding: 40px 20px;
}

#loadingState .fa-spinner {
    display: none !important;
}

#loadingState::before {
    content: '';
    width: 60px;
    height: 60px;
    border: 3px solid rgba(102, 126, 234, 0.1);
    border-top-color: #667eea;
    border-radius: 50%;
    animation: modernSpinnerRotate 1s linear infinite;
    margin-bottom: 24px;
}

@keyframes modernSpinnerRotate {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ✅ TEXTE DE CHARGEMENT SANS CLIGNOTEMENT */
#loadingStatus {
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--text-secondary);
    text-align: center;
    margin-top: 16px;
    /* Animation supprimée pour éviter le clignotement */
}

@media (max-width: 768px) {
    #loadingState::before {
        width: 48px;
        height: 48px;
        border-width: 2.5px;
    }
    
    #loadingStatus {
        font-size: 1rem;
    }
}

@media (max-width: 480px) {
    #loadingState::before {
        width: 40px;
        height: 40px;
        border-width: 2px;
    }
    
    #loadingStatus {
        font-size: 0.95rem;
    }
}

/* ────────────────────────────────────────────────────────────────
   🔧 CORRECTIONS SUPPLÉMENTAIRES MOBILE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .evolution-charts-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    
    .evolution-chart-card {
        padding: 20px !important;
    }
    
    .dupont-container,
    .quality-score-container,
    .waterfall-container {
        padding: 24px 20px !important;
    }
    
    .year-selector-container {
        flex-direction: column;
        align-items: stretch !important;
        gap: 12px !important;
    }
    
    #yearSelect {
        width: 100% !important;
        min-width: auto !important;
    }
}

@media (max-width: 480px) {
    #competitorComparison [style*="display: flex; flex-wrap: wrap"] span {
        font-size: 0.75rem !important;
        padding: 6px 12px !important;
    }
}

/* ════════════════════════════════════════════════════════════════
   ✅ FIN DES CORRECTIONS RESPONSIVE MOBILE
   ════════════════════════════════════════════════════════════════ */

   .advanced-metrics-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 24px;
    margin-bottom: 32px;
}

.advanced-metric-card {
    background: white;
    padding: 28px;
    border-radius: 20px;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
    border-left: 6px solid var(--metric-color);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.advanced-metric-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
}

.advanced-metric-card .metric-icon {
    width: 60px;
    height: 60px;
    background: var(--metric-color);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.8rem;
    color: white;
    margin-bottom: 16px;
}

.advanced-metric-card .metric-label {
    font-size: 0.9rem;
    color: var(--text-tertiary);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 8px;
}

.advanced-metric-card .metric-value {
    font-size: 2.5rem;
    font-weight: 900;
    color: var(--metric-color);
    line-height: 1.2;
    margin-bottom: 8px;
}

.advanced-metric-card .metric-description {
    font-size: 0.85rem;
    color: var(--text-secondary);
    line-height: 1.6;
}

/* ════════════════════════════════════════════════════════════════
   📱 RESPONSIVE MOBILE - ADVANCED METRICS (100% OPTIMISÉ)
   ════════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────────────────────────
   🎯 RECOMMANDATION IA - 2 CARDS PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

   @media (max-width: 768px) {
    /* En-tête recommandation */
    #advancedMetricsTab [style*="display: flex; align-items: flex-start"] {
        flex-direction: column !important;
        gap: 20px !important;
    }
    
    /* Score global centré */
    #advancedMetricsTab [style*="display: flex; align-items: flex-start"] > div:last-child {
        width: 100% !important;
        display: flex !important;
        justify-content: center !important;
    }
    
    /* Titre recommandation */
    #advancedMetricsTab h3[style*="font-size: 3.2rem"] {
        font-size: 2.2rem !important;
        line-height: 1.2 !important;
    }
    
    /* Score /100 */
    #advancedMetricsTab [style*="font-size: 4.5rem"] {
        font-size: 3rem !important;
    }
    
    /* Scores par catégorie - 2 colonnes */
    #advancedMetricsTab [style*="grid-template-columns: repeat(auto-fit, minmax(160px, 1fr))"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    #advancedMetricsTab [style*="grid-template-columns: repeat(2, 1fr)"] > div {
        padding: 16px !important;
    }
    
    #advancedMetricsTab [style*="grid-template-columns: repeat(2, 1fr)"] [style*="font-size: 0.7rem"] {
        font-size: 0.65rem !important;
    }
    
    #advancedMetricsTab [style*="grid-template-columns: repeat(2, 1fr)"] [style*="font-size: 2.4rem"] {
        font-size: 1.8rem !important;
    }
    
    /* Paramètres d'investissement - 1 colonne */
    #advancedMetricsTab [style*="grid-template-columns: repeat(auto-fit, minmax(240px, 1fr))"] {
        grid-template-columns: 1fr !important;
        gap: 12px !important;
    }
    
    #advancedMetricsTab [style*="grid-template-columns: 1fr"] > div {
        padding: 18px 20px !important;
    }
    
    #advancedMetricsTab [style*="grid-template-columns: 1fr"] [style*="font-size: 1.4rem"] {
        font-size: 1.1rem !important;
    }
    
    /* Forces & Préoccupations - 1 colonne */
    #advancedMetricsTab [style*="display: grid; grid-template-columns: 1fr 1fr"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    
    #advancedMetricsTab [style*="display: grid; grid-template-columns: 1fr 1fr"] > div {
        padding: 20px !important;
    }
    
    #advancedMetricsTab [style*="display: grid; grid-template-columns: 1fr 1fr"] h5 {
        font-size: 1rem !important;
    }
    
    #advancedMetricsTab [style*="display: grid; grid-template-columns: 1fr 1fr"] ul {
        font-size: 0.85rem !important;
        line-height: 1.7 !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   💎 VALUATION METRICS - 2 CARDS PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Grid valuation metrics */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #ec4899, #8b5cf6)"] [style*="display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    /* Cards valuation */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #ec4899, #8b5cf6)"] [style*="padding: 22px"] {
        padding: 16px !important;
    }
    
    /* Labels */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #ec4899, #8b5cf6)"] [style*="font-size: 0.85rem; opacity: 0.9"] {
        font-size: 0.7rem !important;
    }
    
    /* Valeurs */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #ec4899, #8b5cf6)"] [style*="font-size: 1.7rem"] {
        font-size: 1.3rem !important;
        line-height: 1.2 !important;
        word-break: break-word !important;
    }
    
    /* Sous-labels */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #ec4899, #8b5cf6)"] [style*="font-size: 0.7rem; opacity: 0.8"] {
        font-size: 0.65rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   📊 EARNINGS HISTORY & EPS TREND TABLES
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Tables responsive */
    #advancedMetricsTab table {
        font-size: 0.75rem !important;
    }
    
    #advancedMetricsTab table th,
    #advancedMetricsTab table td {
        padding: 10px 8px !important;
    }
    
    /* Headers */
    #advancedMetricsTab table thead th {
        font-size: 0.7rem !important;
        line-height: 1.3 !important;
    }
    
    /* Valeurs */
    #advancedMetricsTab table tbody td {
        font-size: 0.75rem !important;
    }
    
    /* Badges surprise */
    #advancedMetricsTab table span[style*="display: inline-flex"] {
        padding: 4px 8px !important;
        font-size: 0.7rem !important;
    }
}

@media (max-width: 480px) {
    #advancedMetricsTab table {
        font-size: 0.7rem !important;
    }
    
    #advancedMetricsTab table th,
    #advancedMetricsTab table td {
        padding: 8px 6px !important;
    }
    
    #advancedMetricsTab table thead th {
        font-size: 0.65rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   💰 GRAHAM NUMBER & MARGIN OF SAFETY - 2 CARDS PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Grid Graham */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #10b981, #059669)"] [style*="display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #10b981, #059669)"] [style*="padding: 24px"] {
        padding: 16px !important;
    }
    
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #10b981, #059669)"] [style*="font-size: 2.2rem"] {
        font-size: 1.6rem !important;
    }
    
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #10b981, #059669)"] [style*="font-size: 0.85rem; opacity: 0.9"] {
        font-size: 0.7rem !important;
    }
    
    /* Margin of Safety (3ème card) - pleine largeur */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #10b981, #059669)"] [style*="grid-column: 1 / -1"] {
        grid-column: 1 / -1 !important;
        max-width: 100% !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   📈 YIELD METRICS - 2 CARDS PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Grid yields */
    #advancedMetricsTab [style*="display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))"][style*="gap: 20px"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 24px"] {
        padding: 16px !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 24px"] [style*="font-size: 2.5rem"] {
        font-size: 1.8rem !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 24px"] [style*="font-size: 0.9rem"] {
        font-size: 0.75rem !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 24px"] [style*="font-size: 0.75rem"] {
        font-size: 0.65rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   ⚙ WACC & COST OF CAPITAL - 2 CARDS PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Grid WACC */
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #8b5cf6, #7c3aed)"] [style*="display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #8b5cf6, #7c3aed)"] [style*="padding: 20px"] {
        padding: 16px !important;
    }
    
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #8b5cf6, #7c3aed)"] [style*="font-size: 2rem"] {
        font-size: 1.5rem !important;
    }
    
    #advancedMetricsTab [style*="background: linear-gradient(135deg, #8b5cf6, #7c3aed)"] [style*="font-size: 0.85rem; opacity: 0.9"] {
        font-size: 0.7rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   🏆 CORE METRICS GRID (ROIC, EVA, CCC, GROWTH) - 2 PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    .advanced-metrics-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 14px !important;
    }
    
    .advanced-metric-card {
        padding: 18px !important;
    }
    
    .advanced-metric-card .metric-icon {
        width: 48px !important;
        height: 48px !important;
        font-size: 1.4rem !important;
        margin-bottom: 12px !important;
    }
    
    .advanced-metric-card .metric-label {
        font-size: 0.7rem !important;
        margin-bottom: 6px !important;
    }
    
    .advanced-metric-card .metric-value {
        font-size: 1.6rem !important;
        margin-bottom: 6px !important;
        word-break: break-word !important;
    }
    
    .advanced-metric-card .metric-description {
        font-size: 0.75rem !important;
        line-height: 1.4 !important;
    }
}

@media (max-width: 480px) {
    .advanced-metrics-grid {
        gap: 10px !important;
    }
    
    .advanced-metric-card {
        padding: 14px !important;
    }
    
    .advanced-metric-card .metric-icon {
        width: 40px !important;
        height: 40px !important;
        font-size: 1.2rem !important;
        margin-bottom: 10px !important;
    }
    
    .advanced-metric-card .metric-label {
        font-size: 0.65rem !important;
    }
    
    .advanced-metric-card .metric-value {
        font-size: 1.4rem !important;
    }
    
    .advanced-metric-card .metric-description {
        font-size: 0.7rem !important;
        display: none !important; /* Masquer description sur très petit écran */
    }
}

/* ────────────────────────────────────────────────────────────────
   🛡 ALTMAN Z-SCORE - LAYOUT VERTICAL MOBILE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Grid Altman */
    #advancedMetricsTab [style*="display: grid; grid-template-columns: 1fr 2fr"] {
        grid-template-columns: 1fr !important;
        gap: 16px !important;
    }
    
    /* Score display */
    #advancedMetricsTab [style*="padding: 32px; border-radius: 16px; text-align: center"] {
        padding: 24px !important;
    }
    
    #advancedMetricsTab [style*="font-size: 4rem"] {
        font-size: 3rem !important;
    }
    
    #advancedMetricsTab [style*="font-size: 1.1rem; font-weight: 800"] {
        font-size: 1rem !important;
    }
    
    /* Risk zones */
    #advancedMetricsTab [style*="display: flex; flex-direction: column; gap: 8px"] {
        font-size: 0.75rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   🏅 PIOTROSKI F-SCORE - LAYOUT VERTICAL MOBILE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Score breakdown */
    #advancedMetricsTab [style*="display: flex; flex-direction: column; gap: 10px"][style*="font-size: 0.85rem"] {
        font-size: 0.75rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   📊 LEVERAGE METRICS - 2 CARDS PAR LIGNE
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Grid leverage */
    #advancedMetricsTab [style*="display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr))"][style*="gap: 20px"] {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 20px"] {
        padding: 16px !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 20px"] [style*="font-size: 2.2rem"] {
        font-size: 1.6rem !important;
    }
    
    #advancedMetricsTab [style*="text-align: center; padding: 20px"] [style*="font-size: 0.9rem"] {
        font-size: 0.75rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   📝 TEXTE & TITRES - AJUSTEMENTS GLOBAUX
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Titres sections */
    #advancedMetricsTab h5[style*="font-size: 1.3rem"] {
        font-size: 1.1rem !important;
        line-height: 1.3 !important;
    }
    
    #advancedMetricsTab h5[style*="font-size: 1.2rem"] {
        font-size: 1rem !important;
        line-height: 1.3 !important;
    }
    
    /* Paragraphes */
    #advancedMetricsTab p[style*="font-size: 1.1rem"] {
        font-size: 0.95rem !important;
        line-height: 1.7 !important;
    }
    
    #advancedMetricsTab p[style*="font-size: 1.05rem"] {
        font-size: 0.9rem !important;
        line-height: 1.7 !important;
    }
    
    /* Badges */
    #advancedMetricsTab [style*="padding: 6px 14px; border-radius: 10px"] {
        padding: 5px 10px !important;
        font-size: 0.7rem !important;
    }
    
    #advancedMetricsTab [style*="padding: 6px 12px; border-radius: 8px"] {
        padding: 5px 10px !important;
        font-size: 0.7rem !important;
    }
}

@media (max-width: 480px) {
    /* Titres très petits écrans */
    #advancedMetricsTab h5[style*="font-size: 1.1rem"] {
        font-size: 1rem !important;
    }
    
    #advancedMetricsTab h5[style*="font-size: 1rem"] {
        font-size: 0.9rem !important;
    }
    
    /* Paragraphes très petits écrans */
    #advancedMetricsTab p[style*="font-size: 0.95rem"] {
        font-size: 0.85rem !important;
    }
    
    #advancedMetricsTab p[style*="font-size: 0.9rem"] {
        font-size: 0.8rem !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   🎨 SECTIONS GLOBALES - PADDING & MARGES
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    /* Sections principales */
    #advancedMetricsTab > div[style*="padding: 48px 40px"],
    #advancedMetricsTab > div[style*="padding: 40px"],
    #advancedMetricsTab > div[style*="padding: 32px"] {
        padding: 24px 20px !important;
    }
    
    #advancedMetricsTab > div[style*="padding: 28px 32px"] {
        padding: 20px 16px !important;
    }
    
    /* Marges */
    #advancedMetricsTab > div[style*="margin-bottom: 32px"] {
        margin-bottom: 24px !important;
    }
    
    /* Border radius */
    #advancedMetricsTab > div[style*="border-radius: 28px"] {
        border-radius: 20px !important;
    }
    
    #advancedMetricsTab > div[style*="border-radius: 24px"] {
        border-radius: 16px !important;
    }
}

@media (max-width: 480px) {
    #advancedMetricsTab > div[style*="padding: 24px 20px"] {
        padding: 20px 16px !important;
    }
    
    #advancedMetricsTab > div[style*="padding: 20px 16px"] {
        padding: 16px 12px !important;
    }
    
    #advancedMetricsTab > div[style*="margin-bottom: 24px"] {
        margin-bottom: 20px !important;
    }
}

/* ────────────────────────────────────────────────────────────────
   ⚡ OVERFLOW & WORD BREAK - PRÉVENTION DÉBORDEMENT
   ──────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
    #advancedMetricsTab * {
        word-wrap: break-word !important;
        overflow-wrap: break-word !important;
    }
    
    #advancedMetricsTab div[style*="display: grid"] {
        overflow: hidden !important;
    }
    
    /* Textes longs */
    #advancedMetricsTab p,
    #advancedMetricsTab li,
    #advancedMetricsTab span {
        max-width: 100% !important;
    }
}

/* ════════════════════════════════════════════════════════════════
   ✅ FIN RESPONSIVE MOBILE - ADVANCED METRICS
   ════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════
   KPI INFO BUTTON — FIX DÉFINITIF (NOIR + TAILLE FORCÉE)
   ══════════════════════════════════════════════════════════════ */
   .kpi-info-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 18px !important;
    height: 18px !important;
    min-width: 18px !important;
    max-width: 18px !important;
    min-height: 18px !important;
    max-height: 18px !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    overflow: hidden !important;
    background: rgba(0, 0, 0, 0.75) !important;
    border: none !important;
    color: white !important;
    font-size: 11px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    font-family: inherit !important;
    border-radius: 50% !important;
    padding: 0 !important;
    margin: 0 0 0 5px !important;
    vertical-align: middle !important;
    cursor: pointer !important;
    outline: none !important;
    box-sizing: border-box !important;
    text-decoration: none !important;
    position: static !important;
    transition: background 0.2s ease, transform 0.2s ease !important;
}
.kpi-info-btn:hover {
    background: #000 !important;
    transform: scale(1.15) !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35) !important;
}
.kpi-info-btn:active {
    transform: scale(0.92) !important;
}

/* ══════════════════════════════════════════════════════════════
   KPI MODAL OVERLAY — RESPONSIVE
   ══════════════════════════════════════════════════════════════ */
.kpi-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}
.kpi-modal-overlay.active {
    opacity: 1;
    pointer-events: all;
}
.kpi-modal-box {
    background: white;
    border-radius: 24px;
    width: 100%;
    max-width: 720px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 24px 80px rgba(0, 0, 0, 0.35);
    transform: translateY(20px) scale(0.97);
    transition: transform 0.3s ease;
}
.kpi-modal-overlay.active .kpi-modal-box {
    transform: translateY(0) scale(1);
}
.kpi-modal-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 28px 32px 20px;
    border-bottom: 2px solid rgba(102, 126, 234, 0.1);
    position: sticky;
    top: 0;
    background: white;
    z-index: 1;
    border-radius: 24px 24px 0 0;
}
.kpi-modal-header-info {
    flex: 1;
    min-width: 0;
}
.kpi-modal-tag {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 20px;
    font-size: 0.75rem;
    font-weight: 700;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}
.kpi-modal-title {
    font-size: 1.4rem;
    font-weight: 900;
    color: #1e293b;
    margin: 0;
    line-height: 1.3;
    word-break: break-word;
}
.kpi-modal-close {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    min-width: 44px;
    background: rgba(100, 116, 139, 0.1);
    border: none;
    border-radius: 12px;
    cursor: pointer;
    font-size: 16px;
    color: #64748b;
    transition: all 0.2s ease;
    flex-shrink: 0;
}
.kpi-modal-close:hover {
    background: #ef4444;
    color: white;
    transform: scale(1.05);
}
.kpi-modal-body {
    padding: 24px 32px 32px;
}
.kpi-modal-section {
    margin-bottom: 24px;
}
.kpi-modal-section-title {
    font-size: 0.8rem;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: #64748b;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.kpi-modal-section-content {
    font-size: 0.95rem;
    color: #475569;
    line-height: 1.8;
}
.kpi-modal-formula {
    background: #f8fafc;
    border: 1.5px solid rgba(102, 126, 234, 0.2);
    border-radius: 12px;
    padding: 16px 20px;
    font-family: 'Courier New', monospace;
    font-size: 0.88rem;
    color: #334155;
    line-height: 1.7;
    white-space: pre-wrap;
    word-break: break-word;
}
.kpi-modal-benchmarks {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.kpi-benchmark-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 14px;
    background: #f8fafc;
    border-radius: 10px;
    font-size: 0.9rem;
    color: #475569;
    font-weight: 600;
}
.kpi-benchmark-dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* ══════════════════════════════════════════════════════════════
   MOBILE — MODAL (bottom sheet) + BOUTONS
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

    /* Bouton ℹ — même taille qu'en desktop, forcée */
    .kpi-info-btn {
        width: 18px !important;
        height: 18px !important;
        min-width: 18px !important;
        max-width: 18px !important;
        min-height: 18px !important;
        max-height: 18px !important;
        font-size: 11px !important;
    }

    /* Modal : bottom sheet style */
    .kpi-modal-overlay {
        align-items: flex-end;
        padding: 0;
    }
    .kpi-modal-box {
        max-width: 100%;
        max-height: 88vh;
        border-radius: 24px 24px 0 0;
    }
    .kpi-modal-header {
        padding: 18px 18px 14px;
    }
    .kpi-modal-title {
        font-size: 1.1rem;
    }
    .kpi-modal-close {
        width: 40px;
        height: 40px;
        min-width: 40px;
    }
    .kpi-modal-body {
        padding: 14px 18px 36px;
    }
    .kpi-modal-formula {
        font-size: 0.76rem;
    }
    .kpi-benchmark-row {
        font-size: 0.82rem;
        padding: 8px 12px;
    }
}

/* ══════════════════════════════════════════════════════════════
   EARNINGS HISTORY TABLE — MOBILE : valeurs uniquement
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

    /* Cacher les en-têtes de colonnes */
    .earnings-history-table thead {
        display: none;
    }

    /* Cacher les lignes d'interprétation textuelle */
    .earnings-history-table .earnings-interp-row {
        display: none;
    }

    /* Cellules plus compactes */
    .earnings-history-table td {
        padding: 10px 6px;
        font-size: 0.78rem;
    }

    /* Badge verdict plus compact */
    .earnings-badge {
        font-size: 0.7rem !important;
        padding: 3px 7px !important;
        white-space: nowrap;
    }
}

/* ══════════════════════════════════════════════════════════════
   QUALITY OF EARNINGS — RESPONSIVE MOBILE
   ══════════════════════════════════════════════════════════════ */
   @media (max-width: 768px) {

    /* ── 4 cartes métriques : 1 colonne ── */
    .quality-score-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    /* ── Padding réduit dans chaque carte ── */
    .quality-metric {
        padding: 18px !important;
    }

    /* ── Label + bouton ℹ ── */
    .quality-metric-label {
        font-size: 0.85rem !important;
        flex-wrap: wrap !important;
    }

    /* ── Score value dans la carte ── */
    .quality-metric > div:first-child > div:last-child {
        font-size: 1.3rem !important;
    }

    /* ── Status badge ── */
    .quality-metric-status {
        font-size: 0.8rem !important;
        padding: 6px 12px !important;
    }

    /* ── Description text ── */
    .quality-metric-description {
        font-size: 0.8rem !important;
        line-height: 1.6 !important;
    }

    /* ── Mini bars (Overall Score box) : min-width supprimé ── */
    .quality-mini-bars {
        min-width: unset !important;
        width: 100% !important;
    }
}

/* ═══════════════════════════════════════════════════════════════
   📌 TABS — OVERRIDE FINAL
   ═══════════════════════════════════════════════════════════════ */

   .financial-tabs-container {
    width: 100%;
    background: var(--card-bg, #ffffff);
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

/* ── Tabs Header : scroll horizontal uniquement ── */
.tabs-header {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    background: var(--bg-secondary, #f8fafc);
    border-bottom: 2px solid var(--border-color, #e2e8f0);
    overflow-x: auto;
    overflow-y: hidden;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: rgba(99, 102, 241, 0.4) transparent;
    flex-wrap: nowrap;
    white-space: nowrap;
    gap: 2px;
    padding: 8px 8px 0 8px;
}

.tabs-header::-webkit-scrollbar { height: 3px; }
.tabs-header::-webkit-scrollbar-track { background: transparent; }
.tabs-header::-webkit-scrollbar-thumb {
    background: rgba(99, 102, 241, 0.4);
    border-radius: 999px;
}
.tabs-header::-webkit-scrollbar-thumb:hover {
    background: rgba(99, 102, 241, 0.7);
}

/* ── Tab Buttons ── */
.tab-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
    white-space: nowrap;
    padding: 10px 18px;
    border: none;
    border-radius: 10px 10px 0 0;
    background: transparent;
    color: var(--text-muted, #64748b);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
    border-bottom: 3px solid transparent;
}

.tab-btn i {
    font-size: 0.95rem;
    flex-shrink: 0;
}

.tab-btn span {
    display: inline;
    overflow: visible;
    text-overflow: unset;
    white-space: nowrap;
}

.tab-btn:hover {
    background: rgba(99, 102, 241, 0.07);
    color: var(--primary, #6366f1);
}

.tab-btn.active {
    background: var(--card-bg, #ffffff);
    color: var(--primary, #6366f1);
    border-bottom: 3px solid var(--primary, #6366f1);
    box-shadow: 0 -2px 8px rgba(99, 102, 241, 0.1);
}

.tab-btn.active i {
    color: var(--primary, #6366f1);
}

/* ── Dark mode ── */
body.dark-mode .tabs-header {
    background: rgba(15, 23, 42, 0.6);
    border-bottom-color: rgba(255, 255, 255, 0.08);
}

body.dark-mode .tab-btn { color: #94a3b8; }

body.dark-mode .tab-btn:hover {
    background: rgba(99, 102, 241, 0.12);
    color: #a5b4fc;
}

body.dark-mode .tab-btn.active {
    background: rgba(15, 23, 42, 0.95);
    color: #a5b4fc;
    border-bottom-color: #818cf8;
}

/* ── Tabs Content ── */
.tabs-content {
    flex: 1;
    min-height: 0;
    position: relative;
}

/* ── Tab Panel : pas de scroll vertical, hauteur libre ── */
.tab-panel {
    display: none;
    padding: 28px;
    overflow-y: visible;
    overflow-x: hidden;
    max-height: none;
}

.tab-panel.active {
    display: block;
    animation: fadeInTab 0.25s ease;
}

@keyframes fadeInTab {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0);   }
}

/* ── Responsive ── */
@media (max-width: 768px) {
    .tab-btn {
        padding: 8px 12px;
        font-size: 0.8rem;
        gap: 5px;
    }

    .tab-btn span {
        display: none; /* icône seule sur mobile */
    }

    .tab-panel {
        padding: 16px;
    }
}

@media (max-width: 480px) {
    .tab-btn {
        padding: 8px 10px;
    }
}