/* ════════════════════════════════════════════════════════════════════
   theme.css — Le Cœur de la Reine
   Ambiance médiévale 1600 : parchemin, encre, dorures, sceaux de cire.
   Partagé par joueur.html et admin.html
   ════════════════════════════════════════════════════════════════════ */

:root {
  /* Parchemin & encre */
  --parchment:      #ece0c4;
  --parchment-2:    #e3d4b0;
  --parchment-deep: #d8c69c;
  --vellum:         #f4ead2;
  --ink:            #2a2018;
  --ink-soft:       #5a4a36;
  --ink-faint:      #8a7553;

  /* Couleurs héraldiques */
  --burgundy:       #6e1423;
  --burgundy-deep:  #4a0d18;
  --royal:          #1d3557;
  --royal-deep:     #122236;
  --gold:           #b8860b;
  --gold-bright:    #d4af37;
  --gold-pale:      #e7cd7a;
  --emerald:        #3a6b3a;
  --rubis:          #9b1b30;

  /* États */
  --alive:   #3a6b3a;
  --alert:   #b8860b;
  --danger:  #8b2222;
  --dead:    #5a4a36;

  /* Surfaces sombres (panneaux bois/cuir) */
  --leather:      #2b2119;
  --leather-2:    #352a1f;
  --wood:         #1f1812;

  --shadow:   0 10px 30px rgba(40, 25, 10, 0.35);
  --shadow-sm: 0 3px 10px rgba(40, 25, 10, 0.25);

  --serif: 'EB Garamond', 'Iowan Old Style', Georgia, serif;
  --display: 'Cinzel', 'Trajan Pro', Georgia, serif;
  --mono: 'Spline Sans Mono', 'JetBrains Mono', ui-monospace, monospace;
}

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

html, body { height: 100%; }

body {
  font-family: var(--serif);
  color: var(--ink);
  background-color: #cdb98a;
  /* Texture parchemin : grain + ombrage de bords */
  background-image:
    radial-gradient(ellipse at 20% 10%, rgba(255,250,235,0.6), transparent 55%),
    radial-gradient(ellipse at 85% 90%, rgba(120,90,40,0.18), transparent 50%),
    repeating-linear-gradient(115deg, rgba(120,90,40,0.025) 0 2px, transparent 2px 5px),
    repeating-linear-gradient(34deg, rgba(120,90,40,0.02) 0 3px, transparent 3px 7px),
    linear-gradient(160deg, var(--vellum), var(--parchment) 45%, var(--parchment-deep));
  -webkit-font-smoothing: antialiased;
  font-size: 18px;
  line-height: 1.5;
}

/* Titres romains gravés */
.display { font-family: var(--display); letter-spacing: 0.06em; }
h1, h2, h3 { font-family: var(--display); font-weight: 600; color: var(--ink); }

/* Filets dorés réutilisables */
.rule-gold {
  height: 2px; border: 0;
  background: linear-gradient(90deg, transparent, var(--gold) 12%, var(--gold-bright) 50%, var(--gold) 88%, transparent);
}
.rule-thin {
  height: 1px; border: 0;
  background: linear-gradient(90deg, transparent, var(--ink-faint), transparent);
}

/* Ornement losange (séparateurs) */
.lozenge {
  display: inline-block; width: 8px; height: 8px;
  background: var(--gold); transform: rotate(45deg);
  box-shadow: 0 0 0 2px rgba(184,134,11,0.25);
}

/* Cartouche : encadré parchemin avec liseré doré */
.cartouche {
  background:
    linear-gradient(160deg, rgba(255,250,235,0.55), rgba(216,198,156,0.25));
  border: 1px solid var(--gold);
  box-shadow: inset 0 0 0 3px rgba(244,234,210,0.5), var(--shadow-sm);
  border-radius: 3px;
}

/* Panneau sombre (cuir / bois — pour barres latérales techniques) */
.panel-dark {
  background:
    linear-gradient(160deg, var(--leather-2), var(--leather));
  color: var(--parchment);
  border: 1px solid #000;
  box-shadow: inset 0 1px 0 rgba(255,220,150,0.08), var(--shadow);
}

/* Sceau de cire (badge circulaire) */
.wax-seal {
  display: inline-flex; align-items: center; justify-content: center;
  width: 60px; height: 60px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, #b83048, var(--burgundy) 55%, var(--burgundy-deep));
  color: var(--gold-pale);
  font-family: var(--display); font-size: 20px;
  box-shadow: 0 4px 10px rgba(0,0,0,0.4), inset 0 2px 6px rgba(255,255,255,0.15), inset 0 -4px 8px rgba(0,0,0,0.4);
  border: 1px solid rgba(0,0,0,0.3);
}

/* Boutons */
.btn {
  font-family: var(--display); font-size: 15px; letter-spacing: 0.05em;
  cursor: pointer; border-radius: 3px; padding: 12px 22px;
  border: 1px solid var(--gold-deep, #8a6508);
  transition: transform 0.12s ease, box-shadow 0.12s ease, filter 0.12s ease;
}
.btn-primary {
  background: linear-gradient(160deg, var(--burgundy), var(--burgundy-deep));
  color: var(--gold-pale);
  border-color: var(--burgundy-deep);
  box-shadow: inset 0 1px 0 rgba(255,200,150,0.25), var(--shadow-sm);
}
.btn-primary:hover:not(:disabled) { transform: translateY(-1px); filter: brightness(1.1); }
.btn-ghost {
  background: rgba(255,250,235,0.4); color: var(--ink);
  border: 1px solid var(--ink-faint);
}
.btn-ghost:hover:not(:disabled) { background: rgba(255,250,235,0.7); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* Champs */
.field {
  font-family: var(--serif); font-size: 18px; color: var(--ink);
  background: rgba(255,250,235,0.7);
  border: 1px solid var(--ink-faint);
  border-radius: 3px; padding: 12px 16px; width: 100%;
}
.field:focus { outline: none; border-color: var(--gold); box-shadow: 0 0 0 3px rgba(184,134,11,0.2); }
.field::placeholder { color: var(--ink-faint); font-style: italic; }

/* Pastilles de statut */
.dot { display: inline-block; width: 9px; height: 9px; border-radius: 50%; vertical-align: middle; }
.dot.alive  { background: var(--alive);  box-shadow: 0 0 6px rgba(58,107,58,0.7); }
.dot.alert  { background: var(--alert);  box-shadow: 0 0 6px rgba(184,134,11,0.7); }
.dot.danger { background: var(--danger); box-shadow: 0 0 6px rgba(139,34,34,0.7); }
.dot.dead   { background: var(--dead); }

/* Scrollbars discrètes */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: rgba(120,90,40,0.08); }
::-webkit-scrollbar-thumb { background: rgba(110,80,40,0.45); border-radius: 5px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: rgba(110,80,40,0.7); background-clip: padding-box; }

/* Utilitaires */
.mono { font-family: var(--mono); font-size: 13px; }
.tag {
  display: inline-block; font-family: var(--mono); font-size: 11px;
  padding: 2px 7px; border-radius: 3px; letter-spacing: 0.03em;
  background: rgba(110,20,35,0.1); color: var(--burgundy);
  border: 1px solid rgba(110,20,35,0.25);
}
.muted { color: var(--ink-soft); }
.faint { color: var(--ink-faint); }
