@import"https://fonts.googleapis.com/css2?family=Cinzel:wght@500;600&family=Source+Serif+4:ital,wght@0,400;0,600;1,400&display=swap";:root{--color-bg: #f4ead8;--color-bg-deep: #120f18;--color-ink: #1c1524;--color-ink-soft: #3b3148;--color-muted: rgba(244, 234, 216, .78);--color-muted-strong: #5c5368;--color-parchment: #f8f0df;--color-surface: #fff9ed;--color-surface-2: #fbf4e4;--color-border: rgba(40, 32, 55, .14);--color-border-strong: rgba(40, 32, 55, .22);--color-gold: #d4af6a;--color-gold-deep: #a67c32;--color-link: #5b4aa1;--color-link-hover: #3f3375;--shadow-soft: 0 10px 30px rgba(18, 12, 28, .35);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .45);--shadow-card: 0 8px 22px rgba(25, 18, 35, .08);--font-display: "Cinzel", "Palatino Linotype", "Book Antiqua", Palatino, serif;--font-body: "Source Serif 4", Georgia, "Times New Roman", serif}*,*:before,*:after{box-sizing:border-box}html{color-scheme:light}body{margin:0;min-height:100vh;font-family:var(--font-body);background:radial-gradient(1200px 600px at 20% -10%,rgba(212,175,106,.22),transparent),radial-gradient(900px 500px at 90% 0%,rgba(90,120,160,.12),transparent),var(--color-bg);color:var(--color-ink)}#root{min-height:100vh}a{color:var(--color-link)}a:hover{color:var(--color-link-hover)}code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}button:focus-visible,input:focus-visible,select:focus-visible,summary:focus-visible{outline:2px solid var(--color-gold-deep);outline-offset:2px}:root{--cls-artificer: #6e5c38;--cls-artificer-bg: rgba(110, 92, 56, .12);--cls-bard: #8a4d72;--cls-bard-bg: rgba(138, 77, 114, .11);--cls-cleric: #3a6f8f;--cls-cleric-bg: rgba(58, 111, 143, .12);--cls-druid: #3f6b45;--cls-druid-bg: rgba(63, 107, 69, .12);--cls-paladin: #7a6a3a;--cls-paladin-bg: rgba(122, 106, 58, .14);--cls-ranger: #4d6336;--cls-ranger-bg: rgba(77, 99, 54, .12);--cls-sorcerer: #8a3d62;--cls-sorcerer-bg: rgba(138, 61, 98, .1);--cls-warlock: #5c4688;--cls-warlock-bg: rgba(92, 70, 136, .11);--cls-wizard: #3a5588;--cls-wizard-bg: rgba(58, 85, 136, .12);--sch-abjuration: #4a6678;--sch-conjuration: #2d6f6a;--sch-divination: #4a5090;--sch-enchantment: #8a4a78;--sch-evocation: #a85a32;--sch-illusion: #6a4a9a;--sch-necromancy: #4d6b52;--sch-transmutation: #7a6a28;--lvl-cantrip-fg: #4a5c48;--lvl-cantrip-bg: rgba(74, 92, 72, .1);--lvl-low-fg: #6b5a38;--lvl-low-bg: rgba(140, 120, 70, .12);--lvl-mid-fg: #7a5a28;--lvl-mid-bg: rgba(180, 140, 60, .12);--lvl-high-fg: #5a4080;--lvl-high-bg: rgba(100, 70, 140, .1)}.chip--cls.chip--artificer{border-color:color-mix(in srgb,var(--cls-artificer) 28%,var(--color-border));background:var(--cls-artificer-bg)}.chip--cls.chip--artificer span{color:var(--cls-artificer)}.chip--cls.chip--bard{border-color:color-mix(in srgb,var(--cls-bard) 28%,var(--color-border));background:var(--cls-bard-bg)}.chip--cls.chip--bard span{color:var(--cls-bard)}.chip--cls.chip--cleric{border-color:color-mix(in srgb,var(--cls-cleric) 28%,var(--color-border));background:var(--cls-cleric-bg)}.chip--cls.chip--cleric span{color:var(--cls-cleric)}.chip--cls.chip--druid{border-color:color-mix(in srgb,var(--cls-druid) 28%,var(--color-border));background:var(--cls-druid-bg)}.chip--cls.chip--druid span{color:var(--cls-druid)}.chip--cls.chip--paladin{border-color:color-mix(in srgb,var(--cls-paladin) 28%,var(--color-border));background:var(--cls-paladin-bg)}.chip--cls.chip--paladin span{color:var(--cls-paladin)}.chip--cls.chip--ranger{border-color:color-mix(in srgb,var(--cls-ranger) 28%,var(--color-border));background:var(--cls-ranger-bg)}.chip--cls.chip--ranger span{color:var(--cls-ranger)}.chip--cls.chip--sorcerer{border-color:color-mix(in srgb,var(--cls-sorcerer) 28%,var(--color-border));background:var(--cls-sorcerer-bg)}.chip--cls.chip--sorcerer span{color:var(--cls-sorcerer)}.chip--cls.chip--warlock{border-color:color-mix(in srgb,var(--cls-warlock) 28%,var(--color-border));background:var(--cls-warlock-bg)}.chip--cls.chip--warlock span{color:var(--cls-warlock)}.chip--cls.chip--wizard{border-color:color-mix(in srgb,var(--cls-wizard) 28%,var(--color-border));background:var(--cls-wizard-bg)}.chip--cls.chip--wizard span{color:var(--cls-wizard)}.chip--tier-cantrip{border-color:color-mix(in srgb,var(--lvl-cantrip-fg) 25%,var(--color-border));background:var(--lvl-cantrip-bg)}.chip--tier-cantrip span{color:var(--lvl-cantrip-fg)}.chip--tier-low{border-color:color-mix(in srgb,var(--lvl-low-fg) 25%,var(--color-border));background:var(--lvl-low-bg)}.chip--tier-low span{color:var(--lvl-low-fg)}.chip--tier-mid{border-color:color-mix(in srgb,var(--lvl-mid-fg) 25%,var(--color-border));background:var(--lvl-mid-bg)}.chip--tier-mid span{color:var(--lvl-mid-fg)}.chip--tier-high{border-color:color-mix(in srgb,var(--lvl-high-fg) 25%,var(--color-border));background:var(--lvl-high-bg)}.chip--tier-high span{color:var(--lvl-high-fg)}.chip--sch.chip--abjuration{border-color:color-mix(in srgb,var(--sch-abjuration) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-abjuration) 8%,var(--color-surface-2))}.chip--sch.chip--abjuration span{color:var(--sch-abjuration)}.chip--sch.chip--conjuration{border-color:color-mix(in srgb,var(--sch-conjuration) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-conjuration) 8%,var(--color-surface-2))}.chip--sch.chip--conjuration span{color:var(--sch-conjuration)}.chip--sch.chip--divination{border-color:color-mix(in srgb,var(--sch-divination) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-divination) 8%,var(--color-surface-2))}.chip--sch.chip--divination span{color:var(--sch-divination)}.chip--sch.chip--enchantment{border-color:color-mix(in srgb,var(--sch-enchantment) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-enchantment) 8%,var(--color-surface-2))}.chip--sch.chip--enchantment span{color:var(--sch-enchantment)}.chip--sch.chip--evocation{border-color:color-mix(in srgb,var(--sch-evocation) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-evocation) 8%,var(--color-surface-2))}.chip--sch.chip--evocation span{color:var(--sch-evocation)}.chip--sch.chip--illusion{border-color:color-mix(in srgb,var(--sch-illusion) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-illusion) 8%,var(--color-surface-2))}.chip--sch.chip--illusion span{color:var(--sch-illusion)}.chip--sch.chip--necromancy{border-color:color-mix(in srgb,var(--sch-necromancy) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-necromancy) 8%,var(--color-surface-2))}.chip--sch.chip--necromancy span{color:var(--sch-necromancy)}.chip--sch.chip--transmutation{border-color:color-mix(in srgb,var(--sch-transmutation) 22%,var(--color-border));background:color-mix(in srgb,var(--sch-transmutation) 8%,var(--color-surface-2))}.chip--sch.chip--transmutation span{color:var(--sch-transmutation)}.spellCard[data-accent-class=artificer]{border-left-color:var(--cls-artificer)}.spellCard[data-accent-class=bard]{border-left-color:var(--cls-bard)}.spellCard[data-accent-class=cleric]{border-left-color:var(--cls-cleric)}.spellCard[data-accent-class=druid]{border-left-color:var(--cls-druid)}.spellCard[data-accent-class=paladin]{border-left-color:var(--cls-paladin)}.spellCard[data-accent-class=ranger]{border-left-color:var(--cls-ranger)}.spellCard[data-accent-class=sorcerer]{border-left-color:var(--cls-sorcerer)}.spellCard[data-accent-class=warlock]{border-left-color:var(--cls-warlock)}.spellCard[data-accent-class=wizard]{border-left-color:var(--cls-wizard)}.schoolTag--abjuration{color:var(--sch-abjuration)}.schoolTag--conjuration{color:var(--sch-conjuration)}.schoolTag--divination{color:var(--sch-divination)}.schoolTag--enchantment{color:var(--sch-enchantment)}.schoolTag--evocation{color:var(--sch-evocation)}.schoolTag--illusion{color:var(--sch-illusion)}.schoolTag--necromancy{color:var(--sch-necromancy)}.schoolTag--transmutation{color:var(--sch-transmutation)}.classPill{display:inline-block;padding:.12rem .45rem;border-radius:999px;font-size:.74rem;border:1px solid var(--color-border);background:#ffffff73}.classPillRow{display:flex;flex-wrap:wrap;gap:.35rem;align-items:center}.classPill--artificer{color:var(--cls-artificer);background:var(--cls-artificer-bg);border-color:color-mix(in srgb,var(--cls-artificer) 22%,var(--color-border))}.classPill--bard{color:var(--cls-bard);background:var(--cls-bard-bg);border-color:color-mix(in srgb,var(--cls-bard) 22%,var(--color-border))}.classPill--cleric{color:var(--cls-cleric);background:var(--cls-cleric-bg);border-color:color-mix(in srgb,var(--cls-cleric) 22%,var(--color-border))}.classPill--druid{color:var(--cls-druid);background:var(--cls-druid-bg);border-color:color-mix(in srgb,var(--cls-druid) 22%,var(--color-border))}.classPill--paladin{color:var(--cls-paladin);background:var(--cls-paladin-bg);border-color:color-mix(in srgb,var(--cls-paladin) 22%,var(--color-border))}.classPill--ranger{color:var(--cls-ranger);background:var(--cls-ranger-bg);border-color:color-mix(in srgb,var(--cls-ranger) 22%,var(--color-border))}.classPill--sorcerer{color:var(--cls-sorcerer);background:var(--cls-sorcerer-bg);border-color:color-mix(in srgb,var(--cls-sorcerer) 22%,var(--color-border))}.classPill--warlock{color:var(--cls-warlock);background:var(--cls-warlock-bg);border-color:color-mix(in srgb,var(--cls-warlock) 22%,var(--color-border))}.classPill--wizard{color:var(--cls-wizard);background:var(--cls-wizard-bg);border-color:color-mix(in srgb,var(--cls-wizard) 22%,var(--color-border))}.filterChipButton--cls.filterChipButton--artificer{color:var(--cls-artificer);background:var(--cls-artificer-bg);border-color:color-mix(in srgb,var(--cls-artificer) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--bard{color:var(--cls-bard);background:var(--cls-bard-bg);border-color:color-mix(in srgb,var(--cls-bard) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--cleric{color:var(--cls-cleric);background:var(--cls-cleric-bg);border-color:color-mix(in srgb,var(--cls-cleric) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--druid{color:var(--cls-druid);background:var(--cls-druid-bg);border-color:color-mix(in srgb,var(--cls-druid) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--paladin{color:var(--cls-paladin);background:var(--cls-paladin-bg);border-color:color-mix(in srgb,var(--cls-paladin) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--ranger{color:var(--cls-ranger);background:var(--cls-ranger-bg);border-color:color-mix(in srgb,var(--cls-ranger) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--sorcerer{color:var(--cls-sorcerer);background:var(--cls-sorcerer-bg);border-color:color-mix(in srgb,var(--cls-sorcerer) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--warlock{color:var(--cls-warlock);background:var(--cls-warlock-bg);border-color:color-mix(in srgb,var(--cls-warlock) 25%,var(--color-border))}.filterChipButton--cls.filterChipButton--wizard{color:var(--cls-wizard);background:var(--cls-wizard-bg);border-color:color-mix(in srgb,var(--cls-wizard) 25%,var(--color-border))}.filterChipButton--school.filterChipButton--abjuration{color:var(--sch-abjuration);background:color-mix(in srgb,var(--sch-abjuration) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-abjuration) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--conjuration{color:var(--sch-conjuration);background:color-mix(in srgb,var(--sch-conjuration) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-conjuration) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--divination{color:var(--sch-divination);background:color-mix(in srgb,var(--sch-divination) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-divination) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--enchantment{color:var(--sch-enchantment);background:color-mix(in srgb,var(--sch-enchantment) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-enchantment) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--evocation{color:var(--sch-evocation);background:color-mix(in srgb,var(--sch-evocation) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-evocation) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--illusion{color:var(--sch-illusion);background:color-mix(in srgb,var(--sch-illusion) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-illusion) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--necromancy{color:var(--sch-necromancy);background:color-mix(in srgb,var(--sch-necromancy) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-necromancy) 22%,var(--color-border))}.filterChipButton--school.filterChipButton--transmutation{color:var(--sch-transmutation);background:color-mix(in srgb,var(--sch-transmutation) 8%,var(--color-surface-2));border-color:color-mix(in srgb,var(--sch-transmutation) 22%,var(--color-border))}.filterChipButton--lvl-tier-cantrip{color:var(--lvl-cantrip-fg);background:var(--lvl-cantrip-bg);border-color:color-mix(in srgb,var(--lvl-cantrip-fg) 22%,var(--color-border))}.filterChipButton--lvl-tier-low{color:var(--lvl-low-fg);background:var(--lvl-low-bg);border-color:color-mix(in srgb,var(--lvl-low-fg) 22%,var(--color-border))}.filterChipButton--lvl-tier-mid{color:var(--lvl-mid-fg);background:var(--lvl-mid-bg);border-color:color-mix(in srgb,var(--lvl-mid-fg) 22%,var(--color-border))}.filterChipButton--lvl-tier-high{color:var(--lvl-high-fg);background:var(--lvl-high-bg);border-color:color-mix(in srgb,var(--lvl-high-fg) 22%,var(--color-border))}.app{min-height:100vh;display:flex;flex-direction:column}.hero{background:linear-gradient(165deg,var(--color-ink) 0%,#1a1428 45%,var(--color-bg-deep) 100%);color:var(--color-parchment);padding:2.25rem 1.25rem 2rem;border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-soft)}.heroInner{max-width:1120px;margin:0 auto}.title{font-family:var(--font-display);font-size:clamp(1.75rem,4vw,2.35rem);letter-spacing:.02em;margin:0 0 .5rem}.subtitle{margin:0 0 1.25rem;max-width:52ch;color:var(--color-muted);line-height:1.55;font-size:.98rem}.main{flex:1;max-width:1120px;margin:0 auto;padding:1.5rem 1.25rem 3rem;width:100%}.controls{margin-bottom:1.5rem}.resultCount{margin:.75rem 0 0;color:var(--color-muted-strong);font-size:.92rem}.footer{border-top:1px solid var(--color-border);padding:1rem 1.25rem 2rem;color:var(--color-muted-strong);font-size:.85rem}.footer p{max-width:1120px;margin:0 auto;line-height:1.5}.footer code{font-size:.82rem}.searchBar{max-width:min(560px,100%)}.searchInput{width:100%;padding:.65rem .85rem;border-radius:10px;border:1px solid var(--color-border);background:#fff8eb14;color:var(--color-parchment);font-size:1rem;outline:none;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.searchInput::placeholder{color:#f5ecdc73}.searchInput:focus{border-color:var(--color-gold);box-shadow:0 0 0 3px #d4af6a40;background:#fff8eb1f}.filterPanel{display:grid;gap:1rem}.filterFieldset{margin:0;padding:.85rem 1rem;border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);box-shadow:var(--shadow-inset)}.filterFieldset legend{padding:0 .35rem;font-family:var(--font-display);font-size:.95rem;color:var(--color-ink-soft)}.chipGrid{display:flex;flex-wrap:wrap;gap:.45rem}.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .55rem;border-radius:999px;border:1px solid var(--color-border);background:var(--color-surface-2);font-size:.82rem;cursor:pointer;-webkit-user-select:none;user-select:none;color:var(--color-ink-soft)}.chipSm{font-size:.78rem}.chip input{accent-color:var(--color-gold-deep)}.filterRow{display:flex;flex-wrap:wrap;align-items:center;gap:.65rem 1rem}.filterSelectLabel{font-size:.85rem;color:var(--color-muted-strong)}.filterSelect{padding:.45rem .6rem;border-radius:8px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-ink);font-size:.88rem}.activeFilters{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem .75rem;margin-top:.85rem;padding:.65rem .85rem;border-radius:10px;border:1px dashed var(--color-border-strong);background:#d4af6a0f}.activeFiltersLabel{font-size:.8rem;color:var(--color-muted-strong);font-weight:600}.activeFilterList{list-style:none;display:flex;flex-wrap:wrap;gap:.35rem;margin:0;padding:0}.filterChipButton{border:1px solid var(--color-border);background:var(--color-surface-2);border-radius:999px;padding:.2rem .55rem;font-size:.78rem;cursor:pointer;color:var(--color-ink-soft);display:inline-flex;align-items:center;gap:.25rem}.filterChipButton:hover{border-color:var(--color-gold)}.filterChipX{opacity:.65;font-size:.95rem;line-height:1}.textButton{border:none;background:none;color:var(--color-link);cursor:pointer;font-size:.82rem;text-decoration:underline;padding:.1rem .2rem}.textButton:hover{color:var(--color-link-hover)}.spellGrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.emptyState{margin:2rem 0;padding:1.25rem;border-radius:12px;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-muted-strong)}.spellCard{border-radius:14px;border:1px solid var(--color-border);border-left:3px solid transparent;background:linear-gradient(180deg,var(--color-surface) 0%,var(--color-surface-2) 100%);padding:1rem 1.05rem 1.1rem;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:.55rem;min-height:100%}.spellCardHeader{display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem}.spellCardTitle{font-family:var(--font-display);font-size:1.12rem;margin:0;line-height:1.25;color:var(--color-ink);flex:1;min-width:0}.spellCardHeaderActions{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}.spellCardPin{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;border:1px solid var(--color-border);border-radius:10px;background:#ffffff80;color:var(--color-muted-strong);cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.spellCardPin:hover{border-color:var(--color-gold);color:var(--color-gold-deep);background:#fff8ebd9}.spellCardPin--active{color:var(--color-gold-deep);border-color:color-mix(in srgb,var(--color-gold-deep) 45%,var(--color-border));background:color-mix(in srgb,var(--color-gold) 18%,var(--color-surface))}.spellCardPin .pinIcon{display:block}.spellCard--pinned{border-color:color-mix(in srgb,var(--color-gold-deep) 18%,var(--color-border));background:linear-gradient(180deg,color-mix(in srgb,var(--color-gold) 10%,var(--color-surface)) 0%,var(--color-surface-2) 100%)}.spellCardBadges{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:flex-end}.badge{font-size:.65rem;text-transform:uppercase;letter-spacing:.06em;padding:.15rem .4rem;border-radius:999px;border:1px solid var(--color-border);color:var(--color-muted-strong);background:#ffffff59}.badgeRitual{border-color:#5a78a059;color:#2c4a6e}.badgeConc{border-color:#8c5a2859;color:#6a4018}.spellCardMeta{margin:0;font-size:.82rem;line-height:1.35}.spellCardLevel,.spellCardMetaSep{color:var(--color-muted-strong);font-style:italic}.schoolTag{font-style:italic;font-weight:600}.spellCardClasses{margin:0;font-size:.78rem;line-height:1.35}.spellCardNoClasses{color:var(--color-ink-soft)}.spellCardStats{margin:0;display:grid;grid-template-columns:1fr 1fr;gap:.35rem .75rem;font-size:.78rem}.spellCardStats dt{margin:0;color:var(--color-muted-strong);font-weight:600}.spellCardStats dd{margin:0;color:var(--color-ink-soft)}.spellCardExcerpt{margin:.15rem 0 0;font-size:.85rem;line-height:1.45;color:var(--color-ink)}.spellCardDetails{margin-top:.15rem;border-radius:10px;border:1px solid var(--color-border);background:#ffffff59;padding:.35rem .55rem}.spellCardDetails summary{cursor:pointer;font-size:.82rem;font-weight:600;color:var(--color-link);list-style:none}.spellCardDetails summary::-webkit-details-marker{display:none}.spellCardBody{margin-top:.5rem}.spellCardFullText{margin:0;font-size:.84rem;line-height:1.5;white-space:pre-wrap;color:var(--color-ink)}.spellHigher{margin-top:.75rem;padding-top:.65rem;border-top:1px solid var(--color-border)}.spellHigherTitle{margin:0 0 .35rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted-strong)}.spellHigherText{margin:0;font-size:.84rem;line-height:1.45;white-space:pre-wrap;color:var(--color-ink)}.srOnly{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media(max-width:520px){.spellCardStats{grid-template-columns:1fr}}
