body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--radius:8px}[data-theme=dark]{--bg-color:#0f172a;--panel-color:#020617;--primary-color:#6366f1;--primary-hover:#4f46e5;--text-color:#e5e7eb;--muted-text:#9ca3af;--error-color:#ef4444;--border-color:#1e293b}[data-theme=light]{--bg-color:#f8fafc;--panel-color:#fff;--primary-color:#4f46e5;--primary-hover:#4338ca;--text-color:#0f172a;--muted-text:#475569;--error-color:#dc2626;--border-color:#cbd5f5}*{box-sizing:border-box}html{font-size:clamp(13px,.5vw + .5vh + 4px,20px)}body{background:linear-gradient(180deg,var(--panel-color),var(--bg-color));color:var(--text-color);font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;margin:0;min-height:100vh}.page-center{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:1rem}.card{background-color:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 20px 40px #00000026;max-width:480px;padding:2.5rem;width:100%}.card h1{font-size:1.75rem;margin-bottom:1.5rem;margin-top:0}.card h1,.card p{text-align:center}.card p{color:var(--muted-text);font-size:.9rem}.form-group{margin-bottom:1rem}input{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);font-size:.875rem;padding:.4rem .6rem;width:100%}input:focus{border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-color);outline:none}button{background-color:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:.875rem;margin-top:.3rem;padding:.4rem .6rem;transition:background-color .15s ease,transform .05s ease;width:100%}button:hover{background-color:var(--primary-hover)}button:active{transform:scale(.98)}a{color:var(--primary-color);text-decoration:none}a:hover{text-decoration:underline}.error{background-color:#ef444426;border:1px solid var(--error-color);border-radius:8px;border-radius:var(--radius);color:var(--error-color);margin-bottom:1rem;padding:.5rem;text-align:center}.dashboard{max-width:1100px;width:100%}.dashboard-header{align-items:center;display:flex;justify-content:space-between}.character-grid{grid-gap:1.75rem;display:grid;gap:1.75rem}.character-slot{background-color:var(--panel-color);border:2px solid var(--border-color);border-radius:8px;border-radius:var(--radius);cursor:pointer;display:flex;flex-direction:column;overflow:hidden;transition:border-color .15s ease,transform .1s ease,box-shadow .15s ease}.character-slot:hover{border-color:var(--primary-color);box-shadow:0 8px 24px #0000004d;transform:translateY(-3px)}.character-slot.empty{border-style:dashed}.character-slot.empty:hover .plus{color:var(--primary-color)}.slot-image-wrap{flex-shrink:0;height:220px;overflow:hidden;position:relative;width:100%}.slot-image{display:block;height:100%;object-fit:cover;width:100%}.slot-image-empty .slot-image{filter:brightness(.35)}.slot-empty-overlay{align-items:center;display:flex;inset:0;justify-content:center;position:absolute}.plus{color:var(--muted-text);font-size:4rem;line-height:1;transition:color .15s ease}.slot-info{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:.3rem;justify-content:center;padding:1.1rem 1rem}.slot-text{color:var(--muted-text);font-size:1rem}.navbar{align-items:center;background-color:var(--panel-color);border-bottom:1px solid var(--border-color);display:flex;height:76px;justify-content:space-between;padding:0 2rem}.nav-brand{color:var(--text-color);font-size:1.35rem;font-weight:600}.nav-right{align-items:center;display:flex;gap:.75rem}.nav-button,.nav-room-btn{font-size:.9rem;margin:0;padding:.5rem 1rem;width:auto}.app-content{min-height:calc(100vh - 76px);padding:2rem 1rem}.dashboard-wide{margin:0 auto;max-width:1400px}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{margin:0}.character-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}[data-theme=dark]{--vital-life:#ef4444;--vital-energy:#6366f1;--card-bg:#1e293b;--selected-bg:#6366f126;--selected-border:#6366f1;--attr-btn-bg:#1e293b}[data-theme=light]{--vital-life:#dc2626;--vital-energy:#4f46e5;--card-bg:#f1f5f9;--selected-bg:#4f46e51a;--selected-border:#4f46e5;--attr-btn-bg:#e2e8f0}.muted,.optional{color:var(--muted-text)}.optional{font-size:.85rem}label{color:var(--muted-text);display:block;font-size:.95rem;margin-bottom:.4rem}.slot-name{font-size:1.2rem;font-weight:700;text-align:center}.slot-level{font-size:.9rem}.slot-delete-btn{background:#0000;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;font-size:.85rem;margin-top:.5rem;padding:.45rem 1.1rem;transition:background-color .15s ease,border-color .15s ease,color .15s ease;width:auto}.slot-delete-btn:hover{background:#ef44441a;border-color:var(--error-color);color:var(--error-color)}.modal-overlay{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal{background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);max-width:560px;padding:2.5rem;width:92%}.modal h2{font-size:1.5rem;margin:0 0 1.25rem}.modal p{font-size:1rem;line-height:1.6;margin:0 0 .9rem}.modal-warning{color:var(--error-color);font-size:.95rem}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn{background:#0000;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);cursor:pointer;font-size:1rem;margin:0;padding:.7rem 1.4rem;transition:background-color .15s ease;width:auto}.btn:hover{background:var(--card-bg)}.btn-danger{background:var(--error-color);border-color:var(--error-color);color:#fff}.btn-danger:hover{background:#dc2626;border-color:#dc2626}.btn-danger:disabled{cursor:not-allowed;opacity:.6}.wizard-container{display:flex;flex-direction:column;margin:0 auto;max-width:min(1100px,96vw);width:100%}.wizard-progress{display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:.75rem;position:relative}.wizard-progress:before{background:var(--border-color);content:"";height:2px;left:0;position:absolute;right:0;top:11px;z-index:0}.wizard-dot{flex-direction:column;gap:.25rem;z-index:1}.wizard-dot,.wizard-dot-circle{align-items:center;display:flex}.wizard-dot-circle{background:var(--panel-color);border:2px solid var(--border-color);border-radius:50%;color:var(--muted-text);font-size:.65rem;font-weight:600;height:22px;justify-content:center;transition:all .15s ease;width:22px}.wizard-dot.active .wizard-dot-circle,.wizard-dot.done .wizard-dot-circle{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.wizard-dot-label{color:var(--muted-text);font-size:.65rem;white-space:nowrap}.wizard-dot.active .wizard-dot-label{color:var(--text-color);font-weight:600}.wizard-body{background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);padding:1rem 1.5rem}.wizard-body,.wizard-step{display:flex;flex-direction:column}.wizard-step.review{gap:.75rem}.wizard-step h2{font-size:1.1rem;margin-bottom:.2rem;margin-top:0}.wizard-hint{font-size:.875rem;margin-top:0}.wizard-hint,.wizard-note{color:var(--muted-text);margin-bottom:.5rem}.wizard-note{font-size:.8rem;margin-top:-.25rem}.wizard-nav{border-top:1px solid var(--border-color);display:flex;gap:.5rem;justify-content:space-between;margin-top:1rem;padding-top:.5rem}.wizard-nav button{width:auto}.wizard-confirm-btn{flex:1 1}.btn-secondary{background:#0000;border:1px solid var(--border-color);color:var(--text-color);padding:.4rem .75rem}.btn-secondary:hover{background:var(--card-bg)}.picker-section{margin-bottom:.5rem}.picker-section h3{font-size:.9rem;margin-bottom:.35rem;margin-top:0}.picker-grid{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.picker-grid.compact{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.picker-list-container{display:flex;flex-direction:column}.picker-list-scroll{padding-right:.25rem}.picker-list{display:flex;flex-direction:column;gap:.5rem}.picker-card{background:var(--card-bg);border:2px solid #0000;border-radius:8px;border-radius:var(--radius);color:var(--text-color);cursor:pointer;font-size:.875rem;padding:.3rem .6rem;text-align:left;transition:border-color .1s,background .1s;width:100%}.picker-card strong{display:block;margin-bottom:.25rem}.picker-card p{color:var(--muted-text);font-size:.88rem;margin:0;text-align:left;width:100%}.picker-card.selected,.picker-card:hover:not(:disabled){background:var(--selected-bg);border-color:var(--selected-border)}.picker-card:disabled{cursor:not-allowed;opacity:.4}.picker-card.compact{padding:.5rem .75rem}.talent-selected-panel{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.talent-selected-card{transition:opacity .1s}.talent-selected-card:hover{opacity:.8}.talent-selected-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem}.talent-selected-header strong{display:inline;margin-bottom:0}.slot-remove{color:var(--muted-text);flex-shrink:0;font-size:1.1rem;line-height:1}.wizard-step-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.wizard-step-header h2{margin:0}.talent-confirm-btn{margin-bottom:1.25rem;width:100%}.talent-search{display:flex;gap:.5rem;margin-bottom:1.25rem}.talent-search input{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);flex:1 1;font-size:.9rem;padding:.45rem .75rem}.talent-search input:focus{border-color:var(--primary-color);outline:none}.talent-search button{font-size:.9rem;padding:.45rem 1rem;width:auto}.talent-pagination{align-items:center;display:flex;gap:.25rem;justify-content:center;margin-top:1.25rem}.pg-btn{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);cursor:pointer;font-size:.875rem;height:2rem;min-width:2rem;padding:0 .5rem;transition:border-color .1s,background .1s;width:auto}.pg-btn:hover:not(:disabled){border-color:var(--primary-color);color:var(--primary-color)}.pg-btn:disabled{cursor:not-allowed;opacity:.4}.pg-num{background:#0000;border-color:#0000}.pg-num:hover:not(:disabled){background:var(--card-bg)}.pg-active,.pg-num:hover:not(:disabled){border-color:var(--border-color);color:var(--text-color)}.pg-active{background:var(--border-color);cursor:default;font-weight:600}.pg-active:hover{background:var(--border-color)!important;border-color:var(--border-color)!important;color:var(--text-color)!important}.pg-ellipsis{color:var(--muted-text);font-size:.875rem;padding:0 .25rem;-webkit-user-select:none;user-select:none}.card-sub{font-size:.8rem;margin-top:.25rem}.card-sub-section{display:flex;flex-direction:column;gap:.2rem;margin-top:.65rem}.card-sub-label{color:var(--text-color);font-size:.88rem;font-weight:700}.card-sub-text{font-size:.88rem}.card-sub-text,.eq-tag{color:var(--muted-text)}.eq-tag{border:1px solid var(--border-color);border-radius:4px;display:inline-block;font-size:.72rem;margin-top:.25rem;padding:1px 5px}.tab-bar{border-bottom:1px solid var(--border-color);display:flex;gap:0;margin-bottom:1rem}.tab-btn{background:#0000;border:none;border-bottom:2px solid #0000;border-radius:0;color:var(--muted-text);font-size:.95rem;margin-bottom:-1px;margin-top:0;padding:.65rem 1.4rem;width:auto}.tab-btn:hover{background:#0000;color:var(--text-color)}.tab-btn.active{border-bottom-color:var(--primary-color);color:var(--text-color);font-weight:600}@keyframes shake{0%{transform:translateX(0)}15%{transform:translateX(-6px)}30%{transform:translateX(6px)}45%{transform:translateX(-5px)}60%{transform:translateX(5px)}75%{transform:translateX(-3px)}90%{transform:translateX(3px)}to{transform:translateX(0)}}.points-badge.shake,.selection-badge.shake{animation:shake .45s ease}.points-badge,.selection-badge{background:var(--card-bg);border:1px solid var(--border-color);border-radius:999px;color:var(--muted-text);display:inline-block;font-size:.85rem;font-weight:600;margin-bottom:1.25rem;padding:.3rem .75rem}.points-badge.done,.selection-badge.done{background:var(--selected-bg);border-color:var(--selected-border);color:var(--primary-color)}.attr-allocator-columns{grid-gap:.75rem;align-items:stretch;display:grid;gap:.75rem;grid-template-columns:1fr 1fr;margin-bottom:1.5rem}@media (max-width:540px){.attr-allocator-columns{grid-template-columns:1fr}}.attr-alloc-row{align-items:center;background:var(--selected-bg);border:1px solid var(--primary-color);border-radius:8px;border-radius:var(--radius);display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.attr-alloc-label-group{display:flex;flex-direction:column;gap:.25rem}.attr-alloc-label{color:var(--primary-color);font-size:1rem;font-weight:700}.attr-alloc-desc{color:var(--text-color);font-size:.8rem;opacity:.8}.attr-alloc-controls{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.attr-btn{background:var(--attr-btn-bg);border:1px solid var(--border-color);border-radius:6px;color:var(--text-color);font-size:1.2rem;height:38px;line-height:1;margin:0;padding:0;width:38px}.attr-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff}.attr-alloc-value{font-size:1.15rem;font-weight:700;text-align:center;width:28px}.derived-preview{background:var(--card-bg);border-radius:8px;border-radius:var(--radius);display:flex;gap:2rem;margin-top:.5rem;padding:.75rem 1rem}.derived-item{color:var(--muted-text);display:flex;flex-direction:column;font-size:.9rem}.derived-item strong{color:var(--text-color);font-size:1.2rem}.equip-badges{align-items:center;display:flex;gap:.5rem}.equip-badges .selection-badge{margin-bottom:0}.equip-columns{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.equip-columns .picker-list,.equip-columns .talent-selected-panel{grid-template-columns:1fr}@media (max-width:768px){.equip-columns{grid-template-columns:1fr}}.equip-section{margin-bottom:0}.equip-section h3{font-size:1rem;margin-bottom:.75rem;margin-top:0}.equip-selected-card{background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:8px;border-radius:var(--radius);padding:.75rem 1rem}.equip-card-hint{color:var(--muted-text);font-size:.8rem;margin:.4rem 0 .25rem}.equip-name-input{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-sizing:border-box;color:var(--text-color);font-size:.9rem;margin-top:.5rem;padding:.4rem .65rem;width:100%}.equip-name-input:focus{border-color:var(--primary-color);outline:none}.equip-remove-btn{background:#0000;border:none;color:var(--muted-text);cursor:pointer;flex-shrink:0;font-size:1.1rem;line-height:1;margin:0;padding:0;width:auto}.equip-remove-btn:hover{background:#0000;color:var(--error-color)}.equip-quality-row{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.equip-quality-badges{display:flex;flex-wrap:wrap;gap:.35rem}.equip-quality-badge{align-items:center;background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:4px;color:var(--text-color);display:inline-flex;font-size:.78rem;gap:.2rem;padding:.15rem .35rem .15rem .5rem}.equip-quality-badge-remove{align-items:center;background:none;border:none;color:var(--muted-text);cursor:pointer;display:inline-flex;font-size:.75rem;line-height:1;margin:0;padding:0;width:auto}.equip-quality-badge-remove:hover{background:#0000;color:var(--error-color)}.equip-add-quality-btn{background:#0000;border:1px dashed var(--border-color);border-radius:4px;color:var(--muted-text);cursor:pointer;font-size:.78rem;padding:.2rem .65rem;transition:border-color .15s,color .15s;width:auto}.equip-add-quality-btn:hover{background:#0000;border-color:var(--primary-color);color:var(--primary-color)}.quality-picker-card-inner{width:100%}.quality-picker-card-inner.quality-selected{border-left:3px solid var(--primary-color);padding-left:.5rem}.quality-picker-card-header{align-items:center;display:flex;justify-content:space-between}.quality-check-mark{color:var(--primary-color);flex-shrink:0;font-size:1rem;font-weight:700}.quality-tag-row{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.35rem}.quality-tag-chip{background:var(--border-color);border-radius:3px;color:var(--muted-text);display:inline-block;font-size:.72rem;padding:.1rem .4rem}.quality-tag-filter-bar{display:flex;flex-shrink:0;flex-wrap:wrap;gap:.35rem;padding:0 0 .75rem}.quality-tag-filter-btn{border:1px solid var(--border-color);border-radius:4px;color:var(--muted-text);cursor:pointer;font-size:.78rem;padding:.25rem .6rem;transition:all .12s;width:auto}.quality-tag-filter-btn,.quality-tag-filter-btn:hover{background:var(--panel-color);background:var(--card-bg,var(--panel-color))}.quality-tag-filter-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.quality-tag-filter-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.selected-list{display:flex;flex-direction:column;gap:.4rem;margin-top:.75rem}.selected-item{align-items:center;display:flex;gap:.5rem}.selected-item input{flex:1 1}.btn-remove{background:#0000;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--muted-text);font-size:.85rem;margin:0;padding:.4rem .6rem;width:auto}.btn-remove:hover{background:#ef44441a;border-color:var(--error-color);color:var(--error-color)}.review-banner{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;gap:2rem;margin-bottom:1.25rem;padding-bottom:1.25rem}.review-banner-identity{align-items:center;display:flex;flex-shrink:0;gap:.75rem}.review-portrait{border:2px solid var(--border-color);border-radius:50%;flex-shrink:0;height:52px;object-fit:cover;width:52px}.review-name{font-size:1.2rem;font-weight:700;margin:0}.review-banner-section{flex:1 1;min-width:0;overflow:hidden}.review-banner-section p,.review-banner-section strong{word-break:break-word}.review-section-label{color:var(--muted-text);display:block;font-size:.75rem;letter-spacing:.05em;margin-bottom:.2rem;text-transform:uppercase}.review-origin-row{display:flex;gap:1.5rem}.review-origin-item{display:flex;flex-direction:column;gap:.1rem}.review-origin-item .muted{font-size:.75rem}.review-panel{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);display:flex;flex-direction:column;min-height:0;padding:1rem 1.25rem}.review-panel>h3{color:var(--muted-text);flex-shrink:0;font-size:.85rem;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.review-panel-attrs{flex-shrink:0}.review-panel-attrs .attr-allocator-columns{margin-bottom:.5rem}.review-attr-pair{display:contents}.review-attr-row{border:none;padding:.5rem .75rem}.review-middle{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.review-panel-scroll{display:flex;flex-direction:column;gap:.5rem}.review-powers-col{display:flex;flex-direction:column;gap:.75rem}.review-card{cursor:default}.review-card:hover{border-color:var(--selected-border);transform:none}.review-equipment-boxes{grid-gap:.75rem;display:grid;flex-shrink:0;gap:.75rem;grid-template-columns:1fr 1fr}.review-equip-item{display:flex;flex-direction:column;gap:.1rem;margin-bottom:.35rem}.review-equip-item:last-child{margin-bottom:0}.review-equip-item strong{font-size:.95rem}.equip-sheet-qualities{display:flex;flex-wrap:wrap;gap:.3rem;margin-top:.4rem}.equip-sheet-quality-badge{background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:4px;color:var(--text-color);display:inline-block;font-size:.75rem;padding:.15rem .5rem}.equip-sheet-quality-card .slot-remove{background:#0000;border:none;border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;flex-shrink:0;font-size:1rem;line-height:1;margin-top:0;padding:.1rem .4rem;transition:color .1s;width:auto}.equip-sheet-quality-card .slot-remove:hover{color:var(--error-color)}.equip-sheet-quality-card .slot-remove:disabled{cursor:not-allowed;opacity:.4}.equip-sheet-quality-section{margin-top:.6rem}.equip-sheet-quality-cards,.equip-sheet-quality-section{display:flex;flex-direction:column;gap:.4rem}.equip-sheet-quality-card{background:var(--card-bg);border:1px solid var(--border-color);border-left:3px solid var(--selected-border);border-radius:8px;border-radius:var(--radius);padding:.45rem .65rem}.equip-sheet-quality-card-header{align-items:center;display:flex;gap:.5rem;justify-content:space-between}.equip-sheet-quality-card-header strong{font-size:.9rem}.equip-sheet-quality-desc{color:var(--muted-text);font-size:.82rem;line-height:1.4;margin:.25rem 0 0}.equip-name-draggable{border-radius:8px;border-radius:var(--radius);cursor:grab;transition:background .12s}.equip-name-draggable:hover{background:var(--card-bg)}.equip-name-draggable:active{cursor:grabbing}.equip-drop-panel{transition:outline .1s,background .1s}.equip-drop-valid{outline:2px dashed var(--selected-border)}.equip-drop-over{background:var(--selected-bg);outline:2px solid var(--primary-color)!important}.equip-dragging{opacity:.45}.inv-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.inv-panel-header h3{margin:0}.inv-lock-btn,.inv-unlock-btn{border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);cursor:pointer;font-size:.82rem;font-weight:600;margin-top:0;padding:.3rem .85rem;transition:background .15s,color .15s;width:auto}.inv-unlock-btn{background:#0000;color:var(--muted-text)}.inv-unlock-btn:hover{background:var(--card-bg);color:var(--text-color)}.inv-lock-btn{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.inv-lock-btn:hover{background:var(--primary-hover)}.inv-lock-btn:disabled,.inv-unlock-btn:disabled{cursor:not-allowed;opacity:.5}.inv-slot-unlocked{cursor:grab}.inv-slot-unlocked:active{cursor:grabbing}.inv-slot-dragging{opacity:.4}.inv-slot-drop-valid{outline:2px dashed var(--selected-border)}.inv-slot-drag-over{background:var(--selected-bg);outline:2px solid var(--primary-color)!important}.inventory-unlocked .inv-slot{border-style:dashed}.equip-slot-empty-panel .equip-slot-placeholder{font-style:italic;opacity:.5}.equip-slot-empty-btn{background:#0000;border:2px dashed var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;font-size:.9rem;margin:0;padding:.6rem 1rem;text-align:center;transition:border-color .15s,color .15s,background .15s;width:100%}.equip-slot-empty-btn:hover:not(:disabled){background:var(--selected-bg);border-color:var(--primary-color);color:var(--primary-color)}.equip-slot-empty-btn:disabled{cursor:not-allowed;opacity:.4}.equip-panel-title-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.equip-panel-title-row h3{margin:0}.equip-delete-btn{background:#0000;border:1px solid var(--error-color);border-radius:8px;border-radius:var(--radius);color:var(--error-color);cursor:pointer;font-size:1rem;font-weight:400;line-height:1.4;margin:0;padding:.1rem .45rem;transition:background .12s,color .12s;width:auto}.equip-delete-btn:hover{background:var(--error-color);color:#fff}.equip-delete-btn:disabled{cursor:not-allowed;opacity:.4}.inv-item-picker-overlay{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:200}.inv-item-picker-modal{animation:slide-up .18s ease;background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 24px 64px #00000080;display:flex;flex-direction:column;max-height:min(680px,90vh);width:min(560px,95vw)}.inv-item-picker-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:1.25rem 1.5rem 1rem}.inv-item-picker-header h2,.inv-item-picker-header h3{font-size:1.2rem;font-weight:700;margin:0}.inv-item-picker-header-actions{align-items:center;display:flex;gap:.5rem}.inv-item-picker-back{background:#0000;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;font-size:.82rem;margin:0;padding:.25rem .7rem;transition:color .1s,border-color .1s;width:auto}.inv-item-picker-back:hover{border-color:var(--muted-text);color:var(--text-color)}.inv-item-picker-close{background:#0000;border:none;border-radius:4px;color:var(--muted-text);cursor:pointer;font-size:1.5rem;line-height:1;margin:0;padding:.2rem .3rem;transition:color .1s,background .1s;width:auto}.inv-item-picker-close:hover{background:var(--card-bg);color:var(--text-color)}.inv-item-picker-categories{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(3,1fr);padding:1.5rem}.inv-item-picker-cat-card{align-items:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);cursor:pointer;display:flex;flex-direction:column;gap:.6rem;justify-content:center;margin:0;padding:1.5rem 1rem;transition:border-color .12s,background .12s;width:100%}.inv-item-picker-cat-card:hover{background:var(--selected-bg);border-color:var(--primary-color)}.inv-item-picker-cat-icon{font-size:2rem;line-height:1}.inv-item-picker-cat-label{font-size:.95rem;font-weight:600}.inv-item-configure{display:flex;flex:1 1;flex-direction:column;gap:1rem;overflow-y:auto;padding:1.25rem 1.5rem}.inv-item-configure-label{color:var(--muted-text);font-size:.82rem;font-weight:600;letter-spacing:.05em;margin:0 0 .4rem;text-transform:uppercase}.inv-type-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(110px,1fr))}.inv-type-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);cursor:pointer;font-size:.88rem;margin:0;padding:.6rem .75rem;text-align:center;transition:border-color .12s,background .12s;width:100%}.inv-type-card:hover{background:var(--selected-bg);border-color:var(--selected-border)}.inv-type-card.selected{background:var(--selected-bg);border-color:var(--primary-color);color:var(--primary-color);font-weight:600}.inv-item-input{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-sizing:border-box;color:var(--text-color);font-size:.95rem;outline:none;padding:.5rem .75rem;transition:border-color .12s;width:100%}.inv-item-input:focus{border-color:var(--primary-color)}.inv-item-textarea{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-sizing:border-box;color:var(--text-color);font-family:inherit;font-size:.95rem;min-height:120px;outline:none;padding:.6rem .75rem;resize:vertical;transition:border-color .12s;width:100%}.inv-item-textarea:focus{border-color:var(--primary-color)}.inv-item-qualities-row{align-items:center;display:flex;flex-wrap:wrap;gap:.4rem}.inv-item-quality-badge{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:99px;color:var(--text-color);display:inline-flex;font-size:.78rem;gap:.3rem;padding:.15rem .55rem}.inv-item-quality-remove{background:#0000;border:none;color:var(--muted-text);cursor:pointer;font-size:.9rem;line-height:1;margin:0;padding:0;transition:color .1s;width:auto}.inv-item-quality-remove:hover{color:var(--error-color)}.inv-item-add-quality-btn{background:#0000;border:1px dashed var(--border-color);border-radius:99px;color:var(--muted-text);cursor:pointer;font-size:.82rem;margin:0;padding:.2rem .65rem;transition:border-color .12s,color .12s;width:auto}.inv-item-add-quality-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.inv-item-picker-footer{border-top:1px solid var(--border-color);flex-shrink:0;padding:.85rem 1.5rem 1.25rem}.inv-item-submit-btn{background:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;margin:0;padding:.65rem 1rem;transition:background .15s;width:100%}.inv-item-submit-btn:hover{background:var(--primary-hover)}.inv-item-submit-btn:disabled{cursor:not-allowed;opacity:.5}.quality-modal-footer{align-items:center;border-top:1px solid var(--border-color);display:flex;flex-shrink:0;gap:.75rem;justify-content:flex-end;margin-top:.5rem;padding-top:.75rem}.quality-modal-count{font-size:.85rem}.quality-accept-btn{background:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:.9rem;font-weight:600;padding:.45rem 1.25rem;transition:background .15s;width:auto}.quality-accept-btn:hover{background:var(--primary-hover)}@media (max-width:900px){.review-equipment-boxes,.review-middle{grid-template-columns:1fr}}@media (max-width:768px){.review-banner{flex-direction:column;gap:1rem}.app-content,.wizard-body{padding:1.5rem}.wizard-dot-circle{font-size:.75rem;height:28px;width:28px}.wizard-progress:before{top:14px}.wizard-dot-label{font-size:.65rem}}@media (max-width:480px){.wizard-dot-label{display:none}.app-content,.wizard-body{padding:1rem}.wizard-progress{margin-bottom:.75rem}}@media (max-height:800px){.app-content{padding:1.5rem 3rem}.wizard-progress{margin-bottom:1rem}.wizard-body{padding:1.5rem}.review-equipment-boxes,.review-middle{grid-template-columns:1fr}}@media (max-height:600px){.app-content,.wizard-body{padding:1rem}.wizard-progress{margin-bottom:.5rem}.wizard-dot-circle{font-size:.75rem;height:28px;width:28px}.wizard-progress:before{top:14px}}.sheet{margin:0 auto;max-width:1600px}.sheet-body{grid-gap:1.5rem;align-items:start;display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}.sheet-col-left,.sheet-col-right{display:flex;flex-direction:column;gap:.75rem;min-width:0}@media (max-width:1100px){.sheet-body{grid-template-columns:1fr}}.sheet-loading{padding:2rem}.sheet-header{align-items:flex-start;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.sheet-name{font-size:2.25rem;font-weight:700;margin:0 0 .15rem}.sheet-title{color:var(--muted-text);font-size:1.1rem;margin:0 0 .25rem}.sheet-meta{font-size:.9rem;margin:0}.sheet-avatar{border:2px solid var(--border-color);border-radius:50%;height:88px;object-fit:cover;width:88px}.sheet-vitals-panel{display:flex;flex-direction:column;gap:.6rem;margin-bottom:.75rem}.vitals-row{align-items:flex-start;display:flex;gap:1.5rem;justify-content:space-between}.vitals-group-left,.vitals-group-right{display:flex;flex-wrap:wrap;gap:1.5rem}.vitals-group-right{justify-content:flex-end}.vital{flex:1 1;min-width:160px}.vital-simple{min-width:100px}.vital-row{align-items:center;display:flex;justify-content:space-between;margin-bottom:.25rem}.vital-label{color:var(--muted-text);font-size:.85rem}.vital-controls{align-items:center;display:flex;gap:.3rem}.vital-value{font-size:.9rem;font-weight:600;min-width:2rem;text-align:center}.vital-btn{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);cursor:pointer;display:flex;font-size:.85rem;height:22px;justify-content:center;line-height:1;margin:0;padding:0;transition:background .1s,border-color .1s;width:22px}.vital-btn:hover{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.vital-track{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;height:10px;overflow:hidden}.vital-fill{border-radius:4px;height:100%;transition:width .3s ease}.vital-controls-below{display:flex;gap:.5rem;justify-content:center;margin-top:.35rem}.vitals-reset-btn{align-self:flex-start;font-size:.82rem;margin:0;padding:.4rem .9rem;width:auto}.vital-value-clickable{border-radius:4px;cursor:pointer;padding:.1rem .3rem;transition:background .15s}.vital-value-clickable:hover{background:var(--card-bg);color:var(--primary-color)}.vmp-panel{animation:slide-up .18s ease;background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 24px 64px #00000080;display:flex;flex-direction:column;overflow:hidden}.vmp-drag-zone{cursor:move;flex-shrink:0;padding:1.25rem 1.5rem .75rem;-webkit-user-select:none;user-select:none}.vmp-header{align-items:center;display:flex;justify-content:space-between}.vmp-header h3{font-size:1.2rem;margin:0}.vmp-body{display:flex;flex:1 1;flex-direction:column;gap:1rem;min-height:0;overflow-y:auto;padding:0 1.5rem 1.5rem}.vmp-current-display{align-items:baseline;display:flex;font-size:2rem;font-weight:700;gap:.4rem;justify-content:center}.vmp-max-value,.vmp-slash{color:var(--muted-text);font-weight:400}.vmp-max-value{font-size:1.4rem}.vmp-bar{background:var(--card-bg);border-radius:6px;height:14px;overflow:hidden;position:relative}.vmp-bar-fill{border-radius:6px;height:100%;transition:width .3s ease}.vmp-bar-preview{background:#0000;border:2px dashed;border-radius:6px;height:100%;left:0;position:absolute;top:0;transition:width .2s ease}.vmp-inputs{display:flex;gap:.75rem}.vmp-input-group{display:flex;flex:1 1;flex-direction:column;gap:.3rem}.vmp-input-group label{color:var(--muted-text);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.vmp-heal label{color:#22c55e}.vmp-damage label{color:var(--error-color)}.vmp-input-group input{font-size:1.1rem;padding:.5rem .65rem}.vmp-input-group input,.vmp-preview{border-radius:8px;border-radius:var(--radius);text-align:center}.vmp-preview{background:var(--card-bg);color:var(--muted-text);font-size:.95rem;padding:.5rem}.vmp-apply-btn{background:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:1rem;margin:0;padding:.75rem;transition:background .15s}.vmp-apply-btn:hover:not(:disabled){background:var(--primary-hover)}.vmp-apply-btn:disabled{cursor:not-allowed;opacity:.4}.vmp-max-section{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);display:flex;justify-content:space-between;padding:.75rem}.vmp-max-label{color:var(--muted-text);font-size:.82rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.vmp-max-controls{align-items:center;display:flex;gap:.5rem}.vmp-max-val{font-size:1.1rem;font-weight:700;min-width:2rem;text-align:center}.sheet-section{margin-bottom:1rem}.section-heading{font-size:1.1rem;font-weight:600;margin:0 0 .75rem}.sheet-col-left>.review-panel,.sheet-col-left>.sheet-section-row{margin-bottom:0}.sheet-col-right>.review-equipment-boxes,.sheet-col-right>.review-panel{flex-shrink:0;margin-bottom:0}.sheet>.review-equipment-boxes,.sheet>.review-panel,.sheet>.sheet-section-row{margin-bottom:.75rem}.sheet-section-row{display:flex;gap:.75rem}.sheet-section-row>.review-panel{flex:1 1;min-width:0}.sheet-col-left .review-panel .sheet-cards,.sheet>.review-panel>.sheet-cards{display:flex;flex-direction:column;gap:.5rem}.equip-panel-armor{grid-column:1/-1}.sheet .review-card .slot-remove{background:#0000;border:none;color:var(--muted-text);cursor:pointer;flex-shrink:0;font-size:1.1rem;line-height:1;margin:0;padding:.2rem;transition:color .1s;width:auto}.sheet .review-card .slot-remove:hover{color:var(--error-color)}.sheet .review-card .slot-remove:disabled{cursor:not-allowed;opacity:.4}.sheet-attrs{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.attr-col{background:var(--card-bg);border-radius:8px;border-radius:var(--radius);padding:1rem}.attr-col-head{font-size:.82rem;letter-spacing:.06em;margin:0 0 .75rem;text-transform:uppercase}.attr-row-sheet{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:.35rem 0}.attr-row-sheet:last-child{border-bottom:none}.attr-sheet-label{font-size:1rem}.attr-sheet-val{font-size:1.2rem;font-weight:700}.sheet-row{display:flex;flex-wrap:wrap;gap:1rem}.sheet-cards{display:flex;flex-direction:column;gap:.6rem}.sheet-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);flex:1 1;min-width:200px;padding:1rem 1.25rem}.card-heading{font-size:.8rem;letter-spacing:.06em;margin:0 0 .25rem;text-transform:uppercase}.card-title{font-size:1.05rem;font-weight:600;margin:0 0 .4rem}.card-body{font-size:.92rem;margin:0 0 .3rem}.card-body,.card-sub{color:var(--muted-text)}.card-sub{font-size:.88rem;margin:0}.equip-slot-sheet{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);flex:1 1;min-width:150px;padding:1rem 1.25rem}.equip-slot-label{font-size:.82rem;letter-spacing:.06em;margin:0 0 .4rem;text-transform:uppercase}.equip-slot-name{font-size:1rem;font-weight:600;margin:0 0 .2rem}.inventory-grid{grid-gap:.55rem;display:grid;gap:.55rem;grid-template-columns:repeat(2,1fr)}@media (max-width:1100px){.inventory-grid{grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr))}}.inv-slot{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);cursor:default;display:flex;flex-direction:column;gap:.25rem;min-height:80px;padding:.6rem .75rem;position:relative;transition:border-color .12s,background .12s}.inv-slot:not(.inv-slot-dragging):not(.inv-slot-drag-over):hover{border-color:var(--selected-border)}.inv-num{align-items:center;background:var(--border-color);border-radius:50%;color:var(--muted-text);display:inline-flex;flex-shrink:0;font-size:.62rem;font-weight:700;height:20px;justify-content:center;line-height:1;margin-bottom:.2rem;width:20px}.inv-main{flex:1 1;min-width:0}.inv-content{display:block;font-size:.9rem;line-height:1.45;word-break:break-word}.inv-content:not(.inv-empty){cursor:pointer}.inv-content.inv-empty{color:var(--muted-text);font-style:italic}.inv-edit-input{background:#0000;border:none;border-bottom:1px solid var(--primary-color);color:var(--text-color);font-size:.9rem;outline:none;padding:0;width:100%}.inv-clear-btn{background:#0000;border:none;color:var(--muted-text);cursor:pointer;font-size:1rem;line-height:1;margin:0;opacity:0;padding:.1rem;position:absolute;right:.4rem;top:.35rem;transition:opacity .1s,color .1s;width:auto}.inv-slot:hover .inv-clear-btn{opacity:1}.inv-clear-btn:hover{color:var(--error-color)}.sheet-add-slot{align-items:center;background:#0000;border:2px dashed var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;display:flex;font-size:.95rem;gap:.6rem;margin:0;padding:.85rem 1.25rem;transition:border-color .15s,color .15s;width:100%}.sheet-add-slot:hover{background:var(--selected-bg);border-color:var(--selected-border);color:var(--primary-color)}.sheet-add-slot:disabled{cursor:not-allowed;opacity:.4}.add-slot-icon{align-items:center;border:2px solid;border-radius:50%;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:600;height:28px;justify-content:center;line-height:1;width:28px}.picker-modal{animation:slide-up .18s ease;background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 24px 64px #00000080;display:flex;flex-direction:column;max-height:85vh;max-width:700px;padding:0 2rem 2rem;width:92%}.picker-modal-drag-zone{cursor:move;flex-shrink:0;padding:1.5rem 0 1.25rem;-webkit-user-select:none;user-select:none}.picker-modal-header{align-items:center;display:flex;justify-content:space-between}.picker-modal-header h2{font-size:1.4rem;margin:0}.picker-modal-close{background:#0000;border:none;border-radius:4px;color:var(--muted-text);cursor:pointer;font-size:1.6rem;line-height:1;margin:0;padding:.25rem;transition:color .1s,background .1s;width:auto}.picker-modal-close:hover{background:var(--card-bg);color:var(--text-color)}.picker-modal .picker-list-container{flex:1 1;min-height:0}.picker-modal .picker-list-scroll{flex:1 1;min-height:200px;overflow-y:auto;scrollbar-color:var(--border-color) #0000;scrollbar-width:thin}.picker-modal .picker-list-scroll::-webkit-scrollbar{width:5px}.picker-modal .picker-list-scroll::-webkit-scrollbar-track{background:#0000}.picker-modal .picker-list-scroll::-webkit-scrollbar-thumb{background-color:var(--border-color);border-radius:3px}.resize-handle{position:absolute;z-index:10}.resize-n{cursor:n-resize;top:-4px}.resize-n,.resize-s{height:8px;left:12px;right:12px}.resize-s{bottom:-4px;cursor:s-resize}.resize-e{cursor:e-resize;right:-4px}.resize-e,.resize-w{bottom:12px;top:12px;width:8px}.resize-w{cursor:w-resize;left:-4px}.resize-ne{cursor:ne-resize;right:-4px}.resize-ne,.resize-nw{height:12px;top:-4px;width:12px}.resize-nw{cursor:nw-resize;left:-4px}.resize-se{cursor:se-resize;right:-4px}.resize-se,.resize-sw{bottom:-4px;height:12px;width:12px}.resize-sw{cursor:sw-resize;left:-4px}.sheet-body{margin-bottom:2rem}.sheet-footer{border-top:1px solid var(--border-color);padding-top:.75rem}.origin-desc-grid{grid-gap:.3rem;display:grid;gap:.3rem;grid-template-columns:repeat(4,1fr);margin-bottom:.35rem}.origin-prof-outer{display:flex;gap:.5rem;margin-bottom:.35rem}.origin-prof-grid{grid-gap:.3rem;display:grid;flex:1 1;gap:.3rem;grid-template-columns:1fr 1fr}.origin-footer{align-items:center;display:flex;gap:.4rem;margin-bottom:.3rem}.origin-random-btn{background:var(--card-bg);border:1px solid var(--border-color);color:var(--text-color);font-size:.8rem;margin:0;padding:.35rem .75rem;white-space:nowrap;width:auto}.origin-random-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);color:#fff}.origin-random-btn.origin-rolling{cursor:not-allowed;opacity:.6}.origin-custom-input{flex:1 1;font-size:.8rem;margin:0;padding:.35rem .6rem}.vision-preview-panel{animation:fade-in .15s ease;background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:8px;border-radius:var(--radius);margin:.75rem 0;padding:1rem 1.25rem}.vision-preview-name{color:var(--primary-color);display:block;font-size:1.1rem;font-weight:700;margin-bottom:.4rem}.vision-preview-desc{color:var(--text-color);font-size:1rem;font-style:italic;line-height:1.6;margin:0}.origin-confirm-btn{font-size:.875rem;margin:0;padding:.35rem;width:100%}.origin-confirmed-row{align-items:center;background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:8px;border-radius:var(--radius);display:flex;gap:.75rem;padding:.65rem .85rem}.origin-confirmed-value{color:var(--primary-color);flex:1 1;font-weight:600}.origin-change-btn{font-size:.85rem;margin:0;padding:.35rem .75rem;width:auto}@keyframes origin-flash{0%{background:var(--primary-color);border-color:var(--primary-color);color:#fff}to{background:var(--primary-color);border-color:var(--primary-color);color:#fff}}.picker-card.origin-anim{background:var(--primary-color);border-color:var(--primary-color);color:#fff;transition:background .04s ease,border-color .04s ease}.picker-card.origin-row-highlight{background:var(--selected-bg);border-color:var(--selected-border);transition:background .15s ease,border-color .15s ease}.prof-modal-overlay{align-items:center;animation:fade-in .15s ease;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:500}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.prof-modal{animation:slide-up .18s ease;background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 24px 64px #00000080;max-width:400px;padding:2rem;width:100%}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.prof-modal-hint{color:var(--muted-text);font-size:.95rem;margin:0 0 1.25rem;text-align:center}.prof-modal-choices{display:flex;flex-direction:column;gap:.6rem;margin-bottom:1rem}.prof-modal-choice{font-size:1.05rem;font-weight:600;padding:.9rem 1rem;text-align:center}.prof-modal-reroll{font-size:.9rem;margin:0;width:100%}.dice-tray{bottom:1rem;right:1rem;z-index:1000}.dice-toggle{background-color:var(--primary-color);border:none;border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:1.2rem;padding:.4rem .6rem;transition:background-color .15s ease;width:auto}.dice-toggle:hover{background-color:var(--primary-hover)}.dice-tray-3d{bottom:1rem;position:fixed;right:1rem;z-index:1000}.dice-panel-3d{background:var(--panel-color);border:1px solid var(--border-color);padding:.75rem;width:420px}.dice-panel-3d,.nav-link{border-radius:8px;border-radius:var(--radius)}.nav-link{color:var(--muted-text);font-size:.9rem;padding:.4rem .6rem;text-decoration:none;transition:color .15s ease,background .15s ease}.nav-link:hover{background:var(--card-bg);color:var(--text-color);text-decoration:none}.admin-new-btn{background:var(--primary-color);border-color:var(--primary-color);color:#fff;font-size:.95rem;padding:.6rem 1.2rem}.admin-new-btn:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.admin-modal{max-width:640px}.admin-label{color:var(--muted-text);display:block;font-size:.875rem;font-weight:600;letter-spacing:.04em;margin-bottom:.35rem;text-transform:uppercase}.admin-textarea{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-sizing:border-box;color:var(--text-color);font-family:inherit;font-size:1rem;padding:.65rem .75rem;resize:vertical;width:100%}.admin-textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-color);outline:none}.admin-select{background-color:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-sizing:border-box;color:var(--text-color);cursor:pointer;font-family:inherit;font-size:1rem;padding:.65rem .75rem;width:100%}.admin-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 1px var(--primary-color);outline:none}.admin-form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.admin-save-btn{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.admin-save-btn:hover{background:var(--primary-hover);border-color:var(--primary-hover)}.admin-save-btn:disabled{cursor:not-allowed;opacity:.6}.admin-modal-actions{justify-content:flex-start}.admin-modal-delete-btn{margin-left:auto}.admin-tag-badge{background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:999px;color:var(--primary-color);display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.03em;margin-top:.4rem;padding:.2rem .55rem}.admin-confirm-overlay{z-index:1100}.admin-users-columns{grid-gap:2rem;align-items:start;display:grid;gap:2rem;grid-template-columns:1fr 1fr}@media (max-width:700px){.admin-users-columns{grid-template-columns:1fr}}.admin-users-section{background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);padding:1.5rem}.admin-users-heading{align-items:center;display:flex;font-size:1.1rem;gap:.6rem;margin:0 0 1rem}.admin-user-count{align-items:center;background:var(--selected-bg);border:1px solid var(--selected-border);border-radius:999px;color:var(--primary-color);display:inline-flex;font-size:.75rem;font-weight:700;height:1.5rem;justify-content:center;line-height:1;min-width:1.5rem;padding:0 .4rem}.admin-user-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.admin-user-card{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);display:flex;gap:1rem;justify-content:space-between;padding:.75rem 1rem}.admin-user-info{display:flex;flex-direction:column;gap:.15rem;min-width:0}.admin-user-name{font-size:.95rem;font-weight:600}.admin-user-email,.admin-user-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-user-email{font-size:.82rem}.admin-approve-btn{background:#22c55e26;border-color:#22c55e;color:#22c55e;flex-shrink:0}.admin-approve-btn:hover{background:#22c55e40}.admin-user-locked{cursor:not-allowed;flex-shrink:0;opacity:.35}.admin-user-locked:hover{background:#0000}.app-layout{align-items:stretch;display:flex;min-height:calc(100vh - 56px)}.app-layout .app-content{flex:1 1;min-width:0}.room-sidebar{background:var(--panel-color);border-left:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;gap:12px;padding:16px 12px;width:240px}.room-sidebar-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding-bottom:8px}.room-sidebar-title{color:var(--text-color);font-size:.9rem;font-weight:600}.room-leave-btn{background:#ef44441f;border:1px solid #ef4444;border-radius:8px;border-radius:var(--radius);color:#ef4444;cursor:pointer;font-size:.75rem;margin-top:4px;padding:3px 8px}.room-leave-btn:hover{background:#ef444438}.room-sidebar-id{display:flex;flex-direction:column;gap:2px}.room-sidebar-id-label{color:var(--muted-text);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase}.room-id-copy{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--text-color);cursor:pointer;font-size:.75rem;margin:0;padding:4px 8px;text-align:center;width:100%}.room-id-copy:hover{background:var(--bg-color);border-color:var(--primary-color)}.room-owner-badge{align-self:flex-start;background:#6366f126;border:1px solid var(--primary-color);border-radius:999px;color:var(--primary-color);font-size:.7rem;padding:2px 8px}.room-card-list{display:flex;flex-direction:column;gap:10px;overflow-y:auto}.room-card{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);cursor:pointer;padding:10px;transition:border-color .15s}.room-card:hover{border-color:var(--primary-color)}.room-card-own{border-color:#6366f166}.room-card-header{align-items:center;display:flex;gap:8px;margin-bottom:8px}.room-card-avatar{border-radius:50%;flex-shrink:0;height:36px;object-fit:cover;width:36px}.room-card-avatar-placeholder{background:var(--border-color)}.room-card-identity{display:flex;flex-direction:column;min-width:0}.room-card-name{color:var(--text-color);font-size:.85rem;font-weight:600}.room-card-name,.room-card-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-card-title{color:var(--muted-text);font-size:.72rem}.room-card-vitals{display:flex;flex-direction:column;gap:4px}.room-vital-row{align-items:center;display:flex;gap:6px}.room-vital-label{color:var(--muted-text);flex-shrink:0;font-size:.68rem;width:30px}.room-vital-track{background:var(--border-color);border-radius:999px;flex:1 1;height:5px;overflow:hidden}.room-vital-fill{border-radius:999px;height:100%;transition:width .2s}.room-vital-hp{background:var(--vital-life)}.room-vital-ep{background:var(--vital-energy)}.room-vital-value{color:var(--muted-text);flex-shrink:0;font-size:.68rem;text-align:right;width:36px}.sheet-header-actions{align-items:flex-start;display:flex;margin-right:8px}.room-open-btn{background:#6366f11a;border:1px solid var(--primary-color);border-radius:8px;border-radius:var(--radius);color:var(--primary-color);cursor:pointer;font-size:.72rem;padding:4px 10px;white-space:nowrap}.room-open-btn:hover{background:#6366f133}.room-open-btn:disabled{cursor:default;opacity:.6}.sheet-readonly-badge{background:#f59e0b1f;border:1px solid #f59e0b;border-radius:999px;color:#f59e0b;display:inline-block;font-size:.7rem;margin-top:4px;padding:2px 7px}.sheet-view-only button:not(.vital-btn):not(.room-open-btn):not(.modal-close-btn):not(.modal-overlay button){opacity:.4;pointer-events:none}.vital-disabled .vital-btn{opacity:.4}.room-modal-choices,.room-modal-join{display:flex;flex-direction:column;gap:10px;margin-top:8px}.room-modal-join-actions{display:flex;gap:8px;justify-content:flex-end}.modal-error{color:var(--error-color);font-size:.82rem;margin-top:6px}.modal-input{background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-sizing:border-box;color:var(--text-color);font-size:.9rem;padding:8px 10px;width:100%}.modal-input:focus{border-color:var(--primary-color);outline:none}.modal-box{background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);max-width:420px;padding:24px 28px;position:relative;width:92%}.modal-title{color:var(--text-color);font-size:1.2rem;font-weight:600;margin:0 0 16px}.modal-close-btn{background:#0000;border:none;border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;font-size:1rem;line-height:1;margin:0;padding:4px 6px;position:absolute;right:12px;top:12px;width:auto}.modal-close-btn:hover{background:var(--card-bg);color:var(--text-color)}.equip-delete-confirm-btn{background:var(--error-color);border:1px solid var(--error-color);border-radius:8px;border-radius:var(--radius);color:#fff;cursor:pointer;font-size:.9rem;margin:0;padding:.5rem 1rem;width:auto}.equip-delete-confirm-btn:hover{background:#dc2626;border-color:#dc2626}.equip-delete-confirm-btn:disabled{cursor:not-allowed;opacity:.5}.room-modal-pick{display:flex;flex-direction:column;gap:10px;margin-top:8px}.room-modal-pick-hint{color:var(--muted-text);font-size:.85rem;margin:0}.room-pick-list{display:flex;flex-direction:column;gap:6px;max-height:300px;overflow-y:auto}.room-pick-card{align-items:center;background:var(--bg-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);cursor:pointer;display:flex;gap:10px;margin:0;padding:8px 12px;text-align:left;transition:border-color .12s;width:100%}.room-pick-card:hover{background:var(--bg-color);border-color:var(--primary-color)}.room-pick-card:disabled{cursor:not-allowed;opacity:.5}.room-pick-avatar{border-radius:50%;flex-shrink:0;height:36px;object-fit:cover;width:36px}.room-pick-avatar-placeholder{background:var(--border-color)}.room-pick-info{display:flex;flex-direction:column;min-width:0}.room-pick-name{color:var(--text-color);font-size:.9rem;font-weight:600}.room-pick-title{color:var(--muted-text);font-size:.78rem}.room-pick-no-char{font-size:.85rem;margin-top:2px}.room-modal-pick-back{align-self:flex-start;font-size:.85rem;margin:0;padding:.4rem .85rem;width:auto}.room-card-gm{background:#facc150a;border-color:#facc1559}.room-card-gm .room-card-name{color:#f59e0b}.room-card-gm:hover{border-color:#facc158c}.room-view{margin:0 auto;max-width:1400px;padding:2rem 1.5rem}.room-view-header{margin-bottom:2rem}.room-view-title-row{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between}.room-view-title{font-size:1.6rem;font-weight:700;margin:0}.room-view-header-actions{align-items:center;display:flex;gap:.6rem}.room-view-copy-btn{font-family:inherit;font-size:.8rem;margin:0;white-space:nowrap;width:auto}.room-view-id{font-family:monospace;font-size:.75rem;letter-spacing:.03em;margin:.4rem 0 0}.room-view-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.room-member-card{background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);display:flex;flex-direction:column;gap:.9rem;padding:1.1rem 1.25rem}.room-member-card-gm{background:#facc150a;border-color:#facc1559}.room-member-card-header{align-items:center;display:flex;gap:.75rem}.room-member-avatar{border-radius:50%;flex-shrink:0;height:44px;object-fit:cover;width:44px}.room-member-avatar-placeholder{background:var(--border-color)}.room-member-identity{display:flex;flex-direction:column;min-width:0}.room-member-name{color:var(--text-color);font-size:1rem;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-member-card-gm .room-member-name{color:#f59e0b}.room-member-title{color:var(--muted-text);font-size:.78rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.room-member-vitals{display:flex;flex-direction:column;gap:.55rem}.room-member-vital-row{grid-gap:.5rem;align-items:center;display:grid;gap:.5rem;grid-template-columns:40px 1fr 52px 52px}.room-member-vital-label{color:var(--muted-text);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.room-member-vital-val{color:var(--text-color);font-size:.82rem;text-align:right;white-space:nowrap}.room-member-vital-btns{display:flex;gap:3px;justify-content:flex-end}.room-member-vital-btns .vital-btn{height:24px;width:24px}.room-member-error{color:var(--error-color);font-size:.75rem;margin:0}.room-member-sheet-btn{background:#0000;border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);color:var(--muted-text);cursor:pointer;font-size:.82rem;margin:0;padding:.45rem .75rem;text-align:center;transition:border-color .12s,color .12s;width:100%}.room-member-sheet-btn:hover{background:#0000;border-color:var(--primary-color);color:var(--primary-color)}.dice-tray{align-items:flex-start;bottom:1.25rem;display:flex;flex-direction:column-reverse;gap:.5rem;left:1.25rem;position:fixed;z-index:200}.dice-toggle-btn{align-items:center;background:var(--panel-color);border:2px solid var(--border-color);border-radius:50%;box-shadow:0 4px 12px #00000059;color:var(--text-color);cursor:pointer;display:flex;flex-shrink:0;font-size:1.3rem;height:46px;justify-content:center;margin:0;padding:0;transition:border-color .15s,background .15s;width:46px}.dice-toggle-btn:hover{background-color:var(--primary-hover);border-color:var(--primary-color)}.dice-panel{animation:slide-up .15s ease;background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 8px 28px #00000073;display:flex;flex-direction:column;gap:.6rem;max-height:calc(100dvh - 80px);overflow-y:auto;padding:.75rem;scrollbar-color:var(--border-color) #0000;scrollbar-width:thin;width:440px}.dice-panel-header{align-items:center;display:flex;justify-content:space-between}.dice-panel-title{font-size:.88rem;font-weight:600}.dice-count-badge{background:var(--card-bg);border:1px solid var(--border-color);border-radius:20px;color:var(--muted-text);font-size:.72rem;padding:.1rem .5rem}.dice-picker{display:flex;gap:3px;justify-content:space-between}.die-btn{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;height:40px;justify-content:center;margin:0;padding:0;position:relative;transition:transform .1s;width:40px}.die-btn:hover:not(:disabled){transform:scale(1.12)}.die-btn:active:not(:disabled){transform:scale(.94)}.die-btn:disabled{cursor:not-allowed;opacity:.35}.die-btn-svg{height:100%;inset:0;overflow:visible;pointer-events:none;position:absolute;width:100%}.die-btn-svg *{fill:var(--card-bg);stroke:var(--border-color);stroke-width:5;transition:stroke .12s}.die-btn:hover:not(:disabled) .die-btn-svg *{stroke:var(--text-color)}.die-btn-label{color:var(--text-color);font-size:.6rem;font-weight:700;margin-top:4px;position:relative;z-index:1}.dice-tray-groups{display:flex;flex-direction:column;gap:4px}.dice-tray-row{align-items:center;display:flex;gap:6px}.dice-row-label{color:var(--muted-text);flex-shrink:0;font-size:.65rem;font-weight:600;text-align:right;width:26px}.dice-row-dice{display:flex;flex-wrap:wrap;gap:4px}.die-result{align-items:center;background:#0000;border:none;cursor:pointer;display:flex;flex-direction:column;flex-shrink:0;gap:0;height:36px;justify-content:center;margin:0;padding:0;position:relative;width:36px}.die-result:disabled{cursor:default}.die-shape-svg{height:100%;inset:0;overflow:visible;pointer-events:none;position:absolute;transform-origin:50% 50%;transition:filter .12s;width:100%}.die-shape-svg *{fill:var(--card-bg);stroke:var(--border-color);stroke-width:5;transition:stroke .15s,fill .15s}.die-result:hover:not(:disabled) .die-shape-svg *{stroke:var(--muted-text)}.die-val{color:var(--text-color);font-size:.85rem;font-weight:800;line-height:1;position:relative;z-index:1}.die-result-d4 .die-val{margin-top:8px}@keyframes spin-cw{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes spin-ccw{0%{transform:rotate(0deg)}to{transform:rotate(-1turn)}}@keyframes pulse-d100{0%,to{transform:scale(1)}50%{transform:scale(.78)}}.die-result-d4.die-anim .die-shape-svg{animation:spin-cw .35s linear infinite}.die-result-d6.die-anim .die-shape-svg{animation:spin-cw .5s linear infinite}.die-result-d8.die-anim .die-shape-svg{animation:spin-ccw .45s linear infinite}.die-result-d10.die-anim .die-shape-svg{animation:spin-cw .6s linear infinite}.die-result-d12.die-anim .die-shape-svg{animation:spin-ccw .7s linear infinite}.die-result-d20.die-anim .die-shape-svg{animation:spin-cw .85s linear infinite}.die-result-d100.die-anim .die-shape-svg{animation:pulse-d100 .28s ease-in-out infinite}@keyframes die-sel-pulse{0%,to{filter:drop-shadow(0 0 2px var(--primary-color))}50%{filter:drop-shadow(0 0 7px var(--primary-color)) drop-shadow(0 0 2px var(--primary-color))}}.die-selected .die-shape-svg *{stroke:var(--primary-color);fill:var(--selected-bg)}.die-selected .die-shape-svg{animation:die-sel-pulse 1.1s ease-in-out infinite}.dice-total{color:var(--muted-text);font-size:.8rem;padding-right:2px;text-align:right}.dice-total strong{color:var(--text-color);font-size:1rem}.dice-actions{display:flex;gap:.4rem}.dice-clear{flex-shrink:0;padding:.38rem .65rem;width:auto}.dice-clear,.dice-reroll{font-size:.78rem;margin:0}.dice-reroll{background:#0000;border:1px solid var(--primary-color);border-radius:8px;border-radius:var(--radius);color:var(--primary-color);cursor:pointer;flex:1 1;padding:.38rem;transition:background .15s}.dice-reroll:hover:not(:disabled){background:var(--selected-bg)}.dice-reroll:disabled{cursor:not-allowed;opacity:.45}.dice-roll{flex:1 1;font-size:.78rem;margin:0;padding:.38rem}.dice-roll:disabled{cursor:not-allowed;opacity:.45}.dice-canvas-wrap{background:#0000002e;border-radius:8px;border-radius:var(--radius);overflow:hidden}.dice-results-row{align-items:center;display:flex;flex-wrap:wrap;gap:4px;padding:0 2px}.dice-result-badge{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);cursor:pointer;display:inline-flex;font-size:.78rem;font-weight:700;height:24px;justify-content:center;min-width:28px;padding:0 5px;transition:border-color .12s,background .12s;-webkit-user-select:none;user-select:none}.dice-result-badge:hover{border-color:var(--muted-text)}.dice-result-selected{background:var(--selected-bg);border-color:var(--primary-color);color:var(--primary-color)}.dice-result-rolling{cursor:default;opacity:.5}.dice-result-total{color:var(--muted-text);font-size:.82rem;margin-left:auto}.dice-result-total strong{color:var(--text-color);font-size:.95rem}.dice-roll-popup-stack{align-items:flex-end;bottom:1.25rem;display:flex;flex-direction:column-reverse;gap:.5rem;pointer-events:none;position:fixed;right:1.25rem;z-index:250}.dice-roll-popup{animation:dice-popup-in .3s ease-out;pointer-events:auto}@keyframes dice-popup-in{0%{opacity:0;transform:translateY(-12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.dice-roll-popup-inner{background:var(--panel-color);border:1px solid var(--border-color);border-radius:8px;border-radius:var(--radius);box-shadow:0 8px 32px #00000080;display:flex;flex-direction:column;gap:.5rem;max-width:400px;min-width:220px;padding:.75rem 1rem 1.75rem;position:relative}.dice-roll-popup-close{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;bottom:.4rem;color:var(--muted-text);cursor:pointer;font-size:.72rem;left:.5rem;line-height:1.2;margin:0;padding:.1rem .4rem;position:absolute;transition:color .12s,border-color .12s;width:auto}.dice-roll-popup-close:hover{background:var(--card-bg);border-color:var(--muted-text);color:var(--text-color)}.dice-roll-popup-header{align-items:center;display:flex;gap:.6rem;padding-right:1rem}.dice-roll-popup-avatar{border:2px solid var(--border-color);border-radius:50%;flex-shrink:0;height:36px;object-fit:cover;width:36px}.dice-roll-popup-avatar-placeholder{background:var(--card-bg)}.dice-roll-popup-name{color:var(--text-color);font-size:.92rem;font-weight:700}.dice-roll-popup-dice{display:flex;flex-wrap:wrap;gap:.35rem}.dice-roll-popup-die{align-items:center;background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;color:var(--text-color);display:inline-flex;font-size:.88rem;font-weight:800;height:26px;justify-content:center;min-width:28px;padding:0 .4rem}.dice-roll-popup-total{border-top:1px solid var(--border-color);color:var(--muted-text);font-size:.85rem;padding-top:.35rem;text-align:right}.dice-roll-popup-total strong{color:var(--text-color);font-size:1.05rem}
/*# sourceMappingURL=main.0ada279f.css.map*/