/* ============================================================
   BAES WIKI — Hoja de estilos owo
   ============================================================ */

/* ============================================================
   1. VARIABLES BASE
   ============================================================ */
:root {
  --bg:        #0e0c0b;
  --bg2:       #161210;
  --bg3:       #1e1916;
  --border:    #2e2825;
  --accent:    #f34b38;
  --accent2:   #8b2020;
  --text:      #faecdf;
  --text-muted:#ac9f99;
  --text-dim:  #918782;
  --highlight: #e8d5c4;
  --tag-bg:    #231f1d;

  /* Color de acento del personaje activo lalala */
  --char-color:        var(--accent);
  --char-color-dim:    #1a0808;
  --char-color-border: var(--accent2);
  --char-color-text:   var(--highlight);

  a {
    color: var(--accent);
  }
}

/* ============================================================
   2. TEMAS POR PERSONAJE
   ============================================================ */

/* Joey — rojo base, no variables extra */
body.theme-joey {
  --char-color:        #c0392b;
  --char-color-dim:    #1a0808;
  --char-color-border: #8b2020;
  --char-color-text:   #e8d5c4;
}

/* Alfonso — rojo base + dorado */
body.theme-alfonso {
  --char-color:        #c0392b;
  --char-color-dim:    #1a0808;
  --char-color-border: #8b2020;
  --char-color-text:   #e8d5c4;
  --alfonso-gold:      #d6a11b;
  --alfonso-gold-dim:  #1a1205;
  --alfonso-gold-border:#774400;
}

/* Eliza — carmesí oscuro + marfil */
body.theme-eliza {
  --char-color:        #8b1a1a;
  --char-color-dim:    #3a1010;
  --char-color-border: #5a1818;
  --char-color-text:   #f0ece4;
  --eliza-ivory:       #f0ece4;
  --eliza-pearl:       #c8c0b8;
  --eliza-gold:        #9a8060;
}

/* Celi — verde bosque */
body.theme-celi {
  --char-color:        #4a7a4a;
  --char-color-dim:    #1a2a1a;
  --char-color-border: #2e4a2e;
  --char-color-text:   #88b888;
  --celi-amber:        #a08040;
  --celi-amber-dim:    #1a1508;
  --celi-amber-border: #3a2e10;
}

/* Lucas — verde neón */
body.theme-lucas {
  --char-color:        #1e6e3a;
  --char-color-dim:    #0a1a10;
  --char-color-border: #1a4a28;
  --char-color-text:   #5de89a;
  --lucas-green:       #39e07a;
}

/* Amadeus — rosa pálido */
body.theme-amadeus {
  --char-color:        #8b2020;
  --char-color-dim:    #1a0e0e;
  --char-color-border: #4a2828;
  --char-color-text:   #d4a8a8;
  --ama-ivory:         #e8e0d4;
  --ama-rose:          #c8a0a0;
}

/* ============================================================
   3. RESET Y BASE
   ============================================================ */
* { margin: 0; padding: 0; box-sizing: border-box; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Crimson Pro', Georgia, serif;
  font-size: 17px;
  line-height: 1.7;
  min-height: 100vh;
}

p { margin-bottom: 12px; }

/* ============================================================
   4. EFECTOS DE FONDO ESPECÍFICOS POR PERSONAJE
   ============================================================ */

/* Eliza */
body.theme-eliza::after {
  content: '';
  position: fixed;
  top: 0; right: 0;
  width: 320px; height: 320px;
  background-image: radial-gradient(circle, #2a2018 1px, transparent 1px);
  background-size: 18px 18px;
  opacity: 0.18;
  pointer-events: none;
  z-index: 0;
}

/* Celi */
body.theme-celi::after {
  content: '';
  position: fixed;
  bottom: 0; left: 0;
  width: 280px; height: 280px;
  background: radial-gradient(ellipse at bottom left, #1a2a1a 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
  opacity: 0.6;
}

/* Lucas */
body.theme-lucas::after {
  content: '';
  position: fixed;
  top: -80px; right: -80px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(57,224,122,0.06) 0%, transparent 65%);
  pointer-events: none;
  z-index: 0;
}

/* ============================================================
   5. HEADER Y NAVEGACIÓN
   ============================================================ */
.site-header {
  border-bottom: 1px solid var(--border);
  padding: 12px 32px;
  display: flex;
  align-items: center;
  gap: 24px;
  background: var(--bg2);
  position: sticky;
  top: 0;
  z-index: 100;
}

.site-logo {
  font-family: 'Space Mono', monospace;
  font-size: 13px;
  color: var(--accent);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  text-decoration: none;
}

.site-nav {
  display: flex;
  gap: 20px;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.08em;
  align-items: center;
}

.site-nav a {
  color: var(--text-muted);
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.2s;
}

.site-nav a:hover { color: var(--text); }

.breadcrumb {
  margin: 1em;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 0.05em;
}

.breadcrumb span { color: var(--text-muted);}

/* ============================================================
   6. LAYOUT
   ============================================================ */

.flex-breadc-button {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.character-grid {
display: grid;
grid-template-columns: repeat(3, 1fr);
grid-template-rows: repeat(5, 1fr);
grid-column-gap: 20px;
grid-row-gap: 20px;
}

.div1 { grid-area: 1 / 1 / 2 / 2; }
.div2 { grid-area: 1 / 2 / 2 / 3; }
.div3 { grid-area: 1 / 3 / 2 / 4; }
.div4 { grid-area: 2 / 1 / 3 / 2; }
.div5 { grid-area: 2 / 2 / 3 / 3; }
.div6 { grid-area: 2 / 3 / 3 / 4; }

.character-grid img {
  height: 200px;
  width: 100%;
  object-fit: cover;
  display: block;
}

.wiki-main,
.site-nav,
.wiki-sidebar {
  min-width: 0;
}

.wiki-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 0;
  max-width: 1100px;
  margin: 0 auto;
  padding: 40px 24px;
  align-items: start;
  position: relative;
  z-index: 1;
}

.wiki-layout.narrow {
  max-width: 960px;
  grid-template-columns: 1fr 260px;
}

.wiki-main  { padding-right: 40px;}
.wiki-sidebar {top: 72px; }

/* ============================================================
   7. ENCABEZADO DEL PERSONAJE
   ============================================================ */
.page-title-area {
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}

.character-role {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--char-color-text);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.page-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 42px;
  font-weight: 700;
  color: var(--highlight);
  line-height: 1.1;
  margin-bottom: 6px;
}

.page-title em {
  font-style: italic;
  color: var(--text-muted);
  font-size: 28px;
}

.character-quote {
  margin-top: 14px;
  padding-left: 16px;
  border-left: 2px solid var(--char-color-border);
  font-size: 17px;
  font-style: italic;
  color: var(--text-muted);
  line-height: 1.5;
}

.character-quote cite {
  display: block;
  font-size: 13px;
  font-family: 'Space Mono', monospace;
  font-style: normal;
  color: var(--text-dim);
  margin-top: 4px;
  letter-spacing: 0.05em;
}

.character-desc {
  margin-top: 14px;
  font-size: 16px;
  color: var(--text);
  line-height: 1.8;
}

/* ============================================================
   8. TABLA DE CONTENIDOS
   ============================================================ */
.toc {
  background: var(--bg3);
  border: 1px solid var(--border);
  padding: 16px 20px;
  margin-bottom: 32px;
  display: inline-block;
  min-width: 220px;
}

.toc-title {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.toc ol { list-style: none; counter-reset: toc; }

.toc ol li {
  counter-increment: toc;
  font-size: 14px;
  padding: 2px 0;
}

.toc ol li::before {
  content: counter(toc) ". ";
  color: var(--char-color-text);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
}

.toc ol li a {
  color: var(--text-muted);
  text-decoration: none;
  transition: color 0.2s;
}

.toc ol li a:hover { color: var(--highlight); }

/* ============================================================
   9. SECCIONES Y ENCABEZADOS
   ============================================================ */
.wiki-section {
  margin-bottom: 36px;
  scroll-margin-top: 80px;
  animation: fadeUp 0.4s ease both;
}

.wiki-section:nth-child(1) { animation-delay: 0.05s; }
.wiki-section:nth-child(2) { animation-delay: 0.10s; }
.wiki-section:nth-child(3) { animation-delay: 0.15s; }
.wiki-section:nth-child(4) { animation-delay: 0.20s; }
.wiki-section:nth-child(5) { animation-delay: 0.25s; }

.section-heading {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  color: var(--highlight);
  border-bottom: 1px solid var(--border);
  padding-bottom: 6px;
  margin-bottom: 16px;
  display: flex;
  align-items: baseline;
  gap: 10px;
}

.section-heading .section-num {
  font-family: 'Space Mono', monospace;
  font-size: 12px;
  color: var(--char-color-text);
  font-weight: 400;
}

.subsection-heading {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  font-style: italic;
  color: var(--text);
  margin: 20px 0 10px;
}

.wiki-divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 32px 0;
}

.character-list img {
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

/* ============================================================
   10. TAGS / ETIQUETAS
   ============================================================ */
.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.tag {
  background: var(--tag-bg);
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  padding: 3px 10px;
  letter-spacing: 0.05em;
  transition: border-color 0.2s, color 0.2s;
}

.tag:hover          { border-color: var(--char-color-border); color: var(--text); }
.tag.accent         { border-color: var(--accent2); color: var(--accent); }
.tag.char           { border-color: var(--char-color-border); color: var(--char-color-text); }
/* Alias de conveniencia */
.tag.green          { border-color: var(--char-color-border); color: var(--char-color-text); }
.tag.ivory          { border-color: var(--char-color-border); color: var(--char-color-text); }
.tag.gold           { border-color: var(--alfonso-gold-border, #5a4a1a); color: var(--alfonso-gold, #b8860b); }
.tag.amber          { border-color: var(--celi-amber-border, #3a2e10); color: var(--celi-amber, #a08040); }

/* ============================================================
   11. GRILLA DE ESTADOS DE ÁNIMO
   ============================================================ */
.mood-grid {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  font-size: 14px;
}

.mood-row-label {
  background: var(--bg3);
  padding: 8px 12px;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--char-color-text);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  display: flex;
  align-items: center;
}

.mood-row-val {
  background: var(--bg2);
  padding: 8px 14px;
  color: var(--text);
  display: flex;
  align-items: center;
}

/* ============================================================
   12. RELACIONES
   ============================================================ */
.relation-item {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  align-items: start;
}

.relation-item:last-child { border-bottom: none; }

.relation-name {
  font-family: 'Space Mono', monospace;
  font-size: 12px;
  color: var(--char-color-text);
  letter-spacing: 0.05em;
  padding-top: 2px;
}

.relation-desc { font-size: 14px; color: var(--text); line-height: 1.6; }

/* ============================================================
   13. CAJAS DE ARCO NARRATIVO
   ============================================================ */
.arc-box {
  background: var(--bg3);
  border-left: 3px solid var(--char-color);
  padding: 14px 18px;
  margin-top: 12px;
  font-size: 15px;
}

.arc-box strong {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--char-color-text);
  display: block;
  margin-bottom: 4px;
}

/* ============================================================
   14. TRIVIA
   ============================================================ */
.trivia-list { list-style: none; padding: 0; }

.trivia-list li {
  padding: 6px 0 6px 18px;
  position: relative;
  font-size: 15px;
  border-bottom: 1px solid var(--border);
}

.trivia-list li:last-child { border-bottom: none; }

.trivia-list li::before {
  content: '—';
  position: absolute;
  left: 0;
  color: var(--char-color-text);
  font-family: 'Space Mono', monospace;
}

/* ============================================================
   15. SIDEBAR — INFOBOX
   ============================================================ */
.infobox {
  background: var(--bg2);
  border: 1px solid var(--border);
  font-size: 14px;
  overflow: hidden;
}

.infobox-header {
  background: var(--char-color-dim);
  border-bottom: 1px solid var(--char-color-border);
  padding: 10px 14px;
  font-family: 'Playfair Display', serif;
  font-size: 15px;
  font-weight: 700;
  color: var(--char-color-text);
  text-align: center;
  letter-spacing: 0.03em;
}

.infobox-image {
  width: 100%;
  aspect-ratio: 3/4;
  background: var(--bg3);
  display: flex;
  align-items: center;
  justify-content: center;
  border-bottom: 1px solid var(--border);
  position: relative;
  overflow: hidden;
}

.infobox-image-corner {
  position: absolute;
  width: 20px;
  height: 20px;
  border-color: var(--char-color-border);
  border-style: solid;
  opacity: 0.7;
  z-index: 2;
}

.infobox-image-corner.tl { top: 8px;    left: 8px;   border-width: 1px 0 0 1px; }
.infobox-image-corner.tr { top: 8px;    right: 8px;  border-width: 1px 1px 0 0; }
.infobox-image-corner.bl { bottom: 8px; left: 8px;   border-width: 0 0 1px 1px; }
.infobox-image-corner.br { bottom: 8px; right: 8px;  border-width: 0 1px 1px 0; }

.infobox-image-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  color: var(--text-dim);
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  z-index: 1;
}

.infobox-image-placeholder svg {
  width: 48px;
  height: 48px;
  opacity: 0.25;
}

.infobox-caption {
  padding: 8px 14px;
  font-style: italic;
  font-size: 13px;
  color: var(--text-muted);
  text-align: center;
  border-bottom: 1px solid var(--border);
  background: var(--bg3);
}

.infobox table  { width: 100%; border-collapse: collapse; }
.infobox tr     { border-bottom: 1px solid var(--border); }
.infobox tr:last-child { border-bottom: none; }

.infobox th {
  padding: 7px 10px 7px 14px;
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  font-weight: 400;
  text-align: left;
  background: var(--bg3);
  white-space: nowrap;
  width: 90px;
}

.infobox td {
  padding: 7px 12px 7px 8px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.4;
}

/* Variantes de valor en la infobox — todas usan el color del personaje */
.infobox td.char-val,
.infobox td.accent-val,
.infobox td.green-val,
.infobox td.rose-val,
.infobox td.ivory-val {
  color: var(--char-color-text);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
}

.infobox td.gold-val {
  color: var(--alfonso-gold, #b8860b);
  font-family: 'Space Mono', monospace;
  font-size: 12px;
}

.infobox-section-label {
  background: var(--border);
  padding: 4px 14px;
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
}

/* ============================================================
   16. SIDEBAR — CAJAS EXTRA
   ============================================================ */
.tropes-box,
.song-box {
  margin-top: 12px;
  background: var(--bg2);
  border: 1px solid var(--border);
  padding: 14px;
}

.tropes-box-title,
.song-box-title {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  margin-bottom: 10px;
}

.trope-pill {
  display: inline-block;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-muted);
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  padding: 4px 8px;
  margin: 3px 3px 0 0;
  letter-spacing: 0.04em;
  transition: all 0.2s;
}

.trope-pill:hover { border-color: var(--char-color-border); color: var(--char-color-text); }

.song-name {
  font-family: 'Playfair Display', serif;
  font-size: 14px;
  font-style: italic;
  color: var(--text);
  margin-bottom: 2px;
}

.song-artist {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--text-muted);
}

.song-empty {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--text-dim);
  font-style: italic;
}

/* ============================================================
   17. BADGES Y ETIQUETAS DE ENTIDAD
   ============================================================ */
.entity-badge,
.status-badge {
  display: inline-block;
  background: var(--char-color-dim);
  border: 1px solid var(--char-color-border);
  color: var(--char-color-text);
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  padding: 3px 8px;
  letter-spacing: 0.08em;
  line-height: 1.4;
  margin-top: 2px;
}

/* status-badge tiene color propio (Alfonso) */
.status-badge {
  background: var(--alfonso-gold-dim, #1a1205);
  border-color: var(--alfonso-gold-border, #5a3a10);
  color: var(--alfonso-gold, #c8860b);
}


/* --- Alfonso: nota de autor --- */
.author-note {
  background: #1a1510;
  border: 1px solid #3a2e1a;
  border-left: 3px solid var(--alfonso-gold, #b8860b);
  padding: 12px 16px;
  margin: 20px 0;
  font-size: 14px;
  font-style: italic;
  color: #9a8560;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.author-note-icon {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--alfonso-gold, #b8860b);
  letter-spacing: 0.1em;
  white-space: nowrap;
  padding-top: 2px;
}

/* ============================================================
   18. COMPONENTES ESPECÍFICOS POR PERSONAJE
   ============================================================ */

/* --- Alfonso: decoración de naipes en la imagen --- */
body.theme-alfonso .infobox-image::after {
  content: '♠ ♣ ♥ ♦ ♠ ♣ ♥ ♦ ♠ ♣ ♥ ♦';
  position: absolute;
  bottom: 10px;
  left: 0; right: 0;
  text-align: center;
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 0.3em;
  pointer-events: none;
}

/* --- Alfonso: timeline --- */
.timeline {
  position: relative;
  padding-left: 28px;
  margin-top: 8px;
}

.timeline::before {
  content: '';
  position: absolute;
  left: 6px; top: 6px; bottom: 6px;
  width: 1px;
  background: var(--border);
}

.timeline-item {
  position: relative;
  margin-bottom: 20px;
}

.timeline-item::before {
  content: '';
  position: absolute;
  left: -24px; top: 7px;
  width: 7px; height: 7px;
  background: var(--char-color-border);
  border: 1px solid var(--char-color-text);
}

.timeline-label {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--char-color-text);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  margin-bottom: 4px;
}

.timeline-text { font-size: 15px; color: var(--text); line-height: 1.65; }

/* --- Alfonso: grilla psicológica --- */
.psych-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 8px;
}

.psych-cell         { background: var(--bg2); padding: 10px 14px; }
.psych-cell-label   { font-family: 'Space Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--text-muted); margin-bottom: 4px; }
.psych-cell-val     { font-size: 14px; color: var(--text); line-height: 1.5; }

/* --- Eliza: número de serie --- */
.serial-box {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: #110c0c;
  border: 1px solid var(--char-color-border);
  padding: 10px 18px;
  margin: 18px 0;
  font-family: 'Space Mono', monospace;
}

.serial-label  { font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; color: var(--text-dim); }
.serial-value  { font-size: 18px; letter-spacing: 0.3em; color: var(--char-color); }
.serial-note   { font-size: 11px; color: var(--text-dim); font-style: italic; margin-left: 4px; }

/* --- Eliza: tarjeta de origen (Candela) --- */
.origin-card {
  background: #110d0d;
  border: 1px solid var(--char-color-border);
  margin: 20px 0;
  overflow: hidden;
}

.origin-card-header {
  background: var(--char-color-dim);
  padding: 8px 16px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.origin-card-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: #c08080;
}

.origin-card-name {
  font-family: 'Playfair Display', serif;
  font-size: 15px;
  color: var(--eliza-ivory, #f0ece4);
  font-style: italic;
}

.origin-card-body {
  padding: 14px 18px;
  font-size: 15px;
  color: var(--text);
  line-height: 1.75;
  border-top: 1px solid var(--char-color-border);
}

.origin-card-body em { color: var(--eliza-pearl, #c8c0b8); font-style: italic; }

.origin-card-serial {
  padding: 8px 18px;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--text-dim);
  border-top: 1px solid var(--char-color-border);
  letter-spacing: 0.08em;
}

/* --- Eliza: pregunta central --- */
.central-question {
  background: #0f0c0c;
  border: 1px solid var(--char-color-border);
  padding: 20px 24px;
  margin: 20px 0;
  text-align: center;
}

.central-question p {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  font-style: italic;
  color: var(--eliza-pearl, #c8c0b8);
  line-height: 1.5;
  margin: 0;
}

.central-question-sub {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--text-dim);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-top: 10px !important;
  font-style: normal !important;
}

/* --- Eliza: aviso de nombre --- */
.name-warning {
  margin: 0;
  padding: 8px 14px;
  background: var(--char-color-dim);
  border-top: 1px solid var(--char-color-border);
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  color: #c08080;
  letter-spacing: 0.08em;
}

/* --- Eliza: patrón en imagen sidebar --- */
body.theme-eliza .infobox-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, #2a1a1a 1px, transparent 1px);
  background-size: 14px 14px;
  opacity: 0.5;
}

/* --- Celi: barra de silencio --- */
.silence-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 20px;
  padding: 12px 0;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}

.silence-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  white-space: nowrap;
}

.silence-dots  { display: flex; gap: 5px; }

.silence-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--border);
}

.silence-dot.active { background: var(--char-color-text); }

.silence-quote {
  font-family: 'Space Mono', monospace;
  font-size: 13px;
  color: var(--text-muted);
  font-style: italic;
  letter-spacing: 0.05em;
}

/* --- Celi: grilla de contraste --- */
.contrast-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin: 16px 0;
}

.contrast-cell         { background: var(--bg2); padding: 14px 16px; }
.contrast-cell-label   { font-family: 'Space Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em; margin-bottom: 8px; }
.contrast-cell-label.exterior { color: var(--text-dim); }
.contrast-cell-label.interior { color: var(--char-color-text); }
.contrast-cell-val     { font-size: 14px; color: var(--text); line-height: 1.6; }

/* --- Celi: caja de hobby --- */
.destacado-box {
  background: var(--bg3);
  border: 1px solid var(--border);
  padding: 18px 20px;
  margin: 16px 0;
  display: flex;
  gap: 20px;
  align-items: flex-start;
}

.destacado-icon { font-size: 32px; line-height: 1; flex-shrink: 0; opacity: 0.7; }
.destacado-text-title { font-family: 'Space Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em; color: var(--text-dim); margin-bottom: 6px; }
.destacado-text-body  { font-size: 15px; color: var(--text); line-height: 1.65; }

/* --- Celi: caja de información redactada --- */
.redacted-box {
  background: #0c0c0c;
  border: 1px solid var(--border);
  padding: 14px 18px;
  margin: 16px 0;
  font-family: 'Space Mono', monospace;
  font-size: 13px;
  color: var(--text-dim);
  line-height: 1.8;
  letter-spacing: 0.03em;
}

.redacted {
  background: var(--text-dim);
  color: transparent;
  border-radius: 1px;
  user-select: none;
  padding: 0 2px;
}

.redacted-note {
  display: block;
  margin-top: 10px;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  font-style: italic;
}

/* --- Celi: caja del silbido --- */
.whistle-box {
  margin-top: 12px;
  background: var(--char-color-dim);
  border: 1px solid var(--char-color-border);
  padding: 12px 14px;
}

.whistle-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--char-color-text);
  margin-bottom: 6px;
  opacity: 0.7;
}

.whistle-desc { font-size: 13px; color: var(--text-muted); font-style: italic; line-height: 1.5; }

/* --- Celi: 
body.theme-celi .infobox-image::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at bottom, #1a2a1a 0%, transparent 65%);
} --- */

/* --- Lucas: barra de stats --- */
.stats-bar {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin-top: 20px;
}

.stat-cell  { background: var(--char-color-dim); padding: 12px 14px; text-align: center; }

.stat-value {
  font-family: 'Space Mono', monospace;
  font-size: 18px;
  color: var(--char-color-text);
  letter-spacing: 0.05em;
  display: block;
  margin-bottom: 3px;
}

.stat-label {
  font-family: 'Space Mono', monospace;
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
}

/* --- Lucas: caja de incidente --- */
.incident-box {
  background: #0c0a08;
  border: 1px solid #3a2e1a;
  margin: 16px 0;
  overflow: hidden;
}

.incident-header {
  background: #1a1208;
  padding: 8px 16px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid #3a2e1a;
}

.incident-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: #806040;
}

.incident-status {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--char-color-text);
  background: var(--char-color-dim);
  border: 1px solid var(--char-color-border);
  padding: 2px 8px;
}

.incident-body {
  padding: 14px 18px;
  font-size: 14px;
  color: var(--text);
  line-height: 1.75;
  font-family: 'Space Mono', monospace;
}

.incident-body .detail {
  color: var(--text-muted);
  font-size: 12px;
  display: block;
  margin-bottom: 6px;
}

.incident-body .result {
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #3a2e1a;
  font-style: italic;
  color: var(--char-color-text);
  font-family: 'Crimson Pro', serif;
  font-size: 15px;
}

/* --- Lucas: grilla de memoria --- */
.memory-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  margin: 16px 0;
}

.memory-cell         { background: var(--bg2); padding: 14px 16px; }
.memory-label        { font-family: 'Space Mono', monospace; font-size: 10px; text-transform: uppercase; letter-spacing: 0.15em; margin-bottom: 10px; }
.memory-label.recuerda    { color: var(--char-color-text); }
.memory-label.no-recuerda { color: var(--text-dim); }

.memory-item {
  font-size: 14px;
  color: var(--text);
  padding: 3px 0;
  border-bottom: 1px solid var(--border);
  line-height: 1.5;
}

.memory-item:last-child { border-bottom: none; }

.memory-item.lost {
  color: var(--text-dim);
  text-decoration: line-through;
  text-decoration-color: var(--text-dim);
}

/* --- Lucas: caja de seguidores --- */
.followers-box {
  margin-top: 12px;
  background: var(--char-color-dim);
  border: 1px solid var(--char-color-border);
  padding: 14px;
  text-align: center;
}

.followers-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  margin-bottom: 8px;
}

.followers-count {
  font-family: 'Space Mono', monospace;
  font-size: 26px;
  color: var(--char-color-text);
  letter-spacing: 0.05em;
  display: block;
  animation: glowPulse 2.5s ease-in-out infinite;
}

.followers-sublabel {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 4px;
  letter-spacing: 0.08em;
}

/* --- Lucas: burbujas flotantes --- */
.bubble {
  position: absolute;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 35%, rgba(57,224,122,0.25), rgba(57,224,122,0.05));
  border: 1px solid rgba(57,224,122,0.15);
  animation: floatBubble linear infinite;
}

.bubble:nth-child(1) { width: 14px; height: 14px; left: 20%; animation-duration: 5s; animation-delay: 0s; }
.bubble:nth-child(2) { width: 8px;  height: 8px;  left: 55%; animation-duration: 7s; animation-delay: 1s; }
.bubble:nth-child(3) { width: 18px; height: 18px; left: 70%; animation-duration: 6s; animation-delay: 2s; }
.bubble:nth-child(4) { width: 6px;  height: 6px;  left: 35%; animation-duration: 4s; animation-delay: 0.5s; }
.bubble:nth-child(5) { width: 10px; height: 10px; left: 80%; animation-duration: 8s; animation-delay: 3s; }

/* --- Amadeus: imagen cuadrada y emoji --- */
body.theme-amadeus .infobox-image {
  aspect-ratio: 1/1;
  font-size: 72px;
  line-height: 1;
}

/* --- 

.rabbit-emoji {
  position: relative;
  z-index: 1;
  filter: grayscale(0.3);
  animation: breathe 3s ease-in-out infinite;
}
 --- */

/* --- Amadeus: caja de opinión --- */
.amadeus-opinion {
  margin-top: 12px;
  background: var(--char-color-dim);
  border: 1px solid var(--char-color-border);
  padding: 16px;
  text-align: center;
}

.amadeus-opinion-label {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text-dim);
  margin-bottom: 10px;
}

.amadeus-opinion-text {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  font-style: italic;
  color: var(--char-color-text);
  letter-spacing: 0.05em;
}

.amadeus-opinion-sub {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  color: var(--text-dim);
  margin-top: 6px;
  letter-spacing: 0.08em;
}

/* --- Amadeus: grilla de opiniones --- */
.opinions-grid {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  font-size: 14px;
  margin-top: 8px;
}

.op-name {
  background: var(--bg3);
  padding: 10px 12px;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  color: var(--char-color-text);
  letter-spacing: 0.05em;
  display: flex;
  align-items: flex-start;
  padding-top: 12px;
}

.op-val {
  background: var(--bg2);
  padding: 10px 14px;
  color: var(--text);
  line-height: 1.6;
}

/* ============================================================
   18. ANIMACIONES
   ============================================================ */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes glowPulse {
  0%, 100% { text-shadow: 0 0 8px rgba(57,224,122,0.3); }
  50%       { text-shadow: 0 0 18px rgba(57,224,122,0.6); }
}

@keyframes floatBubble {
  0%   { transform: translateY(120%) scale(0.8); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 0.6; }
  100% { transform: translateY(-20px) scale(1.1); opacity: 0; }
}

@keyframes breathe {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.04); }
}

/* ============================================================
   19. RESPONSIVE
   ============================================================ */
@media (max-width: 768px) {
  .wiki-layout {
    grid-template-columns: 1fr;
  }

  .wiki-main {
    padding-right: 1em;
  }

  .wiki-sidebar {
    position: static;
    margin-top: 32px;   /* better than margin-bottom here */
  }

  .page-title {
    font-size: 30px;
  }

  .psych-grid,
  .contrast-grid,
  .stats-bar,
  .memory-grid {
    grid-template-columns: 1fr;
  }
}