:root{color-scheme:light dark}:root[data-theme=dark]{--bg: #1a1410;--fg: #f0e6d2;--card: #2a1f1a;--border: #3d2f26}:root[data-theme=light]{--bg: #f5f1e8;--fg: #2d1810;--card: #fdfbf7;--border: #d4c4a8}:root{--print-header-h: 18mm;--print-gap: 8px}body{background:var(--bg);color:var(--fg)}.print-card{background:var(--card);border-color:var(--border)}@media print{html,body{height:auto}body{margin:0;-webkit-print-color-adjust:exact;print-color-adjust:exact}.no-print{display:none!important}.print-header{position:fixed;inset:0 0 auto;height:var(--print-header-h);background:#fff;border-bottom:1px solid #ccc;display:flex;align-items:end;justify-content:space-between;padding:6mm 10mm 4mm;z-index:9999}.print-header h1{font-size:14pt;line-height:1.1;margin:0;text-wrap:balance}.print-header .meta{font-size:9pt;opacity:.85}.print-content{padding-top:calc(var(--print-header-h) + 2mm)}}.print-grid{display:grid;grid-template-columns:repeat(var(--cols, 3),1fr);gap:var(--print-gap)}.print-card{break-inside:avoid;page-break-inside:avoid;border:1px solid var(--border, #bbb);border-radius:8px;padding:10px;background:#fff;color:#111;hyphens:auto;-webkit-hyphens:auto;overflow-wrap:anywhere;orphans:3;widows:3}.print-card h3{margin:0 0 6px;font-size:1em;line-height:1.3;display:flex;flex-direction:column;gap:3px}.print-card h3 .card-title{font-size:1.1em;font-weight:700;line-height:1.2}.print-card h3 .card-school{font-weight:500;font-size:.85em;opacity:.7;font-style:italic}.print-card .pills{display:flex;flex-wrap:wrap;gap:4px;margin:4px 0 6px}.print-card .pill{display:inline-flex;align-items:center;gap:3px;font-size:.8em;line-height:1.2;border:1px solid #666;border-radius:999px;padding:2px 7px;background:#f5f5f5;color:#222;hyphens:none;-webkit-hyphens:none;white-space:nowrap}.print-card .pill--level{background:#e4e4e4;border-color:#8c8c8c;color:#1f1f1f;font-weight:700;letter-spacing:.03em;font-variant:small-caps;padding:3px 10px}.print-card .pill--casting,.print-card .pill--duration{font-weight:600;padding:3px 8px;gap:4px}.print-card .pill--casting{background:#ededed;border-style:dashed}.print-card .pill--duration{background:#f2f2f2;border-color:#777}.print-card .pill--casting svg,.print-card .pill--duration svg{flex-shrink:0}.print-card .pill--components{background:#e8e8e8;border-color:#888;padding:3px 8px;gap:5px;font-weight:600}.print-card .pill--component{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:2px 5px;border-radius:3px;background:#555;color:#fff;font-size:9px;font-weight:700;letter-spacing:.3px;border:1px solid #333}.print-card .pill--component-m{padding:2px 6px;min-width:auto;font-size:8px;background:#666}.print-card .pill--ritual{background:#d0d0d0;border-color:#888;color:#222;font-weight:600;gap:4px;padding:3px 8px}.print-card .pill--ritual svg{fill:#444;stroke:#444}.print-card .pill--concentration{background:#e0e0e0;border-color:#999;color:#222;font-weight:600;gap:4px;padding:3px 8px}.print-card .pill--concentration svg{stroke:#444}.print-card .body{font-size:.95em;line-height:1.25}.print-S{font-size:10px}.print-M{font-size:12px}.print-L{font-size:14px}.cutmarks{position:relative}.cutmarks:before,.cutmarks:after{content:"";position:absolute;left:0;right:0;border-top:1px dotted #aaa;top:-4px}.cutmarks:after{top:auto;bottom:-4px}.print-page-break{break-before:page}@media screen{.print-grid>div[draggable=true]{cursor:grab}.print-grid>div[draggable=true]:active{cursor:grabbing}}.print-grid{display:grid!important;grid-template-columns:repeat(var(--cols, 3),1fr)!important;gap:var(--print-gap)!important}.print-card .pills{display:flex!important;flex-wrap:wrap!important;gap:4px!important}.print-card .pill+.pill{margin-left:4px}:root{--radius: 12px;--radius-pill: 999px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 24px;--space-6: 35px;--shadow: 0 4px 16px rgba(0, 0, 0, .12), 0 2px 4px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .16), 0 4px 8px rgba(0, 0, 0, .12);--bg: #f5f1e8;--surface: #fdfbf7;--text: #2d1810;--muted: #6b5744;--border: #d4c4a8;--primary: #8b2635;--primary-hover: #a52f3f;--primary-weak: #f9e8ea;--accent: #c9941a;--accent-weak: #fef6e4;--sticky-top: calc(70px + max(env(safe-area-inset-top), 0px)) }[data-theme=dark]{--bg: #1a1410;--surface: #2a1f1a;--text: #f0e6d2;--muted: #a89984;--border: #3d2f26;--primary: #d4556d;--primary-hover: #e06b7f;--primary-weak: #3d1f24;--accent: #e6b450;--accent-weak: #3d3020}html,body,#root{height:100%;background:var(--bg);color:var(--text)}*,*:before,*:after{box-sizing:border-box}a{color:var(--primary);font-weight:600;text-decoration:underline;text-decoration-thickness:1.5px;text-underline-offset:3px;transition:color .2s ease,text-decoration-color .2s ease}a:hover{color:var(--accent);text-decoration-color:var(--accent)}a:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:2px}a:visited{color:var(--primary)}[data-theme=dark] a,[data-theme=dark] a:visited{color:var(--accent)}[data-theme=dark] a:hover{color:var(--primary);text-decoration-color:var(--primary)}body{line-height:1.6}h1,h2,h3,h4,h5,h6{line-height:1.2;font-weight:700}input,select,textarea,button{color:var(--text);background:var(--surface);border:1px solid var(--border);font-family:inherit}input,select,textarea{padding:8px 12px;border-radius:8px;transition:border-color .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-weak)}input::placeholder{color:var(--muted);opacity:.9}.container{max-width:1200px;margin:0 auto;padding:0 var(--space-4)}.app-main{display:block;padding:var(--space-4) 0 var(--space-5)}.app-main:focus{outline:none}.page{margin-bottom:var(--space-5)}.site-header{position:sticky;top:max(env(safe-area-inset-top),0px);z-index:60;background:var(--bg);border-bottom:2px solid var(--border);box-shadow:0 2px 8px #0000000f}.site-header__nav{display:flex;gap:var(--space-3);align-items:center;padding:var(--space-3) 0;flex-wrap:wrap;position:relative}.site-logo{display:flex;align-items:center;margin-right:var(--space-3);transition:opacity .2s}.site-logo:hover{opacity:.8}.site-logo img{height:40px;width:auto;display:block}@media(max-width:768px){.site-logo{order:-1;flex:1}.site-logo img{height:32px}}.hamburger{display:none;flex-direction:column;gap:4px;padding:8px;background:transparent;border:none;cursor:pointer;z-index:51}.hamburger span{display:block;width:24px;height:3px;background:var(--text);border-radius:2px;transition:all .3s}.hamburger[aria-expanded=true] span:nth-child(1){transform:rotate(45deg) translate(6px,6px)}.hamburger[aria-expanded=true] span:nth-child(2){opacity:0}.hamburger[aria-expanded=true] span:nth-child(3){transform:rotate(-45deg) translate(6px,-6px)}.toolbar__list{display:flex;gap:var(--space-3);align-items:center;list-style:none;margin:0;padding:0;flex-wrap:wrap}@media(max-width:768px){.hamburger{display:flex}.toolbar__list{position:fixed;inset:0;background:var(--bg);flex-direction:column;justify-content:center;align-items:center;gap:var(--space-4);transform:translate(-100%);transition:transform .3s;z-index:50;padding:var(--space-5)}.toolbar__list--open{transform:translate(0)}.toolbar__list li{width:100%;text-align:center}.toolbar__list a{display:block;width:100%;padding:var(--space-3);font-size:1.25rem}}.toolbar__actions{display:flex;gap:var(--space-2);align-items:center;margin-left:auto}.icon-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);cursor:pointer;transition:all .2s;font-weight:500;font-size:.9rem}.icon-btn:hover{border-color:var(--primary);background:var(--primary-weak);transform:translateY(-1px)}.icon-btn svg{flex-shrink:0}.icon-btn__label{font-weight:600}@media(max-width:480px){.icon-btn__label{display:none}.icon-btn{padding:8px}}.site-header__nav a{padding:6px 12px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-decoration:none;transition:all .2s;font-weight:500}.site-header__nav a:hover{border-color:var(--primary);background:var(--primary-weak)}.site-header__nav a[aria-current=page]{background:var(--primary);color:var(--surface);border-color:var(--primary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 14px;border:1px solid var(--border);border-radius:8px;background:var(--surface);color:var(--text);text-decoration:none;font-weight:500;transition:all .2s;cursor:pointer}.btn:visited{color:var(--text)}.btn:hover{border-color:var(--primary);background:var(--primary-weak);transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.btn-primary{border-color:var(--primary);background:var(--primary);color:var(--surface)}.btn-primary:visited{color:var(--surface)}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}[data-theme=dark] .btn-primary,[data-theme=dark] .btn-primary:visited{color:#fff}.chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.chip{font-size:13px;border:1px solid var(--border);border-radius:var(--radius-pill);padding:4px 12px;background:var(--surface);color:var(--text);transition:all .2s;display:inline-flex;align-items:center;gap:4px}.chip--click{background:var(--surface);cursor:pointer;font-weight:500}.chip--click:hover{border-color:var(--primary);background:var(--primary-weak);transform:translateY(-1px)}.chip--filter-level{border-color:#8b263547;background:#8b26350a;color:var(--muted);font-weight:500;letter-spacing:.01em}.chip--filter-level.chip--click:hover{border-color:#8b26357a;background:#8b26351f;color:var(--text)}.chip--filter-level--active{border-color:var(--accent);background:var(--accent-weak);color:var(--accent);font-weight:600}.chip--filter-level--active.chip--click:hover{background:var(--accent);color:var(--surface)}[data-theme=dark] .chip--filter-level{border-color:#e6b45059;background:#e6b4501a;color:var(--text)}[data-theme=dark] .chip--filter-level.chip--click:hover{border-color:#e6b4508c;background:#e6b4502e}[data-theme=dark] .chip--filter-level--active{border-color:var(--accent);background:#e6b45038;color:var(--accent)}[data-theme=dark] .chip--filter-level--active.chip--click:hover{background:var(--accent);color:#1a1410}.chip--level{background:var(--accent-weak);border-color:var(--accent);color:var(--primary);font-weight:600;letter-spacing:.02em;font-variant:small-caps;padding-inline:14px}[data-theme=dark] .chip--level{background:#e6b45029;border-color:var(--accent);color:var(--accent)}.chip--level.chip--click:hover{background:var(--accent);border-color:var(--accent);color:var(--text)}[data-theme=dark] .chip--level.chip--click:hover{color:#1a1410}.chip--active{border-color:var(--primary);color:var(--primary);background:var(--primary-weak);font-weight:600}.chip--casting,.chip--duration{gap:6px;font-weight:600;padding-inline:12px}.chip--casting{background:var(--primary-weak);border-color:var(--primary);color:var(--primary)}.chip--duration{background:var(--accent-weak);border-color:var(--accent);color:var(--accent)}.chip--casting svg,.chip--duration svg{flex-shrink:0}.chip--components{background:var(--accent-weak);border-color:var(--accent);border-radius:var(--radius);padding:8px 12px;gap:8px;font-weight:600;flex-wrap:wrap;align-items:center;justify-content:flex-start}.chip--component{display:inline-flex;align-items:center;justify-content:center;min-width:22px;min-height:22px;padding:3px 8px;border-radius:6px;background:var(--accent);color:var(--surface);font-size:11px;font-weight:700;letter-spacing:.5px;white-space:nowrap}.chip--component-m{min-height:32px;padding:6px 12px;border-radius:10px;gap:10px;justify-content:flex-start;align-items:center;white-space:normal}.chip--component-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:6px;background:#0000002e;font-size:11px;font-weight:700;letter-spacing:.5px}.chip--component-text{font-size:12px;font-weight:600;line-height:1.25;max-width:260px;white-space:normal;text-align:left}@media(max-width:640px){.chip--component-text{max-width:100%}}.chip--ritual{background:#8b5cf6;border-color:#7c3aed;color:#fff;font-weight:600}.chip--concentration{background:#3b82f6;border-color:#2563eb;color:#fff;font-weight:600}.grid-cards{display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}@media(max-width:640px){.grid-cards{grid-template-columns:1fr}}.card{border:2px solid var(--border);background:var(--surface);border-radius:var(--radius);padding:var(--space-4);box-shadow:var(--shadow);break-inside:avoid;transition:all .3s;position:relative}.card:before{content:"";position:absolute;inset:0;border-radius:var(--radius);background:linear-gradient(135deg,transparent 0%,rgba(0,0,0,.02) 100%);pointer-events:none}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.card__head{display:flex;justify-content:space-between;gap:var(--space-3);align-items:flex-start;margin-bottom:var(--space-2)}.card__h3{margin:0;font-weight:700;line-height:1.2;font-size:1.1rem}.card__h4{margin:4px 0 0;font-weight:600;font-size:14px;color:var(--muted)}.filters-toggle{position:sticky;top:calc(var(--sticky-top) + var(--space-2));z-index:40;display:flex;justify-content:flex-end;margin-bottom:var(--space-3)}.filters-toggle-btn{box-shadow:var(--shadow);transition:transform .2s ease,box-shadow .2s ease}.filters-toggle-btn:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}@media(max-width:768px){.filters-toggle{position:static}.filters-toggle-btn{width:100%}}.filters-toggle--floating{margin-bottom:0}.filters{display:grid;gap:var(--space-3);background:var(--surface);border:2px solid var(--border);border-radius:var(--radius);padding:var(--space-4);box-shadow:var(--shadow);margin-bottom:var(--space-4)}.filters--hidden{display:none}.filters-top{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:flex-end}.filters-top label{flex:1 1 260px}.filters-hide-btn{display:inline-flex;align-items:center;gap:var(--space-2);white-space:nowrap}@media(max-width:640px){.filters-hide-btn{width:100%;justify-content:center}}.filters-controls{display:grid;gap:var(--space-3);grid-template-columns:1fr;align-items:end}@media(min-width:640px){.filters-controls{grid-template-columns:1fr 1fr}}@media(min-width:1024px){.filters-controls{grid-template-columns:repeat(5,1fr)}}.filters label{display:flex;flex-direction:column;gap:var(--space-1);font-weight:500;font-size:.9rem}@media(min-width:769px){.filters-toggle--floating{position:static}.filters-toggle-btn--floating{position:fixed;top:calc(var(--sticky-top) + var(--space-6));right:var(--space-5);width:52px;height:52px;padding:0;border-radius:999px;box-shadow:var(--shadow-lg)}.filters-toggle-btn--floating span{display:none}}.sticky{position:sticky;top:var(--sticky-top);z-index:10}@media(max-width:768px){.sticky{position:relative;top:0}}.pagination{display:flex;gap:8px;align-items:center;justify-content:center;margin:24px 0;flex-wrap:wrap}.pagination button{padding:8px 12px;border-radius:8px;min-width:40px;font-weight:500}.pagination button:disabled{opacity:.5;cursor:not-allowed}.dock{position:fixed;right:16px;bottom:16px;background:var(--surface);border:2px solid var(--primary);border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-lg);display:flex;gap:10px;align-items:center;z-index:50}@media(max-width:640px){.dock{left:16px;right:16px;flex-wrap:wrap;justify-content:center}}.segmented{display:flex;gap:8px;margin-bottom:var(--space-4);background:var(--surface);padding:4px;border-radius:10px;border:2px solid var(--border)}.seg{flex:1;padding:10px 16px;border-radius:8px;border:none;background:transparent;color:var(--text);font-weight:600;transition:all .2s;cursor:pointer}.seg:hover{background:var(--primary-weak)}.seg[aria-pressed=true]{background:var(--primary);color:var(--surface);box-shadow:0 2px 8px #00000026}.pack-actions{display:flex;flex-wrap:wrap;gap:var(--space-2);margin:var(--space-3) 0}.pack-list{list-style:none;display:grid;gap:var(--space-2);padding:0;margin:0}.pack-list__item{display:flex;gap:var(--space-3);justify-content:space-between;align-items:center;padding:var(--space-3);border:2px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:all .2s}.pack-list__item:hover{border-color:var(--primary);box-shadow:var(--shadow)}.pack-list__item .btn{white-space:nowrap}.muted{opacity:.7}.print-toolbar{display:flex;gap:var(--space-3);align-items:center;padding:var(--space-3) 0;flex-wrap:wrap}.print-toolbar__control{display:flex;flex-direction:column;gap:var(--space-1);min-width:120px}.print-toolbar__control select,.print-toolbar__input{min-height:32px}.print-toolbar__input{width:min(220px,100%)}.print-toolbar__check{display:flex;align-items:center;gap:var(--space-2)}.print-toolbar__divider{width:1px;height:28px;background:var(--border)}.print-toolbar__legend{font-weight:600}:where(.btn,.chip,.seg,.site-header__nav a,.pagination button,.icon-btn,.hamburger):focus-visible{outline:3px solid var(--primary);outline-offset:2px}.skip{position:absolute;left:-9999px;top:auto}.skip:focus{left:8px;top:8px;background:var(--surface);color:var(--text);padding:8px 12px;border-radius:8px;box-shadow:var(--shadow);z-index:1000}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(max-width:640px){.container{padding:0 var(--space-3)}h1{font-size:1.75rem}.filters,.card{padding:var(--space-3)}}
