:root{--text:#94a3b8;--text-h:#f8fafc;--bg:#0b0f14;--bg-card:#111827;--bg-card-hover:#161f30;--border:#252f3fcc;--border-hover:#334155;--code-bg:#1e293b;--accent:#8b5cf6;--accent-dim:#8b5cf614;--accent-bg:#8b5cf626;--accent-border:#8b5cf64d;--shadow:0 4px 6px -1px #0006, 0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #00000080, 0 4px 6px -4px #0006;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/150% var(--sans);letter-spacing:.15px;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{background:linear-gradient(160deg,#0b0f14 0%,#0d1424 100%);min-height:100vh;margin:0}#root{width:100%;max-width:1200px;margin:0 auto;padding:32px 24px}h1,h2,h3{font-family:var(--heading);color:var(--text-h);font-weight:600}h1{text-align:center;letter-spacing:-.02em;margin:0 0 28px;font-size:1.75rem}input,button{font-family:var(--sans);border:1px solid var(--border);background:var(--bg-card);color:var(--text-h);border-radius:8px;outline:none;padding:10px 16px;font-size:15px;transition:border-color .2s,box-shadow .2s}input::placeholder{color:var(--text);opacity:.5}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}button{cursor:pointer;background:var(--accent);color:#fff;border:none;font-weight:500}button:hover{filter:brightness(1.1)}button:disabled{opacity:.4;cursor:not-allowed}.container{padding:0}.controls{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.controls input{flex:1;min-width:200px}.pills{flex-wrap:wrap;gap:8px;min-height:0;margin-bottom:24px;display:flex}.pill{background:var(--bg-card);border:1px solid var(--border);color:var(--text-h);border-radius:9999px;align-items:center;gap:7px;padding:6px 10px 6px 14px;font-size:13px;display:inline-flex}.pill button{color:var(--text);background:0 0;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;padding:0;font-size:16px;line-height:1;display:flex}.pill button:hover{background:var(--accent-bg);color:var(--accent);filter:none}.pill.loading{opacity:.6}.pill.error{background:#ef444414;border-color:#ef4444}.filter-toolbar{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;flex-direction:column;gap:8px;margin-bottom:12px;padding:10px 14px;display:flex}.filter-toolbar-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-toolbar-aa{border-top:1px solid var(--border);padding-top:4px}.tome-toggle{letter-spacing:.04em;background:var(--bg);border:1px solid var(--border);color:var(--text);white-space:nowrap;border-radius:6px;padding:5px 14px;font-size:12px;font-weight:600}.tome-toggle.active{background:var(--accent);border-color:var(--accent);color:#fff;filter:none}.tome-toggle:hover:not(.active){border-color:var(--accent-border);color:var(--text-h);filter:none}.filter-divider{background:var(--border);flex-shrink:0;width:1px;height:20px}.filter-group{flex-wrap:wrap;gap:4px;display:flex}.filter-btn{letter-spacing:.03em;background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:5px;padding:3px 9px;font-size:11px;font-weight:600}.filter-btn.active{background:var(--accent-bg);border-color:var(--accent-border);color:var(--accent);filter:none}.filter-btn:hover:not(.active){border-color:var(--border-hover);color:var(--text-h);filter:none}.filter-hint{color:var(--text);opacity:.4;font-size:12px;font-style:italic}.aa-picker-btn{background:var(--bg);border:1px dashed var(--accent-border);color:var(--accent);border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600}.aa-picker-btn:hover:not(:disabled){background:var(--accent-bg);filter:none}.aa-picker-btn:disabled{opacity:.5;cursor:not-allowed}.aa-active-list{flex-wrap:wrap;align-items:center;gap:4px;display:flex}.aa-selected-pill{background:var(--bg);border:1px solid var(--border);color:var(--text-h);border-radius:5px;align-items:center;gap:4px;padding:2px 6px 2px 8px;font-size:11px;font-weight:500;display:inline-flex}.aa-selected-pill button{color:var(--text);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:14px;height:14px;padding:0;font-size:12px;line-height:1;display:flex}.aa-selected-pill button:hover{color:#ef4444;filter:none;background:#ef44441a}.aa-arrow{color:var(--text);opacity:.4;flex-shrink:0;font-size:12px}.aa-tome-tag{letter-spacing:.03em;white-space:nowrap;border-radius:5px;padding:2px 8px;font-size:11px;font-weight:600}.aa-tome-tag.grade-greater{color:#4ade80;background:#22c55e1f;border:1px solid #22c55e40}.aa-tome-tag.grade-exalted{color:#facc15;background:#eab3081f;border:1px solid #eab30840}.aa-tome-tag.grade-ascendant{color:#a78bfa;background:#8b5cf61f;border:1px solid #8b5cf640}.aa-clear-btn{border:1px solid var(--border);color:var(--text);background:0 0;border-radius:5px;margin-left:auto;padding:3px 10px;font-size:11px}.aa-clear-btn:hover{color:#f87171;filter:none;border-color:#ef4444}.aa-picker-panel{background:linear-gradient(#1e2736,#161e2c);border:2px solid #3a4a5e;border-radius:8px;flex-direction:column;width:100%;max-width:520px;max-height:80vh;display:flex;box-shadow:0 0 40px #000c}.aa-picker-filters{border-bottom:1px solid #ffffff12;flex-direction:column;gap:7px;padding:10px 12px;display:flex}.aa-search{border:1px solid var(--border);width:100%;color:var(--text-h);background:#0000004d;border-radius:6px;padding:7px 10px;font-size:13px}.aa-filter-row{flex-wrap:wrap;gap:4px;display:flex}.aa-picker-body{scrollbar-width:thin;scrollbar-color:#8b5cf6 #0b0f14;flex:1;padding:4px 0;overflow-y:auto}.aa-picker-body::-webkit-scrollbar{width:10px}.aa-picker-body::-webkit-scrollbar-track{image-rendering:pixelated;background:#0b0f14;border-left:2px solid #1e2736}.aa-picker-body::-webkit-scrollbar-thumb{image-rendering:pixelated;background-color:#8b5cf6;border:2px solid #0b0f14;box-shadow:inset 2px 2px #a78bfa,inset -2px -2px #5b21b6}.aa-picker-body::-webkit-scrollbar-thumb:hover{background-color:#a78bfa;box-shadow:inset 2px 2px #c4b5fd,inset -2px -2px #7c3aed}.aa-picker-body::-webkit-scrollbar-button{width:10px;height:10px;image-rendering:pixelated;background-color:#1e2736;border:2px solid #0b0f14;display:block}.aa-picker-body::-webkit-scrollbar-button:vertical:decrement{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='4' viewBox='0 0 6 4'%3E%3Cpolygon points='3,0 6,4 0,4' fill='%23a78bfa'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:6px 4px}.aa-picker-body::-webkit-scrollbar-button:vertical:increment{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='6' height='4' viewBox='0 0 6 4'%3E%3Cpolygon points='3,4 6,0 0,0' fill='%23a78bfa'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:6px 4px}.aa-picker-body::-webkit-scrollbar-button:hover{background-color:#2a3748}.aa-picker-body::-webkit-scrollbar-corner{background:#0b0f14}.aa-row{cursor:pointer;border-bottom:1px solid #ffffff0a;align-items:center;gap:10px;padding:8px 14px;transition:background .1s;display:flex}.aa-row:hover{background:var(--bg-card-hover)}.aa-row.selected{background:var(--accent-dim)}.aa-row-check{width:16px;color:var(--accent);flex-shrink:0;font-size:12px;font-weight:700}.aa-row-info{flex-direction:column;gap:2px;min-width:0;display:flex}.aa-row-name{color:var(--text-h);font-size:13px;font-weight:500}.aa-row-meta{color:var(--text);align-items:center;gap:6px;font-size:11px;display:flex}.aa-grade-tag{text-transform:uppercase;letter-spacing:.04em;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.aa-grade-tag.grade-greater{color:#4ade80;background:#22c55e26}.aa-grade-tag.grade-exalted{color:#facc15;background:#eab30826}.aa-grade-tag.grade-ascendant{color:#a78bfa;background:#8b5cf626}.aa-empty{text-align:center;color:var(--text);opacity:.4;padding:24px;font-size:13px}.aa-picker-footer{border-top:1px solid #ffffff12;justify-content:flex-end;align-items:center;gap:10px;padding:10px 14px;display:flex}.aa-sync-info{align-items:center;gap:8px;margin-right:auto;display:flex}.aa-sync-label{color:var(--text);opacity:.5;font-size:11px;font-style:italic}.aa-resync-btn{border:1px solid var(--border);color:var(--text);background:0 0;border-radius:5px;padding:3px 10px;font-size:11px}.aa-resync-btn:hover:not(:disabled){border-color:var(--accent-border);color:var(--accent);filter:none}.aa-resync-btn:disabled{opacity:.4;cursor:not-allowed}.aa-selected-count{color:var(--accent);font-size:12px;font-weight:600}.aa-done-btn{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:6px 20px;font-size:13px;font-weight:600}.row-count{color:var(--text);opacity:.5;white-space:nowrap;flex-shrink:0;font-size:12px}.filter-toolbar-right{flex-shrink:0;align-items:center;gap:10px;margin-left:auto;display:flex}.item-search-input{border:1px solid var(--border);width:200px;color:var(--text-h);background:#0000004d;border-radius:6px;padding:4px 10px;font-size:13px}.item-search-input::placeholder{color:var(--text);opacity:.45}.item-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 2px var(--accent-bg)}.table-wrap{border:1px solid var(--border);background:var(--bg-card);border-radius:10px;overflow-x:auto}.items-table{border-collapse:collapse;width:100%;font-size:14px}.items-table thead th{text-align:left;color:var(--text);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none;background:#0e1520;padding:11px 16px 5px;font-size:11px;font-weight:500}.items-table thead th.sortable{cursor:pointer}.items-table thead th.sortable:hover{color:var(--text-h)}.th-content{align-items:center;gap:4px;display:flex}.sort-indicator{opacity:.7;font-size:10px}.sort-indicator.muted{opacity:.2}.col-filter{border:1px solid var(--border);width:100%;color:var(--text-h);background:#0000004d;border-radius:5px;margin-top:5px;margin-bottom:7px;padding:4px 8px;font-size:12px;display:block}.col-filter:focus{border-color:var(--accent);box-shadow:none}.items-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s}.items-table tbody tr:last-child{border-bottom:none}.items-table tbody tr.main-row:hover{background:var(--bg-card-hover);box-shadow:inset 3px 0 0 var(--accent)}.items-table td{vertical-align:middle;padding:10px 16px}.items-table td:first-child{width:1px;padding:10px 2px 10px 10px}.items-table td:nth-child(2){padding-left:6px}.expand-btn{color:var(--text);cursor:pointer;opacity:.5;background:0 0;border:1px solid #0000;border-radius:5px;padding:4px 7px;font-size:9px;transition:all .15s}.expand-btn:hover{color:var(--accent);background:var(--accent-bg);border-color:var(--accent-border);opacity:1;filter:none}tr.main-row:hover .expand-btn{opacity:1}.item-name-cell{align-items:center;gap:10px;display:flex}.item-name-btn{color:var(--text-h);cursor:pointer;text-align:left;font-size:14px;font-weight:500;font-family:var(--sans);background:0 0;border:none;padding:0}.item-name-btn:hover{color:var(--accent);filter:none;text-decoration:underline}.item-icon{width:36px;height:36px;image-rendering:pixelated;background:#0000004d;border:1px solid #ffffff0f;border-radius:4px;flex-shrink:0}.qty-plain{color:var(--text-h);letter-spacing:.02em;font-size:13px;font-weight:600}.detail-row>td{border-bottom:1px solid var(--border);background:#00000040;padding:10px 16px 14px 54px}.detail-pills{flex-wrap:wrap;gap:8px;display:flex}.detail-pill{background:var(--bg-card);border:1px solid var(--border);border-left:2px solid var(--accent-border);border-radius:8px;min-width:180px;padding:10px 14px}.detail-pill-name{color:var(--accent);text-transform:uppercase;letter-spacing:.06em;margin-bottom:7px;font-size:12px;font-weight:600}.detail-pill-loc{color:var(--text);align-items:baseline;gap:7px;font-size:12.5px;line-height:1.7;display:flex}.detail-pill-qty{color:var(--text-h);text-align:right;min-width:14px;font-size:13px;font-weight:700}.detail-pill-sep{color:var(--border-hover);font-size:11px}.pagination{flex-wrap:wrap;align-items:center;gap:4px;margin-top:14px;display:flex}.pagination button{background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:6px;min-width:32px;padding:5px 11px;font-size:13px}.pagination button:not(:disabled):hover{color:var(--text-h);border-color:var(--border-hover);filter:none}.pagination button:disabled{opacity:.25}.page-info{color:var(--text);opacity:.7;padding:0 8px;font-size:13px}.pagination select{background:var(--bg-card);border:1px solid var(--border);color:var(--text);border-radius:6px;margin-left:auto;padding:5px 10px;font-size:13px}.modal-backdrop{z-index:100;background:#000000bf;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-panel{background:linear-gradient(#1e2736,#161e2c);border:2px solid #3a4a5e;border-radius:6px;width:100%;max-width:380px;box-shadow:0 0 40px #000c,inset 0 1px #ffffff12}.modal-header{background:linear-gradient(#2a3748,#1e2a3a);border-bottom:1px solid #3a4a5e;border-radius:4px 4px 0 0;justify-content:space-between;align-items:center;padding:8px 12px;display:flex}.modal-title{color:#f0c040;letter-spacing:.03em;font-size:13px;font-weight:700}.modal-close{color:#94a3b8;cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:18px;line-height:1}.modal-close:hover{color:#f8fafc;filter:none}.modal-loading{text-align:center;color:var(--text);opacity:.6;padding:24px;font-size:13px}.modal-body{padding:12px}.modal-identity{border-bottom:1px solid #ffffff12;gap:12px;margin-bottom:12px;padding-bottom:12px;display:flex}.modal-icon{width:48px;height:48px;image-rendering:pixelated;background:#0006;border:1px solid #ffffff1a;border-radius:4px;flex-shrink:0}.modal-meta{flex:1;min-width:0}.modal-item-name{color:#6ee27c;margin-bottom:4px;font-size:12px;font-weight:600;line-height:1.3}.modal-detail-line{color:#94a3b8;font-size:11px;line-height:1.6}.modal-detail-label{color:#64748b}.modal-stats{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:3px 12px;display:grid}.modal-stat{justify-content:space-between;padding:1px 0;font-size:11px;display:flex}.modal-stat-label{color:#64748b}.modal-stat-value{color:#f0c040;font-weight:600}.modal-weapon{color:#94a3b8;text-align:center;border-top:1px solid #ffffff12;margin-top:10px;padding-top:10px;font-size:12px}.error-message{color:#f87171;background:#ef444414;border:1px solid #ef444440;border-radius:8px;margin-bottom:16px;padding:10px 16px;font-size:14px}.loading-spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:13px;height:13px;animation:.8s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text);padding:56px 24px}.empty-state p{opacity:.5;margin:0;font-size:15px}.pill button.pill-plan-btn,.pill button.pill-focus-btn{margin-left:0;padding:0 4px}.pill button.pill-remove-btn{margin-left:0}.planner-panel{background:linear-gradient(#1e2736,#161e2c);border:2px solid #3a4a5e;border-radius:8px;flex-direction:column;width:90%;max-width:600px;max-height:85vh;display:flex;overflow:hidden;box-shadow:0 0 40px #000c}.planner-body{flex-direction:column;gap:16px;padding:16px;display:flex;overflow-y:auto}.planner-toolbar{justify-content:space-between;align-items:center;display:flex}.add-aa-btn{background:var(--accent);color:var(--bg);cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-weight:600;transition:all .2s}.add-aa-btn:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.planner-hint{color:var(--text);opacity:.6;font-size:12px}.planner-aa-list{border:1px solid var(--border);background:#0000004d;border-radius:8px;min-height:100px;max-height:300px;overflow-y:auto}.planner-empty{text-align:center;color:var(--text);opacity:.5;padding:30px;font-size:13px}.planner-row{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;padding:10px 14px;display:flex}.planner-row:last-child{border-bottom:none}.planner-row-info{align-items:center;gap:8px;display:flex}.planner-row-name{color:var(--text-h);font-size:14px;font-weight:600}.planner-row-class{color:var(--accent);opacity:.8;font-size:12px}.planner-row-controls{align-items:center;gap:10px;display:flex}.planner-row-controls label{color:var(--text);font-size:12px}.planner-row-controls input{border:1px solid var(--border);width:50px;color:var(--text-h);text-align:center;background:#0b0f14;border-radius:4px;padding:4px;font-family:inherit}.planner-del-btn{color:var(--text);cursor:pointer;background:0 0;border:none;padding:4px;font-size:16px}.planner-del-btn:hover{color:#ef4444}.planner-summary{border:1px solid var(--accent-border);background:#8b5cf60d;border-radius:8px;padding:16px}.planner-summary h3{color:var(--accent);align-items:center;gap:8px;margin:0 0 12px;font-size:14px;display:flex}.planner-empty-hint{color:var(--text);opacity:.6;font-size:13px}.planner-tome-grid{flex-wrap:wrap;gap:8px;display:flex}.planner-tome-item{background:var(--bg);border:1px solid var(--border);border-radius:6px;align-items:center;gap:6px;padding:4px 10px;display:flex}.planner-tome-qty{color:var(--text-h);font-size:13px;font-weight:700}.planner-focus-banner{border:1px solid var(--accent);color:var(--text-h);background:#8b5cf61a;border-radius:8px;align-items:center;gap:10px;margin-bottom:20px;padding:12px 16px;font-size:14px;display:flex}.planner-focus-banner span{color:var(--accent);font-weight:700}.planner-focus-banner button{background:var(--bg);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;margin-left:auto;padding:4px 10px;font-size:12px}.planner-focus-banner button:hover{color:#ef4444;background:#ef44441a;border-color:#ef4444}.qty-plain.needed-qty{color:var(--text-h);font-weight:700}.qty-plain.text-green{color:#4ade80}.qty-plain.deficit-qty{color:#f87171;background:#ef444426;border-radius:4px;padding:2px 6px}
