/* =====================================================================
   Nexus-IA — Design System (§12.1)
   Sombre élégant · bleu roi #1B3A8A · or premium #D4AF37 · Inter
   Tokens centralisés : couleurs, espacements, rayons, ombres, durées.
   ===================================================================== */

:root {
    /* Couleurs de marque */
    --c-royal:        #1B3A8A;
    --c-royal-600:    #2347a8;
    --c-royal-400:    #4f6fd0;
    --c-gold:         #D4AF37;
    --c-gold-soft:    rgba(212, 175, 55, .14);

    /* Fonds sombres */
    --c-bg:           #0b0f1e;
    --c-bg-2:         #0e1426;
    --c-panel:        #141a2e;
    --c-panel-2:      #182040;
    --c-border:       #243056;
    --c-border-soft:  #1e2742;

    /* Texte */
    --c-text:         #e8eaf0;
    --c-text-soft:    #aab2cf;
    --c-text-mute:    #8b95b5;

    /* États */
    --c-success:      #4ade80;
    --c-success-bg:   rgba(74, 222, 128, .12);
    --c-danger:       #fb7185;
    --c-danger-bg:    rgba(251, 113, 133, .12);
    --c-warn:         #fbbf24;
    --c-info:         #60a5fa;

    /* Espacements (échelle 4px) */
    --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
    --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px; --sp-12: 48px;

    /* Rayons */
    --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 22px; --r-full: 999px;

    /* Ombres */
    --sh-sm: 0 1px 3px rgba(0,0,0,.3);
    --sh-md: 0 6px 20px rgba(0,0,0,.35);
    --sh-lg: 0 16px 48px rgba(0,0,0,.45);
    --sh-glow: 0 8px 30px rgba(27, 58, 138, .35);

    /* Animations */
    --t-fast: 150ms; --t-mid: 220ms; --t-slow: 320ms;
    --ease: cubic-bezier(.4, 0, .2, 1);

    --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
    height: 100%;
    font-family: var(--font);
    background:
        radial-gradient(1200px 600px at 80% -10%, rgba(27,58,138,.25), transparent 60%),
        radial-gradient(900px 500px at -10% 110%, rgba(212,175,55,.06), transparent 55%),
        var(--c-bg);
    color: var(--c-text);
    -webkit-font-smoothing: antialiased;
    line-height: 1.5;
}

a { color: var(--c-royal-400); text-decoration: none; }
::selection { background: var(--c-gold-soft); }

/* ── Typo ──────────────────────────────────────────────────────── */
h1 { font-size: 1.6rem; font-weight: 700; letter-spacing: -.02em; }
h2 { font-size: 1.2rem; font-weight: 600; letter-spacing: -.01em; }
.muted { color: var(--c-text-mute); }
.soft  { color: var(--c-text-soft); }

/* ── Boutons ───────────────────────────────────────────────────── */
.btn {
    display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
    padding: 11px 18px; border: 0; border-radius: var(--r-md);
    font: inherit; font-weight: 600; font-size: .95rem; cursor: pointer;
    transition: transform var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), background var(--t-fast);
    background: var(--c-panel-2); color: var(--c-text);
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn-primary { background: linear-gradient(135deg, var(--c-royal-600), var(--c-royal)); box-shadow: var(--sh-glow); }
.btn-primary:hover { box-shadow: 0 10px 34px rgba(27,58,138,.5); }
.btn-gold { background: linear-gradient(135deg, #e9c558, var(--c-gold)); color: #2a2300; }
.btn-ghost { background: transparent; border: 1px solid var(--c-border); }
.btn-block { width: 100%; }

/* ── Champs ────────────────────────────────────────────────────── */
.field { margin-bottom: var(--sp-4); }
.field label { display: block; font-size: .82rem; color: var(--c-text-soft); margin-bottom: 6px; font-weight: 500; }
.input {
    width: 100%; padding: 12px 14px; border-radius: var(--r-md);
    background: var(--c-bg-2); border: 1px solid var(--c-border);
    color: var(--c-text); font: inherit; transition: border var(--t-fast), box-shadow var(--t-fast);
}
.input:focus { outline: none; border-color: var(--c-royal-400); box-shadow: 0 0 0 3px rgba(79,111,208,.18); }
.input::placeholder { color: var(--c-text-mute); }

/* ── Cartes / panneaux ─────────────────────────────────────────── */
.card {
    background: linear-gradient(180deg, var(--c-panel), var(--c-bg-2));
    border: 1px solid var(--c-border); border-radius: var(--r-lg);
    box-shadow: var(--sh-md);
}

/* ── Badges ────────────────────────────────────────────────────── */
.badge {
    display: inline-flex; align-items: center; gap: 5px;
    padding: 3px 10px; border-radius: var(--r-full);
    font-size: .72rem; font-weight: 600;
}
.badge-gold { background: var(--c-gold-soft); color: var(--c-gold); }
.badge-success { background: var(--c-success-bg); color: var(--c-success); }
.badge-danger { background: var(--c-danger-bg); color: var(--c-danger); }
.badge-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--c-success); box-shadow: 0 0 0 3px var(--c-success-bg); }

/* ── Toasts ────────────────────────────────────────────────────── */
.toast {
    position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%);
    background: var(--c-panel-2); border: 1px solid var(--c-border);
    padding: 12px 18px; border-radius: var(--r-md); box-shadow: var(--sh-lg);
    animation: toastIn var(--t-mid) var(--ease);
}
@keyframes toastIn { from { opacity: 0; transform: translate(-50%, 12px); } to { opacity: 1; transform: translate(-50%, 0); } }

/* ── Utilitaires ───────────────────────────────────────────────── */
.flex { display: flex; } .items-center { align-items: center; } .justify-between { justify-content: space-between; }
.gap-2 { gap: var(--sp-2); } .gap-3 { gap: var(--sp-3); } .gap-4 { gap: var(--sp-4); }
.grid { display: grid; }
.mt-2 { margin-top: var(--sp-2); } .mt-4 { margin-top: var(--sp-4); } .mt-6 { margin-top: var(--sp-6); }
.text-center { text-align: center; }
