.layout{flex-direction:column;min-height:100vh;display:flex}.layout-main{flex:1;width:100%;max-width:1080px;margin:0 auto;padding:1.5rem 1.25rem 2.5rem}.app-header{z-index:1000;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(to bottom, #f9f7f1fa, #f9f7f1e6), var(--texture-paper);border-bottom:1px solid var(--color-border-subtle);position:sticky;top:0}:root[data-theme=dark] .app-header{background:linear-gradient(to bottom, #1a120df5, #1a120dd6), var(--texture-paper)}:root[data-theme=darkvision] .app-header{background:linear-gradient(to bottom, #0f1011f5, #0f1011d6), var(--texture-paper)}.header-inner{align-items:center;gap:1.25rem;max-width:1080px;margin:0 auto;padding:.75rem 1.25rem;display:flex}.brand{flex:1}.brand-mark{width:fit-content;transition:transform var(--transition-fast);flex-direction:column;gap:2px;text-decoration:none;display:flex}.brand-mark:hover{transform:translateY(-1px)}.brand-main{color:var(--color-ink);font-family:var(--font-heading);letter-spacing:.03em;font-size:1.6rem;font-weight:700;line-height:1.1}.brand-sub{color:var(--color-ink-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.25em;align-items:center;font-size:.7rem;font-weight:600;display:flex}.brand-divider{color:var(--color-border-subtle);margin:0 6px;font-size:.8rem}.text-accent{color:var(--color-accent)}.main-nav{align-items:center;gap:.75rem;display:inline-flex}.nav-link{color:var(--color-ink);font-family:var(--font-ui);transition:border-color var(--transition-fast), background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);border:1px solid #0000;border-radius:999px;padding:.35rem .7rem;font-size:.9rem;text-decoration:none;display:inline-block;position:relative}.nav-link:hover,.nav-link:focus-visible{border-color:var(--color-border-subtle);background-color:#00000008}.nav-link:focus-visible{outline:2px solid var(--color-border-strong);outline-offset:2px}.nav-link-active{border-color:var(--color-border-strong);background-color:#0000000d}.pill-count{text-align:center;border:1px solid var(--color-border-strong);border-radius:999px;min-width:1.35rem;margin-left:.45rem;padding:0 .4rem;font-size:.73rem;display:inline-block}.theme-toggle{font-family:var(--font-ui)}.app-footer{max-width:1080px;color:var(--color-ink-muted);font-family:var(--font-ui);margin:0 auto;padding:.75rem 1.25rem 1.75rem;font-size:.75rem}@media (width<=768px){.header-inner{flex-wrap:wrap;gap:.5rem .75rem}}@media (prefers-reduced-motion:reduce){.brand-mark,.brand-mark:hover{transition:none;transform:none}}.spell-card{--spell-card-vignette-color:#6a57401f;--spell-card-vignette-stop:30%;--spell-card-vignette-blend:multiply;--spell-card-inner-inset:6px;background-color:var(--color-bg-elevated);background-image:var(--texture-paper), radial-gradient(ellipse at center, transparent var(--spell-card-vignette-stop), var(--spell-card-vignette-color) 100%);background-blend-mode:var(--spell-card-vignette-blend), normal;border-radius:var(--radius-card,12px);border:2px solid var(--color-border-card);box-shadow:var(--shadow-soft), inset 0 0 20px #8e8e8e0d;content-visibility:auto;contain-intrinsic-size:250px;transition:transform var(--transition-fast), box-shadow var(--transition-fast);will-change:transform;backface-visibility:hidden;padding:0;position:relative;overflow:hidden;transform:translateZ(0)}:root[data-theme=dark] .spell-card,:root[data-theme=darkvision] .spell-card{--spell-card-vignette-color:#0006;--spell-card-vignette-blend:overlay}.spell-card:before{content:"";pointer-events:none;border-radius:calc(var(--radius-card,12px) - 8px);border:1px solid #ffffff73;position:absolute;inset:6px}.spell-card-inner{padding:.8rem .85rem .9rem;position:relative;transform:translateZ(0)}.spell-title{font-family:var(--font-heading);margin:0 0 .5rem;font-size:1rem;transform:translateZ(0)}.spell-title-link{color:var(--color-ink);cursor:pointer;text-decoration:none;display:inline-block}.spell-title-link:hover{text-decoration:underline}.spell-meta{gap:.25rem;margin:0 0 .6rem;display:grid}.spell-meta-row{text-align:right;justify-content:space-between;gap:.5rem;display:flex}.spell-meta-row dt{color:var(--color-ink-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.14em;font-size:.75rem}.spell-meta-row dd{margin:0;font-size:.86rem}.spell-card-actions{justify-content:flex-end;display:flex}.spell-card-prepared{border-color:var(--color-accent);box-shadow:var(--shadow-soft), 0 0 0 1px var(--color-accent), inset 0 0 20px #b34d2e26}.spell-title-link:focus-visible,.spell-card-actions button:focus-visible{outline:3px solid var(--color-accent);outline-offset:2px}.page-browse{grid-template-rows:auto 1fr;grid-template-columns:260px 1fr;align-items:start;gap:1.5rem;min-height:100vh;display:grid}.page-title{color:var(--color-primary);font-family:var(--font-heading);margin-top:0;margin-bottom:1.5rem;font-size:1.4rem}.sidebar-filters{z-index:10;background-color:var(--color-bg-elevated);border:2px solid var(--color-border-subtle);border-radius:var(--radius-card);height:fit-content;box-shadow:var(--shadow-soft);contain:layout;align-self:start;padding:1.25rem;position:sticky;top:5rem}.spell-grid-section{flex-direction:column;min-height:80vh;display:flex}.spell-grid{contain:layout;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1rem;display:grid}.load-more-container{border-top:1px solid var(--color-border-subtle);justify-content:center;margin-top:2rem;padding:4rem 0;display:flex}.btn-load-more{cursor:pointer;background-color:var(--color-bg-card,#1a1a1a);color:var(--color-text-main,#eee);border:2px solid var(--color-school-evocation,#822);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:1px;border-radius:4px;padding:.85rem 2.2rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-block;box-shadow:0 4px 10px #0006}.btn-load-more:hover:not(:disabled){background-color:var(--color-school-evocation,#822);color:#fff;transform:translateY(-2px);box-shadow:0 6px 15px #0009}.btn-load-more:active:not(:disabled){transform:translateY(1px)}.btn-load-more:focus-visible{outline-offset:4px;outline:3px solid #fc0}.btn-load-more:disabled{opacity:.4;cursor:wait;filter:grayscale();border-color:var(--color-text-muted)}@media (width<=900px){.page-browse{grid-template-columns:1fr}.sidebar-filters{margin-bottom:1.5rem;position:static}}.page-spellbook-header{justify-content:space-between;align-items:center;margin-bottom:.85rem;display:flex}.page-spellbook-header .page-title{margin-bottom:0}.page-spellbook .spell-grid{margin-top:.6rem}.empty-state{color:var(--color-ink-muted);font-family:var(--font-ui);margin-top:.25rem}.page-detail{background-color:var(--color-bg-elevated);background-image:var(--texture-paper), radial-gradient(ellipse at center, transparent 40%, #6a57401f 100%);background-blend-mode:multiply, normal;border:2px solid var(--color-border-subtle);border-radius:var(--radius-card);box-shadow:var(--shadow-soft), inset 0 0 40px #0000000d;padding:1.5rem;position:relative;overflow:hidden}:root[data-theme=dark] .page-detail,:root[data-theme=darkvision] .page-detail{background-image:var(--texture-paper), radial-gradient(ellipse at center, transparent 40%, #0006 100%);background-blend-mode:overlay, normal}.detail-header{border-bottom:2px double var(--color-border-subtle);flex-direction:column;gap:.25rem;margin-bottom:1.2rem;padding-bottom:.8rem;display:flex}.detail-sub{color:var(--color-ink-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.12em;font-size:.85rem;font-weight:600}.detail-grid{grid-template-columns:minmax(0,260px) minmax(0,1fr);gap:1.5rem 2rem;display:grid}.detail-stats{flex-direction:column;gap:.6rem;margin:0;display:flex}.detail-stat dt{color:var(--color-ink-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.16em;font-size:.75rem}.detail-stat dd{margin:.05rem 0 .4rem;font-size:.95rem;line-height:1.4}.section-title{color:var(--color-ink);font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.08em;margin:0 0 .6rem;font-size:1.1rem}.section-subtitle{color:var(--color-ink-muted);font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.16em;margin:1.2rem 0 .4rem;font-size:.85rem}.detail-description p{margin:0 0 .75rem;line-height:1.6}.detail-actions{border-top:1px solid var(--color-border-subtle);justify-content:flex-end;margin-top:2rem;padding-top:1rem;display:flex}@media (width<=768px){.detail-grid{grid-template-columns:minmax(0,1fr)}.page-detail{padding:1.2rem}}.page-not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;height:100%;padding:4rem 2rem;display:flex}.not-found-title{margin-bottom:1rem;font-size:2.5rem}.not-found-text{opacity:.8;margin-bottom:2rem;font-size:1.2rem}.btn-return{color:inherit;border:1px solid;border-radius:4px;padding:.75rem 1.5rem;text-decoration:none;transition:opacity .2s;display:inline-block}.btn-return:hover{opacity:.6}@font-face{font-family:Cinzel;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/cinzel-v26-latin-regular.woff2)format("woff2")}@font-face{font-family:Cinzel;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/cinzel-v26-latin-700.woff2)format("woff2")}@font-face{font-family:Crimson Text;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/crimson-text-v19-latin-regular.woff2)format("woff2")}@font-face{font-family:Crimson Text;font-style:italic;font-weight:400;font-display:swap;src:url(/fonts/crimson-text-v19-latin-italic.woff2)format("woff2")}@font-face{font-family:Lato;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/lato-v25-latin-regular.woff2)format("woff2")}@font-face{font-family:Lato;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/lato-v25-latin-700.woff2)format("woff2")}*,:before,:after{box-sizing:border-box}html,body{min-height:100vh;margin:0;padding:0}body{background-position:50%;background-repeat:no-repeat;background-size:cover;background-attachment:fixed;background-color:var(--color-bg);background-image:var(--texture-paper), radial-gradient(circle at 0% 0%, #fff3, transparent 50%), radial-gradient(circle at 100% 100%, #0000002e, transparent 50%), repeating-linear-gradient(45deg, #00000005 0px, #00000005 1px, transparent 1px, transparent 3px);background-blend-mode:multiply, normal, normal, normal;color:var(--color-ink);font-family:var(--font-body);-webkit-font-smoothing:antialiased}:root[data-theme=dark] body,:root[data-theme=darkvision] body{background-blend-mode:overlay, normal, normal, normal}:root{--color-bg:#f9f7f1;--color-bg-elevated:#f4f0e5;--color-ink:#2c2c2c;--color-ink-muted:#4c4337;--color-bg-input:#ffffffd9;--color-border-subtle:#cbbda2;--color-border-strong:#6a5740;--color-border-card:#9a8560;--color-accent:#b34d2e;--color-accent-soft:#e0b38a;--color-school-abjuration:#2d6a8a;--color-school-conjuration:#4f7c4f;--color-school-divination:#7c5ca3;--color-school-enchantment:#a6507a;--color-school-evocation:#b84432;--color-school-illusion:#4f6b9c;--color-school-necromancy:#5c3b7a;--color-school-transmutation:#a37b3b;--color-status-error:#7c1f26;--color-status-loading:#3b4a63;--font-heading:"Cinzel", "Times New Roman", serif;--font-body:"Crimson Text", Georgia, serif;--font-ui:"Lato", system-ui, -apple-system, sans-serif;--radius-card:12px;--shadow-soft:0 16px 30px #0000001f;--transition-fast:.18s ease-out;--texture-paper:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='paper'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.012' numOctaves='5' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23paper)' opacity='0.08'/%3E%3C/svg%3E");--theme-light-bg:#f9f7f1;--theme-dark-bg:#1a120d;--theme-dark-ink:#f5efe1;--theme-darkvision-bg:#050505}:root[data-theme=dark]{--color-bg:var(--theme-dark-bg);--color-bg-elevated:#261710;--color-ink:var(--theme-dark-ink);--color-ink-muted:#b5a898;--color-bg-input:#00000073;--color-border-subtle:#4c3a2c;--color-border-strong:#f0e0c7}:root[data-theme=darkvision]{--color-bg:var(--theme-darkvision-bg);--color-bg-elevated:#121212;--color-ink:#e0e0e0;--color-ink-muted:#a0a0a0;--color-bg-input:#0009;--color-border-subtle:#333;--color-border-strong:#fff;--color-school-abjuration:#888;--color-school-conjuration:#888;--color-school-divination:#888;--color-school-enchantment:#888;--color-school-evocation:#888;--color-school-illusion:#888;--color-school-necromancy:#888;--color-school-transmutation:#888}#root,.app-root{z-index:1;background:0 0;min-height:100vh;position:relative}:root[data-theme=darkvision] #root,:root[data-theme=darkvision] .app-root{filter:grayscale()contrast(1.1)}.btn{cursor:pointer;color:var(--color-ink);font-family:var(--font-ui);transition:all var(--transition-fast);background:0 0;border:1px solid #0000;border-radius:999px;padding:.4rem .9rem;font-size:.86rem;text-decoration:none;display:inline-block}.btn-primary{background:linear-gradient(135deg, var(--color-accent) 0%, #7b2e1c 100%);color:#fdf7ed;border-color:#00000040;box-shadow:0 7px 14px #00000040}.btn-primary:hover,.btn-primary:focus-visible{transform:translateY(-1px);box-shadow:0 10px 20px #0000004d}.btn-primary:disabled{opacity:.75;cursor:default;box-shadow:none}.btn-ghost{border-color:var(--color-border-subtle);background-color:#00000005}.btn-ghost:hover,.btn-ghost:focus-visible{background-color:#0000000f}.field{flex-direction:column;gap:.25rem;margin-bottom:.75rem;display:flex}.field-label{font-family:var(--font-ui);text-transform:uppercase;letter-spacing:.15em;font-size:.78rem}.input{background-color:var(--color-bg-input);width:100%;color:var(--color-ink);border:1px solid var(--color-border-subtle);font-family:var(--font-ui);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:7px;padding:.4rem .6rem;font-size:.9rem}.input:focus-visible{border-color:var(--color-border-strong);outline:none;box-shadow:0 0 0 2px #b34d2e73}.input-select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--color-ink) 50%), linear-gradient(135deg, var(--color-ink) 50%, transparent 50%);background-position:calc(100% - 14px),calc(100% - 9px);background-repeat:no-repeat;background-size:6px 6px,6px 6px}.page-title{color:var(--color-ink);font-family:var(--font-heading);text-transform:uppercase;letter-spacing:.06em;margin:0 0 .85rem;font-size:1.4rem}.status{font-family:var(--font-ui);border:1px solid #0000;border-radius:8px;margin-bottom:1rem;padding:.8rem 1rem}.status-loading{color:var(--color-ink-muted);background-color:#3b4a6326;border-color:#3b4a6366}.status-error{color:var(--color-status-error);background-color:#7c1f2626;border-color:#7c1f2699}.empty-state-container{text-align:center;border:2px dashed var(--color-border-subtle);border-radius:var(--radius-card);flex-direction:column;justify-content:center;align-items:center;margin-top:2rem;padding:4rem 2rem;display:flex}.empty-state-text{max-width:550px;color:var(--color-ink-muted);font-family:var(--font-body);margin:0 0 1.2rem;font-size:1.35rem;font-style:italic;line-height:1.6}:focus-visible{outline:2px solid var(--color-border-strong);outline-offset:2px}@media (width<=768px){.header-inner{flex-direction:column;gap:1.25rem;padding:1.5rem 1rem}.main-nav{border-top:1px solid var(--color-border-subtle);justify-content:center;gap:1rem;width:100%;padding-top:1rem}.brand-mark{text-align:center;flex-direction:column;align-items:center;gap:.25rem;display:flex}.sidebar-filters{z-index:100;background:var(--color-bg-elevated);border-radius:0 0 var(--radius-card) var(--radius-card);grid-template-columns:1fr 1fr;gap:.5rem;padding:.75rem;display:grid;position:sticky;top:135px;box-shadow:0 4px 12px #0000001a}.sidebar-filters .field:first-of-type{grid-column:span 2;margin-bottom:.25rem}.sidebar-filters .page-title{display:none}}
