*,
        *::before,
        *::after {
            box-sizing: border-box;
        }

        /* Sfondo evocativo stile pergamena e font classico */
        html {
            max-width: 100%;
            overflow-x: hidden;
        }

        body {
            font-family: 'Georgia', 'Times New Roman', serif;
            background-color: #e2d1b3;
            background-image: radial-gradient(#f5ebd6 20%, transparent 80%), radial-gradient(#ebdcb9 40%, transparent 70%);
            background-size: 8px 8px;
            margin: 0;
            padding: 20px;
            color: #2b1d0c;
            max-width: 100%;
            overflow-x: hidden;
        }

        input,
        select,
        textarea,
        button {
            max-width: 100%;
        }

        .header-title {
            text-align: center;
            background-color: #5c0000;
            color: #f5ebd6;
            padding: 15px;
            margin: 0 0 20px 0;
            border: 3px double #d4af37;
            text-transform: uppercase;
            letter-spacing: 2px;
            font-size: 24px;
            text-shadow: 2px 2px 4px rgba(0,0,0,0.6);
        }

        /* Navigazione Schede in stile Fantasy */
        .tab-container {
            display: grid;
            grid-template-columns: repeat(12, minmax(0, 1fr));
            gap: 5px;
            margin-bottom: 8px;
            position: relative;
            z-index: 2;
            width: 100%;
        }
        .tab-button {
            box-sizing: border-box;
            grid-column: span 4;
            width: 100%;
            min-height: 44px;
            min-width: 0;
            padding: 8px 6px;
            border: 2px solid #5c0000;
            background-color: #c7b299;
            cursor: pointer;
            font-weight: bold;
            font-family: 'Georgia', serif;
            font-size: 12px;
            line-height: 1.15;
            color: #3d0000;
            border-radius: 6px 6px 0 0;
            transition: all 0.2s;
            text-align: center;
            white-space: normal;
            overflow-wrap: anywhere;
        }
        .tab-span-2 {
            grid-column: span 2;
        }
        .tab-span-3 {
            grid-column: span 3;
        }
        .tab-span-4 {
            grid-column: span 4;
        }
        .tab-button-home {
            align-items: center;
            display: inline-flex;
            justify-content: center;
            padding: 6px 4px;
        }
        .tab-home-icon {
            display: block;
            fill: none;
            height: 25px;
            stroke: currentColor;
            stroke-linecap: round;
            stroke-linejoin: round;
            stroke-width: 2.6;
            width: 25px;
        }
        .sr-only {
            height: 1px;
            margin: -1px;
            overflow: hidden;
            padding: 0;
            position: absolute;
            width: 1px;
            clip: rect(0, 0, 0, 0);
            white-space: nowrap;
        }
        .tab-label-line {
            display: block;
        }
        .tab-button:hover {
            background-color: #dbc5ac;
        }
        .tab-button.active {
            background-color: #fffdf6;
            color: #5c0000;
            border-top: 3px solid #5c0000;
            box-shadow: 0 -3px 6px rgba(0,0,0,0.1);
        }

        @media (min-aspect-ratio: 4/5) and (max-aspect-ratio: 5/4) {
            .tab-container {
                grid-template-columns: repeat(12, minmax(0, 1fr));
            }
        }

        @media (max-aspect-ratio: 4/5) {
            .tab-container {
                grid-template-columns: repeat(12, minmax(0, 1fr));
            }
        }

        /* Contenitore Foglio Pergamena */
        .tab-content {
            display: none;
            background-color: #fffdf6;
            padding: 25px;
            border: 2px solid #5c0000;
            box-shadow: 5px 5px 15px rgba(43,29,12,0.3);
            min-height: 600px;
            border-radius: 0 4px 4px 4px;
            min-width: 0;
            backface-visibility: hidden;
            contain: layout paint;
        }
        .tab-content.active {
            display: block;
        }

        /* Sezioni interne stile manuale D&D */
        .box-sezione {
            border: 2px solid #5c0000;
            background-color: #fbf7ed;
            margin-bottom: 20px;
            padding: 15px;
            position: relative;
            box-shadow: inset 0 0 10px rgba(92,0,0,0.05);
            min-width: 0;
            overflow-x: auto;
        }
        .box-sezione h4 {
            background-color: #5c0000;
            color: #fffdf6;
            margin: -10px -8px 12px -8px;
            padding: 8px 12px;
            font-size: 14px;
            text-transform: uppercase;
            letter-spacing: 1px;
            border-bottom: 2px solid #d4af37;
        }

        /* Griglie e Allineamenti */
        .grid-combat {
            display: grid;
            grid-template-columns: 1fr 1.5fr;
            gap: 20px;
        }
        .grid-combat > *,
        .grid-anagrafica-compatta > * {
            min-width: 0;
        }
        .grid-anagrafica-compatta {
            display: grid;
            grid-template-columns: minmax(210px, 0.85fr) minmax(330px, 1.15fr);
            gap: 14px;
            align-items: stretch;
        }
        .box-compatta {
            padding: 8px;
            margin-bottom: 10px;
        }
        .box-compatta h4 {
            margin: -5px -4px 7px -4px;
            padding: 5px 8px;
            font-size: 12px;
        }
        .classi-compatte,
        .progressione-compatta {
            box-sizing: border-box;
        }
        .progressione-compatta {
            height: 178px;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }
        .progressione-scroll {
            min-height: 0;
            overflow-y: auto;
            overflow-x: hidden;
            flex: 1 1 auto;
        }
        .progressione-compatta table {
            font-size: 11px;
            margin-top: 6px;
        }
        .progressione-compatta .tabella-fantasy th,
        .progressione-compatta .tabella-fantasy td {
            padding: 4px 5px;
        }
        .classi-compatte {
            display: flex;
            flex-direction: column;
            min-height: 0;
        }
        .classe-riga-label {
            color: #5c0000;
            font-size: 11px;
            font-weight: bold;
            letter-spacing: 0.5px;
            text-transform: uppercase;
        }
        .classe-riga-campo {
            margin: 2px 0 8px 0;
        }
        .classe-riga-campo:last-child {
            margin-bottom: 0;
        }
        .classe-riga-campo .select-fantasy {
            width: 100%;
            padding: 4px 6px;
        }
        .classe-riga-con-livello {
            align-items: center;
            display: grid;
            gap: 6px;
            grid-template-columns: minmax(0, 1fr) auto;
        }
        .classe-livello-badge {
            align-items: center;
            align-self: stretch;
            border: 1px solid rgba(92, 0, 0, 0.35);
            border-radius: 4px;
            background: rgba(255, 253, 246, 0.78);
            color: #5c0000;
            display: inline-flex;
            font-size: 11px;
            font-weight: bold;
            justify-content: center;
            min-width: 74px;
            padding: 2px 5px;
            white-space: nowrap;
        }
        .grid-anagrafica-compatta > .box-sezione {
            margin-bottom: 0;
        }
        @media (max-width: 850px) {
            .grid-combat { grid-template-columns: 1fr; }
        }
        @media (max-width: 680px) {
            .grid-anagrafica-compatta { grid-template-columns: 1fr; }
        }

        /* Anagrafica Intestazione */
        .riga-anagrafica {
            display: flex;
            gap: 20px;
            margin-bottom: 15px;
            flex-wrap: wrap;
        }
        .riga-misure-pg,
        .riga-progressione-pg {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 20px;
        }
        .campo-anagrafica {
            flex: 1;
            min-width: 140px;
            border-bottom: 1px solid #5c0000;
            padding-bottom: 5px;
        }
        .campo-anagrafica label {
            display: block;
            font-size: 11px;
            text-transform: uppercase;
            font-weight: bold;
            color: #5c0000;
            margin-bottom: 2px;
        }
        .campo-anagrafica input, .campo-anagrafica select {
            width: 100%;
            border: none;
            background: transparent;
            font-family: 'Georgia', serif;
            font-size: 15px;
            color: #2b1d0c;
            outline: none;
        }

        .info-personaggio .riga-identita-pg,
        .info-personaggio .riga-razza-taglia-allineamento {
            display: grid;
            gap: 14px;
        }
        .info-personaggio .riga-identita-pg {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }
        .info-personaggio .riga-razza-taglia-allineamento {
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }
        .info-personaggio .campo-anagrafica,
        .info-personaggio .campo-anagrafica label,
        .info-personaggio .campo-anagrafica input,
        .info-personaggio .campo-anagrafica select,
        .info-personaggio .campo-anagrafica span {
            min-width: 0;
            text-align: center;
        }

        /* Tabelle ad Impatto Visivo */
        .tabella-fantasy {
            width: 100%;
            border-collapse: collapse;
            margin-top: 10px;
            font-size: 13px;
        }
        .tabella-fantasy th {
            border-bottom: 2px solid #5c0000;
            color: #5c0000;
            padding: 6px;
            font-weight: bold;
            text-transform: uppercase;
            font-size: 12px;
            overflow-wrap: anywhere;
        }
        .tabella-fantasy td {
            border-bottom: 1px dashed #c7b299;
            padding: 6px;
            text-align: center;
            overflow-wrap: anywhere;
        }

        /* Input personalizzati per sembrare scritti a mano */
        .input-fantasy {
            background-color: transparent;
            border: none;
            border-bottom: 1px solid #888;
            font-family: 'Georgia', serif;
            font-size: 14px;
            text-align: center;
            color: #2b1d0c;
        }
        .input-fantasy:focus {
            border-bottom: 1px solid #5c0000;
            background-color: #f5ebd6;
        }
        .input-corto { width: 50px; font-weight: bold; font-size: 15px; }
        .input-medio { width: 80px; }

        /* Blocchi Caratteristiche con Modificatore */
        .riga-caratteristica {
            display: flex;
            align-items: center;
            justify-content: space-between;
            background-color: #f3ebd9;
            margin-bottom: 8px;
            padding: 6px 12px;
            border: 1px solid #c7b299;
            border-radius: 4px;
        }
        .caratt-label {
            font-weight: bold;
            font-size: 14px;
            color: #5c0000;
            width: 90px;
        }
        .cerchio-modificatore {
            width: 36px;
            height: 36px;
            border-radius: 50%;
            border: 2px solid #5c0000;
            background-color: #fffdf6;
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: bold;
            font-size: 15px;
            box-shadow: 2px 2px 4px rgba(0,0,0,0.1);
        }

        /* Scudo CA e Cuore PF Grafici */
        .riquadro-ca-totale {
            background-color: #fffdf6;
            border: 3px double #5c0000;
            padding: 15px;
            text-align: center;
            margin-bottom: 15px;
            border-radius: 8px;
            box-shadow: 3px 3px 6px rgba(0,0,0,0.05);
        }
        .valore-ca-grande {
            font-size: 32px;
            font-weight: bold;
            color: #5c0000;
            display: block;
            margin-top: 5px;
        }

        .align-left { text-align: left !important; }

        .database-status {
            margin: -8px 0 18px 0;
            padding: 8px 12px;
            border: 1px solid #9b7b45;
            background: #fbf7ed;
            color: #4c3515;
            font-size: 13px;
            text-align: center;
        }
        .database-status[hidden] {
            display: none !important;
        }
        .database-status.errore {
            border-color: #9b2f2f;
            background: #fff1ea;
            color: #5c0000;
            text-align: left;
        }

        .strumenti-riga {
            display: flex;
            gap: 12px;
            align-items: end;
            flex-wrap: wrap;
            margin-bottom: 12px;
        }

        .strumenti-riga label {
            display: flex;
            flex-direction: column;
            gap: 4px;
            font-size: 11px;
            font-weight: bold;
            color: #5c0000;
            text-transform: uppercase;
        }

        .select-fantasy,
        .input-full {
            border: 1px solid #c7b299;
            background: #fffdf6;
            color: #2b1d0c;
            font-family: 'Georgia', serif;
            font-size: 13px;
            padding: 5px 7px;
        }

        .input-full {
            min-width: 220px;
        }

        .catalogo-compatto {
            max-height: 180px;
            overflow-y: auto;
            border: 1px solid #c7b299;
            background: #fffdf6;
            padding: 8px;
            font-size: 12px;
            line-height: 1.35;
        }

        .riga-catalogo {
            border-bottom: 1px dashed #c7b299;
            padding: 5px 2px;
        }

        .riga-catalogo:last-child {
            border-bottom: none;
        }

        .nota-dati {
            display: block;
            color: #6b4f25;
            font-size: 11px;
            line-height: 1.3;
            margin-top: 3px;
        }

        .mono-piccolo {
            font-size: 11px;
            color: #5c0000;
            font-weight: bold;
        }

        .home-layout {
            display: grid;
            max-width: 520px;
            margin: 12px auto 0 auto;
            gap: 8px;
        }

        .home-main-panel {
            display: grid;
            grid-template-columns: minmax(148px, 174px) minmax(0, 1fr);
            align-items: stretch;
            gap: 10px;
        }

        .home-main-panel.box-sezione {
            margin-bottom: 0;
            overflow-x: hidden;
            padding: 9px;
        }

        .home-actions {
            display: grid;
            grid-template-columns: 1fr;
            gap: 6px;
            align-content: stretch;
            justify-items: center;
        }

        .home-main-panel .home-button {
            min-height: 34px;
            padding: 6px 7px;
        }

        .home-dice-section {
            position: relative;
            border: 2px solid #5c0000;
            background: #fbf7ed;
            padding: 9px;
            box-shadow: inset 0 0 10px rgba(92,0,0,0.05);
            overflow: hidden;
        }

        .home-dice-3d-layer {
            position: absolute;
            z-index: 12;
            inset: 0;
            pointer-events: none;
            opacity: 0;
            transition: opacity 0.12s ease;
        }

        .home-dice-3d-layer.attivo {
            opacity: 1;
        }

        .home-dice-3d-layer canvas {
            display: block;
            width: 100%;
            height: 100%;
        }

        .home-dice-section h4 {
            margin: -5px -4px 8px -4px;
            padding: 5px 8px;
            background: #5c0000;
            color: #fffdf6;
            border-bottom: 2px solid #d4af37;
            font-size: 12px;
            letter-spacing: 1px;
            text-align: center;
            text-transform: uppercase;
        }

        .home-dice-grid {
            display: grid;
            grid-template-columns: repeat(8, minmax(0, 1fr));
            gap: 6px;
        }

        .home-die-card {
            grid-column: span 2;
        }

        .home-die-card:nth-child(5) {
            grid-column: 2 / span 2;
        }

        .home-die-button {
            border: none;
            background: transparent;
            color: #2b1d0c;
            cursor: pointer;
            display: flex;
            gap: 8px;
            align-items: center;
            justify-content: space-between;
            padding: 0;
            font-family: 'Georgia', serif;
            font-weight: bold;
            width: 100%;
        }

        .home-die-card {
            border: 1px solid rgba(92,0,0,0.28);
            border-radius: 4px;
            background: rgba(243, 235, 217, 0.74);
            min-width: 0;
            display: grid;
            grid-template-columns: minmax(0, 1fr) 32px;
            grid-template-areas:
                "label label"
                "shape qty"
                "detail detail";
            gap: 4px 2px;
            min-height: 76px;
            padding: 5px;
            box-shadow: inset 0 0 8px rgba(92,0,0,0.04);
            transition: background-color 0.15s, border-color 0.15s, transform 0.15s;
        }

        .home-die-card:hover {
            background: rgba(245, 235, 214, 0.94);
            border-color: #5c0000;
            transform: translateY(-1px);
        }

        .home-die-card .home-die-button {
            grid-area: shape;
            justify-content: center;
        }

        .home-die-shape {
            --die-clip: inset(0);
            width: 38px;
            height: 38px;
            flex: 0 0 38px;
            background: transparent;
            border: none;
            display: grid;
            place-items: center;
            color: #5c0000;
            font-size: 15px;
            box-shadow: 1px 2px 4px rgba(43,29,12,0.18);
            isolation: isolate;
            position: relative;
            transition: transform 0.15s, background-color 0.15s;
        }

        .home-die-card.is-rolling-3d .home-die-shape {
            opacity: 0.16;
            transform: scale(0.82);
        }

        .home-die-card.is-rolling-3d {
            border-color: rgba(212,175,55,0.78);
            box-shadow: inset 0 0 14px rgba(212,175,55,0.16);
        }

        .home-die-shape::before,
        .home-die-shape::after {
            content: "";
            position: absolute;
            clip-path: var(--die-clip);
            z-index: -1;
        }

        .home-die-shape::before {
            inset: 0;
            background: #5c0000;
        }

        .home-die-shape::after {
            inset: 3px;
            background: #fffdf6;
        }

        .home-die-button:hover .home-die-shape {
            transform: rotate(-2deg);
        }

        .home-die-button:hover .home-die-shape::after {
            background: #f3ebd9;
        }

        .home-die-button.rolling .home-die-shape {
            animation: dado-home-roll 0.28s ease;
        }

        .home-die-label {
            grid-area: label;
            color: #5c0000;
            font-size: 11px;
            letter-spacing: 0.4px;
            text-align: center;
            text-transform: uppercase;
        }

        .home-die-qty {
            grid-area: qty;
            color: #5c0000;
            display: grid;
            gap: 2px;
            justify-items: center;
            font-size: 9px;
            font-weight: bold;
            text-transform: uppercase;
        }

        .home-die-qty input {
            width: 30px;
            border: 1px solid #c7b299;
            background: #fffdf6;
            color: #2b1d0c;
            font-family: 'Georgia', serif;
            font-size: 11px;
            font-weight: bold;
            padding: 2px;
            text-align: center;
        }

        .home-die-breakdown {
            grid-area: detail;
            color: #6b4f25;
            font-size: 10px;
            min-height: 12px;
            overflow-wrap: anywhere;
            text-align: center;
        }

        .shape-d4 {
            --die-clip: polygon(50% 4%, 96% 94%, 4% 94%);
        }

        .shape-d6 {
            --die-clip: inset(0 round 5px);
            border-radius: 5px;
        }

        .shape-d8 {
            --die-clip: polygon(50% 1%, 96% 50%, 50% 99%, 4% 50%);
        }

        .shape-d10 {
            --die-clip: polygon(50% 3%, 97% 38%, 79% 96%, 21% 96%, 3% 38%);
        }

        .shape-d12 {
            --die-clip: polygon(25% 6%, 75% 6%, 98% 50%, 75% 94%, 25% 94%, 2% 50%);
        }

        .shape-d20 {
            --die-clip: polygon(30% 4%, 70% 4%, 96% 30%, 96% 70%, 70% 96%, 30% 96%, 4% 70%, 4% 30%);
        }

        .shape-d100 {
            --die-clip: polygon(50% 0%, 65% 2%, 79% 10%, 90% 21%, 98% 35%, 100% 50%, 98% 65%, 90% 79%, 79% 90%, 65% 98%, 50% 100%, 35% 98%, 21% 90%, 10% 79%, 2% 65%, 0% 50%, 2% 35%, 10% 21%, 21% 10%, 35% 2%);
        }

        @keyframes dado-home-roll {
            0% { transform: rotate(0deg) scale(1); }
            50% { transform: rotate(12deg) scale(1.08); }
            100% { transform: rotate(0deg) scale(1); }
        }

        @media (prefers-reduced-motion: reduce) {
            .home-dice-3d-layer {
                display: none;
            }
        }

        .home-button {
            border: 3px double #d4af37;
            background: #5c0000;
            color: #fffdf6;
            font-family: 'Georgia', serif;
            font-size: 11px;
            font-weight: bold;
            text-transform: uppercase;
            letter-spacing: 0.5px;
            min-height: 42px;
            padding: 7px 6px;
            cursor: pointer;
            box-shadow: 3px 3px 8px rgba(43,29,12,0.22);
            transition: transform 0.15s, background-color 0.15s;
            overflow-wrap: anywhere;
        }

        .home-button:hover {
            background: #7a1111;
            transform: translateY(-1px);
        }

        .home-button.secondary {
            background: #7b5a27;
        }

        .home-button.secondary:hover {
            background: #936c31;
        }

        .home-status {
            display: none;
            min-height: 20px;
            margin-top: 14px;
            color: #5c0000;
            font-weight: bold;
            font-size: 13px;
            text-align: center;
        }

        .home-status:not(:empty) {
            display: block;
        }

        .autosave-status {
            min-height: 16px;
            margin-top: 6px;
            font-size: 11px;
            font-weight: 700;
            letter-spacing: 0;
            color: #3f3526;
            opacity: 0.86;
        }

        .autosave-status[data-state="saving"],
        .autosave-status[data-state="dirty"] {
            color: #7b5a27;
        }

        .autosave-status[data-state="saved"] {
            color: #31533f;
        }

        .autosave-status[data-state="error"] {
            color: #7a1111;
        }

        .wizard-overlay {
            display: none;
            position: fixed;
            inset: 0;
            z-index: 20;
            background: rgba(43, 29, 12, 0.55);
            padding: 24px;
            overflow: auto;
        }

        .wizard-overlay.active {
            display: flex;
            align-items: flex-start;
            justify-content: center;
        }

        .wizard-panel {
            width: var(--scheda-verticale-larghezza);
            max-width: var(--scheda-verticale-larghezza);
            background: #fffdf6;
            border: 3px double #5c0000;
            box-shadow: 7px 7px 20px rgba(0,0,0,0.35);
            padding: 18px;
        }

        .wizard-grid,
        .caratteristiche-wizard {
            display: grid;
            grid-template-columns: repeat(3, minmax(120px, 1fr));
            gap: 12px;
        }

        .wizard-grid.wizard-identity-grid {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            column-gap: 18px;
            row-gap: 12px;
            align-items: end;
        }

        .wizard-identity-grid label {
            display: grid;
            grid-template-rows: auto 34px;
            gap: 5px;
            min-width: 0;
            color: #5c0000;
            font-size: 11px;
            font-weight: bold;
            text-transform: uppercase;
        }

        .wizard-identity-grid input,
        .wizard-identity-grid select {
            box-sizing: border-box;
            width: 100%;
            min-width: 0;
            height: 34px;
        }

        .caratteristiche-wizard {
            grid-template-columns: 1fr;
            gap: 8px;
        }

        .wizard-actions {
            display: flex;
            justify-content: flex-end;
            gap: 10px;
            margin-top: 18px;
            flex-wrap: wrap;
        }

        .button-fantasy {
            border: 2px solid #5c0000;
            background: #5c0000;
            color: #fffdf6;
            cursor: pointer;
            font-family: 'Georgia', serif;
            font-weight: bold;
            padding: 8px 12px;
        }

        .button-fantasy.secondary {
            background: #c7b299;
            color: #3d0000;
        }

        .dice-button {
            border: 1px solid #5c0000;
            background: #c7b299;
            color: #3d0000;
            cursor: pointer;
            font-family: 'Georgia', serif;
            font-size: 12px;
            font-weight: bold;
            margin-left: 6px;
            padding: 4px 7px;
        }

        .caratteristiche-wizard label {
            display: grid;
            grid-template-columns: minmax(76px, 0.8fr) 58px minmax(128px, 1.35fr) 30px;
            gap: 6px;
            align-items: center;
            min-width: 0;
            width: 100%;
        }

        .wizard-dice-area {
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 7px;
            min-width: 0;
        }

        .wizard-stat-control {
            display: grid;
            grid-template-columns: 42px 12px;
            gap: 4px;
            align-items: center;
        }

        .wizard-stat-control .input-corto {
            width: 42px;
            height: 42px;
            border: 2px solid #5c0000;
            border-radius: 50%;
            background: #fffdf6;
            color: #5c0000;
            display: grid;
            font-size: 17px;
            font-weight: bold;
            line-height: 42px;
            padding: 0;
            text-align: center;
            appearance: textfield;
            -moz-appearance: textfield;
        }

        .wizard-stat-control .input-corto::-webkit-outer-spin-button,
        .wizard-stat-control .input-corto::-webkit-inner-spin-button {
            margin: 0;
            -webkit-appearance: none;
        }

        .wizard-stat-control input[readonly] {
            background: #fffdf6;
            cursor: default;
        }

        .stat-move-buttons {
            display: grid;
            gap: 1px;
        }

        .stat-arrow {
            width: 12px;
            height: 14px;
            border: none;
            background: transparent;
            color: #5c0000;
            cursor: pointer;
            font-size: 10px;
            font-weight: bold;
            line-height: 1;
            padding: 0;
        }

        .stat-arrow:hover {
            color: #a00;
            transform: scale(1.18);
        }

        .stat-arrow.placeholder {
            visibility: hidden;
            pointer-events: none;
        }

        .caratteristiche-wizard .dice-button {
            min-width: 32px;
            margin-left: 0;
            padding: 3px 4px;
            font-size: 10px;
            line-height: 1;
        }

        .wizard-stat-label {
            color: #5c0000;
            font-weight: bold;
            font-size: 12px;
            letter-spacing: 0.4px;
            overflow-wrap: anywhere;
            text-transform: uppercase;
        }

        .wizard-race-modifier {
            width: 28px;
            height: 28px;
            border: 1px solid rgba(92, 0, 0, 0.48);
            border-radius: 4px;
            background: rgba(199, 178, 153, 0.42);
            color: #4b3a27;
            display: grid;
            place-items: center;
            font-size: 12px;
            font-weight: bold;
            line-height: 1;
            justify-self: end;
        }

        .wizard-race-modifier.bonus {
            color: #5c0000;
        }

        .wizard-race-modifier.malus {
            color: #16110b;
        }

        .dice-roll {
            display: inline-flex;
            gap: 3px;
            min-height: 26px;
            min-width: 0;
            align-items: center;
            overflow: hidden;
        }

        .die {
            width: 22px;
            height: 22px;
            flex: 0 0 22px;
            border: 1px solid #5c0000;
            border-radius: 5px;
            background: #fffdf6;
            color: #2b1d0c;
            display: grid;
            place-items: center;
            font-size: 12px;
            font-weight: bold;
            box-shadow: 1px 2px 4px rgba(43,29,12,0.25);
            opacity: 0;
            transform: translateY(-14px) rotate(-18deg);
            animation: dado-cade 0.55s cubic-bezier(.2,.8,.25,1.2) forwards;
        }

        .die.scartato {
            background: #eadcc1;
            color: #7b5a27;
            border-style: dashed;
            opacity: 0.65;
        }

        @keyframes dado-cade {
            0% {
                opacity: 0;
                transform: translateY(-16px) rotate(-24deg) scale(0.85);
            }
            60% {
                opacity: 1;
                transform: translateY(2px) rotate(10deg) scale(1.06);
            }
            100% {
                opacity: 1;
                transform: translateY(0) rotate(0deg) scale(1);
            }
        }

        .riepilogo-contatore {
            border: 1px solid #c7b299;
            background: #fffdf6;
            color: #5c0000;
            font-size: 13px;
            font-weight: bold;
            margin: 0 0 10px 0;
            padding: 8px 10px;
            text-align: right;
        }

        .riepilogo-contatore.bottom {
            margin: 10px 0 0 0;
        }

        #cataloghi .cataloghi-aiuto {
            display: block;
            text-align: left;
            color: #5c0000;
            font-size: 12px;
            line-height: 1.25;
            text-transform: none;
        }

        #cataloghi .catalogo-tabella-armi,
        #cataloghi .catalogo-tabella-armature,
        #cataloghi .catalogo-tabella-incantesimi,
        #cataloghi .catalogo-tabella-talenti,
        #cataloghi .catalogo-tabella-oggetti,
        #cataloghi .catalogo-tabella-privilegi {
            table-layout: fixed;
            width: 100%;
            min-width: 0;
        }

        #cataloghi .catalogo-tabella-armi th,
        #cataloghi .catalogo-tabella-armi td,
        #cataloghi .catalogo-tabella-armature th,
        #cataloghi .catalogo-tabella-armature td,
        #cataloghi .catalogo-tabella-incantesimi th,
        #cataloghi .catalogo-tabella-incantesimi td,
        #cataloghi .catalogo-tabella-talenti th,
        #cataloghi .catalogo-tabella-talenti td,
        #cataloghi .catalogo-tabella-oggetti th,
        #cataloghi .catalogo-tabella-oggetti td,
        #cataloghi .catalogo-tabella-privilegi th,
        #cataloghi .catalogo-tabella-privilegi td {
            padding: 5px 3px;
            font-size: 11px;
            line-height: 1.12;
            overflow-wrap: anywhere;
            vertical-align: middle;
        }

        #cataloghi .catalogo-tabella-armi th,
        #cataloghi .catalogo-tabella-armature th,
        #cataloghi .catalogo-tabella-incantesimi th,
        #cataloghi .catalogo-tabella-talenti th,
        #cataloghi .catalogo-tabella-oggetti th,
        #cataloghi .catalogo-tabella-privilegi th {
            white-space: nowrap;
            font-size: 10px;
        }

        #cataloghi .catalogo-tabella-armi th:nth-child(1),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(1) {
            width: 30%;
        }

        #cataloghi .catalogo-tabella-armi th:nth-child(2),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(2),
        #cataloghi .catalogo-tabella-armi th:nth-child(3),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(3) {
            width: 12%;
        }

        #cataloghi .catalogo-tabella-armi th:nth-child(4),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(4) {
            width: 14%;
        }

        #cataloghi .catalogo-tabella-armi th:nth-child(5),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(5),
        #cataloghi .catalogo-tabella-armi th:nth-child(6),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(6),
        #cataloghi .catalogo-tabella-armi th:nth-child(7),
        #cataloghi .catalogo-tabella-armi .catalogo-arma-riga td:nth-child(7) {
            width: 10%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(1),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(1) {
            width: 34%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(2),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(2) {
            width: 9%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(3),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(3) {
            width: 8%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(4),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(4) {
            width: 10%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(5),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(5) {
            width: 13%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(6),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(6) {
            width: 12%;
        }

        #cataloghi .catalogo-tabella-armature th:nth-child(7),
        #cataloghi .catalogo-tabella-armature .catalogo-armatura-riga td:nth-child(7) {
            width: 14%;
        }

        #cataloghi .catalogo-tabella-incantesimi th:nth-child(1),
        #cataloghi .catalogo-tabella-incantesimi .catalogo-incantesimo-riga td:nth-child(1) {
            width: 32%;
        }

        #cataloghi .catalogo-tabella-incantesimi th:nth-child(2),
        #cataloghi .catalogo-tabella-incantesimi .catalogo-incantesimo-riga td:nth-child(2) {
            width: 13%;
        }

        #cataloghi .catalogo-tabella-incantesimi th:nth-child(3),
        #cataloghi .catalogo-tabella-incantesimi .catalogo-incantesimo-riga td:nth-child(3) {
            width: 8%;
        }

        #cataloghi .catalogo-tabella-incantesimi th:nth-child(4),
        #cataloghi .catalogo-tabella-incantesimi .catalogo-incantesimo-riga td:nth-child(4) {
            width: 17%;
        }

        #cataloghi .catalogo-tabella-incantesimi th:nth-child(5),
        #cataloghi .catalogo-tabella-incantesimi .catalogo-incantesimo-riga td:nth-child(5),
        #cataloghi .catalogo-tabella-incantesimi th:nth-child(6),
        #cataloghi .catalogo-tabella-incantesimi .catalogo-incantesimo-riga td:nth-child(6) {
            width: 15%;
        }

        #cataloghi .catalogo-tabella-talenti th:nth-child(1),
        #cataloghi .catalogo-tabella-talenti .catalogo-talento-riga td:nth-child(1) {
            width: 35%;
        }

        #cataloghi .catalogo-tabella-talenti th:nth-child(2),
        #cataloghi .catalogo-tabella-talenti .catalogo-talento-riga td:nth-child(2) {
            width: 17%;
        }

        #cataloghi .catalogo-tabella-talenti th:nth-child(3),
        #cataloghi .catalogo-tabella-talenti .catalogo-talento-riga td:nth-child(3) {
            width: 48%;
        }

        #cataloghi .catalogo-tabella-oggetti th:nth-child(1),
        #cataloghi .catalogo-tabella-oggetti .catalogo-oggetto-riga td:nth-child(1) {
            width: 38%;
        }

        #cataloghi .catalogo-tabella-oggetti th:nth-child(2),
        #cataloghi .catalogo-tabella-oggetti .catalogo-oggetto-riga td:nth-child(2) {
            width: 26%;
        }

        #cataloghi .catalogo-tabella-oggetti th:nth-child(3),
        #cataloghi .catalogo-tabella-oggetti .catalogo-oggetto-riga td:nth-child(3),
        #cataloghi .catalogo-tabella-oggetti th:nth-child(4),
        #cataloghi .catalogo-tabella-oggetti .catalogo-oggetto-riga td:nth-child(4) {
            width: 18%;
        }

        #cataloghi .catalogo-tabella-privilegi th:nth-child(1),
        #cataloghi .catalogo-tabella-privilegi .catalogo-privilegio-riga td:nth-child(1) {
            width: 26%;
        }

        #cataloghi .catalogo-tabella-privilegi th:nth-child(2),
        #cataloghi .catalogo-tabella-privilegi .catalogo-privilegio-riga td:nth-child(2) {
            width: 12%;
        }

        #cataloghi .catalogo-tabella-privilegi th:nth-child(3),
        #cataloghi .catalogo-tabella-privilegi .catalogo-privilegio-riga td:nth-child(3) {
            width: 62%;
        }

        #cataloghi .catalogo-arma-riga td,
        #cataloghi .catalogo-armatura-riga td,
        #cataloghi .catalogo-incantesimo-riga td,
        #cataloghi .catalogo-talento-riga td,
        #cataloghi .catalogo-oggetto-riga td,
        #cataloghi .catalogo-privilegio-riga td {
            border-bottom: 0;
        }

        #cataloghi .catalogo-dettaglio-riga td {
            border-bottom: 1px dashed #c7b299;
            background: rgba(243, 235, 217, 0.62);
            color: #3a2812;
            padding: 3px 6px 7px 6px;
            text-align: left;
        }

        #cataloghi .catalogo-arma-note-label {
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            margin-right: 6px;
            text-transform: uppercase;
        }

        #cataloghi .catalogo-arma-note-label:not(:first-child) {
            margin-left: 12px;
        }

        #cataloghi .catalogo-armatura-dettaglio-label {
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            margin: 0 6px 0 10px;
            text-transform: uppercase;
        }

        #cataloghi .catalogo-armatura-dettaglio-label:first-child {
            margin-left: 0;
        }

        #cataloghi .catalogo-incantesimo-effetto-label {
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            margin-right: 6px;
            text-transform: uppercase;
        }

        #cataloghi .catalogo-talento-effetto-label {
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            margin-right: 6px;
            text-transform: uppercase;
        }

        #cataloghi .catalogo-oggetto-descrizione-label {
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            margin-right: 6px;
            text-transform: uppercase;
        }

        #cataloghi .catalogo-privilegio-dettaglio-label {
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            margin: 0 6px 0 10px;
            text-transform: uppercase;
        }

        #cataloghi .catalogo-privilegio-dettaglio-label:first-child {
            margin-left: 0;
        }

        #cataloghi .catalogo-arma-note-testo {
            font-size: 11px;
            line-height: 1.25;
        }

        #cataloghi .catalogo-armatura-dettaglio-testo {
            font-size: 11px;
            line-height: 1.25;
        }

        #cataloghi .catalogo-incantesimo-effetto-testo {
            font-size: 11px;
            line-height: 1.25;
        }

        #cataloghi .catalogo-talento-effetto-testo {
            font-size: 11px;
            line-height: 1.25;
        }

        #cataloghi .catalogo-oggetto-descrizione-testo {
            font-size: 11px;
            line-height: 1.25;
        }

        #cataloghi .catalogo-privilegio-dettaglio-testo {
            font-size: 11px;
            line-height: 1.25;
        }

        #privilegi-classe .privilegi-aiuto {
            display: block;
            text-align: left;
        }

        .privilegi-classi-riepilogo {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(92px, 1fr));
            gap: 6px;
            margin-bottom: 10px;
        }

        .privilegi-classe-chip,
        .privilegio-card,
        .privilegio-effetto-card,
        .privilegio-attivabile-card,
        .privilegio-contatore-card,
        .privilegio-scelta-card,
        .capacita-razziale-card,
        .talento-attivo-card {
            border: 1px solid rgba(92, 0, 0, 0.35);
            border-radius: 6px;
            background: rgba(255, 253, 246, 0.74);
            box-shadow: inset 0 0 8px rgba(92, 0, 0, 0.05);
            min-width: 0;
        }

        .privilegi-classe-chip {
            padding: 7px 8px;
            text-align: center;
        }

        .privilegi-classe-chip span {
            color: #5c0000;
            display: block;
            font-size: 10px;
            font-weight: bold;
            text-transform: uppercase;
        }

        .privilegi-classe-chip b {
            color: #2b1d0c;
            display: block;
            font-size: 16px;
            margin-top: 2px;
        }

        .privilegi-card-grid {
            display: grid;
            grid-template-columns: 1fr;
            gap: 8px;
            min-width: 0;
        }

        .privilegi-card-grid-compatto {
            grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
        }

        .privilegio-card,
        .privilegio-effetto-card,
        .privilegio-attivabile-card,
        .privilegio-contatore-card,
        .privilegio-scelta-card,
        .capacita-razziale-card,
        .talento-attivo-card {
            padding: 8px;
        }

        .privilegio-card-head,
        .talento-attivo-head {
            align-items: center;
            border-bottom: 1px dashed rgba(92, 0, 0, 0.28);
            display: flex;
            gap: 8px;
            justify-content: space-between;
            margin-bottom: 6px;
            padding-bottom: 5px;
        }

        .privilegio-card-head b,
        .talento-attivo-head b {
            color: #5c0000;
            font-size: 12px;
            text-transform: uppercase;
        }

        .privilegio-card-head span,
        .talento-attivo-head span {
            color: #2b1d0c;
            font-size: 13px;
            font-weight: bold;
            overflow-wrap: anywhere;
        }

        .privilegio-card-body,
        .talento-attivo-body {
            color: #3a2812;
            font-size: 12px;
            line-height: 1.25;
            overflow-wrap: anywhere;
            text-align: left;
        }

        .privilegio-card-meta {
            display: flex;
            flex-wrap: wrap;
            gap: 5px;
            margin-top: 6px;
        }

        .privilegio-meta-pill,
        .capacita-razziale-pill {
            border: 1px solid rgba(92, 0, 0, 0.24);
            border-radius: 4px;
            background: rgba(199, 178, 153, 0.35);
            color: #3a2812;
            font-size: 11px;
            font-weight: bold;
            padding: 3px 5px;
        }

        .capacita-razziale-card {
            text-align: center;
        }

        .capacita-razziale-card span {
            color: #5c0000;
            display: block;
            font-size: 10px;
            font-weight: bold;
            text-transform: uppercase;
        }

        .capacita-razziale-card b {
            color: #2b1d0c;
            display: block;
            font-size: 15px;
            margin-top: 2px;
        }

        .privilegi-empty {
            color: #5c0000;
            font-size: 12px;
            font-style: italic;
            padding: 6px 0;
            text-align: left;
        }

        .privilegio-effetto-automatico {
            border-color: rgba(92, 0, 0, 0.55);
            background: rgba(255, 248, 226, 0.84);
        }

        .privilegio-effetto-riepilogo {
            background: rgba(255, 253, 246, 0.78);
        }

        .privilegio-effetto-scelta {
            border-style: dashed;
            background: rgba(199, 178, 153, 0.28);
        }

        .privilegio-effetto-non-applicato {
            opacity: 0.84;
        }

        .privilegio-attivabile-card {
            background: rgba(255, 253, 246, 0.82);
        }

        .privilegio-attivabile-on {
            border-color: rgba(92, 0, 0, 0.65);
            background: rgba(255, 248, 226, 0.9);
        }

        .privilegio-attivabile-toggle {
            align-items: center;
            display: flex;
            gap: 7px;
            margin-top: 8px;
            color: #3a2812;
            cursor: pointer;
            font-size: 12px;
            font-weight: bold;
            text-align: left;
        }

        .privilegio-attivabile-toggle input {
            accent-color: #5c0000;
            flex: 0 0 auto;
            width: 18px;
            height: 18px;
        }

        .privilegio-contatore-card {
            background: rgba(255, 253, 246, 0.82);
        }

        .privilegio-contatore-meta {
            color: #5c0000;
            font-size: 11px;
            font-weight: bold;
            margin-bottom: 5px;
            text-transform: uppercase;
        }

        .privilegio-contatore-controlli {
            align-items: center;
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            justify-content: flex-start;
            margin-top: 8px;
        }

        .priv-contatore-btn,
        .priv-contatore-reset {
            background: rgba(92, 0, 0, 0.12);
            border: 1px solid rgba(92, 0, 0, 0.45);
            border-radius: 4px;
            color: #5c0000;
            cursor: pointer;
            font-family: Georgia, serif;
            font-weight: bold;
            min-height: 28px;
        }

        .priv-contatore-btn {
            width: 30px;
        }

        .priv-contatore-reset {
            padding: 4px 8px;
        }

        .priv-contatore-input {
            font-size: 16px;
            font-weight: bold;
            text-align: center !important;
            width: 48px;
        }

        .privilegio-scelta-card {
            background: rgba(255, 253, 246, 0.82);
        }

        .privilegio-scelta-pendente {
            border-style: dashed;
        }

        .privilegio-scelta-completa {
            border-color: rgba(92, 0, 0, 0.55);
        }

        .privilegio-scelta-controllo {
            margin-top: 8px;
        }

        .priv-scelta-campo-riga {
            align-items: center;
            display: flex;
            gap: 6px;
        }

        .priv-scelta-campo {
            box-sizing: border-box;
            min-width: 0;
            width: 100%;
        }

        .priv-scelta-catalogo {
            background: rgba(92, 0, 0, 0.12);
            border: 1px solid rgba(92, 0, 0, 0.45);
            border-radius: 4px;
            color: #5c0000;
            cursor: pointer;
            flex: 0 0 auto;
            font-family: Georgia, serif;
            font-size: 11px;
            font-weight: bold;
            min-height: 28px;
            padding: 4px 8px;
        }

        .box-caratteristiche-mini .stat-grid {
            display: grid;
            grid-template-columns: repeat(6, minmax(0, 1fr));
            gap: 6px;
            min-width: 0;
            overflow-x: hidden;
            width: 100%;
        }

        .box-caratteristiche-mini {
            --stat-banner-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20120%20120'%3E%3Cpath%20d='M20%2016%20H35%20C38%207%2043%204%2052%204%20H68%20C77%204%2082%207%2085%2016%20H100%20C111%2016%20116%2023%20116%2030%20C116%2037%20110%2044%20100%2044%20H86%20V79%20C86%2090%2075%2099%2060%20116%20C45%2099%2034%2090%2034%2079%20V44%20H20%20C10%2044%204%2037%204%2030%20C4%2023%209%2016%2020%2016%20Z'%20fill='black'/%3E%3C/svg%3E");
        }

        .box-caratteristiche-mini .riga-caratteristica {
            display: grid;
            grid-template-columns: 1fr;
            justify-items: center;
            gap: 3px;
            margin-bottom: 0;
            min-width: 0;
            padding: 6px 3px 7px;
            overflow: visible;
        }

        .box-caratteristiche-mini .caratt-label {
            width: auto;
            font-size: 11px;
            text-align: center;
            overflow-wrap: anywhere;
        }

        .box-caratteristiche-mini .cerchio-modificatore {
            order: 2;
            width: clamp(50px, 100%, 74px);
            height: 72px;
            border: 0;
            border-radius: 0;
            background: linear-gradient(180deg, rgba(252, 244, 220, 0.95), rgba(222, 198, 154, 0.93));
            -webkit-mask: var(--stat-banner-mask) center / 100% 100% no-repeat;
            mask: var(--stat-banner-mask) center / 100% 100% no-repeat;
            color: #5c0000;
            font-size: 24px;
            font-weight: 900;
            line-height: 1;
            position: relative;
            filter:
                drop-shadow(1px 0 0 rgba(92, 0, 0, 0.88))
                drop-shadow(-1px 0 0 rgba(92, 0, 0, 0.88))
                drop-shadow(0 1px 0 rgba(92, 0, 0, 0.88))
                drop-shadow(0 -1px 0 rgba(92, 0, 0, 0.88))
                drop-shadow(0 2px 3px rgba(45, 10, 8, 0.24));
            text-shadow: 0 1px 0 rgba(255, 253, 246, 0.45);
            overflow: hidden;
        }

        .box-caratteristiche-mini .cerchio-modificatore::before {
            content: none;
        }

        .box-caratteristiche-mini .stat-valori {
            display: contents;
        }

        .box-caratteristiche-mini .valore-caratteristica {
            order: 3;
            color: #2b1d0c;
            font-size: 16px;
            font-weight: bold;
            text-align: center;
            line-height: 1;
        }

        .box-caratteristiche-mini .stat-temp {
            order: 4;
            display: grid;
            grid-template-columns: 1fr;
            align-items: center;
            justify-content: center;
            justify-items: center;
            gap: 2px;
            margin-top: 0;
            font-size: 10px;
            font-weight: bold;
            color: #3d0000;
            line-height: 1;
        }

        .box-caratteristiche-mini .stat-temp input {
            width: 42px;
            min-width: 0;
            height: 22px;
            padding: 1px 2px;
            text-align: center;
            font-size: 11px;
        }

        .resistenze-grid {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 6px;
            margin-top: 8px;
        }

        .ca-extra-grid {
            display: grid;
            grid-template-columns: repeat(5, minmax(0, 1fr));
            gap: 6px;
            margin-top: 8px;
        }

        .resistenze-grid label {
            display: grid;
            grid-template-columns: minmax(0, 1fr) 46px;
            align-items: center;
            gap: 4px;
            min-width: 0;
            padding: 6px;
            border: 1px solid rgba(92, 0, 0, 0.3);
            background: rgba(245, 235, 214, 0.56);
            border-radius: 6px;
            color: #2b1d0c;
            font-size: 11px;
            font-weight: bold;
        }

        .resistenze-grid input {
            width: 46px;
            text-align: center;
            padding-left: 2px;
            padding-right: 2px;
        }

        .totale-evidenza {
            color: #5c0000;
            font-size: 14px;
        }

        .bonus-mini {
            display: block;
            margin-top: 2px;
            color: #5c0000;
            font-size: 9px;
            line-height: 1.1;
            white-space: nowrap;
        }

        #caratteristiche .tabella-ts,
        #caratteristiche .tabella-combattimento {
            width: 100%;
            min-width: 0;
            table-layout: fixed;
        }

        #caratteristiche .tabella-ts th,
        #caratteristiche .tabella-ts td,
        #caratteristiche .tabella-combattimento th,
        #caratteristiche .tabella-combattimento td {
            font-size: 10px;
            padding-left: 2px;
            padding-right: 2px;
            overflow-wrap: normal;
            word-break: normal;
        }

        #caratteristiche .tabella-ts th,
        #caratteristiche .tabella-combattimento th {
            white-space: nowrap;
            line-height: 1.05;
            letter-spacing: 0;
        }

        #caratteristiche .tabella-ts input.input-corto,
        #caratteristiche .tabella-combattimento input.input-corto {
            width: 34px;
            padding-left: 1px;
            padding-right: 1px;
        }

        #abilita .box-sezione {
            overflow-x: hidden;
        }

        #abilita .tabella-abilita-compatta {
            width: 100%;
            min-width: 0;
            table-layout: fixed;
            font-size: 11px;
        }

        #abilita .tabella-abilita-compatta th,
        #abilita .tabella-abilita-compatta td {
            padding: 4px 2px;
            min-width: 0;
            white-space: normal;
            overflow-wrap: anywhere;
            line-height: 1.12;
        }

        #abilita .tabella-abilita-compatta th:first-child,
        #abilita .tabella-abilita-compatta td:first-child {
            width: 6%;
            padding-left: 0;
            padding-right: 0;
            text-align: center;
        }

        #abilita .tabella-abilita-compatta th:nth-child(2),
        #abilita .tabella-abilita-compatta td:nth-child(2) {
            width: 27%;
            text-align: left;
        }

        #abilita .tabella-abilita-compatta th:nth-child(n+3),
        #abilita .tabella-abilita-compatta td:nth-child(n+3) {
            width: 13.4%;
        }

        #abilita .abilita-check-readonly {
            position: relative;
            display: inline-block;
            width: 14px;
            height: 14px;
            margin: 0;
            border: 1.5px solid #241a10;
            border-radius: 2px;
            background: #fffdf6;
            opacity: 1;
            color: #241a10;
            pointer-events: none;
            vertical-align: middle;
        }

        #abilita .abilita-check-readonly.selezionata::after {
            content: "";
            position: absolute;
            left: 3px;
            top: -1px;
            width: 5px;
            height: 10px;
            border-right: 3px solid #8a1a1a;
            border-bottom: 3px solid #8a1a1a;
            transform: rotate(42deg);
        }

        #abilita .tabella-abilita-compatta .input-corto,
        #abilita .tabella-abilita-compatta select {
            width: 100%;
            min-width: 0;
            max-width: 48px;
            font-size: 11px;
        }

        #abilita .abilita-tipo-regola {
            display: block;
            margin-top: 2px;
            color: #6b4f25;
            font-size: 8px;
            font-weight: normal;
            line-height: 1;
            text-transform: uppercase;
        }

        #abilita tr.abilita-incrociata .abilita-tipo-regola {
            color: #241a10;
        }

        #abilita .abilita-sinergia {
            color: #8a1a1a;
            font-weight: bold;
        }

        #abilita .abilita-nome-custom {
            width: 100%;
            min-height: 34px;
            padding: 2px;
            resize: vertical;
            line-height: 1.1;
            text-align: left;
        }

        #caratteristiche .grid-combat {
            grid-template-columns: minmax(0, 1fr) minmax(0, 1.5fr);
            gap: 12px;
        }

        #caratteristiche .grid-combat > div,
        #caratteristiche .box-sezione {
            min-width: 0;
        }

        #caratteristiche .box-sezione {
            overflow-x: auto;
        }

        #caratteristiche .box-caratteristiche-mini {
            overflow-x: hidden;
        }

        #caratteristiche .box-sezione h4 {
            margin: -10px -8px 12px -8px;
        }

        #caratteristiche input,
        #caratteristiche select {
            max-width: 100%;
        }

        .caratteristiche-badges {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 10px;
        }

        #caratteristiche .riquadro-ca-totale {
            min-width: 0;
            padding: 10px 8px;
            margin-bottom: 12px;
        }

        #caratteristiche .box-sezione {
            margin-bottom: 12px;
        }

        #caratteristiche .box-caratteristiche-mini {
            margin-bottom: 12px;
        }

        #caratteristiche .tabella-fantasy {
            margin-top: 6px;
        }

        #caratteristiche .caratteristiche-badges .valore-ca-grande {
            font-size: 26px;
            margin-top: 3px;
        }

        #caratteristiche .caratteristiche-badges span {
            overflow-wrap: anywhere;
        }

        .ca-summary-integrata,
        .pf-summary-integrata {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 8px;
            margin-bottom: 8px;
        }

        .ca-layout-integrata {
            display: grid;
            grid-template-columns: minmax(92px, 112px) minmax(0, 1fr);
            align-items: stretch;
            gap: 8px;
            margin-bottom: 8px;
            min-width: 0;
        }

        .ca-main-card {
            --ca-shield-mask: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20100%20100'%3E%3Cpath%20d='M50%204%20C43%2012%2031%2018%2016%2018%20C14%2049%2023%2076%2050%2096%20C77%2076%2086%2049%2084%2018%20C69%2018%2057%2012%2050%204%20Z'%20fill='black'/%3E%3C/svg%3E");
            aspect-ratio: 1 / 1;
            min-height: 104px;
            border: 0;
            background: linear-gradient(180deg, rgba(92, 0, 0, 0.88), rgba(45, 10, 8, 0.96));
            clip-path: none;
            -webkit-mask: var(--ca-shield-mask) center / 100% 100% no-repeat;
            mask: var(--ca-shield-mask) center / 100% 100% no-repeat;
            color: #5c0000;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 4px;
            padding: 7px 6px;
            text-align: center;
            text-transform: uppercase;
            filter: drop-shadow(0 2px 4px rgba(45, 10, 8, 0.28));
            position: relative;
        }

        .ca-main-card::before {
            content: "";
            position: absolute;
            inset: 5px;
            background: linear-gradient(180deg, rgba(252, 244, 220, 0.92), rgba(222, 198, 154, 0.9));
            clip-path: none;
            -webkit-mask: var(--ca-shield-mask) center / 100% 100% no-repeat;
            mask: var(--ca-shield-mask) center / 100% 100% no-repeat;
            z-index: 0;
        }

        .ca-main-card > span,
        .ca-main-card > b {
            position: relative;
            z-index: 1;
        }

        .ca-main-card > span {
            font-size: 13px;
            font-weight: 900;
            line-height: 1;
        }

        .ca-main-card > b {
            color: #5c0000;
            font-size: 38px;
            line-height: 0.95;
        }

        .ca-components-wrap {
            display: grid;
            grid-template-rows: auto minmax(0, 1fr);
            gap: 5px;
            min-width: 0;
        }

        .ca-formula-line {
            display: grid;
            grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
            align-items: center;
            gap: 6px;
            color: #5c0000;
            font-size: 12px;
            font-weight: 900;
            line-height: 1;
            text-align: center;
            text-transform: uppercase;
        }

        .ca-formula-line::before,
        .ca-formula-line::after {
            content: "";
            height: 1px;
            background: rgba(92, 0, 0, 0.42);
        }

        .ca-formula-line span {
            white-space: nowrap;
        }

        .ca-components-grid {
            display: grid;
            grid-template-columns: repeat(4, minmax(0, 1fr));
            grid-template-rows: repeat(2, minmax(0, 1fr));
            gap: 5px;
            min-width: 0;
        }

        .ca-component-card {
            border: 1px solid rgba(92,0,0,0.28);
            background: rgba(243, 235, 217, 0.74);
            border-radius: 4px;
            color: #5c0000;
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 3px;
            min-width: 0;
            min-height: 48px;
            padding: 4px 2px;
            text-align: center;
            font-size: 9px;
            font-weight: bold;
            line-height: 1;
            text-transform: uppercase;
        }

        .ca-component-card b {
            display: block;
            color: #5c0000;
            font-size: 16px;
            line-height: 1;
            text-transform: none;
        }

        #caratteristiche .ca-component-card input.input-corto {
            width: 38px;
            height: 22px;
            min-width: 0;
            padding: 1px 2px;
            text-align: center;
            font-size: 12px;
        }

        .pf-summary-integrata {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        .caratteristiche-duo {
            display: grid;
            grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
            gap: 12px;
            align-items: stretch;
            margin-bottom: 12px;
            min-width: 0;
        }

        .caratteristiche-duo .box-sezione {
            margin-bottom: 0 !important;
            min-width: 0;
        }

        .ca-card-integrata,
        .pf-card-integrata {
            border: 1px solid rgba(92,0,0,0.28);
            background: rgba(243, 235, 217, 0.74);
            border-radius: 4px;
            color: #5c0000;
            font-size: 11px;
            font-weight: bold;
            min-height: 48px;
            padding: 5px 4px;
            text-align: center;
            text-transform: uppercase;
            line-height: 1.05;
            overflow: hidden;
            overflow-wrap: anywhere;
            word-break: normal;
        }

        .ca-card-integrata b,
        .pf-card-integrata b {
            display: block;
            color: #5c0000;
            font-size: 20px;
            line-height: 1.1;
            margin-top: 2px;
            text-transform: none;
            max-width: 100%;
            overflow-wrap: anywhere;
            word-break: normal;
        }

        #ca-des-max {
            font-size: 16px;
        }

        .pf-card-integrata.totale {
            border-color: rgba(160,0,0,0.45);
        }

        .pf-card-integrata.totale b {
            color: #a00;
        }

        .pf-card-integrata,
        .pf-card-integrata.principale {
            grid-column: auto;
        }

        .pf-card-integrata input {
            width: 70px;
            border-bottom-color: #5c0000;
            color: #5c0000;
            font-size: 24px;
            font-weight: bold;
        }

        .pf-summary-integrata .pf-card-integrata {
            font-size: 10px;
            line-height: 1.15;
            min-height: 52px;
            padding: 6px 7px;
        }

        .pf-summary-integrata .pf-card-integrata b {
            font-size: 20px;
            line-height: 1.1;
            margin-top: 2px;
        }

        .pf-summary-integrata .pf-card-integrata input {
            font-size: 22px;
            line-height: 1;
            width: 64px;
        }

        #caratteristiche .pf-summary-integrata .pf-card-integrata input.input-corto {
            width: 64px;
            max-width: 100%;
            height: 28px;
            font-size: 22px;
            line-height: 1;
            padding: 0;
            text-align: center;
        }

        #caratteristiche .box-punti-ferita {
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }

        #caratteristiche .box-punti-ferita .pf-summary-integrata {
            flex: 1 1 auto;
            grid-template-rows: minmax(56px, 1fr) minmax(56px, 1fr) minmax(92px, 1.25fr);
            gap: 6px;
            height: auto;
            margin-bottom: 0;
            min-height: 0;
        }

        #caratteristiche .box-punti-ferita .pf-card-integrata:not(.pf-attuali-card) {
            min-height: 56px;
            padding: 6px 5px;
            font-size: 9px;
            line-height: 1.05;
        }

        #caratteristiche .box-punti-ferita .pf-card-integrata:not(.pf-attuali-card) b {
            font-size: 18px;
            line-height: 1;
            margin-top: 3px;
        }

        #caratteristiche .box-punti-ferita .pf-card-integrata:not(.pf-attuali-card) input.input-corto {
            width: 54px;
            height: 25px;
            font-size: 18px;
        }

        #caratteristiche .pf-attuali-card {
            grid-column: 1 / -1;
            min-height: 92px;
            border-color: rgba(160, 0, 0, 0.52);
            background: linear-gradient(180deg, rgba(252, 244, 220, 0.88), rgba(232, 212, 174, 0.9));
            display: flex;
            flex-direction: column;
            justify-content: center;
        }

        #caratteristiche .pf-attuali-card b {
            margin-top: 4px;
        }

        #caratteristiche .pf-summary-integrata .pf-attuali-card input.input-corto {
            color: #a00;
            font-size: 34px;
            height: 38px;
            width: 82px;
        }

        #caratteristiche .box-resistenze .resistenze-grid {
            grid-template-columns: 1fr;
            gap: 6px;
        }

        #caratteristiche .box-resistenze .resistenze-grid label {
            min-height: 34px;
            padding: 5px 6px;
            grid-template-columns: minmax(0, 1fr) 46px;
        }

        #caratteristiche .box-resistenze .nota-dati {
            margin-top: 7px;
            font-size: 10px;
            line-height: 1.2;
        }

        .pf-runtime-bonus {
            display: block;
            min-height: 13px;
            margin-top: 3px;
            color: #31533f;
            font-size: 10px;
            font-weight: 800;
            line-height: 1.1;
            text-transform: none;
        }

        #tabella-componenti-ca {
            table-layout: fixed;
        }

        #tabella-componenti-ca th,
        #tabella-componenti-ca td {
            padding: 4px 3px;
            font-size: 10px;
            line-height: 1.1;
        }

        #tabella-componenti-ca .input-corto {
            width: 34px;
            font-size: 12px;
        }

        .peso-summary {
            display: grid;
            grid-template-columns: repeat(6, minmax(0, 1fr));
            gap: 8px;
            text-align: center;
        }

        .peso-card {
            border: 1px solid rgba(92,0,0,0.28);
            background: rgba(243, 235, 217, 0.74);
            border-radius: 4px;
            box-shadow: inset 0 0 8px rgba(92,0,0,0.04);
            color: #5c0000;
            font-size: 11px;
            font-weight: bold;
            min-height: 58px;
            padding: 7px 8px;
            text-transform: uppercase;
        }

        .peso-card b {
            display: block;
            color: #5c0000;
            font-size: 17px;
            margin-top: 3px;
            text-transform: none;
        }

        .peso-summary .peso-card {
            grid-column: span 2;
        }

        .peso-card.movimento-mezza-riga {
            grid-column: span 3;
        }

        .peso-card .nota-dati {
            text-transform: none;
        }

        .risultato-filtro {
            border: 1px solid #c7b299;
            background: #fffdf6;
            padding: 8px;
            min-height: 34px;
            font-size: 12px;
            margin-bottom: 12px;
        }

        .azioni-tabella {
            display: flex;
            justify-content: flex-end;
            margin-bottom: 8px;
        }

        .magic-config-row {
            margin-bottom: 15px;
            display: flex;
            gap: 15px;
            align-items: center;
        }

        .caster-buttons {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 8px;
            flex: 1;
        }

        .caster-button {
            border: 2px solid #5c0000;
            background: #c7b299;
            color: #3d0000;
            cursor: pointer;
            font-family: 'Georgia', serif;
            font-size: 12px;
            font-weight: bold;
            padding: 8px 6px;
            text-align: center;
        }

        .caster-button.active {
            background: #5c0000;
            color: #fffdf6;
            border-color: #d4af37;
        }

        .caster-button:disabled {
            cursor: not-allowed;
            opacity: 0.45;
        }

        #incantesimi .box-sezione {
            overflow-x: hidden;
        }

        #incantesimi .tabella-fantasy {
            table-layout: fixed;
            width: 100%;
        }

        #incantesimi .inc-riga select,
        #incantesimi .inc-riga input {
            width: 100%;
        }

        #incantesimi .inc-info {
            display: block;
            margin-top: 5px;
            color: #5c0000;
            line-height: 1.25;
            white-space: normal;
            overflow-wrap: anywhere;
        }

        #armi-armature .box-sezione {
            overflow-x: hidden;
        }

        #armi-armature .tabella-fantasy {
            table-layout: fixed;
            width: 100%;
        }

        #armi-armature .registro-equip-riga select,
        #armi-armature .registro-equip-riga input {
            width: 100%;
        }

        #armi-armature .registro-armi-grid {
            display: grid;
            gap: 10px;
            min-width: 0;
        }

        #armi-armature .registro-arma-scheda {
            display: grid;
            gap: 8px;
            min-width: 0;
            padding: 8px;
            border: 1px solid rgba(92, 0, 0, 0.28);
            border-radius: 4px;
            background: rgba(243, 235, 217, 0.74);
            box-shadow: inset 0 0 8px rgba(92, 0, 0, 0.04);
        }

        #armi-armature .registro-arma-scheda h5 {
            display: flex;
            align-items: center;
            gap: 8px;
            margin: -3px -3px 0;
            padding: 5px 8px;
            border-bottom: 1px solid rgba(92, 0, 0, 0.24);
            color: #5c0000;
            font-size: 11px;
            line-height: 1.2;
            text-align: left;
            text-transform: uppercase;
            overflow-wrap: anywhere;
        }

        #armi-armature .registro-arma-riga {
            display: grid;
            gap: 8px;
            min-width: 0;
        }

        #armi-armature .registro-arma-riga-doppia {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        #armi-armature .registro-arma-riga-tripla {
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }

        #armi-armature .registro-arma-campo {
            display: grid;
            gap: 4px;
            min-width: 0;
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            line-height: 1.1;
            text-align: left;
            text-transform: uppercase;
        }

        #armi-armature .registro-arma-campo select,
        #armi-armature .registro-arma-campo input {
            width: 100%;
            min-width: 0;
            max-width: none;
            text-align: left;
            text-transform: none;
        }

        #armi-armature .registro-protezioni-grid {
            display: grid;
            gap: 10px;
            min-width: 0;
        }

        #armi-armature .registro-protezione-scheda {
            display: grid;
            gap: 8px;
            min-width: 0;
            padding: 8px;
            border: 1px solid rgba(92, 0, 0, 0.28);
            border-radius: 4px;
            background: rgba(243, 235, 217, 0.74);
            box-shadow: inset 0 0 8px rgba(92, 0, 0, 0.04);
        }

        #armi-armature .registro-protezione-scheda h5 {
            display: flex;
            align-items: center;
            gap: 8px;
            margin: -3px -3px 0;
            padding: 5px 8px;
            border-bottom: 1px solid rgba(92, 0, 0, 0.24);
            color: #5c0000;
            font-size: 11px;
            line-height: 1.2;
            text-align: left;
            text-transform: uppercase;
            overflow-wrap: anywhere;
        }

        #armi-armature .registro-protezione-riga {
            display: grid;
            gap: 8px;
            min-width: 0;
        }

        #armi-armature .registro-protezione-riga-doppia {
            grid-template-columns: repeat(2, minmax(0, 1fr));
        }

        #armi-armature .registro-protezione-riga-tripla {
            grid-template-columns: repeat(3, minmax(0, 1fr));
        }

        #armi-armature .registro-protezione-campo {
            display: grid;
            gap: 4px;
            min-width: 0;
            color: #5c0000;
            font-size: 10px;
            font-weight: bold;
            line-height: 1.1;
            text-align: left;
            text-transform: uppercase;
        }

        #armi-armature .registro-protezione-campo select,
        #armi-armature .registro-protezione-campo input {
            width: 100%;
            min-width: 0;
            max-width: none;
            text-align: left;
            text-transform: none;
        }

        #armi-armature .registro-slot-select-nascosto {
            display: none;
        }

        #armi-armature .registro-slot-dettagli {
            display: grid;
            gap: 8px;
            min-width: 0;
        }

        #armi-armature .registro-slot-trigger {
            display: block;
            flex: 1 1 auto;
            width: auto;
            min-width: 0;
            padding: 0;
            border: 0;
            background: transparent;
            color: inherit;
            font: inherit;
            line-height: inherit;
            text-align: left;
            text-transform: inherit;
            cursor: pointer;
        }

        #armi-armature .registro-slot-stato {
            display: inline-flex;
            flex: 0 0 auto;
            align-items: center;
            gap: 6px;
            color: #5c0000;
            font-family: Georgia, serif;
            font-size: 10px;
            font-weight: bold;
            line-height: 1;
            text-transform: none;
            cursor: pointer;
        }

        #armi-armature .registro-slot-stati {
            display: flex;
            flex: 0 0 auto;
            align-items: center;
            justify-content: flex-end;
            gap: 8px;
            min-width: 0;
        }

        #armi-armature .registro-ca-badge {
            display: inline-flex;
            flex: 0 0 auto;
            align-items: center;
            justify-content: center;
            min-height: 18px;
            padding: 2px 6px;
            border: 1px solid rgba(92, 0, 0, 0.36);
            border-radius: 4px;
            color: #5c0000;
            background: rgba(255, 253, 246, 0.72);
            font-size: 9px;
            font-weight: 800;
            line-height: 1;
            text-transform: none;
            white-space: nowrap;
        }

        #armi-armature .registro-ca-badge[hidden] {
            display: none !important;
        }

        #armi-armature .registro-ca-badge.applicata {
            border-color: rgba(92, 0, 0, 0.58);
            color: #fff7df;
            background: #5c0000;
        }

        #armi-armature .registro-ca-badge.non-applicata {
            color: #2b1d0c;
            background: rgba(234, 220, 187, 0.76);
        }

        #armi-armature .registro-slot-stato input {
            position: absolute;
            width: 1px;
            height: 1px;
            opacity: 0;
            pointer-events: none;
        }

        #armi-armature .registro-slot-switch {
            position: relative;
            display: inline-block;
            width: 30px;
            height: 16px;
            border: 1px solid #8b7355;
            border-radius: 9px;
            background: #d8cfc0;
            transition: background 0.15s ease;
        }

        #armi-armature .registro-slot-switch::after {
            content: "";
            position: absolute;
            top: 2px;
            left: 2px;
            width: 10px;
            height: 10px;
            border-radius: 50%;
            background: #fffdf6;
            box-shadow: 0 1px 2px rgba(46, 22, 10, 0.3);
            transition: transform 0.15s ease;
        }

        #armi-armature .registro-slot-stato input:checked + .registro-slot-switch {
            border-color: #5c0000;
            background: #5c0000;
        }

        #armi-armature .registro-slot-stato input:checked + .registro-slot-switch::after {
            transform: translateX(14px);
        }

        #armi-armature .registro-slot-stato-testo.disattiva {
            color: #1f1a16;
        }

        #armi-armature .registro-slot-stato input:focus-visible + .registro-slot-switch {
            outline: 2px solid #d4af37;
            outline-offset: 2px;
        }

        #armi-armature .registro-slot-trigger:hover,
        #armi-armature .registro-slot-trigger:focus-visible {
            color: #8a1a1a;
            outline: none;
        }

        #armi-armature .registro-slot-nome-display {
            cursor: pointer;
        }

        #armi-armature .registro-slot-nome-display:hover,
        #armi-armature .registro-slot-nome-display:focus {
            border-color: #8a1a1a;
            outline: none;
        }

        #armi-armature .registro-slot-vuoto {
            border-style: dashed;
            background: rgba(243, 235, 217, 0.42);
        }

        #armi-armature .registro-slot-vuoto .registro-slot-dettagli {
            display: none;
        }

        #armi-armature .registro-slot-vuoto h5 {
            margin: -3px;
            border-bottom: 0;
        }

        #armi-armature .registro-slot-vuoto .registro-slot-stato {
            display: none;
        }

        #armi-armature .registro-slot-vuoto .registro-slot-stati {
            display: none;
        }

        #armi-armature .armi-armature-aiuto {
            margin-bottom: 10px;
            text-align: left;
        }

        @media (max-width: 430px) {
            #armi-armature .registro-slot-stati {
                gap: 5px;
            }

            #armi-armature .registro-slot-stato {
                gap: 3px;
                font-size: 8px;
            }

            #armi-armature .registro-slot-switch {
                width: 26px;
                height: 14px;
            }

            #armi-armature .registro-slot-switch::after {
                top: 1px;
                left: 1px;
            }

            #armi-armature .registro-slot-stato input:checked + .registro-slot-switch::after {
                transform: translateX(12px);
            }
        }

        #armi-armature .registro-slot-vuoto .registro-slot-trigger {
            padding: 8px;
            text-align: center;
        }

        #armi-armature .registro-slot-nascosto {
            display: none;
        }

        .registro-equip-action-menu {
            position: fixed;
            z-index: 10030;
            display: grid;
            min-width: 190px;
            padding: 5px;
            border: 1px solid #5c0000;
            border-radius: 4px;
            background: #fbf7ed;
            box-shadow: 0 5px 18px rgba(46, 22, 10, 0.28);
        }

        .registro-equip-action-menu button {
            padding: 8px 10px;
            border: 0;
            background: transparent;
            color: #4c2e18;
            font-family: Georgia, serif;
            font-size: 12px;
            text-align: left;
            cursor: pointer;
        }

        .registro-equip-action-menu button:hover,
        .registro-equip-action-menu button:focus-visible {
            background: rgba(92, 0, 0, 0.1);
            color: #5c0000;
            outline: none;
        }

        .registro-equip-action-menu button:disabled {
            color: #9c8e7c;
            cursor: default;
        }

        .equip-manuale-finestra {
            position: fixed;
            z-index: 10040;
            inset: 0;
            display: none;
            place-items: center;
            padding: 12px;
            background: rgba(33, 20, 12, 0.56);
        }

        .equip-manuale-finestra.equip-manuale-aperta {
            display: grid;
        }

        .equip-manuale-pannello {
            display: grid;
            gap: 10px;
            width: min(100%, 430px);
            max-height: calc(100vh - 24px);
            overflow-y: auto;
            padding: 14px;
            border: 2px double #5c0000;
            border-radius: 4px;
            background: #fbf7ed;
            box-shadow: 0 8px 28px rgba(33, 20, 12, 0.35);
        }

        .equip-manuale-pannello h3 {
            margin: 0;
            color: #5c0000;
            font-size: 15px;
            text-align: left;
        }

        .equip-manuale-pannello label {
            display: grid;
            gap: 4px;
            color: #5c0000;
            font-size: 11px;
            font-weight: bold;
            text-align: left;
        }

        #equip-manuale-campi,
        .equip-manuale-campi {
            display: grid;
            gap: 8px;
        }

        .equip-manuale-pannello input,
        .equip-manuale-pannello select,
        .equip-manuale-pannello textarea {
            width: 100%;
            background: #fffdf6;
            color: #2d2118;
            text-align: left;
        }

        .equip-manuale-pannello textarea {
            min-height: 66px;
            resize: vertical;
        }

        .equip-manuale-errore {
            display: none;
            margin: 0;
            color: #8a1a1a;
            font-size: 11px;
            font-weight: bold;
            text-align: left;
        }

        .equip-manuale-errore.equip-manuale-errore-visibile {
            display: block;
        }

        .equip-manuale-azioni {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 8px;
        }

        .equip-manuale-azioni button {
            min-height: 34px;
        }

        .dialogo-app-pannello {
            width: min(100%, 430px);
        }

        .dialogo-app-finestra {
            z-index: 16000;
        }

        .dialogo-app-messaggio {
            margin: 0;
            color: #2d2118;
            font-size: 12px;
            line-height: 1.45;
            text-align: left;
            white-space: pre-line;
            overflow-wrap: anywhere;
        }

        .dialogo-app-finestra[data-tipo="errore"] .dialogo-app-messaggio {
            color: #5c0000;
            font-weight: bold;
        }

        .dialogo-app-azioni.dialogo-app-azione-singola {
            grid-template-columns: 1fr;
        }

        .home-portrait {
            display: grid;
            gap: 8px;
            margin-top: 0;
            justify-self: stretch;
            width: 100%;
        }

        .portrait-preview {
            width: 100%;
            aspect-ratio: 1 / 1;
            border: 3px double #5c0000;
            background: #fbf7ed;
            display: grid;
            place-items: center;
            color: #6b4f25;
            font-size: 12px;
            font-weight: bold;
            text-align: center;
            overflow: hidden;
        }

        .portrait-preview img {
            display: none;
            width: 100%;
            height: 100%;
            object-fit: cover;
        }

        .portrait-preview.has-image span {
            display: none;
        }

        .portrait-preview.has-image img {
            display: block;
        }

        .portrait-upload-button {
            display: flex;
            align-items: center;
            justify-content: center;
            text-align: center;
        }

        #equipaggiamento .grid-combat > div:nth-child(2) .box-sezione:nth-child(2) {
            display: none;
        }

        @media (max-width: 850px) {
            body {
                padding: 10px;
            }

            .header-title {
                padding: 10px;
                margin-bottom: 12px;
                font-size: 18px;
                letter-spacing: 1px;
            }

            .tab-content {
                padding: 14px;
                min-height: 0;
            }

            .box-sezione {
                padding: 10px;
                margin-bottom: 14px;
            }

            .box-sezione h4 {
                margin: -6px -5px 9px -5px;
                padding: 6px 10px;
                font-size: 12px;
            }

            .grid-combat,
            .grid-anagrafica-compatta {
                grid-template-columns: 1fr;
            }

            .riga-anagrafica {
                gap: 12px;
            }

            .riga-misure-pg,
            .riga-progressione-pg {
                grid-template-columns: repeat(3, minmax(0, 1fr));
                gap: 10px;
            }

            .campo-anagrafica {
                flex: 1 1 170px;
                min-width: min(100%, 170px);
            }

            .strumenti-riga,
            .magic-config-row {
                display: grid;
                grid-template-columns: 1fr;
                align-items: stretch;
                gap: 8px;
            }

            .strumenti-riga label {
                width: 100%;
            }

            .input-full,
            .select-fantasy,
            .strumenti-riga input,
            .strumenti-riga select,
            .wizard-grid input,
            .wizard-grid select,
            .magic-config-row select {
                width: 100%;
                min-width: 0;
            }

            .tabella-fantasy {
                width: max-content;
                min-width: 100%;
                font-size: 12px;
            }

            .tabella-fantasy th,
            .tabella-fantasy td {
                padding: 5px 4px;
            }

            .tabella-fantasy input[type="text"],
            .tabella-fantasy select {
                min-width: 70px;
            }

            .tabella-fantasy .align-left input {
                min-width: 120px;
            }

            .input-corto {
                width: 42px;
                font-size: 13px;
            }

            .input-medio {
                width: 64px;
            }

            .home-layout {
                max-width: 100%;
                margin-top: 6px;
                gap: 7px;
            }

            .home-main-panel {
                grid-template-columns: minmax(132px, 42vw) minmax(0, 1fr);
                gap: 8px;
            }

            .home-actions {
                grid-template-columns: 1fr;
                gap: 5px;
            }

            .home-actions .home-button {
                font-size: 10px;
                letter-spacing: 0;
                min-height: 38px;
                padding: 6px 4px;
            }

            .home-portrait {
                width: 100%;
                gap: 5px;
                margin-top: 0;
            }

            .home-actions .portrait-upload-button {
                min-height: 30px;
                padding: 5px 6px;
                font-size: 9px;
            }

            .wizard-overlay {
                padding: 10px;
            }

            .wizard-panel {
                width: var(--scheda-verticale-larghezza);
                max-width: var(--scheda-verticale-larghezza);
                padding: 12px;
            }

            .wizard-actions {
                display: grid;
                grid-template-columns: 1fr;
            }

            .wizard-actions .button-fantasy {
                width: 100%;
            }

            .home-dice-grid {
                grid-template-columns: repeat(8, minmax(0, 1fr));
                gap: 6px;
            }

            .home-die-card {
                min-height: 76px;
                padding: 5px;
            }

            .home-die-shape {
                width: 38px;
                height: 38px;
                flex-basis: 38px;
                font-size: 14px;
            }

            .caster-buttons {
                grid-template-columns: repeat(3, minmax(0, 1fr));
            }

            .wizard-grid,
            .caratteristiche-wizard {
                grid-template-columns: 1fr;
            }

            .wizard-grid.wizard-identity-grid {
                grid-template-columns: repeat(2, minmax(0, 1fr));
                column-gap: 10px;
                row-gap: 10px;
            }

            #caratteristiche .grid-combat {
                grid-template-columns: 1fr;
            }

            .box-caratteristiche-mini .stat-grid {
                grid-template-columns: repeat(6, minmax(0, 1fr));
                overflow-x: hidden;
            }
        }

        @media (max-width: 380px) {
            .caratteristiche-wizard label {
                grid-template-columns: minmax(62px, 0.8fr) 50px minmax(100px, 1.25fr) 26px;
                gap: 4px;
            }

            .wizard-dice-area {
                gap: 3px;
            }

            .wizard-stat-label {
                font-size: 9px;
            }

            .wizard-stat-control {
                grid-template-columns: 38px 10px;
                gap: 2px;
            }

            .wizard-stat-control .input-corto {
                width: 38px;
                height: 38px;
                font-size: 15px;
                line-height: 38px;
            }

            .stat-arrow {
                width: 10px;
            }

            .caratteristiche-wizard .dice-button {
                min-width: 28px;
                padding-inline: 2px;
                font-size: 9px;
            }

            .dice-roll {
                gap: 2px;
            }

            .die {
                width: 16px;
                height: 16px;
                flex-basis: 16px;
                font-size: 9px;
            }

            .wizard-race-modifier {
                width: 26px;
                height: 26px;
                font-size: 11px;
            }
        }

        @media (max-width: 680px) {
            #caratteristiche {
                padding: 10px;
            }

            #caratteristiche .box-sezione {
                padding: 8px;
                margin-bottom: 10px;
            }

            #caratteristiche .grid-combat {
                gap: 8px;
            }

            #caratteristiche .caratteristiche-duo {
                gap: 8px;
                margin-bottom: 10px;
            }

            #caratteristiche .box-sezione h4 {
                margin: -5px -4px 7px -4px;
                padding: 5px 8px;
                font-size: 11px;
            }

            #caratteristiche .box-caratteristiche-mini .stat-grid {
                grid-template-columns: repeat(3, minmax(0, 1fr));
                overflow-x: hidden;
                gap: 5px;
            }

            #caratteristiche .box-caratteristiche-mini .riga-caratteristica {
                padding: 5px 4px;
            }

            .caratteristiche-badges {
                grid-template-columns: repeat(2, minmax(0, 1fr));
                gap: 8px;
            }

            .ca-summary-integrata,
            .pf-summary-integrata {
                gap: 6px;
                margin-bottom: 6px;
            }

            .ca-layout-integrata {
                grid-template-columns: minmax(86px, 98px) minmax(0, 1fr);
                gap: 6px;
                margin-bottom: 6px;
            }

            .ca-main-card {
                min-height: 96px;
                padding: 6px 4px;
            }

            .ca-main-card > b {
                font-size: 34px;
            }

            .ca-components-wrap {
                gap: 4px;
            }

            .ca-formula-line {
                gap: 5px;
                font-size: 10px;
            }

            .ca-components-grid {
                gap: 4px;
            }

            .ca-component-card {
                min-height: 44px;
                padding: 3px 1px;
                font-size: 8px;
            }

            .ca-component-card b {
                font-size: 15px;
            }

            #caratteristiche .ca-component-card input.input-corto {
                width: 34px;
                height: 21px;
                font-size: 11px;
            }

            .ca-card-integrata,
            .pf-card-integrata {
                min-height: 44px;
                padding: 5px 3px;
                font-size: 8px;
            }

            .ca-card-integrata b,
            .pf-card-integrata b,
            .pf-summary-integrata .pf-card-integrata b {
                font-size: 17px;
            }

            #ca-des-max {
                font-size: 13px;
            }

            #caratteristiche .pf-summary-integrata .pf-card-integrata input.input-corto {
                height: 24px;
                font-size: 18px;
                width: 54px;
            }

            #caratteristiche .riquadro-ca-totale {
                padding: 8px 6px;
            }

            #caratteristiche .caratteristiche-badges .valore-ca-grande {
                font-size: 24px;
            }

            #caratteristiche .tabella-fantasy {
                table-layout: fixed;
                font-size: 11px;
            }

            #caratteristiche #tabella-componenti-ca {
                width: 100%;
                min-width: 0;
            }

            #caratteristiche .tabella-fantasy th,
            #caratteristiche .tabella-fantasy td {
                padding: 3px 2px;
                overflow-wrap: anywhere;
            }

            #caratteristiche .input-corto {
                width: 38px;
                font-size: 12px;
            }

            #caratteristiche .input-medio {
                width: 58px;
            }

            #caratteristiche .align-left input {
                width: 100% !important;
            }
        }

        @media (max-width: 390px) {
            body {
                padding: 8px;
            }

            .header-title {
                font-size: 16px;
            }

            .tab-button {
                min-height: 42px;
                padding: 7px 4px;
                font-size: 11px;
            }

            .tab-content {
                padding: 10px;
            }

            .tabella-fantasy {
                font-size: 11px;
            }

            .tabella-fantasy th {
                font-size: 10px;
            }

            .home-main-panel {
                grid-template-columns: minmax(136px, 43vw) minmax(0, 1fr);
                gap: 6px;
            }

            .home-main-panel .home-button {
                min-height: 30px;
                padding: 5px 4px;
                font-size: 9px;
            }

            .home-die-card {
                gap: 4px;
                min-height: 78px;
                padding: 6px;
            }

            .home-die-label {
                font-size: 11px;
            }

            .home-die-shape {
                width: 38px;
                height: 38px;
                flex-basis: 38px;
                font-size: 14px;
            }

            .peso-summary {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .peso-summary .peso-card,
            .peso-card.movimento-mezza-riga {
                grid-column: span 1;
            }

            .caster-buttons {
                grid-template-columns: 1fr;
            }

            #incantesimi .box-sezione {
                overflow-x: hidden;
            }

            #incantesimi .tabella-fantasy,
            #incantesimi .tabella-fantasy thead,
            #incantesimi .tabella-fantasy tbody,
            #incantesimi .tabella-fantasy tr,
            #incantesimi .tabella-fantasy td {
                display: block;
                width: 100%;
            }

            #incantesimi .tabella-fantasy thead {
                display: none;
            }

            #incantesimi #corpo-incantesimi {
                display: grid;
                gap: 10px;
            }

            #incantesimi .inc-riga {
                border: 1px solid rgba(92,0,0,0.28);
                background: rgba(243, 235, 217, 0.74);
                border-radius: 4px;
                padding: 7px;
                box-shadow: inset 0 0 8px rgba(92,0,0,0.04);
            }

            #incantesimi .inc-riga td {
                border: 0;
                padding: 5px 0;
                text-align: left;
            }

            #incantesimi .inc-riga td:not(.inc-cella-scelta) {
                display: grid;
                grid-template-columns: minmax(78px, 0.38fr) minmax(0, 1fr);
                gap: 8px;
                align-items: center;
            }

            #incantesimi .inc-riga td::before {
                content: attr(data-label);
                color: #5c0000;
                font-size: 10px;
                font-weight: bold;
                line-height: 1.15;
                text-transform: uppercase;
            }

            #incantesimi .inc-cella-scelta {
                display: grid;
                gap: 5px;
            }

            #incantesimi .inc-cella-scelta::before {
                display: block;
                margin-bottom: 2px;
            }

            #incantesimi .inc-info {
                margin-top: 4px;
                font-size: 11px;
            }

            #armi-armature .box-sezione {
                overflow-x: hidden;
            }

            #armi-armature .tabella-fantasy,
            #armi-armature .tabella-fantasy thead,
            #armi-armature .tabella-fantasy tbody,
            #armi-armature .tabella-fantasy tr,
            #armi-armature .tabella-fantasy td {
                display: block;
                width: 100%;
            }

            #armi-armature .tabella-fantasy thead {
                display: none;
            }

            #armi-armature tbody[id^="corpo-registro-"] {
                display: grid;
                gap: 10px;
            }

            #armi-armature .registro-equip-riga {
                border: 1px solid rgba(92,0,0,0.28);
                background: rgba(243, 235, 217, 0.74);
                border-radius: 4px;
                padding: 7px;
                box-shadow: inset 0 0 8px rgba(92,0,0,0.04);
            }

            #armi-armature .registro-equip-riga td {
                border: 0;
                padding: 5px 0;
                text-align: left;
            }

            #armi-armature .registro-equip-riga td:not(.campo-principale):not(.campo-note) {
                display: grid;
                grid-template-columns: minmax(78px, 0.38fr) minmax(0, 1fr);
                gap: 8px;
                align-items: center;
            }

            #armi-armature .registro-equip-riga td::before {
                content: attr(data-label);
                color: #5c0000;
                font-size: 10px;
                font-weight: bold;
                line-height: 1.15;
                text-transform: uppercase;
            }

            #armi-armature .campo-principale,
            #armi-armature .campo-note {
                display: grid;
                gap: 5px;
            }

            #armi-armature .campo-principale::before,
            #armi-armature .campo-note::before {
                display: block;
                margin-bottom: 2px;
            }

            .riga-misure-pg,
            .riga-progressione-pg {
                grid-template-columns: 1fr;
            }

            #caratteristiche .box-caratteristiche-mini .stat-grid {
                grid-template-columns: repeat(3, minmax(0, 1fr));
            }
        }

        .home-actions {
            grid-auto-rows: minmax(38px, 1fr);
        }
        .home-actions .home-button,
        .home-actions .portrait-upload-button {
            width: 75%;
            height: 100%;
            min-height: 0;
            box-sizing: border-box;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 6px 8px;
            line-height: 1.15;
            text-align: center;
        }

        @media (min-width: 851px) {
            .home-main-panel {
                grid-template-columns: minmax(206px, 214px) minmax(0, 1fr);
            }
        }

        .progressione-compatta {
            overflow: hidden;
            overflow-x: hidden;
        }

        #equipaggiamento > .box-sezione:first-child {
            margin-bottom: 10px;
        }

        #equipaggiamento .equip-contenitori {
            display: grid;
            grid-template-columns: 1fr;
            gap: 0;
        }

        #equipaggiamento .equip-contenitore {
            min-width: 0;
            overflow-x: hidden;
        }

        #equipaggiamento .equip-contenitore > h4,
        #equipaggiamento [data-fondi-section] > h4 {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
        }

        #equipaggiamento .equip-peso-riepilogo,
        #equipaggiamento .fondi-peso-riepilogo {
            flex: 0 1 auto;
            color: #f7e8bd;
            font-size: 10px;
            font-weight: normal;
            line-height: 1.15;
            text-align: right;
            text-transform: none;
            white-space: nowrap;
        }

        #equipaggiamento .equip-contenitore-dinamico[hidden] {
            display: none;
        }

        #equipaggiamento .equip-dati-nascosti {
            display: none;
        }

        #equipaggiamento .equip-slot-grid {
            display: grid;
            gap: 7px;
        }

        @media (max-width: 390px) {
            #equipaggiamento .equip-contenitore > h4,
            #equipaggiamento [data-fondi-section] > h4 {
                gap: 4px;
            }

            #equipaggiamento .equip-peso-riepilogo,
            #equipaggiamento .fondi-peso-riepilogo {
                font-size: 8px;
            }
        }

        #equipaggiamento .equip-slot-card {
            min-width: 0;
            overflow: hidden;
            border: 1px solid rgba(92, 0, 0, 0.42);
            border-radius: 4px;
            background: rgba(255, 253, 246, 0.68);
        }

        #equipaggiamento .equip-slot-trigger {
            width: 100%;
            min-height: 34px;
            padding: 7px 9px;
            border: 0;
            border-bottom: 1px solid rgba(92, 0, 0, 0.25);
            background: rgba(92, 0, 0, 0.07);
            color: #4c2e18;
            font-family: Georgia, serif;
            font-size: 13px;
            font-weight: bold;
            line-height: 1.2;
            text-align: left;
            overflow-wrap: anywhere;
            cursor: pointer;
        }

        #equipaggiamento .equip-slot-trigger:hover,
        #equipaggiamento .equip-slot-trigger:focus-visible {
            background: rgba(92, 0, 0, 0.13);
            color: #5c0000;
            outline: none;
        }

        #equipaggiamento .equip-slot-intestazione-fissa {
            width: 100%;
            min-height: 34px;
            padding: 7px 9px;
            box-sizing: border-box;
            border-bottom: 1px solid rgba(92, 0, 0, 0.25);
            background: rgba(92, 0, 0, 0.07);
            color: #4c2e18;
            font-family: Georgia, serif;
            font-size: 13px;
            font-weight: bold;
            line-height: 1.2;
            text-align: left;
        }

        #equipaggiamento .equip-slot-riepilogo-fisso {
            border-style: double;
        }

        #equipaggiamento .equip-slot-vuoto {
            border-style: dashed;
            background: rgba(255, 253, 246, 0.35);
        }

        #equipaggiamento .equip-slot-vuoto .equip-slot-trigger {
            border-bottom: 0;
            background: transparent;
            font-size: 12px;
            font-weight: normal;
            text-align: center;
        }

        #equipaggiamento .equip-slot-dettagli {
            display: grid;
            grid-template-columns: repeat(3, minmax(0, 1fr));
            gap: 1px;
            background: rgba(92, 0, 0, 0.2);
        }

        #equipaggiamento .equip-slot-dettaglio {
            display: grid;
            align-content: center;
            gap: 3px;
            min-width: 0;
            min-height: 48px;
            padding: 5px 4px;
            background: rgba(255, 253, 246, 0.86);
            text-align: center;
        }

        #equipaggiamento .equip-slot-etichetta {
            color: #5c0000;
            font-size: 9px;
            font-weight: bold;
            line-height: 1.1;
            text-transform: uppercase;
        }

        #equipaggiamento .equip-slot-valore {
            color: #2d2118;
            font-size: 12px;
            font-weight: bold;
            line-height: 1.15;
            overflow-wrap: anywhere;
        }

        #equipaggiamento .equip-slot-quantita {
            width: 100%;
            min-width: 0;
            height: 24px;
            padding: 2px;
            box-sizing: border-box;
            background: #fffdf6;
            color: #2d2118;
            font-size: 12px;
            font-weight: bold;
            text-align: center;
        }

        #equipaggiamento .tabella-contenitore {
            width: 100%;
            min-width: 0;
            table-layout: fixed;
            font-size: 11px;
        }

        #equipaggiamento .tabella-contenitore th,
        #equipaggiamento .tabella-contenitore td {
            min-width: 0;
            padding: 4px 2px;
            overflow-wrap: anywhere;
        }

        #equipaggiamento .tabella-contenitore th:nth-child(1),
        #equipaggiamento .tabella-contenitore td:nth-child(1) {
            width: 13%;
        }

        #equipaggiamento .tabella-contenitore th:nth-child(2),
        #equipaggiamento .tabella-contenitore td:nth-child(2) {
            width: 47%;
            text-align: left;
        }

        #equipaggiamento .tabella-contenitore th:nth-child(3),
        #equipaggiamento .tabella-contenitore td:nth-child(3),
        #equipaggiamento .tabella-contenitore th:nth-child(4),
        #equipaggiamento .tabella-contenitore td:nth-child(4) {
            width: 20%;
        }

        #equipaggiamento .tabella-contenitore .equip-oggetto-input,
        #equipaggiamento .tabella-contenitore .input-corto {
            width: 100%;
            min-width: 0;
            max-width: 100%;
            box-sizing: border-box;
            font-size: 11px;
        }

        #equipaggiamento .limiti-carico-nascosti {
            display: none;
        }

        @media (max-width: 850px) {
            .home-actions {
                grid-auto-rows: minmax(32px, 1fr);
            }
            .home-actions .home-button,
            .home-actions .portrait-upload-button {
                height: 100%;
                min-height: 0;
                padding: 5px 5px;
                font-size: 9px;
            }

            #incantesimi .box-sezione {
                overflow-x: hidden;
            }

            #incantesimi .tabella-fantasy,
            #incantesimi .tabella-fantasy thead,
            #incantesimi .tabella-fantasy tbody,
            #incantesimi .tabella-fantasy tr,
            #incantesimi .tabella-fantasy td {
                display: block;
                width: 100%;
            }

            #incantesimi .tabella-fantasy thead {
                display: none;
            }

            #incantesimi #corpo-incantesimi {
                display: grid;
                gap: 10px;
            }

            #incantesimi .inc-riga {
                border: 1px solid rgba(92,0,0,0.28);
                background: rgba(243, 235, 217, 0.74);
                border-radius: 4px;
                padding: 7px;
                box-shadow: inset 0 0 8px rgba(92,0,0,0.04);
            }

            #incantesimi .inc-riga td {
                border: 0;
                padding: 5px 0;
                text-align: left;
            }

            #incantesimi .inc-riga td:not(.inc-cella-scelta) {
                display: grid;
                grid-template-columns: minmax(78px, 0.38fr) minmax(0, 1fr);
                gap: 8px;
                align-items: center;
            }

            #incantesimi .inc-riga td::before {
                content: attr(data-label);
                color: #5c0000;
                font-size: 10px;
                font-weight: bold;
                line-height: 1.15;
                text-transform: uppercase;
            }

            #incantesimi .inc-cella-scelta {
                display: grid;
                gap: 5px;
            }

            #incantesimi .inc-cella-scelta::before {
                display: block;
                margin-bottom: 2px;
            }

            #incantesimi .inc-info {
                margin-top: 4px;
                font-size: 11px;
            }

            #armi-armature .box-sezione {
                overflow-x: hidden;
            }

            #armi-armature .tabella-fantasy,
            #armi-armature .tabella-fantasy thead,
            #armi-armature .tabella-fantasy tbody,
            #armi-armature .tabella-fantasy tr,
            #armi-armature .tabella-fantasy td {
                display: block;
                width: 100%;
            }

            #armi-armature .tabella-fantasy thead {
                display: none;
            }

            #armi-armature tbody[id^="corpo-registro-"] {
                display: grid;
                gap: 10px;
            }

            #armi-armature .registro-equip-riga {
                border: 1px solid rgba(92,0,0,0.28);
                background: rgba(243, 235, 217, 0.74);
                border-radius: 4px;
                padding: 7px;
                box-shadow: inset 0 0 8px rgba(92,0,0,0.04);
            }

            #armi-armature .registro-equip-riga td {
                border: 0;
                padding: 5px 0;
                text-align: left;
            }

            #armi-armature .registro-equip-riga td:not(.campo-principale):not(.campo-note) {
                display: grid;
                grid-template-columns: minmax(78px, 0.38fr) minmax(0, 1fr);
                gap: 8px;
                align-items: center;
            }

            #armi-armature .registro-equip-riga td::before {
                content: attr(data-label);
                color: #5c0000;
                font-size: 10px;
                font-weight: bold;
                line-height: 1.15;
                text-transform: uppercase;
            }

            #armi-armature .campo-principale,
            #armi-armature .campo-note {
                display: grid;
                gap: 5px;
            }

            #armi-armature .campo-principale::before,
            #armi-armature .campo-note::before {
                display: block;
                margin-bottom: 2px;
            }
        }

        :root {
            --scheda-verticale-larghezza: min(100%, calc((100dvh - 40px) * 2 / 3));
        }

        body {
            display: flex;
            flex-direction: column;
            align-items: center;
        }

        .header-title,
        #database-status,
        .tab-container,
        .tab-content {
            width: var(--scheda-verticale-larghezza);
            max-width: var(--scheda-verticale-larghezza);
            margin-left: auto;
            margin-right: auto;
        }

        .tab-container {
            grid-template-columns: repeat(12, minmax(0, 1fr));
        }

        .grid-anagrafica-compatta {
            grid-template-columns: 1fr;
        }

        .tab-content .grid-combat {
            grid-template-columns: 1fr;
            gap: 14px;
        }

        #caratteristiche .grid-combat {
            grid-template-columns: 1fr !important;
            gap: 14px;
        }

        @media (max-width: 850px) {
            :root {
                --scheda-verticale-larghezza: 100%;
            }
        }
/* Progressione per classe e registro incantesimi a slot */
.progressione-compatta .livello-classe-select {
    width: 100%;
    min-width: 0;
    font-size: 11px;
}

.progressione-compatta .input-pf-livello {
    text-align: center !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

.progressione-compatta .dado-vita-cell {
    text-align: center !important;
}

.progressione-compatta .dado-vita-control {
    align-items: center;
    display: inline-flex;
    gap: 4px;
    justify-content: center;
    white-space: nowrap;
}

.progressione-compatta .dado-vita-roll {
    background: rgba(92, 0, 0, 0.12);
    border: 1px solid rgba(92, 0, 0, 0.45);
    border-radius: 4px;
    color: #5c0000;
    cursor: pointer;
    font-family: Georgia, serif;
    font-size: 10px;
    font-weight: bold;
    line-height: 1;
    min-width: 28px;
    padding: 4px 5px;
}

.progressione-compatta .dado-vita-roll:disabled {
    cursor: not-allowed;
    opacity: 0.42;
}

.progressione-compatta .dado-vita-lanciato {
    background: rgba(212, 175, 55, 0.32);
}

.progressione-compatta tr.livello-non-raggiunto {
    opacity: 0.48;
}

#incantesimi .inc-classe-riga td {
    padding: 7px 9px;
    color: #3f160f;
    text-align: left;
    background: rgba(126, 28, 18, 0.12);
    border-top: 2px solid rgba(92, 0, 0, 0.45);
}

#incantesimi .inc-classe-riga strong {
    margin-right: 8px;
    color: #5c0000;
    font-size: 14px;
}

#incantesimi .inc-classe-riga span,
#incantesimi .inc-slot-dettaglio {
    display: block;
    margin-top: 2px;
    color: #4d352f;
    font-size: 10px;
}

#incantesimi .inc-slot-elenco {
    display: grid;
    gap: 4px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

#incantesimi .inc-slot-item,
#incantesimi .inc-slot-trigger {
    min-width: 0;
    width: 100%;
}

#incantesimi .inc-slot-trigger {
    min-height: 34px;
    padding: 5px 6px;
    overflow-wrap: anywhere;
    color: #32110b;
    font-family: Georgia, serif;
    font-size: 11px;
    line-height: 1.15;
    background: rgba(255, 250, 235, 0.74);
    border: 1px solid rgba(92, 0, 0, 0.35);
    border-radius: 4px;
    cursor: pointer;
}

#incantesimi .inc-slot-trigger.vuoto {
    color: #5f514d;
    font-style: italic;
    background: rgba(255, 255, 255, 0.38);
    border-style: dashed;
}

#incantesimi .inc-slot-vuoto td {
    padding: 12px 8px;
    color: #4d352f;
    text-align: left;
}

#armi-armature .registro-slot-stato.stato-non-disponibile {
    opacity: 0.48;
    cursor: not-allowed;
}

#equipaggiamento .fondi-card-title {
    color: var(--fantasy-oxblood);
    text-shadow: 0 1px 0 rgba(255, 239, 185, 0.22);
}

@media (max-width: 700px) {
    .progressione-compatta .tabella-fantasy th,
    .progressione-compatta .tabella-fantasy td {
        padding-left: 2px;
        padding-right: 2px;
        font-size: 10px;
    }

    .progressione-compatta .livello-classe-select {
        font-size: 10px;
    }

    #incantesimi .inc-slot-elenco {
        grid-template-columns: 1fr;
    }

    #incantesimi .inc-classe-riga,
    #incantesimi .inc-classe-riga td,
    #incantesimi .inc-slot-vuoto,
    #incantesimi .inc-slot-vuoto td {
        display: block;
        width: 100%;
    }
}

/* Registro incantesimi verticale, coerente con gli slot di Armi & Armature */
#incantesimi .incantesimi-registro,
#incantesimi .inc-classe-gruppo,
#incantesimi .inc-livello-gruppo {
    display: grid;
    min-width: 0;
}

#incantesimi #corpo-incantesimi.incantesimi-registro {
    gap: 16px;
}

#incantesimi .inc-classe-gruppo {
    gap: 12px;
}

#incantesimi .inc-classe-intestazione {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    gap: 8px;
    min-width: 0;
    padding: 7px 9px;
    border-bottom: 2px solid rgba(92, 0, 0, 0.45);
    background: rgba(126, 28, 18, 0.12);
    color: #4d352f;
    text-align: left;
}

#incantesimi .inc-classe-intestazione strong {
    color: #5c0000;
    font-size: 14px;
    text-transform: uppercase;
}

#incantesimi .inc-classe-intestazione span {
    min-width: 0;
    font-size: 10px;
    overflow-wrap: anywhere;
    text-align: right;
}

#incantesimi .inc-livello-gruppo {
    gap: 8px;
    padding-top: 2px;
}

#incantesimi .inc-livello-intestazione {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    min-width: 0;
    padding: 0 2px 5px;
    border-bottom: 1px solid rgba(92, 0, 0, 0.24);
    color: #5c0000;
}

#incantesimi .inc-livello-intestazione h5 {
    min-width: 0;
    margin: 0;
    font-size: 11px;
    line-height: 1.2;
    text-align: left;
    text-transform: uppercase;
    overflow-wrap: anywhere;
}

#incantesimi .inc-livello-intestazione span {
    flex: 0 0 auto;
    font-size: 10px;
    font-weight: bold;
}

#incantesimi .inc-livello-riepilogo {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 6px;
    min-width: 0;
}

#incantesimi .inc-livello-riepilogo > span {
    display: grid;
    align-content: center;
    gap: 2px;
    min-width: 0;
    min-height: 54px;
    padding: 5px;
    border: 1px solid rgba(92, 0, 0, 0.22);
    border-radius: 4px;
    background: rgba(243, 235, 217, 0.62);
    color: #5c0000;
    text-align: center;
}

#incantesimi .inc-livello-riepilogo small {
    font-size: 9px;
    font-weight: bold;
    line-height: 1.1;
    text-transform: uppercase;
}

#incantesimi .inc-livello-riepilogo b {
    font-size: 16px;
    line-height: 1;
}

#incantesimi .inc-livello-riepilogo em {
    color: #4d352f;
    font-size: 9px;
    font-style: normal;
    line-height: 1.1;
    overflow-wrap: anywhere;
}

#incantesimi .inc-slot-elenco {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
    min-width: 0;
}

#incantesimi .inc-slot-item {
    display: grid;
    gap: 8px;
    min-width: 0;
    width: 100%;
    padding: 8px;
    border: 1px solid rgba(92, 0, 0, 0.28);
    border-radius: 4px;
    background: rgba(243, 235, 217, 0.74);
    box-shadow: inset 0 0 8px rgba(92, 0, 0, 0.04);
}

#incantesimi .inc-slot-item h6 {
    min-width: 0;
    margin: -3px -3px 0;
    padding: 5px 8px;
    border-bottom: 1px solid rgba(92, 0, 0, 0.24);
    color: #5c0000;
    font-size: 11px;
    line-height: 1.2;
    text-align: left;
    text-transform: uppercase;
    overflow-wrap: anywhere;
}

#incantesimi .inc-slot-dettagli,
#incantesimi .inc-slot-campo {
    display: grid;
    gap: 4px;
    min-width: 0;
}

#incantesimi .inc-slot-campo {
    color: #5c0000;
    font-size: 10px;
    font-weight: bold;
    line-height: 1.1;
    text-align: left;
    text-transform: uppercase;
}

#incantesimi .inc-slot-prima-riga {
    display: grid;
    grid-template-columns: minmax(0, 1.7fr) repeat(3, minmax(0, 1fr));
    gap: 8px;
    min-width: 0;
    align-items: start;
    padding: 2px 2px 4px;
}

#incantesimi .inc-slot-nome,
#incantesimi .inc-slot-dato {
    display: grid;
    align-content: start;
    gap: 4px;
    min-width: 0;
    color: #32110b;
    text-align: left;
}

#incantesimi .inc-slot-nome .inc-slot-trigger {
    min-height: 0;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: transparent;
    font-size: 12px;
    font-weight: bold;
}

#incantesimi .inc-slot-dato {
    padding: 0;
}

#incantesimi .inc-slot-nome small,
#incantesimi .inc-slot-dato small,
#incantesimi .inc-slot-effetto small {
    color: #5c0000;
    font-size: 9px;
    font-weight: bold;
    line-height: 1.1;
    text-transform: uppercase;
}

#incantesimi .inc-slot-dato b {
    min-width: 0;
    font-size: 11px;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

#incantesimi .inc-slot-effetto {
    display: grid;
    gap: 4px;
    min-width: 0;
    padding: 6px 8px;
    border-top: 1px solid rgba(92, 0, 0, 0.22);
    color: #32110b;
    text-align: left;
}

#incantesimi .inc-slot-effetto p {
    min-width: 0;
    margin: 0;
    font-size: 11px;
    line-height: 1.3;
    overflow-wrap: anywhere;
}

#incantesimi .inc-slot-trigger {
    width: 100%;
    min-width: 0;
    min-height: 34px;
    padding: 6px 8px;
    border: 1px solid rgba(92, 0, 0, 0.35);
    border-radius: 4px;
    background: rgba(255, 250, 235, 0.74);
    color: #32110b;
    cursor: pointer;
    font-family: Georgia, serif;
    font-size: 12px;
    font-weight: normal;
    line-height: 1.2;
    overflow-wrap: anywhere;
    text-align: left;
    text-transform: none;
}

#incantesimi .inc-slot-trigger:hover,
#incantesimi .inc-slot-trigger:focus-visible {
    border-color: #8a1a1a;
    color: #8a1a1a;
    outline: none;
}

#incantesimi .inc-slot-vuoto {
    border-style: dashed;
    background: rgba(243, 235, 217, 0.42);
}

#incantesimi .inc-slot-vuoto h6 {
    margin: -3px;
    padding: 0;
    border-bottom: 0;
}

#incantesimi .inc-slot-vuoto .inc-slot-trigger {
    min-height: 38px;
    padding: 8px;
    border: 0;
    background: transparent;
    color: #5f514d;
    font-style: italic;
    font-weight: bold;
    text-align: center;
}

#incantesimi .inc-slot-vuoto-messaggio {
    margin: 0;
    padding: 12px 8px;
    border: 1px dashed rgba(92, 0, 0, 0.28);
    border-radius: 4px;
    color: #4d352f;
    text-align: left;
}

@media (max-width: 380px) {
    #incantesimi .inc-classe-intestazione {
        align-items: flex-start;
    }

    #incantesimi .inc-livello-riepilogo {
        gap: 4px;
    }

    #incantesimi .inc-livello-riepilogo > span {
        min-height: 50px;
        padding: 4px 2px;
    }

    #incantesimi .inc-livello-riepilogo small,
    #incantesimi .inc-livello-riepilogo em {
        font-size: 8px;
    }

    #incantesimi .inc-slot-prima-riga {
        gap: 5px;
        padding-left: 0;
        padding-right: 0;
    }

    #incantesimi .inc-slot-nome .inc-slot-trigger {
        font-size: 10px;
    }

    #incantesimi .inc-slot-nome small,
    #incantesimi .inc-slot-dato small {
        font-size: 7px;
    }

    #incantesimi .inc-slot-dato b {
        font-size: 8px;
    }
}
