/* =====================================================
   Encria — thème sombre émeraude
   ===================================================== */

:root {
  --fond:          #0a0c0b;
  --surface:       rgba(23, 28, 25, 0.72);
  --surface-plein: #161b18;
  --encre:         #e9ece9;
  --encre-doux:    #97a39c;
  --trait:         #2b322d;
  --trait-clair:   #3a423c;
  --emeraude:      #34d399;
  --emeraude-vif:  #6ee7c2;
  --emeraude-fonce:#10b981;
  --emeraude-doux: rgba(52, 211, 153, 0.12);
  --err:           #f87171;
  --err-doux:      rgba(248, 113, 113, 0.13);
  --ok:            #34d399;
  --ombre:         0 8px 30px rgba(0, 0, 0, 0.45);
  --ombre-vert:    0 10px 40px rgba(16, 185, 129, 0.18);
}

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

html, body { min-height: 100%; }

body {
  font-family: -apple-system, "Segoe UI", Roboto, Helvetica, sans-serif;
  background: var(--fond);
  color: var(--encre);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow-x: hidden;
}

/* ---- Fond animé : lueurs émeraude diffuses ---- */
body::before, body::after {
  content: "";
  position: fixed;
  inset: -20%;
  z-index: -1;
  pointer-events: none;
}
body::before {
  background:
    radial-gradient(640px 640px at 18% 22%, rgba(52, 211, 153, 0.22), transparent 60%),
    radial-gradient(720px 720px at 82% 72%, rgba(16, 185, 129, 0.20), transparent 62%),
    radial-gradient(520px 520px at 60% 12%, rgba(110, 231, 194, 0.14), transparent 60%);
  animation: lueurs-a 13s ease-in-out infinite;
}
body::after {
  background:
    radial-gradient(560px 560px at 75% 25%, rgba(45, 212, 167, 0.16), transparent 60%),
    radial-gradient(680px 680px at 25% 80%, rgba(52, 211, 153, 0.16), transparent 62%);
  animation: lueurs-b 19s ease-in-out infinite;
}
@keyframes lueurs-a {
  0%, 100% { opacity: .75; transform: scale(1) translate(0, 0); }
  50%      { opacity: 1;   transform: scale(1.18) translate(2%, -3%); }
}
@keyframes lueurs-b {
  0%, 100% { opacity: .6;  transform: scale(1.1) translate(0, 0); }
  50%      { opacity: .95; transform: scale(1) translate(-3%, 2%); }
}
@media (prefers-reduced-motion: reduce) {
  body::before, body::after { animation: none; }
}

/* ---- Apparitions ---- */
@keyframes apparition {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.apparition {
  opacity: 0;
  animation: apparition .6s cubic-bezier(.2,.7,.2,1) forwards;
  animation-delay: calc(var(--ordre, 0) * 95ms);
}
@media (prefers-reduced-motion: reduce) {
  .apparition { animation: none; opacity: 1; transform: none; }
}

/* ---- Boutons ---- */
button, .lien-bouton {
  font: inherit; cursor: pointer; border: 0; border-radius: 10px;
  font-weight: 600;
  transition: transform .12s ease, box-shadow .18s ease, background .18s ease, filter .18s ease;
}
button:active, .lien-bouton:active { transform: scale(.97); }

.lien-bouton {
  background: var(--emeraude); color: #04140d;
  text-decoration: none; padding: .62rem 1.1rem;
  font-size: .9rem; display: inline-block;
}
.lien-bouton:hover { box-shadow: var(--ombre-vert); filter: brightness(1.08); }

/* ---- Connexion ---- */
.centre {
  min-height: 100vh; display: flex; align-items: center;
  justify-content: center; padding: 1.5rem;
}
.carte-auth {
  background: var(--surface);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border: 1px solid var(--trait);
  border-radius: 20px;
  padding: 2.7rem 2.2rem;
  width: 100%; max-width: 392px;
  box-shadow: var(--ombre), var(--ombre-vert);
}
.logo {
  font-size: 2.05rem; font-weight: 800;
  letter-spacing: -0.03em; text-align: center;
}
.logo .point, .logo-petit .point {
  color: var(--emeraude);
  text-shadow: 0 0 16px rgba(52, 211, 153, .7);
}
.sous-titre {
  text-align: center; color: var(--encre-doux);
  font-size: .92rem; margin: .35rem 0 1.8rem;
}

label {
  display: block; font-size: .8rem; font-weight: 600;
  margin: 1rem 0 .35rem; color: var(--encre-doux);
}
input, select {
  width: 100%; padding: .72rem .85rem;
  border: 1.5px solid var(--trait);
  border-radius: 10px; font-size: 1rem;
  background: rgba(255, 255, 255, 0.04);
  color: var(--encre);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
input::placeholder { color: #5d655f; }
input:focus, select:focus {
  outline: none; border-color: var(--emeraude);
  background: rgba(52, 211, 153, 0.06);
  box-shadow: 0 0 0 4px var(--emeraude-doux);
}
select option { background: var(--surface-plein); }

.carte-auth button, .form-large button {
  width: 100%; margin-top: 1.7rem; padding: .88rem;
  background: var(--emeraude); color: #04140d; font-size: 1rem;
}
.carte-auth button:hover, .form-large button:hover {
  box-shadow: var(--ombre-vert); filter: brightness(1.08);
}

.alerte {
  padding: .78rem .98rem; border-radius: 10px;
  font-size: .9rem; margin-bottom: .5rem;
}
.alerte-err  { background: var(--err-doux); border: 1px solid rgba(248,113,113,.4); color: #fca5a5; }
.alerte-ok   { background: var(--emeraude-doux); border: 1px solid rgba(52,211,153,.4); color: var(--emeraude-vif); }
.alerte-warn { background: rgba(251,191,36,.12); border: 1px solid rgba(251,191,36,.4); color: #fcd34d; }

/* ---- Barre du haut ---- */
.barre {
  background: rgba(13, 16, 14, 0.82);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--trait);
  display: flex; align-items: center; justify-content: space-between;
  padding: .85rem 1.6rem;
  position: sticky; top: 0; z-index: 10;
}
.logo-petit { font-weight: 800; font-size: 1.2rem; letter-spacing: -0.02em; }
.barre nav { display: flex; align-items: center; gap: .9rem; }
.barre-gauche { display: flex; align-items: center; gap: .8rem; }
.barre-droite { display: flex; align-items: center; gap: .9rem; }
.salon-nom {
  font-size: .85rem; color: var(--encre-doux);
  padding-left: .8rem; border-left: 1px solid var(--trait);
}
.user { font-size: .88rem; color: var(--encre-doux); }
.lien-deco {
  color: var(--encre); text-decoration: none;
  font-size: .86rem; font-weight: 600;
  border: 1.5px solid var(--trait); padding: .4rem .85rem;
  border-radius: 8px; transition: border-color .15s ease, background .15s ease;
}
.lien-deco:hover { border-color: var(--emeraude); background: var(--emeraude-doux); }

.menu { display: flex; gap: .25rem; flex-wrap: wrap; }
.menu a {
  text-decoration: none; color: var(--encre-doux);
  font-size: .88rem; font-weight: 600;
  padding: .42rem .8rem; border-radius: 8px;
  transition: background .15s ease, color .15s ease;
}
.menu a:hover, .menu a.actif {
  background: var(--emeraude-doux); color: var(--emeraude-vif);
}

/* ---- Contenu ---- */
.contenu { max-width: 860px; margin: 2.4rem auto; padding: 0 1.5rem; position: relative; }
.contenu h1 { font-size: 1.75rem; letter-spacing: -0.02em; }
.contenu h2 { font-size: 1.2rem; letter-spacing: -0.01em; }
.intro { color: var(--encre-doux); margin: .5rem 0 1.8rem; }
.entete-page {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 1rem; margin-bottom: 1.1rem;
}

/* ---- Cartes statistiques ---- */
.cartes { display: flex; gap: 1rem; flex-wrap: wrap; }
.carte-stat {
  background: var(--surface);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--trait);
  border-radius: 16px; padding: 1.5rem 1.7rem;
  min-width: 185px;
  box-shadow: var(--ombre);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position: relative; overflow: hidden;
}
.carte-stat::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: 3px; background: var(--emeraude);
  box-shadow: 0 0 16px rgba(52, 211, 153, .8);
}
.carte-stat:hover {
  transform: translateY(-5px);
  box-shadow: var(--ombre), var(--ombre-vert);
  border-color: var(--trait-clair);
}
.carte-stat .nombre {
  font-size: 2.3rem; font-weight: 800; letter-spacing: -0.02em;
  display: block; line-height: 1.15;
  color: var(--emeraude);
  text-shadow: 0 0 22px rgba(52, 211, 153, .45);
}
.carte-stat .etiquette { color: var(--encre-doux); font-size: .85rem; }

/* ---- Tableau ---- */
.table {
  width: 100%; border-collapse: collapse;
  background: var(--surface);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--trait);
  border-radius: 14px; overflow: hidden;
  font-size: .92rem; box-shadow: var(--ombre);
}
.table th, .table td {
  text-align: left; padding: .8rem .95rem;
  border-bottom: 1px solid var(--trait);
}
.table th {
  background: rgba(255, 255, 255, 0.03);
  font-size: .74rem; text-transform: uppercase;
  letter-spacing: .04em; color: var(--encre-doux);
}
.table tbody tr { transition: background .12s ease; }
.table tbody tr:hover { background: var(--emeraude-doux); }
.table tr:last-child td { border-bottom: 0; }
.mono { font-family: ui-monospace, Menlo, Consolas, monospace; font-size: .85rem; }
.table .mono strong { color: var(--emeraude-vif); }

/* ---- Badges ---- */
.badge {
  display: inline-block; padding: .2rem .62rem;
  border-radius: 30px; font-size: .75rem; font-weight: 700;
  text-transform: capitalize;
}
.badge-actif, .badge-verifie {
  background: var(--emeraude-doux); color: var(--emeraude-vif);
  border: 1px solid rgba(52,211,153,.35);
}
.badge-essai, .badge-depose, .badge-declare {
  background: rgba(125,211,252,.1); color: #7dd3fc;
  border: 1px solid rgba(125,211,252,.3);
}
.badge-suspendu {
  background: var(--err-doux); color: #fca5a5;
  border: 1px solid rgba(248,113,113,.35);
}

/* ---- Petits boutons ---- */
.btn-petit {
  background: rgba(255,255,255,.07); color: var(--encre);
  border: 1px solid var(--trait);
  padding: .38rem .78rem; border-radius: 7px;
  font-size: .82rem;
}
.btn-petit:hover { border-color: var(--emeraude); color: var(--emeraude-vif); }
.btn-danger:hover { border-color: var(--err); color: #fca5a5; }

/* ---- Blocs ---- */
.bloc-info {
  margin-top: 1.6rem;
  background: var(--surface);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--trait);
  border-left: 3px solid var(--emeraude);
  border-radius: 12px; padding: 1.3rem 1.5rem;
  box-shadow: var(--ombre);
}
.bloc-info h2 { font-size: 1rem; margin-bottom: .35rem; }
.bloc-info p  { color: var(--encre-doux); font-size: .92rem; }

.panneau {
  background: var(--surface);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid var(--trait);
  border-radius: 14px; padding: 1.5rem 1.6rem;
  box-shadow: var(--ombre); margin-bottom: 1.3rem;
}
.panneau h2 { font-size: 1rem; margin-bottom: .6rem; }
.panneau button {
  width: auto; margin-top: 1.2rem; padding: .72rem 1.2rem;
  background: var(--emeraude); color: #04140d; font-size: .92rem;
}
.panneau button:hover { box-shadow: var(--ombre-vert); filter: brightness(1.08); }

.form-large { max-width: 470px; }
.form-large h2 {
  font-size: .82rem; text-transform: uppercase; letter-spacing: .05em;
  color: var(--encre-doux); margin: 1.7rem 0 .3rem;
}
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: .15rem 1.1rem; }
@media (max-width: 560px) { .form-grid { grid-template-columns: 1fr; } }
.hint { font-size: .82rem; color: var(--encre-doux); margin-top: .3rem; }

/* ---- Jauge ---- */
.jauge {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--trait);
  height: 13px; border-radius: 30px; overflow: hidden;
  margin: .6rem 0 .35rem;
}
.jauge-remplie {
  height: 100%;
  background: linear-gradient(90deg, var(--emeraude-fonce), var(--emeraude-vif));
  box-shadow: 0 0 18px rgba(52, 211, 153, .6);
  transition: width .9s cubic-bezier(.2,.7,.2,1);
}

code {
  background: var(--emeraude-doux); color: var(--emeraude-vif);
  padding: .1rem .35rem; border-radius: 5px; font-size: .88rem;
}

strong { color: #f3f5f3; }

@media (max-width: 540px) {
  .contenu { margin: 1.5rem auto; }
  .table { font-size: .85rem; }
  .table th, .table td { padding: .6rem .55rem; }
}

/* ---- Espace praticien ---- */
.form-grid .pleine { grid-column: 1 / -1; }
input[readonly] { opacity: .6; cursor: not-allowed; }

.lien-bouton.sobre {
  background: rgba(255,255,255,.06); color: var(--encre);
  border: 1px solid var(--trait); margin-left: .4rem;
}
.lien-bouton.sobre:hover { border-color: var(--emeraude); color: var(--emeraude-vif); filter: none; }

.code-bloc {
  text-align: center;
  background: var(--surface);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(52,211,153,.3);
  border-radius: 18px;
  padding: 2rem 1.5rem;
  margin-bottom: 1.3rem;
  box-shadow: var(--ombre), var(--ombre-vert);
}
.code-label {
  font-size: .78rem; text-transform: uppercase; letter-spacing: .12em;
  color: var(--encre-doux);
}
.code-valeur {
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 3.6rem; font-weight: 800; letter-spacing: .18em;
  color: var(--emeraude);
  text-shadow: 0 0 30px rgba(52,211,153,.6);
  margin: .35rem 0 .6rem;
  animation: code-pulse 2.4s ease-in-out infinite;
}
@keyframes code-pulse {
  0%, 100% { text-shadow: 0 0 26px rgba(52,211,153,.45); }
  50%      { text-shadow: 0 0 40px rgba(52,211,153,.85); }
}
@media (prefers-reduced-motion: reduce) { .code-valeur { animation: none; } }
.code-note {
  font-size: .92rem; color: var(--encre-doux);
  max-width: 420px; margin: 0 auto;
}

/* ---- Graphe d'activité ---- */
.graphe-zone { position: relative; height: 320px; margin-top: .5rem; }
@media (max-width: 540px) { .graphe-zone { height: 260px; } }
