/* ============================================================
   personajes.css — Sistema de Personajes HEX ROL
   Paleta: oro (#d4af37) + violeta (#7c4daa) + neutros oscuros
   ============================================================ */

:root {
    --gold:        #d4af37;
    --gold-dim:    #a8881e;
    --gold-faint:  rgba(212, 175, 55, 0.18);
    --gold-border: rgba(212, 175, 55, 0.28);

    --violet:      #7c4daa;
    --violet-dim:  #4a2870;
    --violet-faint:rgba(124, 77, 170, 0.18);
    --violet-border:rgba(124, 77, 170, 0.35);

    --bg:    #08080e;
    --bg2:   #111120;
    --bg3:   #1a1a2a;
    --bg4:   #242436;

    --text:  #e8e8f8;
    --dim:   #b0b0d0;
    --faint: rgba(196, 196, 212, 0.24);

    --border: rgba(255, 255, 255, 0.20);

    --font-display: 'Cinzel', serif;
    --font-body:    'Inter', system-ui, sans-serif;

    --radius:  6px;
    --radius-lg: 10px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body { background: var(--bg); color: var(--text); font-family: var(--font-body); line-height: 1.5; min-height: 100vh; }

/* ── Aislar paneles externos para que no hereden color/font de body ── */
#pobj-panel, #pobj-panel *,
#pobj-overlay,
#pobj-op-modal, #pobj-op-modal * {
    color: revert;
    font-family: revert;
}

/* ── NAV ─────────────────────────────────────────────────── */
.nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 52px;
    padding: 0 20px;
    background: var(--bg2);
    border-bottom: 1px solid var(--gold-border);
    position: sticky;
    top: 0;
    z-index: 100;
}
.nav-left  { display: flex; align-items: center; gap: 16px; }
.nav-right { display: flex; align-items: center; gap: 10px; }

.nav-back {
    font-family: var(--font-display);
    font-size: 0.75em;
    color: var(--gold-dim);
    text-decoration: none;
    letter-spacing: 0.5px;
    transition: color 0.2s;
}
.nav-back:hover { color: var(--gold); }

.tabs { display: flex; gap: 2px; }
.tab-btn {
    padding: 6px 16px;
    background: transparent;
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--dim);
    font-family: var(--font-body);
    font-size: 0.85em;
    cursor: pointer;
    transition: all 0.2s;
}
.tab-btn:hover  { color: var(--text); }
.tab-btn.active { color: var(--gold); border-bottom-color: var(--gold); }

.btn-op {
    padding: 5px 14px;
    background: var(--violet-faint);
    border: 1px solid var(--violet-border);
    border-radius: var(--radius);
    color: var(--violet);
    font-size: 0.8em;
    cursor: pointer;
    transition: all 0.2s;
}
.btn-op:hover { background: var(--violet-dim); color: #fff; }

/* ── LOADER ──────────────────────────────────────────────── */
.loader {
    padding: 40px 24px;
    text-align: center;
}
.loader-text { font-size: 0.85em; color: var(--dim); display: block; margin-bottom: 10px; }
.loader-track { width: 240px; height: 2px; background: var(--bg4); border-radius: 1px; margin: 0 auto; overflow: hidden; }
.loader-fill  { height: 100%; width: 0%; background: var(--gold); transition: width 0.4s; border-radius: 1px; }

/* ── PAGES ───────────────────────────────────────────────── */
.page { display: none; padding: 20px; }
.page.active { display: block; }

/* ── TOOLBAR ─────────────────────────────────────────────── */
.page-toolbar {
    display: flex;
    align-items: center;
    gap: 14px;
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.filtros { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
.filtro-sep { color: var(--dim); padding: 0 4px; font-size: 0.8em; }

.filtro-btn {
    padding: 5px 12px;
    border-radius: 20px;
    border: 1px solid var(--border);
    background: transparent;
    color: var(--dim);
    font-size: 0.8em;
    cursor: pointer;
    transition: all 0.18s;
}
.filtro-btn:hover { border-color: var(--gold-border); color: var(--text); }
.filtro-btn.active { border-color: var(--gold-border); color: var(--gold); background: var(--gold-faint); }

.input-search {
    flex: 1;
    min-width: 160px;
    max-width: 280px;
    padding: 6px 12px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-size: 0.85em;
}
.input-search:focus { outline: none; border-color: var(--gold-border); }

/* ── GRID DE PERSONAJES ──────────────────────────────────── */
.pj-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
    gap: 12px;
}

/* ── Nueva card compacta ───────────────────────────────────── */
.pj-card {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 14px 14px 10px;
    cursor: pointer;
    transition: border-color 0.2s, box-shadow 0.2s, transform 0.18s;
    position: relative;
    display: flex;
    flex-direction: column;
    gap: 0;
}
.pj-card:hover {
    border-color: var(--gold-border);
    box-shadow: 0 0 18px rgba(212,175,55,0.07);
    transform: translateY(-2px);
}
.pj-inactivo { opacity: 0.42; }

/* Header */
.pjc-header { display: flex; align-items: center; gap: 10px; margin-bottom: 10px; }
.pjc-avatar {
    width: 44px; height: 44px; flex-shrink: 0;
    border-radius: 50%;
    border: 1px solid var(--gold-border);
    background: var(--bg3);
    display: flex; align-items: center; justify-content: center;
    overflow: hidden;
}
.pjc-info { flex: 1; min-width: 0; }
.pjc-name {
    font-family: var(--font-display);
    font-size: 0.88em;
    color: var(--gold);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 4px;
}
.pjc-tags { display: flex; gap: 3px; flex-wrap: wrap; }
.pjc-actions { display: flex; gap: 3px; opacity: 0; transition: opacity 0.18s; flex-shrink: 0; }
.pj-card:hover .pjc-actions { opacity: 1; }

/* Mid: VEX + pushes */
.pjc-mid { display: flex; flex-direction: column; gap: 5px; margin-bottom: 8px; min-height: 0; }

.pjc-vex-row { display: flex; align-items: center; gap: 6px; margin-bottom: 5px; }
.pjc-vex-label { font-size: 0.64em; color: var(--violet); letter-spacing: 0.5px; width: 26px; text-align: right; }
.pjc-vex-track { flex: 1; height: 3px; background: var(--bg4); border-radius: 2px; overflow: hidden; }
.pjc-vex-fill  { height: 100%; background: var(--violet); border-radius: 2px; transition: width 0.5s cubic-bezier(0.4,0,0.2,1); }
.pjc-vex-val   { font-size: 0.67em; color: #9060c0; min-width: 60px; text-align: right; font-variant-numeric: tabular-nums; }
.pjc-sep       { color: var(--dim); margin: 0 1px; }

.pjc-pushes { display: flex; gap: 5px; margin-bottom: 5px; }
.pjc-push { font-size: 0.62em; padding: 2px 7px; border-radius: 9px; border: 1px solid; font-weight: 500; }
.pjc-push-vex   { background: rgba(124,77,170,0.1); border-color: rgba(124,77,170,0.35); color: #9060c0; }
.pjc-push-gua   { background: rgba(212,175,55,0.08); border-color: rgba(212,175,55,0.25); color: var(--gold-dim); }

/* HEX bar row */
.pjc-hex-bar {
    display: flex;
    align-items: center;
    gap: 7px;
    padding: 6px 0 2px;
    border-top: 1px solid rgba(255,255,255,0.05);
    margin-top: auto;
}
.pjc-hex-mini {
    width: 22px; height: 20px;
    flex-shrink: 0;
    transition: filter 0.2s;
}
.pjc-hex-bar:hover .pjc-hex-mini { filter: brightness(1.4); }
.pjc-hex-num {
    font-family: var(--font-display);
    font-size: 1em;
    font-weight: 700;
    letter-spacing: 0.5px;
    line-height: 1;
}
.pjc-hex-lbl {
    font-size: 0.52em;
    color: var(--dim);
    letter-spacing: 2px;
    text-transform: uppercase;
    flex: 1;
}

/* Expand button */
.pjc-expand-btn {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 50%;
    width: 26px; height: 26px;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    color: var(--dim);
    font-size: 0.75em;
    transition: all 0.15s;
    flex-shrink: 0;
}
.pjc-expand-btn:hover { border-color: var(--gold-border); color: var(--gold); background: rgba(212,175,55,0.07); }
.pjc-arrow { display: block; transition: transform 0.2s; }

/* Collapsible detail */
.pjc-detail {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.3s cubic-bezier(0.4,0,0.2,1), padding 0.3s;
    padding: 0;
    border-top: 1px solid transparent;
}
.pjc-detail.open {
    max-height: 280px;
    padding-top: 10px;
    border-top-color: rgba(255,255,255,0.05);
    margin-top: 6px;
}

.pjc-vida-row { display: flex; align-items: center; gap: 6px; margin-bottom: 4px; }
.pjc-vida-lbl { font-size: 0.64em; width: 36px; text-align: right; font-weight: 600; }
.pjc-vida-xy  { font-size: 0.68em; min-width: 50px; text-align: right; color: var(--text); font-variant-numeric: tabular-nums; }

.pjc-afin-section { margin-top: 8px; }
.pjc-afin-row { display: flex; align-items: center; gap: 5px; margin-bottom: 3px; }
.pjc-afin-lbl { width: 26px; font-size: 0.64em; text-align: right; color: var(--dim); }
.pjc-afin-mayor { color: var(--gold-dim) !important; }
.pjc-afin-track { flex: 1; height: 4px; background: var(--bg4); border-radius: 2px; overflow: hidden; }
.pjc-afin-fill { height: 100%; background: rgba(255,255,255,0.2); border-radius: 2px; }
.pjc-fill-mayor { background: var(--gold); }
/* Barra segmentada 4 colores: B · Hz · Ext · Alt */
.pjc-afin-seg { display: flex; gap: 1px; height: 4px; border-radius: 2px; overflow: hidden; }
.pjc-seg { height: 100%; transition: width 0.3s; }
.pjc-seg-b     { background: #6496ff; }
.pjc-seg-hz    { background: #50c88c; }
.pjc-seg-ext   { background: #d4af37; }
.pjc-seg-alt   { background: #e08080; }
.pjc-seg-empty { background: rgba(255,255,255,0.06); }
.pjc-afin-val { width: 22px; font-size: 0.64em; text-align: right; color: var(--dim); }

.empty-state { padding: 60px 20px; text-align: center; color: var(--dim); grid-column: 1/-1; }

/* ── Tags (usados en cards y panel lateral) ─────────────────── */
.tag { padding: 2px 7px; border-radius: 3px; font-size: 0.68em; font-weight: 500; border: 1px solid; }
.tag-jugador { background: var(--violet-faint); border-color: var(--violet-border); color: #a07fd4; }
.tag-npc     { background: var(--gold-faint);   border-color: var(--gold-border);   color: var(--gold-dim); }
.tag-activo  { background: var(--gold-faint);   border-color: var(--gold-border);   color: var(--gold-dim); }
.tag-inactivo{ background: transparent; border-color: var(--border); color: var(--dim); }
.tag-dim     { background: transparent; border-color: var(--border); color: var(--dim); }

/* ── Icon buttons (OP actions) ──────────────────────────────── */
.icon-btn { width: 26px; height: 26px; border-radius: var(--radius); border: 1px solid var(--border); background: var(--bg3); color: var(--dim); cursor: pointer; font-size: 0.85em; display: flex; align-items: center; justify-content: center; transition: all 0.18s; }
.icon-btn:hover { border-color: var(--gold-border); color: var(--gold); }
.icon-btn-danger:hover { border-color: rgba(180,60,60,0.5); color: #c46666; }

/* ── Barras segmentadas (panel pj, hexcast inv) ─────────────── */
.seg-bar-wrap { display: flex; gap: 2px; width: 100%; height: 5px; border-radius: 2px; overflow: hidden; }
.seg-bar-wrap.seg-over .seg-cell { border: 1px solid rgba(255,100,100,0.5); }
.seg-cell { flex: 1; height: 100%; border-radius: 1px; transition: background 0.3s; }
.seg-vida.seg-on    { background: #c8404a; }
.seg-vida.seg-off   { background: rgba(200,64,74,0.12); }
.seg-azul.seg-on    { background: #4ab3e8; }
.seg-azul.seg-off   { background: rgba(74,179,232,0.1); }
.seg-guarda.seg-on  { background: var(--gold); opacity: 0.85; }
.seg-guarda.seg-off { background: rgba(212,175,55,0.1); }
.recurso-xy { min-width: 50px; text-align: right; font-size: 0.73em; color: var(--text); font-variant-numeric: tabular-nums; }
.xy-sep { color: var(--dim); margin: 0 1px; }

/* ── Legacy (panel pj stats) ────────────────────────────────── */
.afin-bar-row { display: flex; align-items: center; gap: 5px; margin-bottom: 3px; }
.afin-bar-label { width: 28px; font-size: 0.68em; text-align: right; color: var(--dim); }
.afin-bar-label.mayor { color: var(--gold-dim); }
.afin-bar-track { flex: 1; height: 2px; background: var(--bg4); border-radius: 1px; overflow: hidden; }
.afin-seg { height: 100%; float: left; }
.afin-seg-base { background: var(--gold); opacity: 0.7; }
.afin-seg-bf   { background: #3ecf6e; opacity: 0.7; }
.afin-seg-ef   { background: #60a8e8; opacity: 0.7; }
.afin-seg-hz   { background: #b080e0; opacity: 0.6; }
.afin-bar-val { width: 20px; font-size: 0.68em; text-align: right; color: var(--dim); }
.val-gold { color: var(--gold-dim); }
.push-mini { display: flex; gap: 5px; margin: 4px 0; }
.push-mini-item { font-size: 0.63em; padding: 2px 7px; border-radius: 9px; border: 1px solid; }
.push-mini-vex   { background: rgba(124,77,170,0.1); border-color: rgba(124,77,170,0.35); color: #9060c0; }
.push-mini-guarda{ background: rgba(212,175,55,0.08); border-color: rgba(212,175,55,0.25); color: var(--gold-dim); }

/* ── PANEL LATERAL ───────────────────────────────────────── */
.panel-lateral {
    position: fixed; top: 52px; right: 0; bottom: 0;
    width: 440px; max-width: 100vw;
    background: var(--bg2);
    border-left: 1px solid var(--gold-border);
    z-index: 200;
    transform: translateX(100%);
    transition: transform 0.28s ease;
    overflow-y: auto;
}
.panel-lateral.open { transform: translateX(0); }

.panel-overlay {
    display: none;
    position: fixed; inset: 52px 0 0 0;
    z-index: 190;
}
.panel-lateral.open ~ .panel-overlay { display: block; }

.panel-header {
    position: sticky; top: 0;
    background: var(--bg2);
    border-bottom: 1px solid var(--gold-border);
    padding: 14px 16px;
    display: flex; justify-content: space-between; align-items: center;
    z-index: 10;
}
.panel-nombre {
    font-family: var(--font-display);
    font-size: 1em;
    color: var(--gold);
}
.panel-header-actions { display: flex; gap: 8px; align-items: center; }
.panel-close {
    font-size: 1.4em; line-height: 1;
    background: none; border: none;
    color: var(--dim); cursor: pointer;
}
.panel-close:hover { color: var(--text); }
.panel-body { padding: 16px; }

/* Detalle sections */
.det-section { margin-bottom: 20px; }
.det-section-title {
    font-size: 0.68em;
    letter-spacing: 1.5px;
    color: var(--dim);
    border-bottom: 1px solid var(--border);
    padding-bottom: 5px;
    margin-bottom: 12px;
}

.det-calc-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
}
.det-calc-item {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 10px 12px;
}
.det-calc-label { font-size: 0.72em; color: var(--dim); margin-bottom: 4px; }
.det-calc-xy {
    display: flex; align-items: center; gap: 4px;
    margin-bottom: 6px;
}
.det-xy-x { font-size: 1.2em; font-weight: 500; color: var(--gold); }
.det-xy-sep { color: var(--dim); }
.det-xy-y { color: var(--dim); font-size: 0.95em; }
.det-calc-formula { font-size: 0.65em; color: var(--dim); font-family: monospace; }

.det-regen-row {
    display: flex; justify-content: space-between;
    font-size: 0.85em;
    padding: 5px 0;
    border-bottom: 1px solid var(--faint);
    color: var(--dim);
}
.det-regen-val { color: var(--gold); font-weight: 500; }

.det-stat-row {
    display: flex; justify-content: space-between; align-items: center;
    padding: 6px 0;
    border-bottom: 1px solid var(--faint);
}
.det-stat-label { font-size: 0.85em; color: var(--dim); }
.det-stat-ctrl  { display: flex; align-items: center; gap: 6px; }
.det-stat-val   { min-width: 32px; text-align: center; font-weight: 500; color: var(--gold); }
.det-stat-sub   { font-size: 0.7em; color: var(--dim); text-align: center; }

.ctrl-btn {
    padding: 3px 8px;
    background: var(--bg4);
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--dim);
    cursor: pointer;
    font-size: 0.8em;
    transition: all 0.18s;
}
.ctrl-btn:hover { border-color: var(--gold-border); color: var(--gold); }
.ctrl-btn-sm { padding: 2px 6px; font-size: 0.75em; }

/* ── FORMULARIO ──────────────────────────────────────────── */
.form-wrap {
    max-width: 680px;
    margin: 0 auto;
}
.form-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 24px;
}
.form-titulo {
    font-family: var(--font-display);
    font-size: 1.1em;
    font-weight: 400;
    color: var(--gold);
}
.form-section { margin-bottom: 24px; }
.form-section-title {
    font-size: 0.72em;
    letter-spacing: 1.5px;
    color: var(--gold-dim);
    border-bottom: 1px solid var(--gold-border);
    padding-bottom: 6px;
    margin-bottom: 14px;
}
.form-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
    gap: 12px;
}
.field { display: flex; flex-direction: column; gap: 5px; }
.field label { font-size: 0.8em; color: var(--dim); }

.input-base {
    padding: 8px 10px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--text);
    font-size: 0.88em;
    font-family: var(--font-body);
    width: 100%;
    transition: border-color 0.18s;
}
.input-base:focus { outline: none; border-color: var(--gold-border); }
.input-sm { max-width: 180px; }
.field-note { font-size: 0.78em; color: var(--dim); font-weight: 400; }
.field-label-inline { font-size: 0.85em; color: var(--dim); }

.toggle-row {
    display: flex; gap: 20px; flex-wrap: wrap;
    margin-top: 14px; align-items: center;
}
.toggle-group { display: flex; align-items: center; gap: 8px; font-size: 0.88em; color: var(--text); }

/* Toggle switch */
.toggle {
    width: 34px; height: 18px;
    border-radius: 9px;
    background: var(--bg4);
    border: 1px solid var(--border);
    cursor: pointer;
    position: relative;
    transition: all 0.2s;
}
.toggle::after {
    content: '';
    position: absolute;
    top: 2px; left: 2px;
    width: 12px; height: 12px;
    border-radius: 50%;
    background: var(--dim);
    transition: transform 0.2s, background 0.2s;
}
.toggle.on { background: var(--gold-faint); border-color: var(--gold-border); }
.toggle.on::after { transform: translateX(16px); background: var(--gold); }

/* Afinidades en formulario */
.afin-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
}
.afin-field { display: flex; flex-direction: column; gap: 4px; }
.afin-field label { font-size: 0.78em; color: var(--dim); }
.input-afin {
    text-align: center;
    color: var(--gold);
    font-size: 1em;
    font-weight: 500;
}

.afin-preview {
    margin-top: 12px;
    padding: 8px 12px;
    background: var(--bg3);
    border-radius: var(--radius);
    border: 1px solid var(--border);
    font-size: 0.8em;
    color: var(--dim);
}
.afin-preview strong { color: var(--gold); }

.form-footer {
    display: flex; justify-content: flex-end;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}

/* Buttons */
.btn-primary {
    padding: 9px 22px;
    background: var(--gold-faint);
    border: 1px solid var(--gold-border);
    border-radius: var(--radius);
    color: var(--gold);
    font-family: var(--font-display);
    font-size: 0.82em;
    cursor: pointer;
    letter-spacing: 0.5px;
    transition: all 0.2s;
}
.btn-primary:hover { background: var(--gold); color: #000; }

.btn-secondary {
    padding: 8px 18px;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--dim);
    font-size: 0.82em;
    cursor: pointer;
    transition: all 0.2s;
}
.btn-secondary:hover { border-color: var(--violet-border); color: var(--violet); }

.btn-ghost {
    padding: 6px 14px;
    background: transparent;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--dim);
    font-size: 0.8em;
    cursor: pointer;
    transition: all 0.2s;
}
.btn-ghost:hover { color: var(--text); border-color: rgba(255,255,255,0.15); }

/* ── FÓRMULAS ────────────────────────────────────────────── */
.formulas-wrap {
    max-width: 760px;
    margin: 0 auto;
}

/* Pool de variables */
.var-pool {
    background: var(--bg2);
    border: 1px solid var(--violet-border);
    border-radius: var(--radius-lg);
    padding: 16px;
    margin-bottom: 24px;
}
.var-pool-label { font-size: 0.75em; color: var(--dim); margin-bottom: 10px; }
.var-pool-grid {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin-bottom: 10px;
}

.var-chip {
    padding: 4px 10px;
    border-radius: 4px;
    border: 1px solid;
    font-size: 0.78em;
    font-family: monospace;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.15s;
}
.var-chip-total {
    border-color: var(--gold-border);
    color: var(--gold-dim);
    background: var(--gold-faint);
}
.var-chip-total:hover { background: var(--gold); color: #000; }
.var-chip-base {
    border-color: var(--violet-border);
    color: #a07fd4;
    background: var(--violet-faint);
}
.var-chip-base:hover { background: var(--violet); color: #fff; }
.var-chip-hechizos {
    border-color: var(--border);
    color: var(--dim);
    background: var(--bg3);
}
.var-chip-hechizos:hover { border-color: var(--gold-border); color: var(--gold-dim); }

.var-pool-legend {
    display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
}
.legend-item { cursor: default; pointer-events: none; }

/* Bloques de fórmulas */
.formulas-block {
    background: var(--bg2);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 20px;
    margin-bottom: 16px;
}
.formulas-block-title {
    font-family: var(--font-display);
    font-size: 0.82em;
    color: var(--gold-dim);
    letter-spacing: 0.5px;
    margin-bottom: 16px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--gold-border);
}
.formulas-help { font-size: 0.78em; color: var(--dim); margin-bottom: 14px; }

.formula-item { margin-bottom: 16px; }
.formula-item-header {
    display: flex; justify-content: space-between; align-items: center;
    margin-bottom: 6px;
}
.formula-item-label { font-size: 0.85em; color: var(--text); }
.formula-aplica { cursor: default; }
.formula-aplica-sel {
    padding: 3px 8px;
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: 4px;
    color: var(--dim);
    font-size: 0.75em;
    cursor: pointer;
}

.formula-input-row { display: flex; gap: 8px; align-items: center; }
.formula-input {
    flex: 1;
    padding: 7px 10px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    color: var(--gold);
    font-family: monospace;
    font-size: 0.85em;
    transition: border-color 0.18s;
}
.formula-input:focus { outline: none; border-color: var(--gold-border); }

.formula-preview {
    margin-top: 5px;
    font-size: 0.75em;
    color: var(--dim);
}
.formula-preview strong { color: var(--gold); }
.prev-pj { color: var(--violet); margin-right: 4px; font-style: italic; }

.formula-actions {
    display: flex; gap: 10px; justify-content: flex-end;
    margin-top: 16px;
    padding-top: 14px;
    border-top: 1px solid var(--border);
}

/* Preview completo */
.preview-box {
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px 14px;
    font-size: 0.82em;
    line-height: 2;
}
.prev-line { display: flex; align-items: center; gap: 10px; }
.prev-label { color: var(--dim); min-width: 180px; }
.prev-val { color: var(--gold); font-weight: 500; min-width: 60px; }
.prev-expr { color: var(--dim); font-family: monospace; font-size: 0.9em; opacity: 0.6; }
.prev-separator {
    border-top: 1px solid var(--border);
    margin: 6px 0;
}

/* ── SYNC BTN ─────────────────────────────────────────────── */
.btn-sync {
    position: fixed; bottom: 20px; right: 20px;
    padding: 11px 20px;
    background: var(--violet-faint);
    border: 1px solid var(--violet-border);
    border-radius: var(--radius);
    color: var(--violet);
    font-family: var(--font-display);
    font-size: 0.8em;
    cursor: pointer;
    letter-spacing: 0.5px;
    z-index: 300;
    transition: all 0.2s;
}
.btn-sync:hover { background: var(--violet); color: #fff; }

/* ── TOAST ───────────────────────────────────────────────── */
.toast {
    position: fixed; bottom: 72px; left: 50%; transform: translateX(-50%);
    padding: 10px 20px;
    border-radius: var(--radius);
    font-size: 0.85em;
    font-weight: 500;
    z-index: 500;
    pointer-events: none;
}
.toast-ok    { background: var(--bg3); border: 1px solid var(--gold-border); color: var(--gold); }
.toast-error { background: var(--bg3); border: 1px solid rgba(180,60,60,0.5); color: #c47070; }

/* ── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar       { width: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--bg4); border-radius: 2px; }

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media (max-width: 600px) {
    .panel-lateral { width: 100vw; }
    .pj-grid { grid-template-columns: 1fr; }
    .afin-grid { grid-template-columns: repeat(2, 1fr); }
    .det-calc-grid { grid-template-columns: 1fr; }
    .form-grid { grid-template-columns: 1fr; }
}

/* ── BARRAS DE AFINIDAD SEGMENTADAS ─────────────────────────── */
.afin-bar-track {
    flex: 1;
    height: 5px;
    background: var(--bg4);
    border-radius: 3px;
    overflow: hidden;
    display: flex;
}
.afin-seg {
    height: 100%;
    transition: width 0.4s;
    min-width: 0;
}
.afin-seg-base { background: var(--gold); }
.afin-seg-bf   { background: #3ecf6e; }      /* verde buffo */
.afin-seg-ef   { background: #4ab3e8; }      /* azul alteración */
.afin-seg-hz   { background: #b06ef0; }      /* violeta hz */

/* ── PANEL: AFINIDADES CON FUENTES ──────────────────────────── */
.det-afin-block {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 8px 10px;
    margin-bottom: 6px;
    background: var(--faint);
}
.det-afin-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
}
.det-afin-total {
    font-size: 1em;
    font-weight: 600;
    color: var(--gold);
}
.det-afin-source {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-bottom: 3px;
}
.det-afin-src-label {
    width: 28px;
    font-size: 0.68em;
    font-weight: 700;
    text-align: center;
    border-radius: 3px;
    padding: 1px 3px;
    letter-spacing: 0.3px;
}
.src-base  { background: rgba(212,175,55,0.2);  color: var(--gold); }
.src-bf    { background: rgba(62,207,110,0.18); color: #3ecf6e; }
.src-ef    { background: rgba(74,179,232,0.18); color: #4ab3e8; }
.src-hz    { background: rgba(176,110,240,0.18);color: #b06ef0; }

.det-afin-src-val {
    min-width: 28px;
    text-align: center;
    font-size: 0.85em;
    color: var(--text);
}

.ctrl-btn-xs {
    padding: 1px 6px;
    font-size: 0.8em;
    height: 20px;
    line-height: 1;
}

/* ── LEYENDA AFINIDADES ──────────────────────────────────────── */
.afin-leyenda {
    float: right;
    font-size: 0.68em;
    font-family: var(--font-body);
    color: var(--dim);
    display: flex;
    gap: 6px;
    align-items: center;
}
.ley-dot {
    font-size: 0.75em;
    font-weight: 700;
    border-radius: 3px;
    padding: 1px 3px;
}
.src-base-dot { background: rgba(212,175,55,0.2);  color: var(--gold); }
.src-bf-dot   { background: rgba(62,207,110,0.18); color: #3ecf6e; }
.src-ef-dot   { background: rgba(74,179,232,0.18); color: #4ab3e8; }
.src-hz-dot   { background: rgba(176,110,240,0.18);color: #b06ef0; }

/* ── PANEL: REGENERACIÓN CON FUENTES ─────────────────────────── */
.det-regen-block { margin-bottom: 10px; }
.det-regen-total {
    color: var(--gold);
    font-weight: 600;
}
.det-regen-breakdown {
    color: var(--dim);
    font-size: 0.75em;
    font-weight: 400;
}
.det-regen-sources {
    display: flex;
    gap: 12px;
    margin-top: 4px;
    padding-left: 4px;
}

/* ── SISTEMA PUSH ─────────────────────────────────────────── */

/* Mini indicador en la tarjeta del catálogo */
.push-mini {
    display: flex;
    gap: 8px;
    margin-bottom: 6px;
    flex-wrap: wrap;
}
.push-mini-item {
    font-size: 0.72em;
    padding: 2px 7px;
    border-radius: 20px;
    border: 1px solid;
    font-variant-numeric: tabular-nums;
}
.push-mini-vex {
    border-color: var(--violet-border);
    color: #a07fd4;
    background: var(--violet-faint);
}
.push-mini-guarda {
    border-color: var(--gold-border);
    color: var(--gold-dim);
    background: var(--gold-faint);
}

/* Bloque de push en panel lateral */
.push-bloque {
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 10px 12px;
    margin-bottom: 8px;
    background: var(--faint);
}
.push-bloque-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 8px;
}
.push-bloque-label {
    font-size: 0.82em;
    font-weight: 500;
    color: var(--text);
}
.push-dots {
    display: flex;
    align-items: center;
    gap: 4px;
    flex: 1;
    padding: 0 8px;
}
.push-dot {
    display: inline-block;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    border: 1px solid var(--border);
    transition: background 0.2s;
}
.push-dot-avail {
    background: var(--gold-faint);
    border-color: var(--gold-border);
}
.push-dot-used {
    background: var(--violet);
    border-color: var(--violet);
    opacity: 0.7;
}
.push-counter {
    font-size: 0.78em;
    color: var(--dim);
    font-variant-numeric: tabular-nums;
    white-space: nowrap;
}
.push-cd {
    font-size: 0.72em;
    color: #c47070;
    padding: 1px 6px;
    border: 1px solid rgba(180,60,60,0.3);
    border-radius: 3px;
    background: rgba(180,60,60,0.08);
    white-space: nowrap;
}

.push-bloque-info {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}
.push-valor {
    font-size: 0.78em;
    color: var(--dim);
    font-variant-numeric: tabular-nums;
}

/* Botón de Push */
.btn-push {
    padding: 5px 16px;
    background: var(--gold-faint);
    border: 1px solid var(--gold-border);
    border-radius: var(--radius);
    color: var(--gold);
    font-family: var(--font-display);
    font-size: 0.75em;
    cursor: pointer;
    letter-spacing: 0.3px;
    transition: all 0.2s;
    white-space: nowrap;
}
.btn-push:hover { background: var(--gold); color: #000; }
.btn-push-disabled {
    opacity: 0.35;
    cursor: not-allowed;
    background: transparent;
    color: var(--dim);
    border-color: var(--border);
}

/* Fila de admin en bloque push */
.push-admin-row {
    display: flex;
    align-items: center;
    gap: 5px;
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid var(--faint);
}
.push-admin-label {
    font-size: 0.7em;
    color: var(--dim);
    min-width: 52px;
}
.push-admin-val {
    min-width: 24px;
    text-align: center;
    font-size: 0.85em;
    color: var(--text);
}
.push-reset-btn {
    margin-left: auto;
    font-size: 0.7em;
    border-color: rgba(180,60,60,0.3);
    color: #c47070;
}
.push-reset-btn:hover {
    border-color: rgba(180,60,60,0.7);
    color: #e08080;
    background: rgba(180,60,60,0.1);
}

.push-help {
    font-size: 0.75em;
    color: var(--dim);
    margin-bottom: 12px;
    line-height: 1.5;
}

/* Panel de sección title con botón inline */
.det-section-title {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.btn-ghost-xs {
    padding: 2px 8px;
    font-size: 0.72em;
    border-radius: 3px;
}

/* ── FÓRMULAS: Config push ─────────────────────────────────── */

.formula-item-desc {
    font-size: 0.75em;
    color: var(--dim);
    margin-bottom: 6px;
    font-style: italic;
}

/* Cooldown grid */
.push-cooldown-grid {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
    margin-top: 6px;
}
.push-cd-field {
    display: flex;
    flex-direction: column;
    gap: 5px;
}
.push-cd-field label {
    font-size: 0.78em;
    color: var(--dim);
}

/* Umbrales */
.umbral-help {
    font-size: 0.72em;
    color: var(--dim);
    margin-bottom: 10px;
    line-height: 1.6;
}
.umbral-row {
    display: flex;
    gap: 6px;
    align-items: center;
    margin-bottom: 6px;
    flex-wrap: wrap;
}
.umbral-desc { flex: 1.5; min-width: 120px; }
.umbral-cond { flex: 2; min-width: 160px; }
.umbral-pushes { width: 56px; text-align: center; }
