/**
 * portal.css — espace client dotflo (connexion + tableau de bord).
 * Scopé .page-portal.
 */

.page-portal .portal-auth { padding: clamp(3.5rem, 9vw, 7rem) 0; }
.page-portal .portal-auth__inner { max-width: 30rem; margin-inline: auto; display: flex; flex-direction: column; gap: var(--space-2); }
.page-portal .portal-auth h1 { font-size: var(--text-h2); }
.page-portal .intro { color: var(--color-neutral-1); font-size: 1.0625rem; line-height: 1.6; }

/* ── Formulaire connexion ─────────────────────────────── */
.page-portal .portal-form { display: flex; flex-direction: column; gap: 0.5rem; margin-top: var(--space-2); }
.page-portal .portal-form__label { font-size: 0.8125rem; font-weight: var(--font-weight-medium); color: var(--color-text); }
.page-portal .portal-form__input {
  font-size: 16px; font-family: var(--font-body); color: var(--color-text);
  background: var(--color-surface); border: 1px solid var(--color-neutral-2);
  border-radius: var(--radius-lg); height: 52px; padding: 0 1rem; width: 100%;
  transition: border-color var(--duration-fast) var(--ease-out), box-shadow var(--duration-fast) var(--ease-out);
}
.page-portal .portal-form__input:focus { outline: none; border-color: var(--color-accent); box-shadow: 0 0 0 3px var(--color-accent-alpha-10); }
.page-portal .portal-form__error { color: #D32F2F; font-size: 0.8125rem; }
.page-portal .portal-form__submit { margin-top: var(--space-1); justify-content: center; }
.page-portal .portal-help { font-size: 0.875rem; color: var(--color-neutral-1); margin-top: var(--space-2); }

/* ── Message flash ────────────────────────────────────── */
.page-portal .portal-note { border-radius: var(--radius-md); padding: 0.75rem 1rem; font-size: 0.9rem; }
.page-portal .portal-note--ok {
  background: var(--color-accent-alpha-10);
  border: 1px solid color-mix(in srgb, var(--color-accent) 35%, transparent);
  color: var(--color-text);
}

/* ── Tableau de bord ──────────────────────────────────── */
.page-portal .portal { padding: clamp(2.5rem, 6vw, 5rem) 0 clamp(3.5rem, 8vw, 7rem); }
.page-portal .portal__head { display: flex; justify-content: space-between; align-items: center; gap: var(--space-3); flex-wrap: wrap; margin-bottom: var(--space-3); }
.page-portal .portal__head h1 { font-size: var(--text-h2); margin-top: 0.5rem; }
.page-portal .portal__section-title { font-size: var(--text-h3); margin: var(--space-6) 0 var(--space-3); }
.page-portal .portal-empty { color: var(--color-neutral-1); }

/* ── Prélèvement automatique ──────────────────────────── */
.page-portal .portal-autopay {
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); flex-wrap: wrap;
  border: 1px solid color-mix(in srgb, var(--color-accent) 30%, var(--color-neutral-2));
  background: radial-gradient(120% 140% at 100% 0%, var(--color-accent-alpha-10), transparent 60%), var(--color-surface);
  border-radius: var(--radius-lg); padding: var(--space-3); margin-bottom: var(--space-4);
}
.page-portal .portal-autopay__desc { color: var(--color-neutral-1); font-size: 0.9rem; margin-top: 0.25rem; }
.page-portal .portal-autopay__on { color: #4fd07f; font-weight: var(--font-weight-medium); }

/* ── Tables ───────────────────────────────────────────── */
.page-portal .portal-table-wrap { border: 1px solid var(--color-neutral-2); border-radius: var(--radius-lg); overflow: hidden; }
.page-portal .portal-table { width: 100%; border-collapse: collapse; }
.page-portal .portal-table th {
  text-align: left; font-family: var(--font-body); font-size: 0.72rem; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--color-neutral-1); background: var(--color-bg-2);
  padding: 0.75rem 1rem; border-bottom: 1px solid var(--color-neutral-2);
}
.page-portal .portal-table td { padding: 0.85rem 1rem; border-bottom: 1px solid var(--color-neutral-2); font-size: 0.95rem; }
.page-portal .portal-table tr:last-child td { border-bottom: 0; }
.page-portal .portal-table .r { text-align: right; }
.page-portal .portal-table .c { text-align: center; }

.page-portal .badge { display: inline-block; padding: 2px 9px; border-radius: var(--radius-pill); font-size: 0.72rem; font-weight: var(--font-weight-medium); }
.page-portal .badge--ok { background: color-mix(in srgb, #1a7a3a 20%, transparent); color: #4fd07f; }
.page-portal .badge--warn { background: color-mix(in srgb, #b7791f 25%, transparent); color: #f0b64a; }
.page-portal .badge--muted { background: var(--color-neutral-2); color: var(--color-neutral-1); }

.page-portal .portal-actions { display: flex; gap: 0.6rem; justify-content: flex-end; align-items: center; }
.page-portal .portal-link { color: var(--color-accent); font-weight: 600; font-size: 0.85rem; }
.page-portal .portal-pay { min-height: 34px; padding-inline: var(--space-2); font-size: 0.8rem; }

/* ── Mobile : tables en cartes ────────────────────────── */
@media (max-width: 720px) {
  .page-portal .portal-table thead { display: none; }
  .page-portal .portal-table, .page-portal .portal-table tbody, .page-portal .portal-table tr, .page-portal .portal-table td { display: block; width: 100%; }
  .page-portal .portal-table tr { border-bottom: 1px solid var(--color-neutral-2); padding: 0.5rem 0; }
  .page-portal .portal-table tr:last-child { border-bottom: 0; }
  .page-portal .portal-table td { border: 0; padding: 0.35rem 1rem; display: flex; justify-content: space-between; gap: 1rem; text-align: right; }
  .page-portal .portal-table td::before { content: attr(data-label); color: var(--color-neutral-1); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; text-align: left; }
  .page-portal .portal-actions { justify-content: flex-end; }
}
