/* ═══════════════════════════════════════════════════════════
   Collectif des Payeurs — Inscription multi-étapes
   ═══════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────────── */
.cdpi-wrap {
    --gold:   #C9A566;
    --gold-d: rgb(182, 137, 32);
    --gold-a: rgba(201,165,102,.12);
    --dark:   #1a2035;
    --text:   #2d3748;
    --muted:  #6b7a94;
    --dim:    #9aa5bb;
    --bdr:    #e5ddd0;
    --bg:     #f7f2eb;
    --white:  #ffffff;
    --ok:     #22c55e;
    --warn:   #f59e0b;
    --err:    #ef4444;
    --r:      12px;
    --shadow: 0 2px 12px rgba(0,0,0,.06);

    max-width: 720px;
    margin: 0 auto;
    padding: 20px 16px 32px;
    font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, sans-serif;
    font-size: 14px;
    line-height: 1.5;
    color: var(--text);
    box-sizing: border-box;
}

.cdpi-wrap *, .cdpi-wrap *::before, .cdpi-wrap *::after {
    box-sizing: border-box;
}

/* ── Override reset thème (Hello/Elementor) sur tous les boutons ── */
.cdpi-wrap [type="button"],
.cdpi-wrap [type="submit"],
.cdpi-wrap button {
    background-color: transparent;
    border: none;
    border-radius: 0;
    color: inherit;
    padding: 0;
    font-size: inherit;
    font-weight: inherit;
    text-align: left;
    white-space: normal;
    -webkit-appearance: none;
    appearance: none;
    outline: none;
    -webkit-tap-highlight-color: transparent;
}

.cdpi-wrap [type="button"]:focus,
.cdpi-wrap [type="submit"]:focus,
.cdpi-wrap button:focus { outline: none; }

/* ── Déjà connecté ─────────────────────────────────────────── */
.cdpi-already-logged {
    text-align: center;
    padding: 48px 20px;
    color: var(--muted);
    background: var(--white);
    border: 1px solid var(--bdr);
    border-radius: var(--r);
}

/* ── En-tête compact ───────────────────────────────────────── */
.cdpi-top {
    display: flex;
    align-items: center;
    gap: 12px;
    background: linear-gradient(135deg, #1a2b4a, #0f1e38);
    border-radius: var(--r);
    padding: 14px 18px;
    margin-bottom: 14px;
}

.cdpi-top-logo {
    width: 42px;
    height: 42px;
    border-radius: 10px;
    background: linear-gradient(135deg, #F5B544, #FFD080);
    color: #0f1e38;
    font-weight: 800;
    font-size: 13px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    letter-spacing: -.3px;
}

.cdpi-top-text {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.cdpi-top-text strong {
    color: #fff;
    font-size: 14px;
    font-weight: 700;
}

.cdpi-top-text span {
    color: rgba(255,255,255,.55);
    font-size: 12px;
}

/* ── Barre de progression ──────────────────────────────────── */
.cdpi-progress {
    background: var(--white);
    border: 1px solid var(--bdr);
    border-radius: var(--r);
    padding: 14px 20px;
    margin-bottom: 14px;
    box-shadow: var(--shadow);
}

.cdpi-prog-track {
    display: flex;
    align-items: center;
    gap: 0;
}

.cdpi-prog-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
    cursor: default;
}

.cdpi-prog-dot {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: #e8ecf4;
    color: var(--dim);
    font-weight: 700;
    font-size: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background .25s, color .25s;
    position: relative;
}

.cdpi-prog-check { display: none; }

/* Done */
.cdpi-prog-item.is-done .cdpi-prog-dot {
    background: #dcfce7;
    color: #16a34a;
}
.cdpi-prog-item.is-done .cdpi-prog-num  { display: none; }
.cdpi-prog-item.is-done .cdpi-prog-check { display: block; }

/* Active */
.cdpi-prog-item.is-active .cdpi-prog-dot {
    background: var(--gold);
    color: var(--dark);
    box-shadow: 0 0 0 3px var(--gold-a);
}

.cdpi-prog-lbl {
    font-size: 10px;
    font-weight: 600;
    color: var(--dim);
    text-transform: uppercase;
    letter-spacing: .04em;
    white-space: nowrap;
    transition: color .25s;
}

.cdpi-prog-item.is-active .cdpi-prog-lbl { color: var(--dark); }
.cdpi-prog-item.is-done   .cdpi-prog-lbl { color: #16a34a; }

.cdpi-prog-line {
    flex: 1;
    height: 2px;
    background: var(--bdr);
    margin: 0 4px;
    margin-bottom: 14px; /* align with dots, above labels */
    border-radius: 2px;
    transition: background .3s;
}

.cdpi-prog-line.is-done { background: #86efac; }

/* ── Message global ────────────────────────────────────────── */
.cdpi-message {
    padding: 13px 16px;
    border-radius: 8px;
    margin-bottom: 12px;
    font-size: 13px;
    line-height: 1.6;
}
.cdpi-message.cdpi-success {
    background: rgba(34,197,94,.09);
    border: 1px solid rgba(34,197,94,.28);
    color: #155e2b;
}

.cdpi-message.cdpi-success a {
    color: #155e2b;
    font-weight: 700;
    text-decoration: underline;
}
.cdpi-message.cdpi-error {
    background: rgba(239,68,68,.07);
    border: 1px solid rgba(239,68,68,.22);
    color: #991b1b;
}

/* ── Étape ─────────────────────────────────────────────────── */
.cdpi-step {
    display: none;
    background: var(--white);
    border: 1px solid var(--bdr);
    border-radius: var(--r);
    padding: 26px 24px;
    box-shadow: var(--shadow);
    margin-bottom: 12px;
}

.cdpi-step.is-active {
    display: block;
    animation: cdpiIn .22s ease;
}

@keyframes cdpiIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}

.cdpi-step.anim-fwd {
    animation: cdpiFwd .22s ease;
}
@keyframes cdpiFwd {
    from { opacity: 0; transform: translateX(16px); }
    to   { opacity: 1; transform: translateX(0); }
}

.cdpi-step.anim-back {
    animation: cdpiBack .22s ease;
}
@keyframes cdpiBack {
    from { opacity: 0; transform: translateX(-16px); }
    to   { opacity: 1; transform: translateX(0); }
}

/* ── En-tête d'étape ───────────────────────────────────────── */
.cdpi-step-hd {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--bdr);
}

.cdpi-step-ico {
    font-size: 22px;
    line-height: 1;
    flex-shrink: 0;
}

.cdpi-step-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--dark);
    margin: 0 0 2px;
}

.cdpi-step-sub {
    font-size: 12px;
    color: var(--muted);
    margin: 0;
}

/* ── Grilles de champs ─────────────────────────────────────── */
.cdpi-grid   { display: grid; gap: 20px; }
.cdpi-g2     { grid-template-columns: 1fr 1fr; }
.cdpi-gcol2  { grid-column: 1 / -1; }

/* ── Champ individuel ──────────────────────────────────────── */
.cdpi-field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}

.cdpi-field-gap { margin-bottom: 16px; }

.cdpi-label {
    font-size: 11px;
    font-weight: 700;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: .05em;
}

.cdpi-label em {
    color: var(--gold);
    font-style: normal;
    margin-left: 2px;
}

.cdpi-opt {
    font-weight: 400;
    font-size: 11px;
    color: var(--dim);
}

.cdpi-hint {
    font-size: 11px;
    color: var(--dim);
    margin: 0;
}

/* ── Inputs / Select / Textarea ────────────────────────────── */
.cdpi-input,
.cdpi-select,
.cdpi-textarea {
    width: 100%;
    padding: 10px 13px;
    border: 1.5px solid var(--bdr);
    border-radius: 8px;
    font-size: 13px;
    font-family: inherit;
    color: var(--text);
    background: var(--bg);
    outline: none;
    -webkit-appearance: none;
    appearance: none;
    transition: border-color .15s, box-shadow .15s, background .15s;
    min-height: 42px;
}

.cdpi-select {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7' viewBox='0 0 11 7'%3E%3Cpath d='M1 1l4.5 4.5L10 1' stroke='%2399a7c2' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 34px;
    cursor: pointer;
}

.cdpi-textarea { resize: vertical; min-height: 80px; }

.cdpi-input:focus,
.cdpi-select:focus,
.cdpi-textarea:focus {
    border-color: var(--gold);
    background: var(--white);
    box-shadow: 0 0 0 3px var(--gold-a);
}

/* ── Champ mot de passe ────────────────────────────────────── */
.cdpi-pw-wrap { position: relative; }
.cdpi-pw-wrap .cdpi-input { padding-right: 38px; }

.cdpi-wrap .cdpi-toggle-pw {
    position: absolute;
    right: 9px;
    top: 50%;
    transform: translateY(-50%);
    background: none !important;
    border: none !important;
    color: inherit !important;
    cursor: pointer;
    font-size: 14px;
    padding: 4px;
    opacity: .4;
    transition: opacity .15s;
    line-height: 1;
    border-radius: 4px !important;
}
.cdpi-wrap .cdpi-toggle-pw:hover { opacity: .85; }

.cdpi-pw-strength {
    height: 3px;
    background: var(--bdr);
    border-radius: 3px;
    overflow: hidden;
    margin-top: 4px;
}
.cdpi-pw-bar { height: 100%; width: 0; border-radius: 3px; transition: width .3s, background-color .3s; }
.cdpi-pw-bar.weak   { width: 33%; background: var(--err); }
.cdpi-pw-bar.medium { width: 66%; background: var(--warn); }
.cdpi-pw-bar.strong { width: 100%; background: var(--ok); }

/* ── Radios ────────────────────────────────────────────────── */
.cdpi-radio-group {
    display: flex;
    flex-wrap: wrap;
    gap: 7px;
}

.cdpi-radio-label {
    display: flex;
    align-items: center;
    gap: 8px;
    cursor: pointer;
    font-size: 13px;
    color: var(--text);
    padding: 9px 14px;
    border: 1.5px solid var(--bdr);
    border-radius: 8px;
    background: var(--white);
    transition: border-color .15s, background .15s;
    user-select: none;
    -webkit-user-select: none;
}

.cdpi-radio-label:hover { border-color: #c8d0e0; }

.cdpi-radio-label.is-checked {
    border-color: var(--gold);
    background: var(--gold-a);
    color: var(--dark);
    font-weight: 600;
}

.cdpi-radio-label input[type="radio"] {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
}

.cdpi-radio-dot {
    width: 15px;
    height: 15px;
    border: 2px solid var(--bdr);
    border-radius: 50%;
    flex-shrink: 0;
    transition: border-color .15s, background .15s;
    position: relative;
}

.cdpi-radio-label.is-checked .cdpi-radio-dot {
    border-color: var(--gold);
    background: var(--gold);
}

.cdpi-radio-label.is-checked .cdpi-radio-dot::after {
    content: '';
    position: absolute;
    inset: 0;
    margin: auto;
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background: #fff;
}

/* ── Photo ─────────────────────────────────────────────────── */
.cdpi-photo-zone {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-top: 6px;
}

.cdpi-photo-prev {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: 2px dashed var(--bdr);
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
    background: var(--bg);
    font-size: 28px;
    cursor: pointer;
    transition: border-color .15s;
}

.cdpi-photo-prev:hover { border-color: var(--gold); }
.cdpi-photo-prev img { width: 100%; height: 100%; object-fit: cover; }

.cdpi-photo-btn {
    display: inline-block;
    background: var(--white);
    border: 1.5px solid var(--gold-d);
    border-radius: 8px;
    padding: 8px 16px;
    font-size: 12px;
    font-weight: 700;
    color: var(--gold-d);
    cursor: pointer;
    transition: background .15s, color .15s;
    font-family: inherit;
}

.cdpi-photo-btn:hover {
    background: var(--gold-d);
    color: #fff;
}

.cdpi-photo-name {
    font-size: 11px;
    color: var(--muted);
    font-weight: 600;
    margin: 3px 0 0;
    max-width: 200px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Navigation ────────────────────────────────────────────── */
.cdpi-nav {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: var(--white);
    border: 1px solid var(--bdr);
    border-radius: var(--r);
    padding: 13px 18px;
    box-shadow: var(--shadow);
    margin-bottom: 8px;
}

.cdpi-nav-single { justify-content: flex-end; }
.cdpi-nav-single .cdpi-btn-submit { min-width: 200px; }

.cdpi-counter {
    font-size: 12px;
    color: var(--muted);
    white-space: nowrap;
}

.cdpi-counter strong { color: var(--dark); }

.cdpi-wrap .cdpi-btn-prev,
.cdpi-wrap .cdpi-btn-next {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 10px 20px;
    border-radius: 8px;
    border: 1.5px solid var(--bdr) !important;
    background: var(--white) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--muted) !important;
    cursor: pointer;
    font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
    transition: border-color .15s, background .15s, color .15s;
    text-align: center;
    white-space: nowrap;
}

.cdpi-wrap .cdpi-btn-prev:hover { border-color: var(--gold) !important; color: var(--text) !important; }

.cdpi-wrap .cdpi-btn-next {
    border-color: var(--gold-d) !important;
    background: linear-gradient(135deg, var(--gold), #ddb96e) !important;
    color: var(--dark) !important;
    font-weight: 700 !important;
}

.cdpi-wrap .cdpi-btn-next:hover { opacity: .88; }

.cdpi-wrap .cdpi-btn-prev:disabled,
.cdpi-wrap .cdpi-btn-next:disabled {
    opacity: .45;
    cursor: not-allowed;
}

/* Retour caché sur étape 1 */
.cdpi-wrap .cdpi-btn-prev.is-hidden { visibility: hidden; }

/* ── Bouton de soumission ──────────────────────────────────── */
.cdpi-wrap .cdpi-btn-submit {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 24px;
    background: linear-gradient(135deg, var(--gold), #ddb96e) !important;
    color: var(--dark) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    border-radius: 8px !important;
    border: none !important;
    cursor: pointer;
    font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
    transition: opacity .15s;
    box-shadow: 0 2px 8px rgba(201,165,102,.35) !important;
}

.cdpi-wrap .cdpi-btn-submit:hover:not(:disabled) { opacity: .88; }
.cdpi-wrap .cdpi-btn-submit:disabled { opacity: .55; cursor: not-allowed; }

/* ── Spinner ───────────────────────────────────────────────── */
.cdpi-spinner {
    display: inline-block;
    width: 13px;
    height: 13px;
    border: 2px solid rgba(15,30,56,.25);
    border-top-color: #0f1e38;
    border-radius: 50%;
    animation: cdpiSpin .7s linear infinite;
    vertical-align: middle;
}

@keyframes cdpiSpin { to { transform: rotate(360deg); } }

/* ── Mentions RGPD ─────────────────────────────────────────── */
.cdpi-rgpd {
    text-align: center;
    font-size: 11px;
    color: var(--dim);
    margin: 0;
    line-height: 1.5;
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 560px) {
    .cdpi-wrap { padding: 12px 10px 24px; }

    .cdpi-g2 { grid-template-columns: 1fr; }
    .cdpi-gcol2 { grid-column: 1; }
    .cdpi-grid { gap: 14px; }

    .cdpi-prog-lbl { display: none; }
    .cdpi-prog-line { margin-bottom: 0; }
    .cdpi-prog-track { align-items: center; }

    .cdpi-top-text span { display: none; }

    .cdpi-radio-group { flex-direction: column; }

    .cdpi-step { padding: 18px 16px; }
    .cdpi-nav  { padding: 11px 14px; }
}

@media (max-width: 380px) {
    .cdpi-counter { display: none; }
    .cdpi-btn-submit { font-size: 12px; padding: 9px 14px; }
}
