/* ============================================================
   CYBERENTA — Login partagé (identique sur tous les modules)
   Source unique copiée dans chaque module (shared/css/auth-login.css).
   À lier APRÈS design-system.css. Tout est scopé sous .auth-page :
   n'affecte QUE la page de connexion, jamais les pages applicatives.
   La palette sombre est posée sur .auth-page (les variables cascadent
   vers .input/.btn/.form-label…), ce qui rend le login identique quel
   que soit le thème par défaut du module.
   ============================================================ */

/* ── Carte de connexion + palette sombre scopée ─────────────── */
.auth-page {
    /* Palette sombre (alignée sur les jetons par défaut du design-system) */
    --bg-primary: #050506;
    --bg-elevated: #121217;
    --surface: rgba(255, 255, 255, 0.045);
    --surface-hover: rgba(255, 255, 255, 0.075);
    --surface-active: rgba(255, 255, 255, 0.11);
    --glass-bg: rgba(255, 255, 255, 0.05);
    --glass-border: rgba(255, 255, 255, 0.12);
    --glass-line: rgba(255, 255, 255, 0.12);
    --glass-blur: 22px;
    --border: rgba(255, 255, 255, 0.16);
    --border-light: rgba(255, 255, 255, 0.08);
    --border-focus: rgba(255, 255, 255, 0.65);
    --accent: #ffffff;
    --accent-hover: #f0f0f0;
    --accent-active: #e4e4e4;
    --text-primary: #ffffff;
    --text-secondary: rgba(255, 255, 255, 0.64);
    --text-tertiary: rgba(255, 255, 255, 0.42);
    --text-inverse: #000000;
    --shadow-focus: 0 0 0 3px rgba(255, 255, 255, 0.20);
    --success: #4ade80;
    --success-border: rgba(74, 222, 128, 0.25);
    --warning: #fbbf24;
    --danger: #f87171;

    min-height: 100vh; display: flex; align-items: center; justify-content: center;
    padding: var(--space-6); position: relative; overflow: hidden; z-index: 1;
    background: var(--bg-primary); color: var(--text-primary);
}

/* ── Ambiance (halo + grille) ───────────────────────────────── */
body { position: relative; overflow-x: hidden; background-color: var(--bg-primary, #050506); }
body::before {
    content: ''; position: fixed; inset: 0; z-index: 0; pointer-events: none;
    background:
        radial-gradient(900px 520px at 50% -60px, rgba(255, 255, 255, 0.10), transparent 60%),
        radial-gradient(760px 520px at 100% 200px, rgba(255, 255, 255, 0.04), transparent 55%),
        radial-gradient(760px 520px at 0% 320px, rgba(255, 255, 255, 0.035), transparent 55%);
}
body::after {
    content: ''; position: fixed; top: 0; left: 0; right: 0; height: 1200px; z-index: 0; pointer-events: none;
    opacity: 0.4;
    background-image:
        linear-gradient(rgba(255, 255, 255, 0.035) 1px, transparent 1px),
        linear-gradient(90deg, rgba(255, 255, 255, 0.035) 1px, transparent 1px);
    background-size: 64px 64px;
    -webkit-mask-image: radial-gradient(ellipse 80% 55% at 50% 12%, #000 0%, transparent 75%);
    mask-image: radial-gradient(ellipse 80% 55% at 50% 12%, #000 0%, transparent 75%);
}

.auth-aurora {
    position: fixed; inset: 0; z-index: 0; pointer-events: none;
    background:
        radial-gradient(620px 420px at 50% 8%, rgba(255, 255, 255, 0.16), transparent 60%),
        radial-gradient(520px 520px at 12% 100%, rgba(255, 255, 255, 0.06), transparent 60%),
        radial-gradient(520px 520px at 88% 90%, rgba(255, 255, 255, 0.05), transparent 60%);
    filter: saturate(120%);
}
.auth-card {
    position: relative; z-index: 1; width: 100%; max-width: 440px;
    padding: var(--space-10) var(--space-8) var(--space-8);
    border-radius: var(--radius-2xl);
    background: rgba(255, 255, 255, 0.055);
    backdrop-filter: blur(26px) saturate(150%);
    -webkit-backdrop-filter: blur(26px) saturate(150%);
    border: 1px solid var(--glass-border);
    box-shadow: 0 40px 120px rgba(0, 0, 0, 0.7), inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.auth-card::before {
    content: ''; position: absolute; inset: 0; border-radius: inherit; padding: 1px;
    background: linear-gradient(160deg, rgba(255, 255, 255, 0.35), rgba(255, 255, 255, 0) 40%);
    -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
    -webkit-mask-composite: xor; mask-composite: exclude;
    pointer-events: none; opacity: 0.6;
}

/* ── Wordmark : « Cyberenta » gras + sous-titre fin ─────────── */
.brand-text { display: inline-flex; align-items: baseline; gap: 7px; line-height: 1; white-space: nowrap; }
.brand-name { font-weight: var(--font-bold); letter-spacing: -0.03em; color: #fff; }
.brand-sub  { font-weight: var(--font-light); letter-spacing: 0.02em; color: var(--text-secondary); }
.brand-logo { height: 30px; width: auto; display: block; flex-shrink: 0; }
.login-lockup { display: flex; flex-direction: column; align-items: center; gap: var(--space-4); margin-bottom: var(--space-3); }
.login-lockup .brand-logo { height: 52px; }
.login-lockup .brand-text { font-size: var(--text-2xl); }
.auth-tagline { text-align: center; color: var(--text-secondary); font-size: var(--text-sm); margin-bottom: var(--space-8); }
.auth-card .form-group { margin-bottom: var(--space-5); }
.auth-card .btn-lg, .auth-card .w-full { width: 100%; }
.auth-foot { margin-top: var(--space-6); text-align: center; font-size: var(--text-xs); color: var(--text-tertiary); }
.auth-foot a { color: var(--text-secondary); }
.auth-foot a:hover { color: #fff; }
.hidden { display: none !important; }

/* ── Onglets connexion / inscription (module Support) ───────── */
.login-tabs {
    display: flex; background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--glass-line); border-radius: var(--radius-full);
    padding: 4px; margin-bottom: var(--space-6);
}
.login-tab {
    flex: 1; padding: var(--space-2) var(--space-4);
    font-size: var(--text-sm); font-weight: var(--font-medium);
    color: var(--text-secondary); background: none; border: none;
    border-radius: var(--radius-full); cursor: pointer; font-family: inherit;
    transition: all var(--transition-fast);
}
.login-tab.active { background: #fff; color: #000; box-shadow: 0 4px 18px rgba(255, 255, 255, 0.18); }
.login-tab:hover:not(.active) { color: #fff; }

/* ── Liens texte (mot de passe oublié, retour) ─────────────── */
.link-btn {
    background: none; border: none; cursor: pointer; font-family: inherit;
    color: var(--text-secondary); font-size: var(--text-sm);
    text-decoration: underline; text-underline-offset: 3px;
}
.link-btn:hover { color: var(--text-primary); }

/* ── Bascule de thème (bouton flottant) + logo ──────────────── */
.theme-toggle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px; flex-shrink: 0;
    border-radius: var(--radius-sm);
    border: 1px solid var(--glass-line);
    background: transparent; color: var(--text-secondary);
    cursor: pointer; transition: all var(--transition-fast);
}
.theme-toggle:hover { background: var(--surface-hover); color: var(--text-primary); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-moon { display: none; }
:root[data-theme="light"] .theme-toggle .icon-sun  { display: none; }
:root[data-theme="light"] .theme-toggle .icon-moon { display: inline-flex; }
.theme-toggle-float {
    position: fixed; top: 18px; right: 18px; z-index: var(--z-sticky);
    width: 42px; height: 42px; border-radius: var(--radius-full);
    background: rgba(11, 11, 14, 0.55);
    backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
/* Le logo fourni est blanc → version noire en mode clair. */
.logo-light { display: none; }
:root[data-theme="light"] .logo-dark  { display: none; }
:root[data-theme="light"] .logo-light { display: block; }

/* ── Animation d'entrée ─────────────────────────────────────── */
.fade-in-up { animation: authFadeUp var(--transition-base, 0.3s) ease both; }
@keyframes authFadeUp { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ════════════════════════════════════════════════════════════
   MODE CLAIR (DAY MODE) — remappage scopé au login uniquement
   ════════════════════════════════════════════════════════════ */
:root[data-theme="light"] .auth-page {
    --bg-primary: #eef1f5;
    --bg-elevated: #ffffff;
    --surface: rgba(18, 20, 28, 0.04);
    --surface-hover: rgba(18, 20, 28, 0.06);
    --surface-active: rgba(18, 20, 28, 0.09);
    --glass-bg: rgba(255, 255, 255, 0.70);
    --glass-border: rgba(18, 20, 28, 0.12);
    --glass-line: rgba(18, 20, 28, 0.12);
    --border: rgba(18, 20, 28, 0.18);
    --border-light: rgba(18, 20, 28, 0.10);
    --border-focus: rgba(18, 20, 28, 0.55);
    --accent: #15171c;
    --accent-hover: #2a2d34;
    --accent-active: #3a3d44;
    --text-primary: #15171c;
    --text-secondary: rgba(21, 23, 28, 0.66);
    --text-tertiary: rgba(21, 23, 28, 0.46);
    --text-inverse: #ffffff;
    --shadow-focus: 0 0 0 3px rgba(21, 23, 28, 0.14);
}
:root[data-theme="light"] body { background-color: #eef1f5; }
:root[data-theme="light"] body::before {
    background:
        radial-gradient(900px 520px at 50% -60px, rgba(20, 50, 110, 0.06), transparent 60%),
        radial-gradient(760px 520px at 100% 200px, rgba(20, 50, 110, 0.04), transparent 55%),
        radial-gradient(760px 520px at 0% 320px, rgba(20, 50, 110, 0.03), transparent 55%);
}
:root[data-theme="light"] body::after {
    opacity: 0.55;
    background-image:
        linear-gradient(rgba(18, 24, 40, 0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(18, 24, 40, 0.05) 1px, transparent 1px);
}
:root[data-theme="light"] .brand-name { color: var(--text-primary); }
:root[data-theme="light"] .auth-foot a:hover { color: var(--text-primary); }
:root[data-theme="light"] .auth-aurora {
    background:
        radial-gradient(620px 420px at 50% 8%, rgba(20, 50, 110, 0.10), transparent 60%),
        radial-gradient(520px 520px at 12% 100%, rgba(20, 50, 110, 0.05), transparent 60%),
        radial-gradient(520px 520px at 88% 90%, rgba(20, 50, 110, 0.04), transparent 60%);
}
:root[data-theme="light"] .auth-card {
    background: rgba(255, 255, 255, 0.78);
    border-color: var(--glass-line);
    box-shadow: 0 30px 90px rgba(18, 22, 40, 0.18), inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
:root[data-theme="light"] .auth-card::before {
    background: linear-gradient(160deg, rgba(18, 20, 28, 0.18), rgba(18, 20, 28, 0) 40%);
}
:root[data-theme="light"] .auth-page .input,
:root[data-theme="light"] .auth-page .select,
:root[data-theme="light"] .auth-page .textarea {
    background-color: #ffffff; border-color: var(--glass-line); color: var(--text-primary);
}
:root[data-theme="light"] .theme-toggle-float { background: rgba(255, 255, 255, 0.8); }
:root[data-theme="light"] .login-tabs { background: rgba(18, 20, 28, 0.05); }
:root[data-theme="light"] .login-tab.active { background: #15171c; color: #fff; box-shadow: 0 4px 18px rgba(18, 22, 40, 0.18); }
:root[data-theme="light"] .login-tab:hover:not(.active) { color: var(--text-primary); }
