/* ============================================
   ZOOM / RÉSOLUTION - Affichage trop zoomé
   Pour délégués avec mise à l'échelle Windows (125%/150%)
   ou petite résolution : adaptation automatique au viewport.
   ============================================ */

/* 1) Base fluide : la taille de référence (rem) s'adapte à la largeur du viewport */
html {
    font-size: clamp(13px, 0.35vw + 10px, 16px);
}

/* 2) Zoom progressif selon la résolution perçue (Chrome, Edge, Safari) */
@media screen and (max-width: 1680px) {
    html { zoom: 0.95; }
}
@media screen and (max-width: 1440px) {
    html { zoom: 0.9; }
}
@media screen and (max-width: 1280px) {
    html { zoom: 0.85; }
}
@media screen and (max-width: 1100px) {
    html { zoom: 0.8; }
}

/* Fallback Firefox (ignore zoom) : la base fluide + media queries ci‑dessous suffisent */

/* Zone contenu : permettre le défilement horizontal si besoin */
#content,
.content {
    min-width: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Conteneur du tableau Qualification : défilement horizontal visible */
#qualifTableContainer {
    overflow-x: auto !important;
    overflow-y: visible;
    -webkit-overflow-scrolling: touch;
    max-width: 100%;
    /* Indice visuel pour le scroll horizontal */
    border-radius: 0 0 8px 8px;
}
#qualifTableContainer::-webkit-scrollbar {
    height: 12px;
}
#qualifTableContainer::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 6px;
}
#qualifTableContainer::-webkit-scrollbar-thumb:hover {
    background: #94a3b8;
}

/* ============================================
   Mode compact : vue "zoomed" / résolution limitée
   (max-width ~ 1600px = écran standard ou zoom 125%)
   ============================================ */
@media screen and (max-width: 1600px) {
    .content {
        padding: 20px 24px !important;
    }

    .page-header {
        margin-bottom: 16px !important;
        gap: 12px !important;
    }

    .page-header-content h1 {
        font-size: 1.5rem !important;
    }

    .page-subtitle {
        font-size: 0.9rem !important;
    }

    /* Cartes stats plus compactes */
    #qualifStats,
    .stats-grid {
        gap: 12px !important;
        margin-bottom: 20px !important;
    }

    .stat-card {
        padding: 14px 16px !important;
        gap: 12px !important;
    }

    .stat-icon {
        width: 44px !important;
        height: 44px !important;
        font-size: 18px !important;
    }

    .stat-content h3 {
        font-size: 24px !important;
    }

    .stat-label {
        font-size: 12px !important;
    }

    /* Filtres */
    .qualif-filters-card {
        margin-bottom: 16px !important;
        padding: 0 !important;
    }

    .qualif-filter-tabs {
        padding: 8px 12px !important;
        gap: 6px !important;
    }

    .qualif-filter-tab {
        padding: 10px 14px !important;
        font-size: 13px !important;
    }

    .qualif-filter-content {
        padding: 16px !important;
    }

    .filters-row {
        gap: 12px !important;
    }

    .filters-row .form-group label {
        font-size: 12px !important;
    }

    .filters-row .form-group input,
    .filters-row .form-group select {
        padding: 8px 10px !important;
        font-size: 13px !important;
    }

    /* Tableau */
    .table-header {
        padding: 12px 16px !important;
    }

    .table-header h3 {
        font-size: 15px !important;
    }

    .qualif-table-dynamic th,
    .qualif-table-dynamic td {
        padding: 8px 5px !important;
        font-size: 12px !important;
    }

    /* Modale Qualification : plus compacte */
    .qualif-modal-wide {
        max-width: 92% !important;
        max-height: 88vh !important;
    }
    .qualif-modal-grid {
        gap: 14px;
        padding: 12px 18px;
    }
    .qualif-modal-grid .qualif-modal-hcp-card {
        padding: 14px;
        gap: 8px;
    }
    .qualif-modal-grid .qualif-modal-avatar-lg {
        width: 56px;
        height: 56px;
        font-size: 20px;
    }
    .qualif-modal-grid .qualif-modal-info h3 {
        font-size: 14px;
    }
    .qualif-modal-meta-row span {
        font-size: 11px;
    }
    .qualif-modal-map-container {
        height: 150px;
    }
    .qualif-col {
        min-height: 280px;
    }
    .qualif-col-header {
        padding: 10px 12px;
    }
    .qualif-col-header h4 {
        font-size: 13px;
    }
    .qualif-col-content {
        padding: 12px;
    }
}

/* ============================================
   Mode très compact : zoom élevé ou petite résolution
   (max-width ~ 1280px)
   ============================================ */
@media screen and (max-width: 1280px) {
    .content {
        padding: 16px 20px !important;
    }

    .page-header-content h1 {
        font-size: 1.35rem !important;
    }

    .page-subtitle {
        font-size: 0.85rem !important;
    }

    #qualifStats,
    .stats-grid {
        grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
        gap: 8px !important;
        margin-bottom: 16px !important;
    }

    .stat-card {
        padding: 10px 12px !important;
        flex-direction: column !important;
        align-items: center !important;
        text-align: center !important;
        gap: 6px !important;
    }

    .stat-icon {
        width: 36px !important;
        height: 36px !important;
        font-size: 14px !important;
        margin: 0 auto !important;
    }

    .stat-content h3 {
        font-size: 18px !important;
    }

    .stat-label {
        font-size: 10px !important;
        text-transform: uppercase !important;
    }

    .qualif-filter-tab {
        padding: 8px 12px !important;
        font-size: 12px !important;
    }

    .qualif-filter-content {
        padding: 12px !important;
    }

    .filters-actions .btn {
        padding: 8px 14px !important;
        font-size: 13px !important;
    }

    .qualif-table-dynamic th,
    .qualif-table-dynamic td {
        padding: 6px 4px !important;
        font-size: 11px !important;
    }

    /* Modale Qualification : très compacte */
    .qualif-modal-wide {
        max-width: 96% !important;
        max-height: 85vh !important;
    }
    .qualif-modal-grid {
        gap: 10px;
        padding: 10px 14px;
    }
    .qualif-modal-grid .qualif-modal-hcp-card {
        padding: 10px;
        gap: 6px;
    }
    .qualif-modal-grid .qualif-modal-avatar-lg {
        width: 48px;
        height: 48px;
        font-size: 18px;
    }
    .qualif-modal-grid .qualif-modal-info h3 {
        font-size: 13px;
    }
    .qualif-modal-meta-row span {
        font-size: 10px;
    }
    .qualif-modal-addresses {
        gap: 8px;
    }
    .qualif-modal-map-container {
        height: 120px;
    }
    .qualif-col {
        min-height: 240px;
    }
    .qualif-col-header {
        padding: 8px 10px;
    }
    .qualif-col-header i {
        font-size: 14px;
    }
    .qualif-col-header h4 {
        font-size: 12px;
    }
    .qualif-col-content {
        padding: 10px;
    }
    .qualif-modal-footer {
        padding: 10px 14px;
    }
    .qualif-modal-footer .btn {
        padding: 8px 16px;
        font-size: 13px;
    }
}
