.app-header{background-color:#0000004d;padding:1rem 2rem;border-bottom:2px solid var(--color-borde-hierro);-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.header-container{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}.logo{font-family:var(--font-titulo);font-size:2rem;font-weight:700;color:var(--color-oro-antiguo);text-shadow:1px 1px 3px rgba(0,0,0,.7)}.app-header nav{display:flex;align-items:center;gap:1.5rem}.app-header nav a{font-family:var(--font-cuerpo);font-weight:600;font-size:1.1rem}.register-button{padding:.5rem 1rem}.welcome-user{color:var(--color-texto-secondary);margin-right:1rem}.logout-button{background-color:transparent;border:1px solid var(--color-borde-hierro);color:var(--color-texto-secondary);padding:.5rem 1rem;text-transform:none;font-family:var(--font-cuerpo);font-weight:400;box-shadow:none}.logout-button:hover{background-color:var(--color-cuero-gastado);color:var(--color-texto-ceniza);border-color:var(--color-borde-hierro);transform:none}.form-container{max-width:450px;margin:3rem auto;padding:2.5rem;background-color:var(--color-cuero-gastado);border:1px solid var(--color-borde-hierro);border-radius:4px;box-shadow:0 5px 15px #00000080}.form-container h1{text-align:center;margin-bottom:2rem;color:var(--color-oro-antiguo)}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-family:var(--font-titulo);font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.form-group input{width:100%;padding:.8rem 1rem;background-color:var(--color-pergamino-oscuro);border:1px solid var(--color-borde-hierro);border-radius:2px;color:var(--color-texto-ceniza);font-family:var(--font-cuerpo);font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--color-oro-antiguo);box-shadow:0 0 8px var(--color-oro-antiguo) inset}.form-container button{width:100%;margin-top:1rem}.form-message{text-align:center;margin-top:1rem}.form-message a{font-weight:700}.error-message{color:#ff6b6b;background-color:#4d2020;border:1px solid #ff6b6b;padding:.8rem;border-radius:4px;text-align:center;margin-bottom:1rem}.auth-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 70px);padding:2rem}.auth-form{width:100%;max-width:450px;display:flex;flex-direction:column;gap:1.5rem}.auth-title{text-align:center;font-size:2.5rem;margin-bottom:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-family:var(--font-titulo);font-size:1rem;text-transform:uppercase;letter-spacing:1px}.auth-redirect{text-align:center;margin-top:1rem}.personaje-card{display:flex;flex-direction:column;text-decoration:none;color:var(--color-pergamino-claro);transition:transform .2s ease-out,box-shadow .2s ease-out,border-color .2s ease-out;overflow:hidden}.personaje-card:hover{transform:translateY(-5px) scale(1.02);box-shadow:0 8px 25px #000000b3;border-color:var(--color-verde-oliva)}.card-header{background-color:var(--color-musgo-profundo);padding:.8rem 1rem;border-bottom:1px solid var(--color-corteza-roble)}.card-header h3{font-size:1.2rem;margin:0;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.card-body{padding:1rem;flex-grow:1;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:.5rem;font-size:.9rem;font-style:italic;color:#b0b0a0}.dashboard-container{max-width:1200px;margin:2rem auto;padding:0 2rem}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-corteza-roble)}.dashboard-header h1{font-size:2.5rem;color:var(--color-pergamino-claro)}.personajes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:1.5rem}.no-personajes{text-align:center;padding:3rem;background-color:#1e201c80;border:1px solid var(--color-musgo-profundo);border-radius:4px;box-shadow:0 4px 15px #00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.no-personajes p{margin-bottom:1.5rem;font-size:1.2rem}.seleccion-container h2{text-align:center;margin-bottom:2rem;font-size:2rem}.seleccion-layout{display:grid;grid-template-columns:300px 1fr;gap:2rem;min-height:50vh}.lista-seleccion{border:1px solid var(--color-musgo-profundo);border-radius:4px;overflow-y:auto;max-height:60vh;background-color:var(--color-sombra-bosque)}.item-seleccion{padding:1rem 1.5rem;font-family:var(--font-titulo);font-size:1.2rem;cursor:pointer;border-bottom:1px solid var(--color-musgo-profundo);transition:background-color .2s,color .2s}.item-seleccion:hover{background-color:var(--color-corteza-roble)}.item-seleccion.selected{background-color:var(--color-verde-oliva);color:var(--color-pergamino-claro);font-weight:700}.detalle-seleccion{padding:1.5rem;border:1px solid var(--color-musgo-profundo);border-radius:4px;background-color:var(--color-sombra-bosque)}.detalle-seleccion h3{font-size:1.8rem;margin-bottom:1rem}.detalle-seleccion h4{font-size:1.2rem;margin-top:1.5rem;margin-bottom:.5rem;border-bottom:1px solid var(--color-corteza-roble);padding-bottom:.5rem}.detalle-seleccion ul{list-style-position:inside;padding-left:.5rem}.detalle-seleccion li{margin-bottom:.5rem}.detalle-seleccion button{margin-top:2rem;width:100%}.sub-seleccion{margin-top:2rem;padding:1rem;background-color:#0003;border:1px dashed var(--color-corteza-roble);border-radius:4px}.item-subseleccion{display:inline-block;padding:.5rem 1rem;margin:.5rem;border:1px solid var(--color-corteza-roble);border-radius:20px;cursor:pointer;transition:all .2s}.item-subseleccion:hover{background-color:var(--color-corteza-roble)}.item-subseleccion.selected{background-color:var(--color-verde-oliva);border-color:var(--color-verde-oliva)}.skill-list{display:grid;grid-template-columns:1fr 1fr;gap:.5rem}.skill-checkbox{display:flex;align-items:center;gap:.5rem}.skill-checkbox input[type=checkbox]{width:auto}.seleccion-container h2{text-align:center;margin-bottom:1rem;font-size:2rem}.puntos-restantes{text-align:center;font-family:var(--font-titulo);font-size:1.5rem;margin-bottom:2rem}.puntos-restantes span{color:var(--color-verde-oliva);font-weight:700}.atributos-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1.5rem}.atributo-card{padding:1.5rem 1rem;border:1px solid var(--color-musgo-profundo);border-radius:4px;text-align:center;background-color:var(--color-sombra-bosque);display:flex;flex-direction:column;align-items:center}.atributo-card h3{font-size:1.2rem;margin-bottom:1rem}.puntuacion-total{font-family:var(--font-titulo);font-size:3rem;color:var(--color-pergamino-claro);margin-bottom:1rem}.puntuacion-control{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.puntuacion-control button{font-size:1.5rem;padding:0;width:40px;height:40px;line-height:40px;border-radius:50%}.puntuacion-base{font-size:1.2rem;font-weight:700}.bonificacion-racial,.costo-puntos{font-size:.8rem;color:#b0b0a0;font-style:italic}.bonificacion-racial{margin-bottom:.5rem}.detalles-container h2{text-align:center;margin-bottom:2rem;font-size:2rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem}.form-group,.form-group-full{display:flex;flex-direction:column;gap:.5rem}.form-group-full{grid-column:1 / -1}.form-group label,.form-group-full label,.form-group-full h4{font-family:var(--font-titulo);font-size:1rem;text-transform:uppercase;letter-spacing:1px;color:#b0b0a0}.form-group-full h4{margin-bottom:1rem;border-bottom:1px solid var(--color-corteza-roble);padding-bottom:.5rem}.form-group-full textarea{margin-bottom:1rem}.confirmar-atributos{display:block;width:50%;margin:3rem auto 0}.creacion-container{max-width:1200px;margin:2rem auto;padding:2rem}.progreso-creacion{display:flex;justify-content:space-between;margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid var(--color-corteza-roble)}.paso-progreso{flex:1;text-align:center;padding:.5rem;color:#b0b0a0;border-bottom:4px solid transparent;font-family:var(--font-titulo);position:relative}.paso-progreso.active{color:var(--color-pergamino-claro);border-bottom-color:var(--color-verde-oliva)}.paso-progreso.completed{color:var(--color-verde-oliva)}.paso-progreso:not(:last-child):after{content:"";position:absolute;top:50%;right:-25px;width:50px;height:1px;background-color:var(--color-corteza-roble);transform:translateY(-50%)}.contenido-paso{margin-top:2rem;padding:2rem;background-color:#11130f80;border:1px solid var(--color-musgo-profundo);border-radius:4px}.hoja-personaje-container{max-width:1400px;margin:2rem auto;padding:0 2rem}.controles-principales{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;border-bottom:1px solid var(--color-corteza-roble);padding-bottom:1rem}.navegacion-pestañas{display:flex;gap:.5rem}.navegacion-pestañas button{background:transparent;border:2px solid transparent;border-bottom-color:var(--color-corteza-roble);color:#b0b0a0;font-size:1.2rem;padding:.5rem 1rem;border-radius:3px 3px 0 0}.navegacion-pestañas button.active{background-color:var(--color-musgo-profundo);border-color:var(--color-verde-oliva);color:var(--color-pergamino-claro)}.controles-edicion{display:flex;gap:1rem}.controles-edicion .boton-guardar{background-color:var(--color-verde-oliva)}.controles-edicion .boton-cancelar{background-color:#c0392b}.hoja-header-editable{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem;padding:1.5rem}.header-detalles-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.hoja-grid{display:grid;grid-template-columns:300px 1fr 1fr;gap:2rem}.columna-izquierda,.columna-central,.columna-derecha{display:flex;flex-direction:column;gap:2rem}.campo,.atributo-box,.checkbox-item,.col-izquierda-seccion{display:flex;flex-direction:column}.campo label,.atributo-box>label,.col-izquierda-seccion h4{font-family:var(--font-titulo);font-size:.8rem;text-transform:uppercase;color:#b0b0a0;margin-bottom:.5rem;letter-spacing:1px}.campo-valor{font-size:1.1rem;color:var(--color-pergamino-claro);min-height:24px}.campo-valor.texto-largo{white-space:pre-wrap;word-wrap:break-word;line-height:1.5}.campo input,.campo textarea{font-size:1.1rem}.campo-textarea textarea{min-height:120px}.atributos-principales-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.atributo-box{background-color:var(--color-sombra-bosque);border:1px solid var(--color-corteza-roble);border-radius:4px;padding:1rem;text-align:center}.puntuacion-grande,.puntuacion-grande-input{font-family:var(--font-titulo);font-size:2.5rem;color:var(--color-pergamino-claro);margin-bottom:.5rem}.puntuacion-grande-input{width:100%;text-align:center;background:transparent;border:none;border-bottom:1px solid var(--color-musgo-profundo)}.modificador{font-size:1.2rem;font-weight:700;color:var(--color-verde-oliva)}.col-izquierda-seccion{padding:1rem;border:1px solid var(--color-corteza-roble);border-radius:4px}.checkbox-item{flex-direction:row;align-items:center;gap:.8rem}.checkbox-item input[type=checkbox]{width:auto}.checkbox-item .bonus{font-weight:700;width:30px;text-align:center}.checkbox-item .bonus.competente{color:var(--color-verde-oliva)}.checkbox-item label{margin:0}.bloque-combate-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;text-align:center;margin-bottom:2rem}.combate-item{padding:1rem;border:1px solid var(--color-corteza-roble);border-radius:4px}.combate-item .campo-valor{font-size:2rem;font-family:var(--font-titulo)}.combate-item.hp{grid-column:1 / -1}.hp-actuales .campo-valor{font-size:3rem}.columna-derecha .campo-textarea textarea{min-height:250px}.stats-conjuros-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;text-align:center}.stat-conjuro-item{padding:1rem;border:1px solid var(--color-corteza-roble);border-radius:4px}.stat-conjuro-item div{font-size:1.5rem;font-family:var(--font-titulo)}.gestion-conjuros-grid{display:grid;grid-template-columns:300px 1fr 300px;gap:2rem;min-height:60vh}.grimorio-completo,.detalle-conjuro,.conjuros-personaje{padding:1.5rem;border:1px solid var(--color-corteza-roble);border-radius:4px;display:flex;flex-direction:column}.grimorio-completo h3,.conjuros-personaje h3{text-align:center;margin-bottom:1rem}.buscador-conjuros{margin-bottom:1rem}.lista-conjuros{list-style:none;padding:0;margin:0;overflow-y:auto;flex-grow:1}.lista-conjuros li{padding:.5rem;border-bottom:1px solid var(--color-musgo-profundo);cursor:pointer;transition:background-color .2s;display:flex;justify-content:space-between;align-items:center}.lista-conjuros li:hover{background-color:var(--color-musgo-profundo)}.detalle-conjuro h4{font-size:1.5rem}.detalle-conjuro p{margin-bottom:.8rem}.descripcion-conjuro{font-style:italic;color:#b0b0a0}.boton-quitar{background:#c0392b;border:none;color:#fff;border-radius:50%;width:20px;height:20px;line-height:20px;text-align:center;cursor:pointer}.campanas-container{max-width:1200px;margin:2rem auto;padding:0 2rem}.campanas-header{text-align:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-corteza-roble)}.campanas-header h1{font-size:2.5rem}.acciones-campana{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-bottom:3rem}.accion-box{padding:2rem}.accion-box h2{margin-bottom:1.5rem;text-align:center}.accion-box form{display:flex;flex-direction:column;gap:1rem}.lista-campanas{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.campana-card{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.campana-card h3{font-size:1.5rem;color:var(--color-pergamino-claro)}.campana-card .dm-info{font-size:.9rem;color:#b0b0a0;font-style:italic}.campana-card .dm-info strong{color:var(--color-verde-oliva)}.campana-card .acciones-card{margin-top:auto}.modal-overlay{position:fixed;inset:0;background-color:#000000bf;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{width:90%;max-width:500px;padding:2rem}.modal-content h2{text-align:center;margin-bottom:1.5rem}.modal-content form{display:flex;flex-direction:column;gap:1rem}.modal-acciones{display:flex;justify-content:flex-end;gap:1rem;margin-top:1.5rem}.dm-container{max-width:1200px;margin:2rem auto;padding:0 2rem}.dm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--color-corteza-roble)}.dm-header h1{font-size:2.5rem}.codigo-invitacion{background-color:var(--color-sombra-bosque);border:1px dashed var(--color-verde-oliva);padding:.5rem 1rem;border-radius:4px;text-align:center}.codigo-invitacion span{display:block;font-size:.8rem;color:#b0b0a0}.codigo-invitacion strong{font-family:var(--font-titulo);font-size:1.5rem;letter-spacing:2px;color:var(--color-pergamino-claro)}.jugadores-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.jugador-card-dm{display:flex;flex-direction:column}.jugador-card-header{display:flex;justify-content:space-between;align-items:center;background-color:var(--color-musgo-profundo);padding:.8rem 1rem;border-bottom:1px solid var(--color-corteza-roble)}.jugador-card-header h3{margin:0;font-size:1.2rem}.jugador-card-header span{font-size:.8rem;font-style:italic;color:#b0b0a0}.jugador-stats-dm{padding:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.stat-editable{display:flex;flex-direction:column;gap:.5rem}.stat-editable label{font-size:.8rem;text-transform:uppercase;color:#b0b0a0}.stat-editable input{font-family:var(--font-titulo);text-align:center;font-size:1.8rem;padding:.5rem}.jugador-card-actions{margin-top:auto;padding:1rem;border-top:1px solid var(--color-musgo-profundo);display:flex;gap:.5rem;justify-content:space-between;align-items:center}.boton-expulsar{background-color:#9b2c2c;border-color:#742a2a}.boton-expulsar:hover{background-color:#c53030;border-color:#e53e3e}.status-message{padding:.5rem 1rem;text-align:center;font-size:.9rem;border-top:1px solid var(--color-corteza-roble)}.status-message.success{color:#9ae6b4;background-color:#2d805333}.status-message.error{color:#feb2b2;background-color:#9b2c2c4d}:root{--color-sombra-bosque: #11130F;--color-musgo-profundo: #2A402D;--color-verde-oliva: #596646;--color-corteza-roble: #63553D;--color-pergamino-claro: #E6E6D5;--font-titulo: "Cinzel", serif;--font-cuerpo: "Lora", serif;font-family:var(--font-cuerpo);line-height:1.6;font-weight:400;color:var(--color-pergamino-claro);background-color:var(--color-sombra-bosque);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-width:320px;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-titulo);color:var(--color-pergamino-claro);letter-spacing:1px}a{color:var(--color-verde-oliva);text-decoration:none;font-weight:600;transition:color .2s,text-shadow .2s}a:hover{color:#8a9a70;text-shadow:0 0 4px #8a9a7033}button,.button-style{font-family:var(--font-titulo);font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--color-pergamino-claro);background-color:var(--color-verde-oliva);border:2px solid var(--color-musgo-profundo);padding:.8rem 1.8rem;border-radius:3px;cursor:pointer;transition:all .25s ease-out;box-shadow:0 3px 6px #0006;text-align:center}button:hover,.button-style:hover{background-color:#6a7c53;border-color:#8a9a70;box-shadow:0 5px 12px #00000080;transform:translateY(-2px)}button:disabled{background-color:var(--color-corteza-roble);border-color:var(--color-musgo-profundo);color:#a4a49a;cursor:not-allowed;transform:none;box-shadow:none}input,textarea,select{width:100%;padding:.8rem 1rem;font-family:var(--font-cuerpo);font-size:1rem;color:var(--color-pergamino-claro);background-color:var(--color-corteza-roble);border:1px solid var(--color-musgo-profundo);border-radius:3px;transition:border-color .2s,box-shadow .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-verde-oliva);box-shadow:0 0 10px var(--color-verde-oliva) 33}textarea{min-height:100px;resize:vertical}.card{background-color:#1e201c80;border:1px solid var(--color-musgo-profundo);border-radius:4px;padding:1.5rem;box-shadow:0 4px 15px #00000080;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.loading-fullscreen{display:flex;justify-content:center;align-items:center;height:80vh;font-family:var(--font-titulo);font-size:1.5rem;color:var(--color-verde-oliva)}.error-mensaje{text-align:center;padding:2rem;margin:2rem auto;max-width:600px;background-color:var(--color-corteza-roble);border:1px solid #c0392b;color:#f2a299;border-radius:4px}
