/* ═══════════════════════════════════════════════════════
   FPP Access -- Frontend Forms CSS
   All values driven by FPP UI Customizer design tokens.
   ═══════════════════════════════════════════════════════ */

/* ── Auth container ── */
.fppa-auth {
    max-width: 400px;
    margin: 0 auto;
    font-family: var(--fpp-font-body, -apple-system, BlinkMacSystemFont, sans-serif);
    -webkit-font-smoothing: antialiased;
}

/* ── Tabs ── */
.fppa-tabs {
    display: flex;
    border-radius: var(--fpp-rounded-lg, 12px);
    overflow: hidden;
    background: var(--fpp-bg, #f8fafc);
    margin-bottom: 24px;
    border: 1px solid var(--fpp-border, #e2e8f0);
}

.fppa-tab {
    flex: 1;
    padding: 12px 16px;
    font-size: 14px;
    font-weight: 600;
    border: none;
    background: transparent;
    color: var(--fpp-muted, #64748b);
    cursor: pointer;
    transition: all 0.2s ease;
    font-family: inherit;
}

.fppa-tab:hover { color: var(--fpp-body, #334155); }

.fppa-tab--active {
    background: var(--fpp-primary, #0891b2);
    color: var(--fpp-white, #fff);
}

.fppa-tab--active:hover { color: var(--fpp-white, #fff); }

/* ── HTMX loading states ── */
.fppa-btn-loading { display: none; }
form.htmx-request .fppa-btn-text { display: none; }
form.htmx-request .fppa-btn-loading { display: inline; }
form.htmx-request button[type="submit"] { opacity: 0.6; cursor: wait; }

/* ── Form wrapper (legacy) ── */
.fppa-form-wrap {
    max-width: 400px;
    margin: 40px auto;
    font-family: var(--fpp-font-body, -apple-system, BlinkMacSystemFont, sans-serif);
    -webkit-font-smoothing: antialiased;
}

.fppa-form {
    background: var(--fpp-white, #fff);
    border: 1px solid var(--fpp-border, #e2e8f0);
    border-radius: var(--fpp-rounded-lg, 12px);
    padding: 32px;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1), 0 1px 2px rgba(0,0,0,0.06);
}

.fppa-form-header { text-align: center; margin-bottom: 24px; }

.fppa-form-header h2 {
    margin: 0 0 8px;
    font-size: 24px;
    font-weight: 600;
    color: var(--fpp-heading, #0f172a);
    font-family: var(--fpp-font-heading, var(--fpp-font-body, sans-serif));
}

.fppa-form-header p { margin: 0; font-size: 14px; color: var(--fpp-muted, #64748b); }

/* ── Fields ── */
.fppa-field { margin-bottom: 16px; }

.fppa-field label {
    display: block;
    font-size: 14px;
    font-weight: 500;
    color: var(--fpp-body, #334155);
    margin-bottom: 8px;
}

.fppa-field input[type="text"],
.fppa-field input[type="email"],
.fppa-field input[type="password"] {
    width: 100%;
    box-sizing: border-box;
    border: 1px solid var(--fpp-border, #e2e8f0);
    border-radius: var(--fpp-rounded-md, 8px);
    padding: 12px 16px;
    font-size: 16px;
    color: var(--fpp-body, #334155);
    background: var(--fpp-white, #fff);
    transition: all 0.2s ease;
    font-family: inherit;
    line-height: 1.5;
    min-height: 44px;
}

.fppa-field input:focus {
    border-color: var(--fpp-primary, #0891b2);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--fpp-primary, #0891b2) 15%, transparent);
    outline: none;
}

.fppa-field input::placeholder { color: var(--fpp-muted, #64748b); }

.fppa-field-hint { display: block; font-size: 12px; color: var(--fpp-muted, #64748b); margin-top: 4px; }

.fppa-fields-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }

.fppa-field-row { display: flex; align-items: center; justify-content: space-between; }

/* ── Checkbox ── */
.fppa-checkbox-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: var(--fpp-body, #334155);
    cursor: pointer;
}

.fppa-checkbox-label input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--fpp-primary, #0891b2);
    border-radius: var(--fpp-rounded-sm, 4px);
}

/* ── Links ── */
.fppa-link-small {
    font-size: 14px;
    color: var(--fpp-primary, #0891b2);
    text-decoration: none;
    font-weight: 500;
    transition: all 0.2s ease;
}

.fppa-link-small:hover {
    color: var(--fpp-primary-hover, #0e7490);
    text-decoration: underline;
}

/* ── Form intro text ── */
.fppa-form-intro {
    font-size: 14px;
    color: var(--fpp-muted, #64748b);
    margin: 0 0 16px;
    line-height: 1.5;
}

/* ── Inline form (no card wrapper, e.g. account section) ── */
.fppa-form--inline {
    background: none;
    border: none;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
}

/* ── Lost password link as button ── */
button.fppa-link-small {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
}

/* ── Buttons ── */
.fppa-btn,
a.fppa-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: auto;
    max-width: 100%;
    padding: var(--fpp-btn-py, 12px) var(--fpp-btn-px, 28px);
    border-radius: var(--fpp-btn-radius, var(--fpp-rounded-md, 8px));
    font-size: var(--fpp-btn-font-size, 15px);
    font-weight: var(--fpp-btn-font-weight, 600);
    cursor: pointer;
    transition: all 0.2s ease;
    border: none;
    text-decoration: none;
    font-family: inherit;
    line-height: 1.5;
    min-height: 44px;
}
.fppa-btn-full,
a.fppa-btn-full { width: 100%; }

.fppa-btn-primary,
a.fppa-btn-primary {
    background: var(--fpp-primary, #0891b2);
    color: var(--fpp-white, #fff);
}

.fppa-btn-primary:hover,
a.fppa-btn-primary:hover {
    background: var(--fpp-primary-hover, #0e7490);
    color: var(--fpp-white, #fff);
    box-shadow: 0 4px 6px rgba(0,0,0,0.1), 0 2px 4px rgba(0,0,0,0.06);
}

.fppa-btn-primary:disabled {
    background: var(--fpp-primary-light, #22d3ee);
    opacity: 0.6;
    cursor: not-allowed;
}

.fppa-btn-secondary,
a.fppa-btn-secondary {
    background: var(--fpp-bg, #f8fafc);
    color: var(--fpp-body, #334155);
    border: 1px solid var(--fpp-border, #e2e8f0);
}

.fppa-btn-secondary:hover,
a.fppa-btn-secondary:hover {
    background: var(--fpp-border, #e2e8f0);
    color: var(--fpp-body, #334155);
}

.fppa-btn-accent,
a.fppa-btn-accent {
    background: var(--fpp-accent, #22c55e);
    color: var(--fpp-white, #fff);
}

.fppa-btn-accent:hover,
a.fppa-btn-accent:hover {
    background: var(--fpp-accent-hover, #16a34a);
    color: var(--fpp-white, #fff);
}

/* ── Messages ── */
.fppa-form-messages { margin-bottom: 16px; }
.fppa-form-messages:empty { display: none; }

.fppa-msg {
    padding: 12px 16px;
    border-radius: var(--fpp-rounded-md, 8px);
    font-size: 14px;
    font-weight: 500;
}

.fppa-msg-error {
    background: var(--fpp-error-light, #fef2f2);
    border: 1px solid var(--fpp-error, #dc2626);
    color: var(--fpp-error, #dc2626);
}

.fppa-msg-success {
    background: var(--fpp-success-light, #f0fdf4);
    border: 1px solid var(--fpp-success, #16a34a);
    color: var(--fpp-success, #16a34a);
}

.fppa-msg-warning {
    background: var(--fpp-warning-light, #fffbeb);
    border: 1px solid var(--fpp-warning, #d97706);
    color: var(--fpp-warning, #d97706);
}

/* ── Footer ── */
.fppa-form-footer {
    text-align: center;
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid var(--fpp-border, #e2e8f0);
}

.fppa-form-footer p { margin: 0; font-size: 14px; color: var(--fpp-muted, #64748b); }

.fppa-form-footer a {
    color: var(--fpp-primary, #0891b2);
    text-decoration: none;
    font-weight: 600;
}

.fppa-form-footer a:hover { color: var(--fpp-primary-hover, #0e7490); }

/* ── Honeypot ── */
.fppa-hp { position: absolute; left: -9999px; opacity: 0; height: 0; overflow: hidden; }

/* ── Account page ── */
.fppa-account-wrap { max-width: 560px; margin: 0 auto; }

.fppa-account-header {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 24px;
    background: linear-gradient(135deg, var(--fpp-heading, #164e63) 0%, var(--fpp-primary, #0891b2) 100%);
    border-radius: var(--fpp-rounded-lg, 12px);
    margin-bottom: 24px;
    color: var(--fpp-white, #fff);
}

.fppa-account-avatar img {
    border-radius: 9999px;
    border: 3px solid rgba(255,255,255,0.25);
}

.fppa-account-info h2 {
    margin: 0;
    font-size: 20px;
    font-weight: 600;
    color: var(--fpp-white, #fff);
    font-family: var(--fpp-font-heading, var(--fpp-font-body, sans-serif));
}

.fppa-account-info p { margin: 4px 0 0; opacity: 0.85; font-size: 14px; }

.fppa-role-badge {
    display: inline-block;
    margin-top: 8px;
    padding: 4px 12px;
    background: rgba(255,255,255,0.15);
    border-radius: 9999px;
    font-size: 12px;
    font-weight: 600;
}

.fppa-account-section {
    background: var(--fpp-white, #fff);
    border: 1px solid var(--fpp-border, #e2e8f0);
    border-radius: var(--fpp-rounded-lg, 12px);
    padding: 24px;
    margin-bottom: 16px;
    box-shadow: 0 1px 2px rgba(0,0,0,0.05);
    transition: box-shadow 0.2s ease;
}

.fppa-account-section:hover { box-shadow: 0 4px 6px rgba(0,0,0,0.06); }

.fppa-account-section h3 {
    margin: 0 0 16px;
    font-size: 16px;
    font-weight: 600;
    color: var(--fpp-heading, #0f172a);
    font-family: var(--fpp-font-heading, var(--fpp-font-body, sans-serif));
}

.fppa-account-details .fppa-detail-row {
    display: flex;
    padding: 12px 0;
    border-bottom: 1px solid var(--fpp-bg, #f8fafc);
    font-size: 14px;
}

.fppa-account-details .fppa-detail-row:last-child { border-bottom: none; }

.fppa-account-details .fppa-detail-label {
    color: var(--fpp-muted, #64748b);
    font-weight: 500;
    min-width: 140px;
}

.fppa-account-details .fppa-detail-value {
    color: var(--fpp-body, #334155);
    font-weight: 600;
}

.fppa-account-actions { text-align: center; }
.fppa-account-actions .fppa-btn { width: auto; display: inline-flex; }

/* ── Restricted content ── */
.fppa-restricted-message {
    padding: 16px 20px;
    background: var(--fpp-warning-light, #fffbeb);
    border: 1px solid var(--fpp-warning, #d97706);
    border-radius: var(--fpp-rounded-md, 8px);
    color: var(--fpp-warning, #d97706);
    font-size: 14px;
    margin: 16px 0;
}

/* ── Responsive ── */
@media (max-width: 480px) {
    .fppa-auth { margin: 0 16px; }
    .fppa-form-wrap { margin: 20px 16px; }
    .fppa-form { padding: 24px 20px; }
    .fppa-fields-row { grid-template-columns: 1fr; }
    .fppa-account-header { flex-direction: column; text-align: center; }
}

/* ──────────────────────────────────────────────────────────────────────
   Modal "E-mail envoyé" (apres register / lost-password)
   Base : API Popover native (popover="auto").
   Le navigateur fournit : top-layer, ::backdrop, light-dismiss, Esc,
   focus trap + restauration. Zero JS pour show/hide.
   ────────────────────────────────────────────────────────────────────── */
.fppa-email-sent-modal[popover] {
    /* reset UA styles du popover */
    position: fixed;
    inset: 0;
    margin: auto;
    border: 0;
    padding: 32px 28px 24px;
    max-width: 440px;
    width: calc(100% - 32px);
    max-height: calc(100dvh - 32px);
    overflow: auto;
    background: var(--fpp-white, #fff);
    color: var(--fpp-text, #0f172a);
    border-radius: var(--fpp-rounded-lg, 12px);
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.25);
    text-align: center;
}
.fppa-email-sent-modal[popover]:popover-open {
    animation: fppa-es-pop 0.22s cubic-bezier(0.16, 1, 0.3, 1);
}
.fppa-email-sent-modal[popover]::backdrop {
    background: rgba(15, 23, 42, 0.55);
    backdrop-filter: blur(2px);
    animation: fppa-es-fade 0.18s ease;
}
@keyframes fppa-es-fade { from { opacity: 0; } to { opacity: 1; } }
@keyframes fppa-es-pop {
    from { opacity: 0; transform: translateY(10px) scale(0.96); }
    to   { opacity: 1; transform: translateY(0)    scale(1); }
}

.fppa-email-sent-close {
    position: absolute;
    top: 10px;
    right: 12px;
    background: transparent;
    border: 0;
    font-size: 26px;
    line-height: 1;
    color: var(--fpp-muted, #64748b);
    cursor: pointer;
    padding: 4px 8px;
    border-radius: 6px;
    transition: background 0.15s, color 0.15s;
}
.fppa-email-sent-close:hover {
    background: var(--fpp-gray-100, #f1f5f9);
    color: var(--fpp-text, #0f172a);
}

.fppa-email-sent-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    background: var(--fpp-success-light, #f0fdf4);
    color: var(--fpp-success, #16a34a);
    margin-bottom: 16px;
}

.fppa-email-sent-title {
    font-size: 20px;
    font-weight: 700;
    color: var(--fpp-text, #0f172a);
    margin: 0 0 12px;
}

.fppa-email-sent-intro {
    font-size: 14px;
    color: var(--fpp-muted, #64748b);
    margin: 0 0 4px;
}

.fppa-email-sent-email {
    font-size: 15px;
    color: var(--fpp-text, #0f172a);
    margin: 0 0 12px;
    word-break: break-word;
}

.fppa-email-sent-help {
    font-size: 13px;
    color: var(--fpp-muted, #64748b);
    margin: 0 0 24px;
    line-height: 1.5;
}

.fppa-email-sent-actions {
    display: flex;
    flex-direction: column;
    gap: 10px;
    align-items: stretch;
}

.fppa-email-sent-resend-slot {
    min-height: 44px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.fppa-email-sent-resend-slot .fppa-msg {
    margin: 0;
    text-align: center;
}

.fppa-email-sent-resend {
    width: 100%;
}

.fppa-email-sent-actions .fppa-btn-primary {
    width: 100%;
}

@media (max-width: 480px) {
    .fppa-email-sent-content { padding: 24px 20px 18px; }
    .fppa-email-sent-icon { width: 60px; height: 60px; }
    .fppa-email-sent-icon svg { width: 40px; height: 40px; }
    .fppa-email-sent-title { font-size: 18px; }
}
