:root {
  --fondo: #1b1813;
  --panel: #262019;
  --panel2: #2f2820;
  --borde: #4a3f30;
  --texto: #ece3d4;
  --tenue: #b3a489;
  --acento: #b5402e;     /* rojo D&D */
  --acento2: #c8a45a;    /* dorado */
  --ok: #3f7d4f;
  --peligro: #8c2f24;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  font-family: "Segoe UI", system-ui, sans-serif;
  background: var(--fondo);
  color: var(--texto);
  line-height: 1.5;
}

/* --- Barra superior --- */
.barra {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: .7rem 1.2rem;
  background: var(--panel); border-bottom: 2px solid var(--acento);
}
.marca { font-size: 1.2rem; font-weight: 700; color: var(--acento2); text-decoration: none; }
.barra nav { display: flex; align-items: center; gap: 1rem; }
.barra nav a { color: var(--texto); text-decoration: none; }
.barra nav a:hover { color: var(--acento2); }
.rol { color: var(--tenue); font-size: .85rem; }

.contenido { max-width: 980px; margin: 0 auto; padding: 1.5rem 1.2rem 3rem; }

h1 { color: var(--acento2); margin-top: 0; }
h2 { color: var(--acento2); border-bottom: 1px solid var(--borde); padding-bottom: .3rem; }
.sub, .meta, .nota, .vacio { color: var(--tenue); }
.nota { font-size: .82rem; font-style: italic; }
a { color: var(--acento2); }

/* --- Avisos flash --- */
.aviso { padding: .6rem 1rem; border-radius: 6px; margin-bottom: 1rem; }
.aviso-ok { background: rgba(63,125,79,.25); border: 1px solid var(--ok); }
.aviso-warn { background: rgba(181,64,46,.2); border: 1px solid var(--acento); }

/* --- Selección de rol --- */
.seleccion { text-align: center; padding-top: 2rem; }
.tarjetas-rol { display: flex; gap: 1.5rem; justify-content: center; flex-wrap: wrap; margin-top: 2rem; }
.tarjeta-rol {
  width: 260px; padding: 1.5rem; background: var(--panel); border: 1px solid var(--borde);
  border-radius: 10px; text-decoration: none; color: var(--texto); transition: .15s;
}
.tarjeta-rol:hover { border-color: var(--acento2); transform: translateY(-3px); }
.tarjeta-rol .emoji { font-size: 2.5rem; }
.tarjeta-rol h2 { border: 0; }

/* --- Grillas de personajes --- */
.grilla-personajes { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px,1fr)); gap: 1rem; }
.tarjeta-personaje {
  display: block; padding: 1rem; background: var(--panel); border: 1px solid var(--borde);
  border-radius: 8px; text-decoration: none; color: var(--texto);
}
.tarjeta-personaje:hover { border-color: var(--acento2); }
.tarjeta-personaje h2 { border: 0; margin: 0 0 .3rem; }

/* --- Formularios --- */
.formulario fieldset { border: 1px solid var(--borde); border-radius: 8px; margin-bottom: 1.2rem; }
.formulario legend { color: var(--acento2); padding: 0 .4rem; }
.campos { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px,1fr)); gap: .8rem; }
.campos-caracteristicas { grid-template-columns: repeat(6, 1fr); }
label { display: flex; flex-direction: column; gap: .25rem; font-size: .9rem; color: var(--tenue); }
input {
  padding: .4rem .5rem; background: var(--panel2); border: 1px solid var(--borde);
  border-radius: 5px; color: var(--texto); font-size: 1rem;
}
input:focus { outline: none; border-color: var(--acento2); }

/* --- Botones --- */
.acciones { display: flex; gap: .6rem; align-items: center; flex-wrap: wrap; }
.btn {
  display: inline-block; padding: .5rem .9rem; border-radius: 6px; border: 1px solid var(--borde);
  background: var(--panel2); color: var(--texto); text-decoration: none; cursor: pointer; font-size: .95rem;
}
.btn:hover { border-color: var(--acento2); }
.btn-principal { background: var(--acento); border-color: var(--acento); color: #fff; }
.btn-peligro { background: var(--peligro); border-color: var(--peligro); color: #fff; }
.acciones form { margin: 0; }

/* --- Hoja de personaje --- */
.hoja-cabecera { display: flex; justify-content: space-between; align-items: flex-start; gap: 1rem; flex-wrap: wrap; }
.resumen { display: flex; gap: 1rem; flex-wrap: wrap; margin: 1.2rem 0; }
.dato {
  flex: 1; min-width: 110px; background: var(--panel); border: 1px solid var(--borde);
  border-radius: 8px; padding: .8rem; text-align: center;
}
.dato .num { display: block; font-size: 1.6rem; font-weight: 700; color: var(--acento2); }
.dato .etiq { font-size: .78rem; color: var(--tenue); }
.dato-pg .num { color: var(--ok); }

.dos-columnas { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
@media (max-width: 720px) { .dos-columnas { grid-template-columns: 1fr; } .campos-caracteristicas { grid-template-columns: repeat(3,1fr); } }

.grilla-caract { display: grid; grid-template-columns: repeat(3,1fr); gap: .7rem; }
.caract {
  background: var(--panel); border: 1px solid var(--borde); border-radius: 8px;
  padding: .6rem; text-align: center; position: relative;
}
.caract .sigla { font-size: .75rem; color: var(--tenue); }
.caract .mod { display: block; font-size: 1.5rem; font-weight: 700; color: var(--acento2); }
.caract .valor {
  position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%);
  background: var(--panel2); border: 1px solid var(--borde); border-radius: 12px;
  padding: 0 .5rem; font-size: .8rem;
}

.lista-mods { list-style: none; padding: 0; margin: 0 0 .5rem; }
.lista-mods li {
  display: flex; justify-content: space-between; padding: .35rem .2rem;
  border-bottom: 1px solid var(--borde);
}
.lista-mods .mod { color: var(--acento2); font-weight: 600; }
.dot { display: inline-block; width: 11px; height: 11px; border-radius: 50%; border: 1px solid var(--tenue); vertical-align: middle; margin-right: .2rem; }
.dot.lleno { background: var(--acento2); border-color: var(--acento2); }
.dot.experto { background: var(--acento); border-color: var(--acento); box-shadow: 0 0 0 2px var(--acento2); }

/* --- Inventario --- */
.campos-monedas { grid-template-columns: repeat(5, 1fr) auto; align-items: end; }
.campos-monedas label small { color: var(--tenue); font-weight: normal; }
label.check { flex-direction: row; align-items: center; gap: .4rem; }
.dato.sobrecarga .num { color: var(--acento); }

.contenedor { background: var(--panel); border: 1px solid var(--borde); border-radius: 8px; padding: .8rem 1rem; margin-bottom: 1rem; }
.contenedor.sobre { border-color: var(--acento); }
.cont-cab { display: flex; align-items: center; gap: .7rem; }
.cont-cab strong { color: var(--acento2); font-size: 1.05rem; }
.cont-cab form { margin: 0 0 0 auto; }
.tag { font-size: .8rem; color: var(--tenue); background: var(--panel2); border: 1px solid var(--borde); border-radius: 12px; padding: .1rem .6rem; }

.tabla-items { margin-top: .6rem; }
.tabla-items td, .tabla-items th { padding: .35rem .5rem; }
.inline-form { margin: 0; }
.mini-num { width: 60px; padding: .2rem .3rem; }
.btn-mini { padding: .15rem .5rem; font-size: .85rem; }

.agregar-cont { margin-top: .5rem; }
.agregar-cont summary { cursor: pointer; color: var(--acento2); padding: .4rem 0; }

/* --- Tabla point-buy (creación) --- */
.tabla-pointbuy td, .tabla-pointbuy th { text-align: center; padding: .4rem .5rem; }
.tabla-pointbuy td:first-child, .tabla-pointbuy th:first-child { text-align: left; }
.tabla-pointbuy .pb-base { width: 64px; text-align: center; }
.tabla-pointbuy .pb-total { font-weight: 700; color: var(--acento2); font-size: 1.1rem; }
.tabla-pointbuy .pb-bonus { color: var(--ok); }
.tabla-pointbuy .pb-mod { color: var(--acento2); }

/* --- Rasgos y dotes --- */
.lista-rasgos { list-style: none; padding: 0; margin: 0; }
.lista-rasgos li { padding: .6rem .8rem; margin-bottom: .5rem; background: var(--panel); border: 1px solid var(--borde); border-radius: 8px; position: relative; }
.lista-rasgos li strong { color: var(--acento2); }
.lista-rasgos li p { margin: .35rem 0 0; color: var(--texto); font-size: .92rem; }
.lista-rasgos .conj-borrar { position: absolute; top: .5rem; right: .6rem; }

/* --- Conjuros --- */
.ranuras { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px,1fr)); gap: .6rem; margin-bottom: 1rem; }
.ranura { background: var(--panel); border: 1px solid var(--borde); border-radius: 8px; padding: .5rem .7rem; }
.ranura.vacia { opacity: .55; }
.ran-nivel { font-weight: 600; color: var(--acento2); }
.ran-puntos { display: flex; flex-wrap: wrap; gap: .25rem; margin: .35rem 0; min-height: 14px; }
.punto { width: 14px; height: 14px; border-radius: 50%; background: var(--acento2); border: 1px solid var(--acento2); }
.punto.gastado { background: transparent; }
.ran-sin { color: var(--tenue); }
.ran-ctrl { display: flex; align-items: center; gap: .4rem; }
.ran-cuenta { font-size: .85rem; color: var(--tenue); margin-left: auto; }

.lista-conjuros { list-style: none; padding: 0; margin: 0; }
.conjuro { display: flex; align-items: center; gap: .6rem; padding: .35rem .2rem; border-bottom: 1px solid var(--borde); }
.conjuro.preparado { background: rgba(200,164,90,.08); }
.chk-prep { background: none; border: none; color: var(--acento2); font-size: 1.2rem; cursor: pointer; padding: 0; }
.conj-nombre { font-weight: 500; }
.conj-escuela { font-size: .8rem; color: var(--tenue); }
.conj-borrar { margin-left: auto; }
.inline-form { margin: 0; display: inline; }

/* --- Ilustraciones --- */
.ilustracion { display: block; max-width: 100%; border-radius: 10px; border: 1px solid var(--borde); margin: 0 0 1rem; }
.miniatura { width: 64px; height: 44px; object-fit: cover; border-radius: 5px; border: 1px solid var(--borde); vertical-align: middle; }

/* --- Ficha de monstruo --- */
.ficha-texto { white-space: pre-wrap; line-height: 1.55; background: var(--panel); border: 1px solid var(--borde); border-radius: 8px; padding: 1rem; }

/* --- Tabla DM --- */
.tabla { width: 100%; border-collapse: collapse; margin-top: 1rem; }
.tabla th, .tabla td { padding: .55rem .6rem; border-bottom: 1px solid var(--borde); text-align: left; }
.tabla th { color: var(--acento2); }
