/* Auth flow styles. Loaded via $authPage flag in head.php, plus password-
   toggle utility used outside auth (profile/security, admin/user). */

body:has(.auth-page) {
    min-height: 100vh;
    background:
        radial-gradient(circle at 22% 8%, color-mix(in srgb, var(--t-primary-light) 24%, transparent), transparent 34%),
        radial-gradient(circle at 78% 0%, color-mix(in srgb, var(--t-cta-bg) 12%, transparent), transparent 30%),
        color-mix(in srgb, var(--t-primary-dark) 88%, black);
    color: var(--t-hero-text);
}

.auth-page {
    position: relative;
    min-height: 100vh;
    align-items: flex-start;
    padding-top: clamp(36px, 8vh, 72px);
    overflow: hidden;
}

.auth-page::before {
    content: '';
    position: fixed;
    inset: 0;
    background:
        linear-gradient(145deg, transparent 0 58%, color-mix(in srgb, var(--t-cta-bg) 9%, transparent) 58% 59%, transparent 59%),
        var(--t-hero-halo);
    pointer-events: none;
}

/* ── Brand header above .card content ─────────────────────────────────── */
.auth-brand {
    position: relative;
    z-index: 1;
    text-align: center;
    margin-bottom: 22px;
}
.auth-brand__logo {
    display: inline-flex; align-items: center; justify-content: center;
    text-decoration: none;
    padding: 8px 12px;
    border-radius: 16px;
    background: color-mix(in srgb, var(--t-on-primary) 7%, transparent);
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--t-on-primary) 14%, transparent);
}
.auth-brand__logo-img {
    max-height: 42px; width: auto; display: block;
    filter: drop-shadow(0 10px 24px color-mix(in srgb, var(--t-primary-dark) 52%, transparent));
}
.auth-brand__tagline {
    font-size: 0.82rem; line-height: 1.45;
    color: var(--t-hero-text-muted);
    max-width: 320px;
    margin: 10px auto 0;
    font-weight: 500;
}
.auth-brand__signals {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}
.auth-brand__signal {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 28px;
    padding: 5px 9px;
    border: 1px solid color-mix(in srgb, var(--t-cta-bg) 32%, transparent);
    border-radius: var(--t-radius-pill);
    background: color-mix(in srgb, var(--t-cta-bg) 12%, transparent);
    color: var(--t-hero-text);
    font-size: 0.75rem;
    font-weight: 700;
    white-space: nowrap;
}
.auth-brand__signal .ph,
.auth-brand__signal .ph-fill {
    color: var(--t-cta-bg);
    font-size: 15px;
    line-height: 1;
}

.auth-page .card {
    position: relative;
    z-index: 1;
    background:
        linear-gradient(150deg, color-mix(in srgb, var(--t-hero-bg) 92%, var(--t-primary-dark)) 0%, var(--t-hero-bg) 100%);
    color: var(--t-hero-text);
    border: 1px solid var(--t-hero-border);
    box-shadow: var(--t-hero-glow), 0 24px 70px color-mix(in srgb, black 38%, transparent);
    overflow: hidden;
}

.auth-page .card::before {
    content: '';
    position: absolute;
    inset: 0 0 auto;
    height: 3px;
    background: linear-gradient(90deg, var(--t-cta-bg), color-mix(in srgb, var(--t-primary-light) 70%, var(--t-cta-bg)));
}

.auth-page .page-title {
    color: var(--t-hero-text);
}

/* ── Page subtitle (used only on auth pages) ──────────────────────────── */
.auth-page .page-subtitle {
    color: var(--t-hero-text-muted);
    font-size: 0.9rem;
    margin: 0 0 24px;
}

/* ── Label hint (right-aligned link inside .label) ────────────────────── */
.label__hint {
    font-weight: 600; font-size: 0.8rem; color: var(--t-cta-bg);
}

/* ── Hint line under inputs ───────────────────────────────────────────── */
.auth-page .hint { font-size: 0.78rem; color: var(--t-hero-text-muted); }

.auth-page .label {
    color: var(--t-hero-text);
}

.auth-page .input {
    background: color-mix(in srgb, var(--t-on-primary) 5%, transparent);
    border-color: color-mix(in srgb, var(--t-on-primary) 14%, transparent);
    color: var(--t-hero-text);
}

.auth-page .input::placeholder {
    color: color-mix(in srgb, var(--t-hero-text-muted) 72%, transparent);
}

.auth-page .input:focus {
    border-color: var(--t-cta-bg);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--t-cta-bg) 24%, transparent);
}

.auth-page .checkbox-wrap span,
.auth-page .auth-divider {
    color: var(--t-hero-text-muted);
}

.auth-page a {
    color: var(--t-cta-bg);
}

.auth-page .checkbox-wrap input[type="checkbox"] {
    accent-color: var(--t-cta-bg);
}

/* ── Auth-scoped alerts (icon + flex layout, token-driven) ────────────── */
/* Scoped under .auth-page so the global .alert in style.css is untouched. */
.auth-page .alert {
    padding: 12px 14px; border-radius: var(--t-radius-sm);
    font-size: 0.88rem; line-height: 1.45;
    display: flex; gap: 10px; align-items: flex-start;
}
.auth-page .alert i { font-size: 18px; flex-shrink: 0; line-height: 1.4; }
.auth-page .alert--error   { background: color-mix(in srgb, var(--t-pink) 14%, transparent); color: var(--t-hero-text); border: 1px solid color-mix(in srgb, var(--t-pink) 35%, transparent); }
.auth-page .alert--error i { color: var(--t-pink); }
.auth-page .alert--success { background: color-mix(in srgb, var(--t-cta-bg) 14%, transparent); color: var(--t-hero-text); border: 1px solid color-mix(in srgb, var(--t-cta-bg) 45%, transparent); }
.auth-page .alert--success i { color: var(--t-accent-dark); }
.auth-page .alert--info    { background: color-mix(in srgb, var(--t-primary-light) 16%, transparent); color: var(--t-hero-text); border: 1px solid color-mix(in srgb, var(--t-primary-light) 26%, transparent); }
.auth-page .alert--info i  { color: var(--t-primary); }
.auth-page .alert--warn    { background: color-mix(in srgb, var(--t-cta-bg) 11%, transparent); color: var(--t-hero-text); border: 1px solid color-mix(in srgb, var(--t-cta-bg) 35%, transparent); }
.auth-page .alert--warn i  { color: var(--t-cta-bg); }

/* ── Yellow CTA scope (auth pages override .btn--primary to brand yellow) */
.auth-page .btn--primary {
    background: var(--t-cta-bg);
    color: var(--t-cta-fg);
    width: 100%;
    box-shadow: var(--t-cta-glow), var(--t-cta-inset);
}
.auth-page .btn--primary:hover {
    background: var(--t-accent-dark);
    box-shadow: var(--t-cta-glow-hover), var(--t-cta-inset);
}
.auth-page .btn--primary:disabled {
    opacity: 0.55; cursor: not-allowed;
    box-shadow: none;
}

/* ── Centered confirmation (verify success / error, reset success / error) */
.auth-confirm { text-align: center; padding: 8px 0; }
.auth-confirm__icon {
    width: 76px; height: 76px; margin: 0 auto 18px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 50%; font-size: 44px;
}
.auth-confirm__icon--success {
    background: color-mix(in srgb, var(--t-cta-bg) 15%, transparent); color: var(--t-accent-dark);
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--t-cta-bg) 6%, transparent);
}
.auth-confirm__icon--error {
    background: var(--t-pink-light); color: var(--t-pink);
    box-shadow: 0 0 0 6px color-mix(in srgb, var(--t-pink) 6%, transparent);
}

/* ── Register consent box ─────────────────────────────────────────────── */
.reg-consent {
    background: color-mix(in srgb, var(--t-hero-text) 8%, transparent);
    border: 1px solid color-mix(in srgb, var(--t-cta-bg) 28%, transparent);
    border-radius: var(--t-radius-sm);
    padding: 12px 14px;
    box-shadow: inset 0 1px 0 color-mix(in srgb, var(--t-hero-text) 8%, transparent);
}
.reg-consent .checkbox-wrap span { color: var(--text); font-weight: 500; }
.auth-page .reg-consent .checkbox-wrap span { color: var(--t-hero-text-muted); }
