/* ─── Toolbar ─── */
.op-ic-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}

.op-ic-filters {
    display: flex;
    gap: 8px;
}

.op-ic-filter-select {
    padding: 8px 12px;
    border: 2px solid #ddd;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #333;
    background: #fff;
    cursor: pointer;
    transition: border-color 0.15s;
}

.op-ic-filter-select:focus {
    outline: none;
    border-color: #470000 !important;
}

/* ─── Onglets de statut ─── */
.op-ic-tabs {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}

.op-ic-tab {
    padding: 8px 16px;
    border: 2px solid #ddd;
    border-radius: 8px;
    background: #fff;
    color: #333;
    cursor: pointer;
    font-weight: 600;
    font-size: 0.9rem;
    transition: all 0.15s;
    display: flex;
    align-items: center;
    gap: 8px;
}

.op-ic-tab:hover,
.op-ic-tab:focus {
    border-color: #999 !important;
    background: #f8f9fa !important;
    color: #333 !important;
}

.op-ic-tab--active,
.op-ic-tab--active:hover,
.op-ic-tab--active:focus {
    border-color: #470000 !important;
    background: #470000 !important;
    color: #fff !important;
}

.op-ic-tab-count {
    display: inline-block;
    min-width: 22px;
    text-align: center;
    padding: 2px 8px;
    border-radius: 12px;
    font-size: 0.8rem;
    font-weight: 700;
    background: rgba(0, 0, 0, 0.1);
}

.op-ic-tab--active .op-ic-tab-count {
    background: rgba(255, 255, 255, 0.25);
}

/* ─── Badges statut ─── */
.op-ic-badge {
    display: inline-block;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}

.op-ic-badge--pending {
    background: #fff3e0;
    color: #e65100;
}

.op-ic-badge--ok {
    background: #e7f7ed;
    color: #1b7f4b;
}

.op-ic-badge--refused {
    background: #fdeaea;
    color: #c62828;
}

/* ─── Établissement ─── */
.op-ic-etab {
    font-size: 0.88rem;
    color: #666;
}

/* ─── Type badge ─── */
.op-ic-type {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 6px;
    font-size: 0.82rem;
    font-weight: 600;
    background: #f0f0f0;
    color: #555;
}

/* ─── Boutons actions ─── */
.op-ic-actions {
    display: flex;
    gap: 6px;
}

.op-ic-btn--accept,
.op-ic-btn--refuse,
.op-ic-btn--view {
    width: 32px !important;
    height: 32px !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 50% !important;
    cursor: pointer;
    font-size: 0.9rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s;
}

.op-ic-btn--accept {
    background: #1b7f4b !important;
    color: #fff !important;
}

.op-ic-btn--accept:hover {
    background: #15663d !important;
}

.op-ic-btn--refuse {
    background: #c62828 !important;
    color: #fff !important;
}

.op-ic-btn--refuse:hover {
    background: #a01c1c !important;
}

.op-ic-btn--view {
    background: #470000 !important;
    color: #fff !important;
}

.op-ic-btn--view:hover {
    background: #2e0000 !important;
}

.op-ic-col-actions {
    width: 80px !important;
    text-align: center;
}

/* ─── Motif refus ─── */
.op-ic-motif {
    font-size: 0.82rem;
    color: #999;
    font-style: italic;
}

/* ─── DataTable overrides ─── */
#op-ic-table_wrapper .dataTables_filter {
    float: left !important;
    text-align: left !important;
    padding-left: 0;
}

#op-ic-table_filter input {
    max-width: 100%;
    box-sizing: border-box;
}

#op-ic-table_wrapper .dataTables_processing {
    display: none !important;
}

#op-ic-table tbody tr {
    transition: background-color 0.2s;
}

#op-ic-table tbody tr:hover {
    background-color: #f8f9fa !important;
}

/* ─── Popup membres ─── */
.op-ic-members-table {
    width: 100%;
    border-collapse: collapse;
    text-align: left;
    font-size: 0.9rem;
}

.op-ic-members-table th {
    background: #470000;
    color: #fff;
    padding: 8px 12px;
    font-weight: 600;
}

.op-ic-members-table td {
    padding: 8px 12px;
    border-bottom: 1px solid #eee;
}

.op-ic-members-table tbody tr:hover {
    background: #f8f9fa;
}

/* ─── Bouton inscription en masse ─── */
.op-ic-btn-bulk {
    padding: 8px 16px;
    border: none;
    border-radius: 8px;
    background: #1b7f4b !important;
    color: #fff !important;
    font-size: 0.9rem;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.15s;
    white-space: nowrap;
}

.op-ic-btn-bulk:hover,
.op-ic-btn-bulk:focus {
    background: #15663d !important;
    color: #fff !important;
}

.op-ic-btn-bulk i {
    margin-right: 4px;
}

/* ─── Popup inscription en masse ─── */
.op-ic-bulk-step {
    text-align: left;
    margin-bottom: 12px;
}

.op-ic-bulk-step h4 {
    margin: 0 0 8px;
    font-size: 1rem;
    color: #333;
}

.op-ic-bulk-select {
    width: 100%;
    padding: 8px 12px;
    border: 2px solid #ddd;
    border-radius: 8px;
    font-size: 0.9rem;
    font-weight: 600;
    color: #333;
    margin-bottom: 12px;
}

.op-ic-bulk-teams {
    max-height: 300px;
    overflow-y: auto;
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.op-ic-bulk-team-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border: 1px solid #eee;
    border-radius: 8px;
    background: #fafafa;
    cursor: pointer;
    transition: 0.15s;
    font-size: 0.93rem;
}

.op-ic-bulk-team-item:hover {
    background: #f0f4ff;
    border-color: #c7d2fe;
}

.op-ic-bulk-team-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #1b7f4b;
    flex-shrink: 0;
}

.op-ic-bulk-team-item .team-info {
    flex: 1;
}

.op-ic-bulk-team-item .team-name {
    font-weight: 600;
}

.op-ic-bulk-team-item .team-etab {
    font-size: 0.85rem;
    color: #888;
}

.op-ic-bulk-team-item .team-membres {
    font-size: 0.82rem;
    color: #999;
}

.op-ic-bulk-selectall {
    margin-bottom: 8px;
    padding: 6px 0;
    font-size: 0.88rem;
}

.op-ic-bulk-selectall label {
    cursor: pointer;
    font-weight: 600;
    color: #470000;
}

.op-ic-bulk-recap {
    margin-top: 12px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 8px;
    border: 1px solid #eee;
    text-align: left;
}

.op-ic-bulk-recap-row {
    display: flex;
    justify-content: space-between;
    padding: 4px 0;
    font-size: 0.9rem;
}

.op-ic-bulk-recap-total {
    border-top: 2px solid #470000;
    margin-top: 6px;
    padding-top: 6px;
    font-weight: 700;
    font-size: 1rem;
}

/* ─── Recap teams sélectionnées (grille tarifs, pas de prix par team) ─── */
.op-ic-bulk-recap-teams {
    list-style: none;
    margin: 0 0 10px;
    padding: 0;
    max-height: 180px;
    overflow-y: auto;
    border: 1px solid #eee;
    border-radius: 6px;
    background: #fff;
}

.op-ic-bulk-recap-teams li {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 10px;
    border-bottom: 1px solid #f0f0f0;
    font-size: 0.88rem;
}

.op-ic-bulk-recap-teams li:last-child {
    border-bottom: none;
}

.op-ic-bulk-recap-team-name {
    font-weight: 600;
    color: #333;
}

.op-ic-bulk-recap-team-etab {
    color: #777;
    font-size: 0.82rem;
    margin-left: 8px;
    text-align: right;
}

.op-ic-bulk-tarif-grid {
    margin-top: 8px;
    padding: 10px 12px;
    background: #fff;
    border: 1px solid #eee;
    border-radius: 6px;
}

.op-ic-bulk-tarif-title {
    margin: 0 0 6px;
    font-size: 0.88rem;
    font-weight: 700;
    color: #470000;
}

.op-ic-bulk-tarif-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.op-ic-bulk-tarif-list li {
    padding: 3px 0;
    font-size: 0.88rem;
    color: #333;
}

.op-ic-bulk-tarif-line {
    margin: 4px 0;
    font-size: 0.95rem;
}

.op-ic-bulk-tarif-licence {
    margin: 6px 0 0;
    padding-top: 6px;
    border-top: 1px dashed #ddd;
    font-size: 0.88rem;
    color: #333;
}

.op-ic-bulk-tarif-note {
    margin: 8px 0 0;
    padding: 6px 8px;
    background: #fff8e1;
    border-left: 3px solid #f4b400;
    font-size: 0.8rem;
    color: #5a4a00;
    line-height: 1.4;
}

.op-ic-bulk-tarif-note i {
    margin-right: 4px;
}

/* ─── Popup validation joueurs ─── */
.op-ic-validate-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    text-align: left;
}

.op-ic-validate-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border: 1px solid #eee;
    border-radius: 8px;
    background: #fafafa;
    cursor: pointer;
    transition: 0.15s;
    font-size: 0.93rem;
}

.op-ic-validate-item:hover {
    background: #f0f4ff;
    border-color: #c7d2fe;
}

.op-ic-validate-item input[type="checkbox"] {
    width: 18px;
    height: 18px;
    accent-color: #1b7f4b;
    flex-shrink: 0;
}

/* ─── Responsive ─── */
@media (max-width: 768px) {
    .op-ic-tabs {
        flex-direction: column;
    }

    .op-ic-actions {
        flex-direction: column;
        gap: 4px;
    }
}
