/* ── HelloAsso Club Manager – Public Profile CSS ─────────────────────────── */

.hacm-profile-public {
    max-width: 860px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    color: #1e293b;
    font-size: 14px;
    line-height: 1.5;
}
.hacm-profile-public *, .hacm-profile-public *::before, .hacm-profile-public *::after {
    box-sizing: border-box;
}

/* ── Notices ── */
.hacm-pub-notice {
    padding: 11px 16px; border-radius: 8px; margin-bottom: 16px;
    font-size: 13px; line-height: 1.5; border: 1px solid transparent;
}
.hacm-pub-notice--success { background:#f0fdf4; color:#166534; border-color:#bbf7d0; }
.hacm-pub-notice--warning { background:#fffbeb; color:#92400e; border-color:#fde68a; }
.hacm-pub-notice--info    { background:#eff6ff; color:#1e40af; border-color:#bfdbfe; }

/* ── Header profil ── */
.hacm-pub-header {
    display: flex; align-items: flex-start; gap: 18px;
    background: #fff; border: 1px solid #e2e8f0; border-radius: 14px;
    padding: 22px; margin-bottom: 18px;
    box-shadow: 0 1px 4px rgba(0,0,0,.06);
    flex-wrap: wrap;
}
.hacm-pub-avatar { border-radius: 50%; border: 3px solid #e2e8f0; display: block; }
.hacm-pub-identity { flex: 1; min-width: 180px; }
.hacm-pub-name  { font-size: 20px; font-weight: 700; margin-bottom: 3px; }
.hacm-pub-email { color: #64748b; font-size: 13px; margin-bottom: 10px; }
.hacm-pub-sports { display: flex; gap: 6px; flex-wrap: wrap; }
.hacm-pub-belts { display: flex; flex-direction: column; gap: 8px; margin-left: auto; align-items: flex-end; }
.hacm-pub-belt-wrap { text-align: right; }

/* ── Sport pills ── */
.hacm-sport-pill {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 3px 10px; border-radius: 999px; font-size: 12px; font-weight: 500;
}
.hacm-sport-pill--karate    { background:#fff7ed; color:#9a3412; }
.hacm-sport-pill--krav_maga { background:#fdf4ff; color:#7e22ce; }

/* ── Belt pill ── */
.hacm-belt-pill {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 4px 12px; border-radius: 5px; border: 2px solid;
    font-size: 12px; font-weight: 700; letter-spacing: .03em; white-space: nowrap;
}
.hacm-belt-pill-title {
    font-size: 10px; font-weight: 600; opacity: .8;
    text-transform: uppercase; letter-spacing: .06em;
    border-left: 1px solid currentColor; padding-left: 6px;
}

/* ── Statuts ── */
.hacm-pub-statuts {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 18px;
}
.hacm-pub-statut-card {
    background: #fff; border: 1px solid #e2e8f0; border-radius: 12px;
    padding: 18px; text-align: center;
    box-shadow: 0 1px 4px rgba(0,0,0,.05); transition: transform .15s;
}
.hacm-pub-statut-card:hover { transform: translateY(-2px); }
.hacm-pub-statut-card.ok { border-color: #86efac; background: #f0fdf4; }
.hacm-pub-statut-card.ko { border-color: #fca5a5; background: #fef2f2; }
.hacm-pub-statut-icon  { font-size: 26px; margin-bottom: 6px; }
.hacm-pub-statut-label { font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.hacm-pub-statut-sub   { font-size: 11px; color: #64748b; }

/* ── Sections ── */
.hacm-pub-section {
    background: #fff; border: 1px solid #e2e8f0; border-radius: 14px;
    padding: 22px; margin-bottom: 18px;
    box-shadow: 0 1px 4px rgba(0,0,0,.05);
}
.hacm-pub-section-title {
    font-size: 15px; font-weight: 700; margin-bottom: 16px; color: #0f172a;
}

/* ── Enfants ── */
.hacm-pub-children { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 14px; }
.hacm-pub-child-card {
    border: 1px solid #e2e8f0; border-radius: 10px; padding: 14px; background: #f8fafc;
}
.hacm-pub-child-name { font-weight: 600; font-size: 14px; margin-bottom: 8px; }
.hacm-pub-child-age  { font-size: 12px; color: #64748b; font-weight: 400; }
.hacm-pub-child-sports  { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; align-items: center; }
.hacm-pub-child-statuts { display: flex; gap: 10px; flex-wrap: wrap; }
.hacm-pub-child-statut  { font-size: 12px; font-weight: 500; }
.hacm-pub-child-statut.ok { color: #16a34a; }
.hacm-pub-child-statut.ko { color: #dc2626; }

/* ── Formulaire ── */
.hacm-pub-form {}
.hacm-pub-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-bottom: 16px; }
.hacm-pub-form-field > label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 5px; }
.hacm-pub-input {
    width: 100%; padding: 9px 12px; border: 1.5px solid #d1d5db; border-radius: 8px;
    font-size: 14px; font-family: inherit; color: #1e293b; background: #f9fafb;
    transition: border-color .15s;
}
.hacm-pub-input:focus { border-color: #1a56db; outline: none; box-shadow: 0 0 0 3px rgba(26,86,219,.1); }
.hacm-pub-btn {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 10px 22px; background: #1a56db; color: #fff;
    border: none; border-radius: 8px; font-size: 14px; font-weight: 600;
    cursor: pointer; transition: background .15s;
}
.hacm-pub-btn:hover { background: #1045b8; }

/* ── Admin bar ── */
.hacm-pub-admin-bar {
    text-align: right; margin-top: 8px; font-size: 13px;
}
.hacm-pub-admin-bar a { color: #1a56db; text-decoration: none; }
.hacm-pub-admin-bar a:hover { text-decoration: underline; }

/* ── Responsive ── */
@media (max-width: 640px) {
    .hacm-pub-statuts  { grid-template-columns: 1fr; }
    .hacm-pub-header   { flex-direction: column; }
    .hacm-pub-belts    { margin-left: 0; align-items: flex-start; }
    .hacm-pub-form-row { grid-template-columns: 1fr; }
}
