:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:280px}#root{width:100%}button{border-radius:6px;border:1px solid transparent;padding:.4em .8em;font-size:.85rem;font-weight:500;font-family:inherit;background-color:#1a1a1a;color:inherit;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:2px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}button{background-color:#f9f9f9}}.app{padding:.75rem}.app-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.app-header h1{font-size:1.1rem;margin:0}.role-badge{font-size:.75rem;padding:.2rem .5rem;border-radius:4px;background:#ffffff1a}.role-badge[data-role=GM]{background:#7c3aed4d;color:#c4b5fd}.role-badge[data-role=PLAYER]{background:#3b82f64d;color:#93c5fd}.app-content{min-height:200px}.loading{display:flex;align-items:center;justify-content:center;height:100px;color:#888}.dm-view-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.dm-view-header-btns{display:flex;gap:.35rem}.dm-view h2{font-size:.95rem;margin:0;color:#ccc}.config-gear-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#aaa;padding:.3rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:color .15s,border-color .15s}.config-gear-btn:hover{color:#c4b5fd;border-color:#7c3aed66}.caster-type.unknown{color:#f87171;background:#ef444426}.player-list{display:flex;flex-direction:column;gap:.75rem}.player-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.75rem}.player-card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;font-weight:600;font-size:.9rem}.player-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.player-card-controls{display:flex;gap:.75rem}.player-card-controls label{display:flex;flex-direction:column;gap:.2rem;flex:1}.label-text{font-size:.7rem;color:#888;text-transform:uppercase;letter-spacing:.05em}.player-card-controls select{padding:.35rem .5rem;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:inherit;font-size:.85rem;font-family:inherit;cursor:pointer}.player-card-controls select:disabled{opacity:.4;cursor:not-allowed}.slot-summary{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06);display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.caster-type{font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;color:#888;padding:.15rem .4rem;border-radius:3px;background:#ffffff0f}.no-slots{font-size:.8rem;color:#666;font-style:italic}.slot-badges{display:flex;gap:.35rem;flex-wrap:wrap}.slot-badge{font-size:.75rem;padding:.15rem .4rem;border-radius:3px;background:#7c3aed33;color:#c4b5fd}.player-view{text-align:center}.player-status{margin-bottom:1rem}.class-label{font-size:1rem;font-weight:600}.empty-state{color:#888;text-align:center;margin-top:2rem;font-size:.9rem}.placeholder-detail{color:#666;text-align:center;font-size:.85rem}.class-config-panel{display:flex;flex-direction:column;gap:.75rem;max-height:calc(600px - 5rem)}.config-header{display:flex;align-items:center;justify-content:space-between}.config-header h2{font-size:.95rem;margin:0;color:#ccc}.config-close-btn{background:none;border:none;color:#888;font-size:1.2rem;cursor:pointer;padding:0 .25rem;line-height:1}.config-close-btn:hover{color:#fff}.config-class-list{display:flex;flex-direction:column;gap:.75rem;flex:1;min-height:0;overflow-y:auto}.class-config-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.6rem}.class-config-card-header{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:.5rem}.class-config-card-header-row{display:flex;flex-direction:row;justify-content:space-between;width:100%}.class-name-input{flex:1;padding:.3rem .5rem;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:inherit;font-size:.85rem;font-family:inherit;font-weight:600}.caster-type-select{padding:.3rem .4rem;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:inherit;font-size:.75rem;font-family:inherit;cursor:pointer}.delete-class-btn{background:none;border:1px solid rgba(239,68,68,.3);border-radius:4px;color:#f87171;font-size:1rem;cursor:pointer;padding:.1rem .4rem;line-height:1}.delete-class-btn:hover{background:#ef444426}.slot-table-wrapper{overflow-x:auto;margin-bottom:.4rem}.slot-table{border-collapse:collapse;width:100%;font-size:.75rem}.slot-table th{padding:.2rem .15rem;text-align:center;color:#888;font-weight:500;font-size:.65rem;text-transform:uppercase;border-bottom:1px solid rgba(255,255,255,.1)}.slot-table td{padding:.1rem;text-align:center}.slot-table .level-label{color:#888;font-size:.7rem;padding-right:.3rem;text-align:right;min-width:1.5rem}.slot-table input[type=number]{width:2rem;padding:.15rem .1rem;text-align:center;border-radius:3px;border:1px solid rgba(255,255,255,.1);background:#0003;color:inherit;font-size:.75rem;font-family:inherit;-moz-appearance:textfield}.slot-table input[type=number]::-webkit-inner-spin-button,.slot-table input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.slot-table input[type=number]:focus{outline:1px solid rgba(124,58,237,.5);border-color:#7c3aed80}.class-config-card-footer{display:flex;gap:.4rem}.class-config-card-footer button{font-size:.7rem;padding:.2rem .5rem}.add-class-btn{width:100%;padding:.5rem;border:1px dashed rgba(255,255,255,.2);border-radius:8px;background:none;color:#888;font-size:.85rem;cursor:pointer}.add-class-btn:hover{border-color:#7c3aed66;color:#c4b5fd}.config-actions{display:flex;justify-content:space-between;align-items:center;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.config-actions-left,.config-actions-right{display:flex;gap:.4rem}.config-actions button{font-size:.8rem;padding:.35rem .7rem}.save-btn{background:#7c3aed66!important;color:#c4b5fd;border-color:#7c3aed80!important}.save-btn:hover:not(:disabled){background:#7c3aed99!important}.save-btn:disabled{opacity:.4;cursor:not-allowed}.slots-status-badge{text-align:center;padding:.4rem .6rem;border-radius:6px;font-size:.8rem;margin-bottom:.75rem;background:#ef444426;color:#f87171}.slots-status-badge[data-unlocked=true]{background:#22c55e26;color:#4ade80}.spell-selection-area{display:flex;flex-direction:column;gap:.75rem}.spell-level-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:.5rem}.spell-level-heading{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem;font-size:.8rem;font-weight:600;color:#ccc}.spell-fill-count{font-size:.7rem;color:#888;font-weight:400}.spell-slot-list{display:flex;flex-direction:column;gap:.3rem}.spell-slot-select{width:100%;padding:.35rem .5rem;border-radius:4px;border:1px solid rgba(255,255,255,.15);background:#0000004d;color:inherit;font-size:.8rem;font-family:inherit;cursor:pointer}.spell-slot-select:disabled{opacity:.4;cursor:not-allowed}.spell-status{margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.06)}.spell-status-row{display:flex;align-items:center;gap:.4rem}.unlock-toggle-btn{background:none;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#f87171;padding:.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:color .15s,border-color .15s}.unlock-toggle-btn[data-unlocked=true]{color:#4ade80;border-color:#22c55e4d}.unlock-toggle-btn:hover{border-color:#ffffff4d}.spell-status-progress{display:flex;gap:.25rem;flex-wrap:wrap;flex:1;min-width:0}.spell-progress-badge{font-size:.65rem;padding:.1rem .3rem;border-radius:3px;background:#ffffff0f;color:#888}.spell-progress-badge[data-complete=true]{background:#22c55e26;color:#4ade80}.spell-total-count{font-size:.7rem;color:#888;flex-shrink:0}.spell-total-count[data-complete=true]{color:#4ade80}.reset-spells-btn{font-size:.65rem;padding:.2rem .4rem;background:none;border:1px solid rgba(239,68,68,.3);border-radius:3px;color:#f87171;cursor:pointer;flex-shrink:0}.reset-spells-btn:hover{background:#ef444426}.spell-detail-list{display:flex;flex-direction:column;gap:.2rem;margin-top:.4rem}.spell-detail-row{display:flex;align-items:center;gap:.4rem;padding:.2rem .3rem;border-radius:3px;font-size:.75rem}.spell-detail-row[data-cast=true]{opacity:.5}.spell-detail-level{font-size:.65rem;color:#888;min-width:1.5rem;flex-shrink:0}.spell-detail-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.spell-detail-row[data-cast=true] .spell-detail-name{text-decoration:line-through;color:#666}.dm-cast-btn,.uncast-btn{font-size:.6rem;padding:.1rem .35rem;border-radius:3px;cursor:pointer;flex-shrink:0;font-family:inherit}.dm-cast-btn{background:none;border:1px solid rgba(124,58,237,.3);color:#c4b5fd}.dm-cast-btn:hover{background:#7c3aed33}.uncast-btn{background:none;border:1px solid rgba(239,68,68,.3);color:#f87171}.uncast-btn:hover{background:#ef444426}.spell-cast-area{display:flex;flex-direction:column;gap:.75rem}.cast-level-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:.5rem}.cast-level-heading{font-size:.8rem;font-weight:600;color:#ccc;margin-bottom:.4rem}.cast-spell-list{display:flex;flex-direction:column;gap:.25rem}.cast-spell-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;width:100%;padding:.4rem .6rem;border-radius:4px;border:1px solid rgba(255,255,255,.1);background:#0003;color:inherit;font-size:.85rem;font-family:inherit;cursor:pointer;text-align:left;transition:border-color .15s,background .15s}.cast-spell-row:hover:not(:disabled){border-color:#7c3aed66;background:#7c3aed1a}.cast-spell-row[data-cast=true]{cursor:default;opacity:.5}.cast-spell-row[data-cast=true] .cast-spell-name{text-decoration:line-through;color:#666}.cast-spell-icon{color:#c4b5fd;display:flex;align-items:center;flex-shrink:0}.spell-list-section{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:8px;overflow:hidden}.spell-list-section-header{display:flex;justify-content:space-between;align-items:center;width:100%;padding:.5rem .6rem;background:none;border:none;color:inherit;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer}.spell-list-section-header:hover{background:#ffffff08}.spell-list-section-meta{font-size:.7rem;color:#888;font-weight:400;display:flex;align-items:center;gap:.3rem}.spell-list-section-toggle{font-size:.65rem;color:#888}.spell-list-levels{padding:0 .5rem .5rem;display:flex;flex-direction:column;gap:.5rem}.spell-list-level{background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:6px;padding:.4rem}.spell-list-level-header{display:flex;align-items:center;gap:.4rem;width:100%;padding:.25rem .3rem;background:none;border:none;color:inherit;font-family:inherit;cursor:pointer;border-radius:3px}.spell-list-level-header:hover{background:#ffffff08}.spell-list-level-label{font-size:.8rem;font-weight:600;color:#ccc}.spell-list-level-count{font-size:.65rem;color:#888;flex:1}.spell-list-names{display:flex;flex-direction:column;gap:.2rem;padding:.25rem .3rem 0}.spell-list-name-row{display:flex;gap:.25rem;align-items:center}.spell-name-input{flex:1;padding:.25rem .4rem;border-radius:3px;border:1px solid rgba(255,255,255,.1);background:#0003;color:inherit;font-size:.75rem;font-family:inherit}.spell-name-input:focus{outline:1px solid rgba(124,58,237,.5);border-color:#7c3aed80}.delete-spell-btn{background:none;border:none;color:#f87171;font-size:.9rem;cursor:pointer;padding:0 .2rem;line-height:1;flex-shrink:0}.delete-spell-btn:hover{color:#ef4444}.add-spell-btn{padding:.2rem;border:1px dashed rgba(255,255,255,.15);border-radius:3px;background:none;color:#888;font-size:.7rem;cursor:pointer;margin-top:.15rem}.add-spell-btn:hover{border-color:#7c3aed66;color:#c4b5fd}.spell-book-panel{display:flex;flex-direction:column;max-height:calc(600px - 5rem)}.spell-book-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding:.25rem 0}.spell-book-player{border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden}.spell-book-player-header{display:flex;align-items:center;gap:.5rem;width:100%;padding:.5rem .75rem;background:#ffffff0d;border:none;color:inherit;font-size:.85rem;cursor:pointer;text-align:left}.spell-book-player-header:hover{background:#ffffff14}.spell-book-player-name{flex:1;font-weight:600}.spell-book-count{font-size:.75rem;opacity:.6}.spell-book-levels{padding:.5rem .75rem;display:flex;flex-direction:column;gap:.75rem}.spell-book-level-heading{font-size:.8rem;font-weight:600;margin-bottom:.25rem;color:#c4b5fd}.spell-book-checkboxes{display:flex;flex-direction:column;gap:.25rem}.spell-book-checkbox{display:flex;align-items:center;gap:.4rem;font-size:.8rem;cursor:pointer}.spell-book-checkbox input[type=checkbox]{accent-color:#7c3aed}.spell-book-actions{display:flex;justify-content:flex-end;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.08)}.spell-list-level-actions{display:flex;justify-content:space-between;align-items:center;margin-top:.4rem}
