/* =====================================================================
   TEMIA TRAINING v2.0 — Theme tokens
   Variables CSS partagées (préfixe --temia-*).
   ===================================================================== */

:root {
  /* Couleurs */
  --temia-primary:    #2563eb;
  --temia-primary-d:  #1d4ed8;
  --temia-primary-l:  #dbeafe;
  --temia-success:    #16a34a;
  --temia-warning:    #d97706;
  --temia-danger:     #dc2626;
  --temia-info:       #0891b2;

  --temia-fg:         #0f172a;
  --temia-fg-2:       #334155;
  --temia-fg-3:       #64748b;
  --temia-bg:         #ffffff;
  --temia-bg-1:       #f8fafc;
  --temia-bg-2:       #ffffff;
  --temia-bg-3:       #f1f5f9;
  --temia-border:     #e2e8f0;
  --temia-border-2:   #cbd5e1;

  /* Typographie */
  --temia-font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
                "Helvetica Neue", Arial, sans-serif;
  --temia-font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  --temia-fs-sm: 0.875rem;
  --temia-fs-md: 1rem;
  --temia-fs-lg: 1.125rem;
  --temia-fs-xl: 1.5rem;

  /* Espacements */
  --temia-sp-1: 0.25rem;
  --temia-sp-2: 0.5rem;
  --temia-sp-3: 0.75rem;
  --temia-sp-4: 1rem;
  --temia-sp-5: 1.5rem;
  --temia-sp-6: 2rem;

  /* Rayons */
  --temia-radius:    6px;
  --temia-radius-lg: 10px;

  /* Ombres */
  --temia-shadow-1: 0 1px 2px rgba(15,23,42,.08);
  --temia-shadow-2: 0 6px 18px rgba(15,23,42,.12);
  --temia-shadow-3: 0 16px 48px rgba(15,23,42,.18);
}

@media (prefers-color-scheme: dark) {
  :root {
    --temia-fg:       #e2e8f0;
    --temia-fg-2:     #cbd5e1;
    --temia-fg-3:     #94a3b8;
    --temia-bg:       #0f172a;
    --temia-bg-1:     #1e293b;
    --temia-bg-2:     #1e293b;
    --temia-bg-3:     #334155;
    --temia-border:   #334155;
    --temia-border-2: #475569;
    --temia-primary-l: #1e3a8a;
  }
}

/* Reset minimal */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; height: 100%; }
body {
  font-family: var(--temia-font);
  font-size: var(--temia-fs-md);
  color: var(--temia-fg);
  background: var(--temia-bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--temia-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
h1, h2, h3, h4 { margin: 0 0 var(--temia-sp-3); }
h1 { font-size: var(--temia-fs-xl); }
h2 { font-size: 1.25rem; }
p { margin: 0 0 var(--temia-sp-3); }

/* Layout helpers */
.temia-page {
  max-width: 1080px;
  margin: 0 auto;
  padding: var(--temia-sp-6) var(--temia-sp-5);
}
.temia-card {
  background: var(--temia-bg-2);
  border: 1px solid var(--temia-border);
  border-radius: var(--temia-radius-lg);
  padding: var(--temia-sp-5);
  box-shadow: var(--temia-shadow-1);
}
.temia-stack > * + * { margin-top: var(--temia-sp-4); }
.temia-row { display: flex; gap: var(--temia-sp-3); align-items: center; }

/* Login layout */
.temia-login-wrap {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--temia-bg-1), var(--temia-primary-l) 220%);
  padding: var(--temia-sp-5);
}
.temia-login-card {
  width: 100%;
  max-width: 420px;
}
.temia-login-card h1 {
  font-size: 1.4rem;
  margin-bottom: var(--temia-sp-1);
}
.temia-login-card .temia-login-sub {
  color: var(--temia-fg-3);
  font-size: var(--temia-fs-sm);
  margin-bottom: var(--temia-sp-5);
}
.temia-login-debug {
  background: var(--temia-bg-3);
  padding: var(--temia-sp-3);
  border-radius: var(--temia-radius);
  font-family: var(--temia-font-mono);
  font-size: var(--temia-fs-sm);
  margin-top: var(--temia-sp-4);
}

/* Brand */
.temia-brand {
  display: flex;
  align-items: center;
  gap: var(--temia-sp-2);
  font-weight: 700;
  letter-spacing: .02em;
}
.temia-brand__dot {
  width: 28px; height: 28px;
  background: var(--temia-primary);
  border-radius: 8px;
  display: inline-grid; place-items: center;
  color: #fff; font-size: 0.85rem;
}
