.spell-card.svelte-15e9sdo{background:var(--bg-secondary, #181825);border:1px solid var(--border-color, #313244);border-left:4px solid;border-radius:10px;padding:.875rem;cursor:pointer;transition:all .15s ease;display:flex;flex-direction:column;gap:.5rem}.spell-card.svelte-15e9sdo:hover{border-color:var(--accent-primary, #cba6f7);border-left-width:4px;background:var(--bg-tertiary, #11111b)}.spell-card.selected.svelte-15e9sdo{border-color:var(--accent-primary, #cba6f7);border-left-width:4px;box-shadow:0 0 0 1px var(--accent-primary, #cba6f7)}.card-header.svelte-15e9sdo{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.spell-name.svelte-15e9sdo{font-weight:600;font-size:.95rem;color:var(--text-primary, #cdd6f4);line-height:1.2}.header-actions.svelte-15e9sdo{display:flex;align-items:center;gap:.375rem;flex-shrink:0}.favorite-btn.svelte-15e9sdo{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;padding:0;background:transparent;border:none;border-radius:4px;cursor:pointer;color:var(--text-secondary, #a6adc8);transition:all .15s ease}.favorite-btn.svelte-15e9sdo:hover{color:var(--accent-danger, #f38ba8);background:#f38ba81a}.favorite-btn.is-favorite.svelte-15e9sdo{color:var(--accent-danger, #f38ba8)}.level-badge.svelte-15e9sdo{font-size:.7rem;font-weight:600;padding:.15rem .4rem;color:#fff;border-radius:4px;white-space:nowrap;flex-shrink:0;min-width:1.25rem;text-align:center}.card-body.svelte-15e9sdo{display:flex;flex-direction:column;gap:.5rem}.spell-school.svelte-15e9sdo{font-size:.8rem;color:var(--text-secondary, #a6adc8);font-style:italic}.spell-meta.svelte-15e9sdo{display:flex;gap:.375rem;flex-wrap:wrap}.badge.svelte-15e9sdo{font-size:.65rem;font-weight:600;padding:.15rem .35rem;border-radius:3px;text-transform:uppercase;letter-spacing:.02em}.badge.ritual.svelte-15e9sdo{background:#89b4fa33;color:var(--accent-info, #89b4fa)}.badge.concentration.svelte-15e9sdo{background:#fab38733;color:var(--accent-warning, #fab387)}.spell-info.svelte-15e9sdo{display:flex;flex-wrap:wrap;gap:.5rem;font-size:.75rem;color:var(--text-secondary, #a6adc8)}.info-item.svelte-15e9sdo{display:flex;align-items:center;gap:.25rem}.info-item.svelte-15e9sdo svg:where(.svelte-15e9sdo){opacity:.6;flex-shrink:0}.spell-classes.svelte-15e9sdo{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.25rem}.class-tag.svelte-15e9sdo{font-size:.65rem;padding:.1rem .3rem;background:var(--bg-tertiary, #11111b);color:var(--text-secondary, #a6adc8);border-radius:3px}.class-tag.more.svelte-15e9sdo{background:var(--bg-primary, #1e1e2e);color:var(--text-secondary, #a6adc8)}.spell-modal.svelte-7z5sz7{max-width:700px;width:90vw;max-height:85vh;padding:0;border:1px solid var(--border-color, #313244);border-radius:16px;background:var(--bg-primary, #1e1e2e);color:var(--text-primary, #cdd6f4);box-shadow:0 25px 50px -12px #00000080}.spell-modal.svelte-7z5sz7::backdrop{background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content.svelte-7z5sz7{display:flex;flex-direction:column;max-height:85vh}.modal-header.svelte-7z5sz7{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem;border-bottom:1px solid var(--border-color, #313244);background:var(--bg-secondary, #181825);border-radius:16px 16px 0 0}.header-info.svelte-7z5sz7{display:flex;flex-direction:column;gap:.25rem}.modal-header.svelte-7z5sz7 h2:where(.svelte-7z5sz7){margin:0;font-size:1.5rem;color:var(--text-primary, #cdd6f4)}.subtitle.svelte-7z5sz7{font-size:.9rem;color:var(--text-secondary, #a6adc8);font-style:italic}.header-actions.svelte-7z5sz7{display:flex;align-items:center;gap:.5rem}.close-btn.svelte-7z5sz7{display:flex;align-items:center;justify-content:center;padding:.5rem;background:transparent;border:none;border-radius:8px;color:var(--text-secondary, #a6adc8);cursor:pointer;transition:all .15s ease}.close-btn.svelte-7z5sz7:hover{background:var(--bg-tertiary, #11111b);color:var(--text-primary, #cdd6f4)}.modal-body.svelte-7z5sz7{padding:1.5rem;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.spell-stats.svelte-7z5sz7{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;padding:1rem;background:var(--bg-secondary, #181825);border-radius:10px}.stat.svelte-7z5sz7{display:flex;flex-direction:column;gap:.25rem}.stat-label.svelte-7z5sz7{font-size:.75rem;font-weight:600;color:var(--text-secondary, #a6adc8);text-transform:uppercase;letter-spacing:.05em}.stat-value.svelte-7z5sz7{font-size:.9rem;color:var(--text-primary, #cdd6f4)}.conc-indicator.svelte-7z5sz7{color:var(--accent-warning, #fab387)}.spell-tags.svelte-7z5sz7{display:flex;flex-wrap:wrap;gap:.5rem}.tag.svelte-7z5sz7{font-size:.75rem;font-weight:500;padding:.25rem .5rem;border-radius:5px}.tag.ritual.svelte-7z5sz7{background:#89b4fa33;color:var(--accent-info, #89b4fa)}.tag.concentration.svelte-7z5sz7{background:#fab38733;color:var(--accent-warning, #fab387)}.tag.class.svelte-7z5sz7{background:var(--bg-tertiary, #11111b);color:var(--text-secondary, #a6adc8)}.spell-description.svelte-7z5sz7{line-height:1.7;color:var(--text-primary, #cdd6f4);font-size:.95rem}.spell-description.svelte-7z5sz7 p:where(.svelte-7z5sz7){margin:0;white-space:pre-wrap}.higher-levels.svelte-7z5sz7{padding:1rem;background:#cba6f71a;border-left:3px solid var(--accent-primary, #cba6f7);border-radius:0 8px 8px 0}.higher-levels.svelte-7z5sz7 h3:where(.svelte-7z5sz7){margin:0 0 .5rem;font-size:.9rem;font-weight:600;color:var(--accent-primary, #cba6f7)}.higher-levels.svelte-7z5sz7 p:where(.svelte-7z5sz7){margin:0;font-size:.9rem;color:var(--text-primary, #cdd6f4);line-height:1.6}.spell-source.svelte-7z5sz7{font-size:.8rem;color:var(--text-secondary, #a6adc8);padding-top:.5rem;border-top:1px solid var(--border-color, #313244)}.source-label.svelte-7z5sz7{font-weight:500;margin-right:.25rem}.page-num.svelte-7z5sz7{margin-left:.5rem;opacity:.7}.spells-page.svelte-b9ede0{display:flex;flex-direction:column;height:100%;padding:1.5rem;gap:1rem;position:relative}.toast.svelte-b9ede0{position:fixed;top:1rem;right:1rem;z-index:1000;display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:.5rem;font-size:.875rem;animation:svelte-b9ede0-slideIn .3s ease-out}.toast-error.svelte-b9ede0{background:#dc2626e6;color:#fff;border:1px solid rgba(255,255,255,.2)}.toast-dismiss.svelte-b9ede0{background:transparent;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:0;line-height:1;opacity:.7}.toast-dismiss.svelte-b9ede0:hover{opacity:1}@keyframes svelte-b9ede0-slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.page-header.svelte-b9ede0{display:flex;justify-content:space-between;align-items:center}.header-left.svelte-b9ede0{display:flex;align-items:baseline;gap:1rem}.page-header.svelte-b9ede0 h1:where(.svelte-b9ede0){margin:0;font-size:1.5rem;color:var(--text-primary, #cdd6f4)}.spell-count.svelte-b9ede0{font-size:.9rem;color:var(--text-secondary, #a6adc8)}.view-toggle.svelte-b9ede0{display:flex;background:var(--bg-tertiary, #11111b);border:1px solid var(--border-color, #313244);border-radius:8px;overflow:hidden}.toggle-btn.svelte-b9ede0{display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;background:transparent;border:none;color:var(--text-secondary, #a6adc8);cursor:pointer;transition:all .15s ease}.toggle-btn.svelte-b9ede0:hover{color:var(--text-primary, #cdd6f4)}.toggle-btn.active.svelte-b9ede0{background:var(--accent-primary, #cba6f7);color:var(--bg-primary, #1e1e2e)}.filters.svelte-b9ede0{display:flex;flex-direction:column;gap:.75rem}.filters-row.svelte-b9ede0{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.search-box.svelte-b9ede0{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg-tertiary, #11111b);border:1px solid var(--border-color, #313244);border-radius:8px;flex:1;max-width:300px}.search-box.svelte-b9ede0 svg:where(.svelte-b9ede0){color:var(--text-secondary, #a6adc8);flex-shrink:0}.search-box.svelte-b9ede0 input:where(.svelte-b9ede0){flex:1;background:transparent;border:none;color:var(--text-primary, #cdd6f4);font-size:.9rem;outline:none}.search-box.svelte-b9ede0 input:where(.svelte-b9ede0)::placeholder{color:var(--text-secondary, #a6adc8);opacity:.6}.clear-btn.svelte-b9ede0{display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:none;color:var(--text-secondary, #a6adc8);cursor:pointer;border-radius:4px}.clear-btn.svelte-b9ede0:hover{background:var(--bg-secondary, #181825);color:var(--text-primary, #cdd6f4)}.filter-select.svelte-b9ede0{padding:.5rem .75rem;background:var(--bg-tertiary, #11111b);border:1px solid var(--border-color, #313244);border-radius:8px;color:var(--text-primary, #cdd6f4);font-size:.85rem;cursor:pointer;outline:none}.filter-select.svelte-b9ede0:focus{border-color:var(--accent-primary, #cba6f7)}.filter-toggle.svelte-b9ede0{display:flex;align-items:center;gap:.5rem;font-size:.85rem;color:var(--text-secondary, #a6adc8);cursor:pointer}.filter-toggle.svelte-b9ede0 input:where(.svelte-b9ede0){accent-color:var(--accent-primary, #cba6f7)}.filter-toggle.favorites-toggle.svelte-b9ede0{color:var(--accent-danger, #f38ba8)}.filter-toggle.favorites-toggle.svelte-b9ede0 svg:where(.svelte-b9ede0){flex-shrink:0}.hint.svelte-b9ede0{font-size:.85rem;opacity:.7}.reset-btn.svelte-b9ede0{padding:.25rem .5rem;background:transparent;border:none;color:var(--accent-primary, #cba6f7);font-size:.8rem;cursor:pointer}.reset-btn.svelte-b9ede0:hover{text-decoration:underline}.error-banner.svelte-b9ede0{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#f38ba826;border:1px solid var(--accent-danger, #f38ba8);border-radius:8px;color:var(--accent-danger, #f38ba8);font-size:.9rem}.error-banner.svelte-b9ede0 button:where(.svelte-b9ede0){padding:.25rem .5rem;background:transparent;border:1px solid var(--accent-danger, #f38ba8);border-radius:4px;color:var(--accent-danger, #f38ba8);font-size:.8rem;cursor:pointer}.content.svelte-b9ede0{display:flex;gap:1.5rem;flex:1;overflow:hidden}.spell-list.svelte-b9ede0{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:1rem}.loading.svelte-b9ede0{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:2rem;color:var(--text-secondary, #a6adc8)}.spinner.svelte-b9ede0{width:20px;height:20px;border:2px solid var(--border-color, #313244);border-top-color:var(--accent-primary, #cba6f7);border-radius:50%;animation:svelte-b9ede0-spin .6s linear infinite}@keyframes svelte-b9ede0-spin{to{transform:rotate(360deg)}}.empty-list.svelte-b9ede0{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-secondary, #a6adc8)}.empty-list.svelte-b9ede0 p:where(.svelte-b9ede0){margin:0 0 1rem}.btn-secondary.svelte-b9ede0{padding:.5rem 1rem;background:var(--bg-tertiary, #11111b);color:var(--text-secondary, #a6adc8);border:1px solid var(--border-color, #313244);border-radius:8px;font-size:.85rem;cursor:pointer}.btn-secondary.svelte-b9ede0:hover{background:var(--bg-secondary, #181825);color:var(--text-primary, #cdd6f4)}.spell-grid.svelte-b9ede0{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.spell-table-container.svelte-b9ede0{overflow-x:auto;border:1px solid var(--border-color, #313244);border-radius:8px}.spell-table.svelte-b9ede0{width:100%;border-collapse:collapse;font-size:.875rem}.spell-table.svelte-b9ede0 thead:where(.svelte-b9ede0){background:var(--bg-tertiary, #11111b);position:sticky;top:0;z-index:1}.spell-table.svelte-b9ede0 th:where(.svelte-b9ede0){padding:.75rem .5rem;text-align:left;font-weight:600;color:var(--text-secondary, #a6adc8);border-bottom:1px solid var(--border-color, #313244);white-space:nowrap;-webkit-user-select:none;user-select:none}.spell-table.svelte-b9ede0 th.sortable:where(.svelte-b9ede0){cursor:pointer;transition:color .15s ease}.spell-table.svelte-b9ede0 th.sortable:where(.svelte-b9ede0):hover{color:var(--text-primary, #cdd6f4)}.spell-table.svelte-b9ede0 th.sorted:where(.svelte-b9ede0){color:var(--accent-primary, #cba6f7)}.sort-icon.svelte-b9ede0{margin-left:.25rem;font-size:.7rem}.spell-table.svelte-b9ede0 td:where(.svelte-b9ede0){padding:.625rem .5rem;color:var(--text-primary, #cdd6f4);border-bottom:1px solid var(--border-color, #313244)}.spell-row.svelte-b9ede0{cursor:pointer;transition:background .15s ease}.spell-row.svelte-b9ede0:hover{background:var(--bg-tertiary, #11111b)}.spell-row.selected.svelte-b9ede0{background:#cba6f71a}.col-fav.svelte-b9ede0{width:2.5rem;text-align:center}.col-name.svelte-b9ede0{font-weight:500;min-width:150px}.col-level.svelte-b9ede0{width:3.5rem;text-align:center}.col-school.svelte-b9ede0,.col-time.svelte-b9ede0{width:100px}.col-range.svelte-b9ede0{width:90px}.col-conc.svelte-b9ede0,.col-ritual.svelte-b9ede0{width:4rem;text-align:center}.col-classes.svelte-b9ede0{min-width:120px}.fav-btn.svelte-b9ede0{display:flex;align-items:center;justify-content:center;padding:.25rem;background:transparent;border:none;border-radius:4px;color:var(--text-secondary, #a6adc8);cursor:pointer;transition:color .15s ease}.fav-btn.svelte-b9ede0:hover,.fav-btn.is-favorite.svelte-b9ede0{color:var(--accent-danger, #f38ba8)}.level-badge.svelte-b9ede0{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;font-size:.75rem;font-weight:600;background:var(--accent-primary, #cba6f7);color:var(--bg-primary, #1e1e2e);border-radius:4px}.badge-conc.svelte-b9ede0{font-size:.7rem;padding:.15rem .35rem;background:#fab38733;color:var(--accent-warning, #fab387);border-radius:3px}.badge-ritual.svelte-b9ede0{font-size:.7rem;padding:.15rem .35rem;background:#89b4fa33;color:var(--accent-info, #89b4fa);border-radius:3px}.classes-text.svelte-b9ede0{font-size:.8rem;color:var(--text-secondary, #a6adc8)}.pagination.svelte-b9ede0{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary, #181825);border:1px solid var(--border-color, #313244);border-radius:8px}.page-info-left.svelte-b9ede0{font-size:.85rem;color:var(--text-secondary, #a6adc8)}.page-controls.svelte-b9ede0{display:flex;align-items:center;gap:.5rem}.page-btn.svelte-b9ede0{padding:.4rem .75rem;background:var(--bg-tertiary, #11111b);border:1px solid var(--border-color, #313244);border-radius:6px;color:var(--text-primary, #cdd6f4);font-size:.85rem;cursor:pointer;transition:all .15s ease}.page-btn.svelte-b9ede0:hover:not(:disabled){border-color:var(--accent-primary, #cba6f7);color:var(--accent-primary, #cba6f7)}.page-btn.svelte-b9ede0:disabled{opacity:.4;cursor:not-allowed}.page-info.svelte-b9ede0{font-size:.85rem;color:var(--text-secondary, #a6adc8);min-width:100px;text-align:center}.detail-panel.svelte-b9ede0{width:380px;flex-shrink:0;background:var(--bg-secondary, #181825);border:1px solid var(--border-color, #313244);border-radius:12px;overflow:hidden;display:flex;flex-direction:column}.detail-header.svelte-b9ede0{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;border-bottom:1px solid var(--border-color, #313244)}.detail-header.svelte-b9ede0 h2:where(.svelte-b9ede0){margin:0;font-size:1.1rem;color:var(--text-primary, #cdd6f4)}.detail-actions.svelte-b9ede0{display:flex;gap:.25rem}.btn-icon.svelte-b9ede0{display:flex;align-items:center;justify-content:center;padding:.4rem;background:transparent;border:none;border-radius:6px;color:var(--text-secondary, #a6adc8);cursor:pointer}.btn-icon.svelte-b9ede0:hover{background:var(--bg-tertiary, #11111b);color:var(--text-primary, #cdd6f4)}.detail-body.svelte-b9ede0{flex:1;overflow-y:auto;padding:1.25rem;display:flex;flex-direction:column;gap:1rem}.spell-subtitle.svelte-b9ede0{font-size:.9rem;font-style:italic;color:var(--text-secondary, #a6adc8)}.ritual-tag.svelte-b9ede0{color:var(--accent-info, #89b4fa)}.detail-section.svelte-b9ede0{display:flex;flex-direction:column;gap:.5rem}.detail-section.svelte-b9ede0 h3:where(.svelte-b9ede0){margin:0;font-size:.85rem;font-weight:600;color:var(--text-secondary, #a6adc8);text-transform:uppercase;letter-spacing:.05em}.stat-row.svelte-b9ede0{display:flex;gap:.5rem;font-size:.9rem}.stat-row.svelte-b9ede0 .label:where(.svelte-b9ede0){font-weight:600;color:var(--text-secondary, #a6adc8)}.stat-row.svelte-b9ede0 span:where(.svelte-b9ede0):not(.label){color:var(--text-primary, #cdd6f4)}.conc.svelte-b9ede0{color:var(--accent-warning, #fab387)}.description.svelte-b9ede0{margin:0;font-size:.9rem;color:var(--text-primary, #cdd6f4);line-height:1.6;white-space:pre-wrap}.higher-levels.svelte-b9ede0{padding:.75rem;background:#cba6f71a;border-left:3px solid var(--accent-primary, #cba6f7);border-radius:0 6px 6px 0}.higher-levels.svelte-b9ede0 h3:where(.svelte-b9ede0){color:var(--accent-primary, #cba6f7)}.higher-levels.svelte-b9ede0 p:where(.svelte-b9ede0){margin:0;font-size:.85rem;color:var(--text-primary, #cdd6f4);line-height:1.5}.class-tags.svelte-b9ede0{display:flex;flex-wrap:wrap;gap:.375rem}.class-tag.svelte-b9ede0{font-size:.75rem;padding:.2rem .5rem;background:var(--bg-tertiary, #11111b);color:var(--text-secondary, #a6adc8);border-radius:4px}.source-info.svelte-b9ede0{font-size:.8rem;color:var(--text-secondary, #a6adc8);padding-top:.5rem;border-top:1px solid var(--border-color, #313244)}.source-info.svelte-b9ede0 .page:where(.svelte-b9ede0){opacity:.7;margin-left:.5rem}
