/* ============================================
   Estilos específicos: Personajes
   ============================================ */

.personaje-ocupacion {
    font-size: 0.83rem;
    color: var(--color-accent);
    font-style: italic;
}

.personaje-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.stat-badge {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.2rem 0.5rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.stat-badge strong {
    color: var(--color-text);
}

/* Ficha completa */
.ficha-investigador {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
}

.ficha-seccion {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
}

.ficha-seccion h4 {
    font-family: var(--font-heading);
    font-size: 0.9rem;
    color: var(--color-text-heading);
    margin-bottom: 0.75rem;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid var(--color-border);
}

.ficha-caracteristicas {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0.5rem;
}

.caract-item {
    text-align: center;
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.5rem;
}

.caract-label {
    font-size: 0.7rem;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

.caract-valor {
    font-size: 1.2rem;
    font-weight: 600;
    color: var(--color-text-heading);
}

/* Habilidades en la ficha */
.ficha-habilidades-lista {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.25rem;
}

.habilidad-item {
    display: flex;
    justify-content: space-between;
    padding: 0.25rem 0.5rem;
    font-size: 0.8rem;
    border-radius: 3px;
}

.habilidad-item:hover {
    background: var(--color-bg-card);
}

.habilidad-nombre {
    color: var(--color-text);
}

.habilidad-valor {
    color: var(--color-text-heading);
    font-weight: 500;
}

.habilidad-valor.modificada {
    color: var(--color-primary);
}

/* Formulario de personaje */
.form-habilidades-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.5rem;
}

.form-habilidad-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.83rem;
}

.form-habilidad-item label {
    flex: 1;
    margin-bottom: 0;
}

.form-habilidad-item input {
    width: 55px;
    text-align: center;
    padding: 0.3rem;
}

@media (max-width: 768px) {
    .ficha-investigador {
        grid-template-columns: 1fr;
    }

    .ficha-caracteristicas {
        grid-template-columns: repeat(4, 1fr);
    }

    .ficha-habilidades-lista {
        grid-template-columns: 1fr;
    }

    .form-habilidades-grid {
        grid-template-columns: 1fr;
    }
}


/* ============================================
   Guía de cálculo y dados en creación
   ============================================ */

.caract-guia {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem 1.2rem;
    margin-bottom: 1rem;
}

.caract-guia-reglas {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
}

.caract-guia-titulo {
    font-weight: 600;
    font-size: 0.9rem;
    color: var(--color-text-heading);
    margin-bottom: 0.3rem;
}

.caract-guia-grupo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    font-size: 0.85rem;
}

.caract-guia-formula {
    font-family: 'Courier New', monospace;
    font-weight: 700;
    font-size: 0.9rem;
    color: var(--color-primary);
    background: var(--color-bg-card);
    border: 1px solid var(--color-border);
    border-radius: 4px;
    padding: 0.15rem 0.5rem;
    min-width: 90px;
    text-align: center;
}

.caract-guia-stats {
    color: var(--color-text);
}

.caract-guia-nota {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    margin-top: 0.4rem;
    font-style: italic;
}

/* Características con dados */
.caract-con-dados {
    gap: 0.75rem;
}

.caract-item-con-dado {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.3rem;
    padding: 0.6rem 0.4rem;
}

.caract-formula-mini {
    font-family: 'Courier New', monospace;
    font-size: 0.6rem;
    color: var(--color-text-muted);
    letter-spacing: -0.5px;
}

.btn-dado-caract {
    font-size: 0.85rem;
    padding: 0.2rem 0.5rem;
    background: var(--color-bg-card);
    border: 1px solid var(--color-accent);
    border-radius: 4px;
    cursor: pointer;
    transition: all 0.2s;
    line-height: 1;
}

.btn-dado-caract:hover {
    background: var(--color-accent);
    transform: scale(1.1);
}

.caract-tirada-detalle {
    font-size: 0.65rem;
    color: var(--color-text-muted);
    font-family: 'Courier New', monospace;
    min-height: 1em;
    text-align: center;
    white-space: nowrap;
}

/* Input grande para características */
.caract-input-grande {
    width: 75px;
    text-align: center;
    background: var(--color-bg);
    border: 1px solid var(--color-border);
    color: var(--color-text-heading);
    font-size: 1.3rem;
    font-weight: 600;
    border-radius: 4px;
    padding: 0.35rem 0.25rem;
    -moz-appearance: textfield;
    appearance: textfield;
}

.caract-input-grande::-webkit-outer-spin-button,
.caract-input-grande::-webkit-inner-spin-button {
    -webkit-appearance: none;
    appearance: none;
    margin: 0;
}

.caract-input-grande:focus {
    border-color: var(--color-border-focus);
    outline: none;
}

/* Animación al tirar */
.caract-valor-animado {
    animation: caract-flash 0.5s ease;
}

.caract-detalle-animado {
    animation: caract-fade-in 0.4s ease;
}

@keyframes caract-flash {
    0% { background-color: var(--color-primary); color: #fff; transform: scale(1.1); }
    100% { background-color: var(--color-bg); color: var(--color-text-heading); transform: scale(1); }
}

@keyframes caract-fade-in {
    0% { opacity: 0; transform: translateY(-4px); }
    100% { opacity: 1; transform: translateY(0); }
}

/* Suerte con dado */
.caract-item-suerte .caract-tirada-detalle {
    font-size: 0.75rem;
}


/* ============================================
   Editor de Habilidades
   ============================================ */

.hab-editor-container {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 1rem;
}

.hab-editor-buscar {
    margin-bottom: 0.75rem;
}

.hab-editor-buscar input {
    width: 100%;
}

.form-habilidades-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.35rem 1rem;
    max-height: 350px;
    overflow-y: auto;
    padding-right: 0.5rem;
}

.form-habilidad-item {
    display: flex;
    align-items: center;
    gap: 0.4rem;
    font-size: 0.82rem;
    padding: 0.2rem 0.3rem;
    border-radius: 3px;
    transition: background 0.15s;
}

.form-habilidad-item:hover {
    background: var(--color-bg-card);
}

.form-habilidad-item label {
    flex: 1;
    margin-bottom: 0;
    font-size: 0.82rem;
    color: var(--color-text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    cursor: pointer;
}

.form-habilidad-item input {
    width: 55px;
    text-align: center;
    padding: 0.2rem 0.3rem;
    font-size: 0.85rem;
    font-weight: 500;
}

.hab-base-hint {
    font-size: 0.68rem;
    color: var(--color-text-muted);
    min-width: 30px;
}

.hab-editor-acciones {
    display: flex;
    gap: 0.5rem;
    margin-top: 0.75rem;
    padding-top: 0.75rem;
    border-top: 1px solid var(--color-border);
}

/* Habilidades en ficha (solo lectura) */
.ficha-habilidades-lista {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.15rem;
    max-height: 300px;
    overflow-y: auto;
}

.habilidad-item {
    display: flex;
    justify-content: space-between;
    padding: 0.2rem 0.5rem;
    font-size: 0.8rem;
    border-radius: 3px;
    transition: background 0.15s;
}

.habilidad-item:hover {
    background: var(--color-bg-card);
}

.habilidad-nombre {
    color: var(--color-text);
}

.habilidad-valor {
    color: var(--color-text-heading);
    font-weight: 500;
    min-width: 25px;
    text-align: right;
}

.habilidad-valor.modificada {
    color: var(--color-primary);
    font-weight: 600;
}

@media (max-width: 768px) {
    .form-habilidades-grid {
        grid-template-columns: 1fr;
    }

    .ficha-habilidades-lista {
        grid-template-columns: 1fr;
    }
}


/* ============================================
   Info de ocupación en creación de personaje
   ============================================ */

.ocupacion-info {
    background: var(--color-bg-input);
    border: 1px solid var(--color-primary);
    border-radius: var(--radius);
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    animation: caract-fade-in 0.3s ease;
}

.ocupacion-info-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 0.5rem;
    flex-wrap: wrap;
    gap: 0.5rem;
}

.ocupacion-puntos {
    font-size: 0.8rem;
    color: var(--color-primary);
    background: var(--color-bg-card);
    padding: 0.2rem 0.6rem;
    border-radius: 10px;
}

.ocupacion-info-body p {
    font-size: 0.83rem;
    margin-bottom: 0.4rem;
    color: var(--color-text);
}

.ocupacion-habilidades {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: 0.3rem;
}

.ocupacion-hab-tag {
    font-size: 0.75rem;
    padding: 0.2rem 0.5rem;
    background: var(--color-bg-card);
    border: 1px solid var(--color-primary);
    border-radius: 10px;
    color: var(--color-text);
}

.ocupacion-hab-electiva {
    border-color: var(--color-accent);
    color: var(--color-accent);
    font-style: italic;
}


/* ============================================
   Selector de modo (Clásico / Pulp)
   ============================================ */

.pj-modo-selector {
    display: flex;
    gap: 0.5rem;
}

.pj-modo-opcion {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    background: var(--color-bg-input);
    border: 2px solid var(--color-border);
    border-radius: var(--radius);
    cursor: pointer;
    font-size: 0.9rem;
    font-weight: 500;
    transition: all 0.2s;
}

.pj-modo-opcion:hover {
    border-color: var(--color-text-muted);
}

.pj-modo-opcion.pj-modo-activa {
    border-color: var(--color-primary);
    background: #1a2a1a;
    color: var(--color-text-heading);
}

.pj-modo-opcion input[type="radio"] {
    display: none;
}


/* ============================================
   Fobias y Manías
   ============================================ */

.fobias-manias-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
    margin-bottom: 1rem;
}

.fobias-columna {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.fobias-columna h4 {
    font-family: var(--font-heading);
    font-size: 0.95rem;
    color: var(--color-text-heading);
    margin: 0;
}

.fobias-buscar-col {
    width: 100%;
}

.fobias-lista {
    display: flex;
    flex-direction: column;
    gap: 0.25rem;
    max-height: 400px;
    overflow-y: auto;
    padding-right: 0.3rem;
}

.fobia-item {
    padding: 0.35rem 0.5rem;
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    font-size: 0.8rem;
    line-height: 1.4;
}

.fobia-item strong {
    color: var(--color-text-heading);
}

@media (max-width: 768px) {
    .fobias-manias-layout {
        grid-template-columns: 1fr;
    }
}


/* ============================================
   Fase de Desarrollo
   ============================================ */

.desarrollo-info {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    padding: 0.75rem 1rem;
    margin-bottom: 1rem;
    font-size: 0.85rem;
}

.desarrollo-info p {
    margin-bottom: 0.3rem;
}

.desarrollo-habilidades {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.25rem;
    max-height: 350px;
    overflow-y: auto;
}

.desarrollo-hab-item {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.3rem 0.5rem;
    border-radius: 3px;
    font-size: 0.82rem;
    cursor: pointer;
    transition: background 0.15s;
}

.desarrollo-hab-item:hover {
    background: var(--color-bg-card);
}

.desarrollo-hab-item.marcada {
    background: #1a2a1a;
}

.desarrollo-hab-item input {
    accent-color: var(--color-primary);
}

.desarrollo-hab-nombre {
    flex: 1;
}

.desarrollo-hab-valor {
    font-weight: 600;
    color: var(--color-text-heading);
    min-width: 25px;
    text-align: right;
}

.desarrollo-resultados-lista {
    display: flex;
    flex-direction: column;
    gap: 0.3rem;
}

.desarrollo-resultado {
    padding: 0.4rem 0.6rem;
    border-radius: var(--radius);
    font-size: 0.83rem;
}

.desarrollo-resultado.exito {
    background: #1a2a1a;
    border: 1px solid var(--color-primary);
}

.desarrollo-resultado.fallo {
    background: var(--color-bg-input);
    border: 1px solid var(--color-border);
    color: var(--color-text-muted);
}

@media (max-width: 768px) {
    .desarrollo-habilidades {
        grid-template-columns: 1fr;
    }
}
