@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;600;700;800&display=swap');
.associapro-inscription,.associapro-cotisation,.associapro-espace-membre,.associapro-liste-membres,.associapro-frontend-dashboard{font-family:'Plus Jakarta Sans',sans-serif;max-width:900px;margin:0 auto}
.assoc-form-header{margin-bottom:24px}.assoc-form-header h2{font-size:22px;font-weight:800;color:#0f4c75;margin:0 0 6px}.assoc-form-header p{color:#6b7e93;margin:0}
.assoc-form{background:#fff;padding:28px;border-radius:18px;box-shadow:0 4px 24px rgba(15,76,117,.08)}
.assoc-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.assoc-form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.assoc-form-group label{font-size:12px;font-weight:700;color:#6b7e93}
.assoc-input{border:2px solid #e2e8f0;border-radius:10px;padding:10px 14px;font-size:14px;width:100%;font-family:inherit;outline:none;transition:border-color .2s}
.assoc-input:focus{border-color:#1b9aaa}
.assoc-btn-primary{display:inline-block;background:linear-gradient(135deg,#0f4c75,#1b9aaa);color:#fff;padding:12px 28px;border-radius:12px;font-weight:700;font-size:14px;border:none;cursor:pointer;width:100%;margin-top:8px;font-family:inherit}
.assoc-member-card{background:#fff;border-radius:18px;overflow:hidden;max-width:360px;box-shadow:0 8px 32px rgba(15,76,117,.15)}
.assoc-card-header{background:linear-gradient(135deg,#0f4c75,#1b9aaa);padding:18px 22px;display:flex;align-items:center;gap:10px}
.assoc-card-logo{font-size:26px}.assoc-card-org{color:rgba(255,255,255,.9);font-weight:700;font-size:14px}
.assoc-card-body{padding:22px;display:flex;gap:14px;align-items:center}
.assoc-card-avatar{width:60px;height:60px;border-radius:50%;overflow:hidden;flex-shrink:0}
.assoc-card-avatar img{width:100%;height:100%;object-fit:cover}
.assoc-card-initials{width:60px;height:60px;border-radius:50%;background:linear-gradient(135deg,#0f4c75,#1b9aaa);display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px;font-weight:800}
.assoc-card-info h3{font-size:17px;font-weight:800;color:#1a2332;margin:0 0 3px}.assoc-card-categorie{color:#6b7e93;font-size:12px;margin:0 0 3px}.assoc-card-numero{color:#1b9aaa;font-weight:700;font-size:13px;margin:0}
.assoc-card-footer{background:#f8fafc;padding:14px 22px;display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.assoc-card-label{font-size:10px;color:#6b7e93;display:block}.assoc-card-value{font-size:12px;font-weight:700;color:#1a2332}
.assoc-table{width:100%;border-collapse:collapse;font-size:14px}
.assoc-table th{background:linear-gradient(135deg,#0f4c75,#1b9aaa);color:#fff;padding:11px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase}
.assoc-table td{padding:11px 14px;border-bottom:1px solid #f0f4f8}
.assoc-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:700;background:#e8f4fd;color:#0f4c75}
.assoc-status-ok{background:#eafaf1!important;color:#27ae60!important}.assoc-status-warn{background:#fef5e7!important;color:#f39c12!important}
.assoc-espace-header{background:linear-gradient(135deg,#0f4c75,#1b9aaa);color:#fff;padding:28px;border-radius:18px;margin-bottom:22px}
.assoc-espace-header h2{margin:0 0 5px;font-size:20px;font-weight:800}
.assoc-espace-grid{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}
.assoc-espace-section{background:#fff;padding:22px;border-radius:14px;box-shadow:0 4px 20px rgba(15,76,117,.07)}
.assoc-espace-section h3{font-size:15px;font-weight:800;color:#0f4c75;margin:0 0 14px}
@media(max-width:600px){.assoc-form-row,.assoc-espace-grid{grid-template-columns:1fr}}

/* ── Messages formulaire inscription ── */
.assoc-msg-success {
    background: #eafaf1;
    border: 1px solid #a9dfbf;
    color: #1e8449;
    padding: 14px 18px;
    border-radius: 10px;
    margin-top: 14px;
    font-size: 14px;
    line-height: 1.6;
}
.assoc-msg-error {
    background: #fdf2f2;
    border: 1px solid #f5c6cb;
    color: #c0392b;
    padding: 14px 18px;
    border-radius: 10px;
    margin-top: 14px;
    font-size: 14px;
}
.assoc-msg-info {
    background: #eaf4fd;
    border: 1px solid #aed6f1;
    color: #1a5276;
    padding: 12px 16px;
    border-radius: 10px;
    margin-top: 14px;
    font-size: 14px;
}

/* Formulaire inscription — améliorations */
.assoc-form-section-title {
    font-size: 12px;
    font-weight: 800;
    color: #0f4c75;
    text-transform: uppercase;
    letter-spacing: .8px;
    padding: 14px 0 8px;
    margin-top: 8px;
    border-bottom: 2px solid #e2e8f0;
    margin-bottom: 14px;
}
.assoc-required { color: #e74c3c; }
.assoc-form-note {
    font-size: 12px;
    color: #6b7e93;
    margin-top: 12px;
    text-align: center;
    line-height: 1.5;
}

/* ═══════════════════════════════════════════════
   Carte membre — Banner rôle associatif
═══════════════════════════════════════════════ */
.assoc-card-role-banner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    background: linear-gradient(135deg, #f5a623, #f39c12);
    padding: 7px 16px;
    border-bottom: 1px solid rgba(0,0,0,.06);
}
.assoc-card-role-icon {
    font-size: 14px;
}
.assoc-card-role-text {
    font-size: 12px;
    font-weight: 800;
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .8px;
}

/* ═══════════════════════════════════════════════
   Page Événements Publics
═══════════════════════════════════════════════ */
.assoc-evenements-publics { padding: 10px 0; }
.assoc-evt-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 22px;
    margin-top: 20px;
}
.assoc-evt-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(15,76,117,.09);
    display: flex;
    gap: 0;
    overflow: hidden;
    transition: transform .2s, box-shadow .2s;
}
.assoc-evt-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 32px rgba(15,76,117,.14);
}
.assoc-evt-past { opacity: .6; }
.assoc-evt-date-badge {
    background: linear-gradient(135deg, #0f4c75, #1b9aaa);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 18px 16px;
    min-width: 72px;
    color: #fff;
    text-align: center;
}
.assoc-evt-jour  { font-size: 28px; font-weight: 900; line-height: 1; }
.assoc-evt-mois  { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: .5px; margin-top: 4px; }
.assoc-evt-body  { padding: 16px; flex: 1; display: flex; flex-direction: column; gap: 6px; }
.assoc-evt-type-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .6px;
    background: #e8f4fd;
    color: #0f4c75;
    padding: 2px 10px;
    border-radius: 20px;
    width: fit-content;
}
.assoc-evt-titre  { font-size: 15px; font-weight: 800; color: #1a2332; margin: 4px 0; }
.assoc-evt-lieu   { font-size: 12px; color: #6b7e93; margin: 0; }
.assoc-evt-heure  { font-size: 12px; color: #6b7e93; margin: 0; }
.assoc-evt-desc-short { font-size: 12px; color: #8a9bb0; margin: 4px 0; }
.assoc-evt-footer { display: flex; align-items: center; justify-content: space-between; margin-top: auto; padding-top: 8px; }
.assoc-evt-btn {
    font-size: 12px;
    font-weight: 700;
    color: #0f4c75;
    text-decoration: none;
    border: 1.5px solid #0f4c75;
    padding: 4px 12px;
    border-radius: 20px;
    transition: all .2s;
}
.assoc-evt-btn:hover { background: #0f4c75; color: #fff; }
.assoc-evt-statut-ok   { background:#eafaf1 !important; color:#27ae60 !important; }
.assoc-evt-statut-warn { background:#fff8e1 !important; color:#f39c12 !important; }
.assoc-no-events { text-align:center; color:#999; padding:40px; font-size:15px; }

/* Détail événement CPT */
.assoc-evt-public { max-width: 700px; margin: 0 auto; }
.assoc-evt-desc   { font-size: 15px; line-height: 1.7; color: #444; margin-bottom: 20px; }
.assoc-evt-details { width: 100%; border-collapse: collapse; border-radius: 10px; overflow: hidden; }
.assoc-evt-details th { background: #f0f4f8; color: #0f4c75; font-weight: 700; padding: 10px 14px; text-align: left; width: 120px; }
.assoc-evt-details td { padding: 10px 14px; border-bottom: 1px solid #f0f4f8; color: #444; }

/* ═══════════════════════════════════════════════════════════════
   CARTE MEMBRE  v3.0  —  Format CIN  105×75mm
   ═══════════════════════════════════════════════════════════════ */
.assoc-id-card {
    max-width: 430px;
    font-family: 'Segoe UI', Arial, sans-serif;
    margin: 0 auto;
}

/* ── Conteneur carte ── */
.assoc-id-card-wrap {
    width: 412px;
    height: 293px;
    border-radius: 12px;
    overflow: hidden;
    font-family: 'Segoe UI', Arial, sans-serif;
    box-shadow: 0 8px 32px rgba(15,76,117,.22);
    border: 1.5px solid #b0c8e0;
    background: #fafcff;
    display: flex;
    flex-direction: column;
    position: relative;
}

/* ── EN-TÊTE ── */
.assoc-cin-header {
    background: linear-gradient(135deg, #0f4c75 0%, #1b9aaa 100%);
    height: 46px;
    display: flex;
    align-items: center;
    position: relative;
    padding: 0 14px;
    flex-shrink: 0;
}
.assoc-cin-flag-bar {
    display: none; /* Supprimé */
}
.assoc-cin-header-inner {
    margin-left: 0;
    flex: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px;
}
.assoc-cin-asso-name {
    color: #fff;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .3px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 200px;
}
.assoc-cin-card-title {
    color: rgba(255,255,255,.8);
    font-size: 8px;
    font-weight: 700;
    letter-spacing: 2px;
    text-transform: uppercase;
}
.assoc-cin-numero-badge {
    background: rgba(255,255,255,.18);
    border: 1px solid rgba(255,255,255,.4);
    color: #fff;
    font-size: 9px;
    font-weight: 800;
    padding: 3px 9px;
    border-radius: 20px;
    letter-spacing: .5px;
    white-space: nowrap;
    font-family: 'Courier New', monospace;
}

/* ── CORPS ── */
.assoc-cin-body {
    display: flex;
    flex: 1;
    gap: 0;
    overflow: hidden;
    background: #fafcff;
}

/* Colonne photo */
.assoc-cin-photo-col {
    width: 88px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 10px 8px;
    background: linear-gradient(180deg, #f0f5fb 0%, #e6eef6 100%);
    border-right: 1px solid #dde8f2;
}
.assoc-cin-photo {
    width: 62px; height: 78px;
    object-fit: cover;
    border-radius: 4px;
    border: 2px solid #b0c8e0;
    display: block;
}
.assoc-cin-initials {
    width: 62px; height: 78px;
    border-radius: 4px;
    background: linear-gradient(135deg, #0f4c75, #1b9aaa);
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 22px; font-weight: 800;
}
.assoc-cin-statut {
    font-size: 7px; font-weight: 900;
    border-radius: 10px; padding: 2px 7px;
    text-align: center; white-space: nowrap;
    letter-spacing: .5px;
}
.assoc-cin-statut.ok   { background: #d1fae5; color: #065f46; }
.assoc-cin-statut.warn { background: #fef3c7; color: #92400e; }

/* Colonne infos */
.assoc-cin-info-col {
    flex: 1;
    padding: 10px 10px 6px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-width: 0;
    overflow: hidden;
}
.assoc-cin-name-block {
    border-bottom: 1px solid #dde8f2;
    padding-bottom: 6px;
}
.assoc-cin-label {
    font-size: 7px;
    font-weight: 800;
    color: #1b9aaa;
    letter-spacing: 1px;
    text-transform: uppercase;
    line-height: 1.4;
}
.assoc-cin-prenom {
    font-size: 12px;
    font-weight: 700;
    color: #2d3748;
    line-height: 1.2;
    word-break: break-word;
}
.assoc-cin-nom {
    font-size: 15px;
    font-weight: 900;
    color: #0f2d4a;
    line-height: 1.2;
    word-break: break-word;
    margin-top: 3px;
}
.assoc-cin-fields {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.assoc-cin-field {
    display: flex;
    flex-direction: column;
    line-height: 1.2;
}
.assoc-cin-value {
    font-size: 10px;
    font-weight: 700;
    color: #1a202c;
    word-break: break-word;
}
.assoc-cin-field-expir { margin-top: 2px; }
.assoc-cin-value-expir {
    font-size: 10px;
    font-weight: 900;
    color: #c53030;
    background: #fff5f5;
    padding: 1px 5px;
    border-radius: 3px;
    display: inline-block;
}

/* Colonne QR */
.assoc-cin-qr-col {
    width: 106px;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    padding: 10px 8px;
    background: #fff;
    border-left: 1px solid #dde8f2;
}
.assoc-cin-qr {
    border: 2px solid #0f4c75;
    border-radius: 6px;
    display: block;
    background: #fff;
}
.assoc-cin-qr-label {
    font-size: 7px;
    color: #718096;
    text-align: center;
    line-height: 1.4;
    letter-spacing: .3px;
}

/* ── PIED (bande MRZ) ── */
.assoc-cin-footer {
    height: 38px;
    background: linear-gradient(135deg, #0f4c75 0%, #1b9aaa 100%);
    border-top: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 14px;
    flex-shrink: 0;
    gap: 8px;
}
.assoc-cin-mrz {
    font-family: 'Courier New', monospace;
    font-size: 7.5px;
    color: rgba(255,255,255,.75);
    letter-spacing: 1.5px;
    line-height: 1.6;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}
.assoc-cin-footer-asso {
    font-size: 8px;
    font-weight: 800;
    color: rgba(255,255,255,.9);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 120px;
    text-align: right;
}

/* ── Boutons actions carte (impression + export) ── */
.assoc-btn-action {
    border-radius:8px; padding:9px 20px; font-size:13px; font-weight:700;
    cursor:pointer; transition:all .15s; display:inline-flex;
    align-items:center; gap:6px; white-space:nowrap;
}
.assoc-btn-print-card {
    background: linear-gradient(135deg,#0f4c75,#1b9aaa);
    color:#fff; border:none;
}
.assoc-btn-print-card:hover { opacity:.85; }
.assoc-btn-export-card {
    background: #fff;
    color: #0f4c75;
    border: 2px solid #0f4c75;
}
.assoc-btn-export-card:hover { background:#f0f6ff; }
.assoc-btn-export-card:disabled,
.assoc-btn-print-card:disabled { opacity:.6; cursor:wait; }

/* ── Zone d'impression ── */
#assoc-print-zone { display: none; }

@media print {
    body.assoc-printing * { visibility: hidden; }
    body.assoc-printing #assoc-print-zone,
    body.assoc-printing #assoc-print-zone * { visibility: visible; }
    body.assoc-printing #assoc-print-zone {
        display: block !important;
        position: fixed !important;
        top: 0 !important; left: 0 !important;
        margin: 0 !important; padding: 0 !important;
    }
    body.assoc-printing .assoc-id-card-wrap {
        width: 101mm !important;  /* 105mm - 2×2mm marges */
        height: 71mm !important;  /* 75mm  - 2×2mm marges */
        border-radius: 8px !important;
        box-shadow: none !important;
        border: 1px solid #b0c8e0 !important;
    }
    @page { size: 105mm 75mm; margin: 2mm; }
}

/* ─── Photo upload — formulaire d'inscription public ─── */
.assoc-photo-upload-zone {
    position: relative;
    border: 2px dashed #c0cfe0;
    border-radius: 12px;
    background: #f8fafc;
    padding: 24px 20px;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    min-height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.assoc-photo-upload-zone:hover {
    border-color: #1b9aaa;
    background: #edf9fb;
}
.assoc-photo-placeholder {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    color: #6b7e93;
    font-size: 13px;
    pointer-events: none;
}
.assoc-photo-preview {
    position: relative;
    display: inline-block;
}
.assoc-photo-preview img {
    width: 90px;
    height: 90px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid #1b9aaa;
    display: block;
}
.assoc-photo-remove {
    position: absolute;
    top: -6px;
    right: -6px;
    background: #e74c3c;
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 22px;
    height: 22px;
    font-size: 11px;
    cursor: pointer;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* ─── Impression carte membre (frontend) ─── */
#assoc-print-zone { display: none; }

@media print {
    .assoc-no-print,
    .assoc-id-card-actions { display: none !important; }

    /* Quand la classe assoc-printing est présente : tout masquer sauf la zone carte */
    body.assoc-printing * { visibility: hidden; }
    body.assoc-printing #assoc-print-zone,
    body.assoc-printing #assoc-print-zone * { visibility: visible; }
    body.assoc-printing #assoc-print-zone {
        display: block !important;
        position: fixed !important;
        top: 0 !important; left: 0 !important;
        margin: 0 !important; padding: 0 !important;
    }
    @page {
        size: 100mm 75mm;
        margin: 0;
    }
    .assoc-id-card-wrap { box-shadow: none !important; border: 1px solid #ccc; }
    body { background: white !important; }
}

.assoc-status-done { background: #e9ecef; color: #6c757d; }

/* ═══════════════════════════════════════════════════════════════
   MODAL DÉTAIL ÉVÉNEMENT (front-office)
   ═══════════════════════════════════════════════════════════════ */
.assoc-evt-modal {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 99999;
    align-items: center;
    justify-content: center;
    padding: 70px 16px 70px; /* espace égal haut et bas */
    box-sizing: border-box;
}
.assoc-evt-modal-overlay {
    position: absolute;
    inset: 0;
    background: rgba(10, 30, 60, 0.6);
    backdrop-filter: blur(3px);
}
.assoc-evt-modal-box {
    position: relative;
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 20px 60px rgba(15,76,117,.25);
    max-width: 540px;
    width: 100%;
    max-height: calc(100vh - 140px); /* 70px haut + 70px bas */
    overflow-y: auto;
    z-index: 1;
    animation: assocModalIn .22s ease;
    margin: 0 auto;
}
@keyframes assocModalIn {
    from { opacity: 0; transform: scale(.96) translateY(16px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.assoc-evt-modal-close {
    position: absolute;
    top: 14px; right: 16px;
    background: rgba(255,255,255,.9);
    border: 1px solid #e0e8f0;
    border-radius: 50%;
    width: 32px; height: 32px;
    font-size: 14px; font-weight: 700;
    cursor: pointer; color: #4a5568;
    display: flex; align-items: center; justify-content: center;
    z-index: 2;
    transition: background .15s;
}
.assoc-evt-modal-close:hover { background: #f0f4f8; }
.assoc-evt-modal-header {
    background: linear-gradient(135deg, #0f4c75, #1b9aaa);
    padding: 28px 24px 20px;
    border-radius: 18px 18px 0 0;
}
.assoc-evt-modal-header .assoc-evt-type-tag {
    background: rgba(255,255,255,.2);
    color: #fff;
    border: none;
    margin-bottom: 10px;
    display: inline-block;
}
.assoc-evt-modal-header h2 {
    color: #fff;
    font-size: 22px;
    font-weight: 800;
    line-height: 1.3;
    margin: 0;
}
.assoc-evt-modal-body { padding: 24px; }
.assoc-evt-modal-meta {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 20px;
}
.assoc-evt-modal-row {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    font-size: 14px;
    color: #2d3748;
}
.assoc-evt-modal-icon { font-size: 18px; flex-shrink: 0; line-height: 1.4; }
.assoc-evt-modal-desc {
    background: #f8fafc;
    border-left: 4px solid #1b9aaa;
    border-radius: 0 8px 8px 0;
    padding: 14px 16px;
    font-size: 14px;
    color: #4a5568;
    line-height: 1.7;
}
