.pf-section { padding: 2.5rem 0; }

/* Badges */
.pf-badges { display: flex; flex-wrap: wrap; gap: .4rem .5rem; margin: 0 0 .9rem 0; padding: 0; list-style: none; }
.badge-chip {
    --badge-bg: #eef2ff; --badge-fg: #1e293b; --badge-bd: color-mix(in srgb, var(--badge-bg) 70%, #94a3b8);
    display: inline-flex; align-items: center; gap: .4rem; padding: .35rem .6rem; border-radius: 999px;
    font-size: .82rem; font-weight: 700; letter-spacing: .2px; color: var(--badge-fg); background: var(--badge-bg);
    border: 1px solid var(--badge-bd); line-height: 1; white-space: nowrap;
}
.badge-chip .dot { width: .5rem; height: .5rem; border-radius: 50%; background: currentColor; opacity: .9; }
.badge--sec { --badge-bg: #e9f7ef; --badge-fg: #166534; }
.badge--soft{ --badge-bg: #f1f5f9; --badge-fg: #334155; }
.badge--lang{ --badge-bg: #e7f0ff; --badge-fg: #1e40af; }

/* Actions */
.pf-actions { display: flex; gap: .6rem; flex-wrap: wrap; margin-bottom: .5rem; }

/* Buttons premium */
.btn-cert {
    --btn-bg: var(--brand-primary, #2d6cdf); --btn-fg: #fff; --btn-bd: transparent;
    height: 2.4rem; padding: 0 1rem; border-radius: .6rem; border: 1px solid var(--btn-bd);
    font-weight: 700; letter-spacing: .2px; display: inline-flex; align-items: center; gap: .45rem;
    transition: transform .12s ease, box-shadow .12s ease, background-color .12s ease, border-color .12s ease, color .12s ease;
    text-decoration: none; box-shadow: 0 6px 18px rgba(45,108,223,.12);
}
.btn-cert .icon { line-height: 1; font-size: 1rem; }
.btn-cert-primary {
    background: linear-gradient(180deg, color-mix(in srgb, var(--btn-bg) 96%, #ffffff 4%), var(--btn-bg));
    color: var(--btn-fg); border-color: color-mix(in srgb, var(--btn-bg) 85%, #000 15%);
}
.btn-cert-primary:hover { transform: translateY(-1px); box-shadow: 0 10px 24px rgba(45,108,223,.18); filter: saturate(1.05); }
.btn-cert-primary:focus-visible { outline: none; box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--btn-bg) 28%, transparent); }
.btn-cert-ghost {
    --ghost-bd: color-mix(in srgb, var(--brand-border, #e5e7eb) 60%, #94a3b8);
    background: #fff; color: #1f2937; border-color: var(--ghost-bd);
}
.btn-cert-ghost:hover {
    background: color-mix(in srgb, #fff 92%, var(--brand-primary, #2d6cdf));
    border-color: color-mix(in srgb, var(--ghost-bd) 60%, var(--brand-primary, #2d6cdf));
    transform: translateY(-1px);
}
.btn-cert-ghost:focus-visible { outline: none; box-shadow: 0 0 0 .2rem color-mix(in srgb, var(--brand-primary, #2d6cdf) 22%, transparent); }

/* Cards */
.pf-card { border: 1px solid var(--brand-border, #e5e7eb); border-radius: .9rem; background: var(--brand-surface, #fff); }
.pf-card .card-body { padding: 1.1rem 1.1rem; }
.pf-list { margin: 0; padding-left: 1.1rem; }
.pf-list li { margin-bottom: .4rem; }

/* Workflow des statuts */
.pf-status-flow {
    display: flex; align-items: center; flex-wrap: wrap; gap: .6rem;
    background: #f8fafc; border: 1px dashed #cbd5e1; padding: .75rem; border-radius: .7rem;
}
.pf-status {
    --st-bg: #fff; --st-fg: #334155; --st-bd: #cbd5e1;
    display: inline-flex; align-items: center; gap: .45rem;
    padding: .4rem .7rem; border-radius: 999px; background: var(--st-bg);
    color: var(--st-fg); border: 1px solid var(--st-bd); font-weight: 700; letter-spacing: .2px;
}
.pf-status .pf-dot {
    width: .55rem; height: .55rem; border-radius: 50%; background: currentColor; opacity: .95;
}
.pf-arrow { color: #94a3b8; font-weight: 700; }

.pf-status--pending  { --st-bg:#fff7ed; --st-fg:#9a3412; --st-bd:#fdba74; }
.pf-status--reported { --st-bg:#eff6ff; --st-fg:#1d4ed8; --st-bd:#93c5fd; }
.pf-status--processed{ --st-bg:#ecfdf5; --st-fg:#047857; --st-bd:#6ee7b7; }
.pf-status--watch    { --st-bg:#f5f3ff; --st-fg:#6d28d9; --st-bd:#c4b5fd; }
