*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--bg: #fafaf7;--panel: #f3f1ed;--text: #2b2a28;--muted: #6a6a6a;--accent: #7a99c1;--border: rgba(0,0,0,.08);--grimoire-card: linear-gradient(145deg, #f7f1e8 0%, #efe6d9 100%);--grimoire-border: #b89a75;--grimoire-highlight: #b07a2a;--grimoire-text: #4b3b2a;--grimoire-muted: #6f5b45;--quest-card: linear-gradient(145deg, #f4e8d0 0%, #e8d4b0 100%);--quest-border: #8b6f47;--quest-highlight: #d4a574;--quest-text: #2d2520;--quest-muted: #4a3f35;--quest-ribbon: #c9454d;--quest-wax: #8b2f35}:root.dark{--bg: #1a1d23;--panel: #23262d;--text: #e4e4e1;--muted: #a0a0a0;--accent: #8ba9ca;--border: rgba(255,255,255,.08);--grimoire-card: linear-gradient(145deg, #2d2520 0%, #1a1510 100%);--grimoire-border: #8b7355;--grimoire-highlight: #ffd780;--grimoire-text: #c9c3b0;--grimoire-muted: #8b7355;--quest-card: linear-gradient(145deg, #f4e2c3 0%, #ead2a6 100%);--quest-border: #c6a070;--quest-highlight: #d8b98a;--quest-text: #3c2f24;--quest-muted: #6b5845;--quest-ribbon: #c84b55;--quest-wax: #9b2f35}:root.light{--bg: #fafaf7;--panel: #f3f1ed;--text: #2b2a28;--muted: #6a6a6a;--accent: #7a99c1;--border: rgba(0,0,0,.08);--grimoire-card: linear-gradient(145deg, #f7f1e8 0%, #efe6d9 100%);--grimoire-border: #b89a75;--grimoire-highlight: #b07a2a;--grimoire-text: #4b3b2a;--grimoire-muted: #6f5b45;--quest-card: linear-gradient(145deg, #f4e8d0 0%, #e8d4b0 100%);--quest-border: #8b6f47;--quest-highlight: #d4a574;--quest-text: #2d2520;--quest-muted: #4a3f35;--quest-ribbon: #c9454d;--quest-wax: #8b2f35}@media (prefers-color-scheme: dark){:root:not(.light):not(.dark){--bg: #1a1d23;--panel: #23262d;--text: #e4e4e1;--muted: #a0a0a0;--accent: #8ba9ca;--border: rgba(255,255,255,.08);--grimoire-card: linear-gradient(145deg, #2d2520 0%, #1a1510 100%);--grimoire-border: #8b7355;--grimoire-highlight: #ffd780;--grimoire-text: #c9c3b0;--grimoire-muted: #8b7355;--quest-card: linear-gradient(145deg, #f4e2c3 0%, #ead2a6 100%);--quest-border: #c6a070;--quest-highlight: #d8b98a;--quest-text: #3c2f24;--quest-muted: #6b5845;--quest-ribbon: #c84b55;--quest-wax: #9b2f35}:root:not(.light):not(.dark) .stack-tag{color:var(--text);background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}}body{position:relative;margin:0;overflow-x:hidden;background-color:var(--bg);font-family:Inter,sans-serif;line-height:1.625;color:var(--text)}.particles{pointer-events:none;position:fixed;top:0;left:0;z-index:0;height:100%;width:100%}.particle{position:absolute;width:3px;height:3px;background-color:var(--accent);border-radius:50%;opacity:0;animation:float 15s infinite ease-in-out}@keyframes float{0%,to{transform:translateY(0) translate(0);opacity:0}10%{opacity:.4}90%{opacity:.3}to{transform:translateY(-100vh) translate(30px);opacity:0}}.section-title{position:relative;margin-bottom:1rem;display:inline-block;font-family:EB Garamond,serif;font-size:2.2rem;color:var(--accent)}.section-title:after{content:"✦";margin-left:.5rem;font-size:.7em;opacity:.3;animation:sparkle 3s ease-in-out infinite}@keyframes sparkle{0%,to{opacity:.3}50%{opacity:.6}}.card{position:relative;overflow:hidden;border-radius:10px;border-width:1px;border-color:var(--border);background-color:var(--panel);padding:1.5rem;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.3s}.card:before{content:"";position:absolute;top:0;left:-100%;height:100%;width:100%;background:linear-gradient(90deg,transparent,rgba(122,153,193,.05),transparent);transition:left .5s ease}.card:hover:before{left:100%}.card:hover{--tw-translate-y: -.25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));box-shadow:0 12px 28px #7a99c126}.card-static{transition-property:none}.card-static:hover{--tw-translate-y: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));box-shadow:none}.card-static:before{transition:none}.card-static:hover:before{left:-100%}.tag{margin-top:.5rem;display:inline-block;border-radius:9999px;border-width:1px;border-color:var(--accent);padding:.3rem .65rem;font-size:.75rem;color:var(--accent)}.quest-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2.5rem}.quest-card{background:var(--quest-card);border:3px solid var(--quest-border);border-radius:8px;position:relative;overflow:visible;transition:all .3s ease;box-shadow:0 6px 25px #00000059,inset 0 1px #ffffff40;color:var(--quest-text);display:flex;flex-direction:column;height:100%}.quest-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,color-mix(in srgb,var(--quest-border) 6%,transparent) 2px,color-mix(in srgb,var(--quest-border) 6%,transparent) 4px);pointer-events:none;border-radius:8px}.quest-card:hover{transform:translateY(-6px);box-shadow:0 12px 35px #00000073,0 0 20px color-mix(in srgb,var(--quest-highlight) 30%,transparent),inset 0 1px #ffffff59;border-color:var(--quest-highlight)}.quest-pin{position:absolute;top:-10px;left:50%;transform:translate(-50%);width:20px;height:20px;background:radial-gradient(circle,color-mix(in srgb,var(--quest-highlight) 70%,#fff 30%) 0%,var(--quest-border) 100%);border-radius:50%;box-shadow:0 2px 8px #00000059,inset 0 1px 2px #ffffff4d;z-index:10}.quest-pin:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:8px;height:8px;background:color-mix(in srgb,var(--quest-border) 70%,#000 30%);border-radius:50%}.wax-seal{position:absolute;top:15px;right:15px;width:50px;height:50px;background:radial-gradient(circle,var(--quest-ribbon) 0%,var(--quest-wax) 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 10px color-mix(in srgb,var(--quest-wax) 60%,transparent),inset 0 1px 3px #fff3;z-index:5}.wax-seal:before{content:"⚔";font-size:1.5rem;color:color-mix(in srgb,var(--quest-text) 15%,#fff 85%);text-shadow:0 1px 2px rgba(0,0,0,.3)}.ribbon{position:absolute;top:-5px;right:70px;width:30px;height:60px;background:linear-gradient(180deg,var(--quest-ribbon) 0%,var(--quest-wax) 100%);clip-path:polygon(0 0,100% 0,100% 85%,50% 100%,0 85%);box-shadow:2px 2px 8px #0000004d}.quest-header{padding:2rem 1.5rem 1.5rem;border-bottom:2px solid color-mix(in srgb,var(--quest-border) 20%,transparent);position:relative}.quest-rank{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;background:linear-gradient(135deg,color-mix(in srgb,var(--quest-highlight) 60%,#fff 40%),color-mix(in srgb,var(--quest-border) 35%,#fff 65%));border:2px solid var(--quest-border);border-radius:20px;font-size:.75rem;color:var(--quest-text);letter-spacing:1px;text-transform:uppercase;font-weight:600;margin-bottom:1rem;box-shadow:0 2px 6px #0003}.quest-rank:before{content:"★";color:var(--quest-highlight);font-size:1rem}.quest-title{font-size:1.5rem;color:var(--quest-text);margin-bottom:.8rem;font-weight:500;letter-spacing:.5px}.quest-description{color:var(--quest-muted);line-height:1.6;font-size:.95rem;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden;text-overflow:ellipsis}.quest-body{padding:1.5rem;display:flex;align-items:center;justify-content:space-between;justify-items:flex-end;gap:1rem;flex-wrap:wrap;margin-top:auto}.quest-tags{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:0}.quest-tag{padding:.35rem .9rem;background:color-mix(in srgb,var(--quest-border) 12%,transparent);border:1px solid color-mix(in srgb,var(--quest-border) 30%,transparent);border-radius:15px;font-size:.8rem;color:var(--quest-muted);letter-spacing:.5px}:root.dark .stack-tag{color:var(--text);background:color-mix(in srgb,var(--accent) 22%,transparent);border-color:color-mix(in srgb,var(--accent) 45%,transparent)}.quest-status{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:6px;font-size:.85rem;margin-bottom:0}.status-completed{background:#4caf502e;border:1px solid rgba(76,175,80,.4);color:#2d5f2f}.status-progress{background:#ffc1072e;border:1px solid rgba(255,193,7,.4);color:#7d5e00}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor}.accept-quest{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;color:var(--quest-text);text-decoration:none;font-size:.95rem;padding:.8rem 1.5rem;border:2px solid var(--quest-border);border-radius:6px;transition:all .3s;background:color-mix(in srgb,var(--quest-highlight) 25%,transparent);font-weight:500;letter-spacing:.5px;white-space:nowrap}.accept-quest:hover{background:color-mix(in srgb,var(--quest-highlight) 40%,transparent);border-color:var(--quest-highlight);box-shadow:0 0 15px color-mix(in srgb,var(--quest-highlight) 40%,transparent)}.accept-quest:after{content:"→";font-size:1.2rem}.corner-tear{position:absolute;width:15px;height:15px;background:var(--bg);opacity:.6}.tear-tl{top:0;left:0;clip-path:polygon(0 0,100% 0,0 100%)}.tear-tr{top:0;right:0;clip-path:polygon(100% 0,100% 100%,0 0)}.parchment-texture{position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 20% 50%,color-mix(in srgb,var(--quest-border) 8%,transparent) 0%,transparent 50%),radial-gradient(circle at 80% 80%,color-mix(in srgb,var(--quest-border) 8%,transparent) 0%,transparent 50%);pointer-events:none;border-radius:8px}.grimoire-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:2.5rem}.grimoire-card{background:var(--grimoire-card);border:3px solid var(--grimoire-border);border-radius:8px;position:relative;overflow:hidden;transition:all .4s ease;box-shadow:0 4px 20px #00000080,inset 0 1px color-mix(in srgb,var(--grimoire-border) 40%,transparent)}.grimoire-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(90deg,transparent,transparent 2px,color-mix(in srgb,var(--grimoire-border) 10%,transparent) 2px,color-mix(in srgb,var(--grimoire-border) 10%,transparent) 4px),repeating-linear-gradient(0deg,transparent,transparent 2px,color-mix(in srgb,var(--grimoire-border) 10%,transparent) 2px,color-mix(in srgb,var(--grimoire-border) 10%,transparent) 4px);pointer-events:none}.grimoire-card:after{content:"";position:absolute;top:8px;left:8px;right:8px;bottom:8px;border:1px solid color-mix(in srgb,var(--grimoire-border) 25%,transparent);border-radius:4px;pointer-events:none}.grimoire-card:hover{transform:translateY(-8px);box-shadow:0 12px 35px #000000b3,0 0 30px color-mix(in srgb,var(--grimoire-highlight) 30%,transparent),inset 0 1px color-mix(in srgb,var(--grimoire-border) 60%,transparent);border-color:var(--grimoire-highlight)}.card-corner{position:absolute;width:20px;height:20px;border:2px solid var(--grimoire-border)}.corner-tl{top:15px;left:15px;border-right:none;border-bottom:none}.corner-tr{top:15px;right:15px;border-left:none;border-bottom:none}.corner-bl{bottom:15px;left:15px;border-right:none;border-top:none}.corner-br{bottom:15px;right:15px;border-left:none;border-top:none}.preview-area{height:200px;background:#0000004d;display:flex;align-items:center;justify-content:center;border-bottom:2px solid color-mix(in srgb,var(--grimoire-border) 35%,transparent);position:relative;overflow:hidden}.preview-area img,.preview-area iframe{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.85;transition:all .4s;border:0}.grimoire-card:hover .preview-area img,.grimoire-card:hover .preview-area iframe{opacity:1;transform:scale(1.05)}.preview-placeholder{color:var(--grimoire-muted);font-style:italic;font-size:1.1rem;letter-spacing:1px}.event-carousel-frame{margin-top:1.5rem}.event-carousel-preview{height:260px}.event-carousel-preview img{-o-object-fit:contain;object-fit:contain;background:#0000001f}@media (min-width: 768px){.event-carousel-preview{height:640px}}.event-carousel-nav{position:absolute;top:50%;transform:translateY(-50%);background:color-mix(in srgb,var(--grimoire-card) 70%,transparent);border:1px solid color-mix(in srgb,var(--grimoire-border) 60%,transparent);color:var(--grimoire-text);width:38px;height:38px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:1.4rem;box-shadow:0 8px 16px #00000040;transition:transform .2s ease,border-color .2s ease,color .2s ease}.event-carousel-nav:hover{transform:translateY(-50%) scale(1.05);border-color:var(--grimoire-highlight);color:var(--grimoire-highlight)}.event-carousel-nav.nav-prev{left:16px}.event-carousel-nav.nav-next{right:16px}.event-carousel-controls{display:flex;align-items:center;justify-content:center;gap:.6rem;padding:1.2rem 1.8rem 1.6rem}.event-carousel-dot{width:10px;height:10px;border-radius:999px;background:color-mix(in srgb,var(--grimoire-border) 35%,transparent);border:1px solid color-mix(in srgb,var(--grimoire-border) 55%,transparent);transition:transform .2s ease,background .2s ease,border-color .2s ease}.event-carousel-dot.active{background:var(--grimoire-highlight);border-color:var(--grimoire-highlight);transform:scale(1.15)}.card-content{padding:2rem;position:relative;z-index:1}.card-title{font-size:1.6rem;color:var(--grimoire-highlight);margin-bottom:.8rem;font-weight:400;letter-spacing:1px}.card-description{color:var(--grimoire-text);line-height:1.6;margin-bottom:1.5rem;font-size:.95rem}.view-diagram{display:inline-flex;align-items:center;gap:.5rem;color:var(--grimoire-highlight);font-size:1rem;border:1px solid var(--grimoire-border);padding:.6rem 1.2rem;border-radius:4px;transition:all .3s;background:color-mix(in srgb,var(--grimoire-border) 10%,transparent)}.view-diagram:hover{background:color-mix(in srgb,var(--grimoire-highlight) 15%,transparent);border-color:var(--grimoire-highlight);box-shadow:0 0 15px color-mix(in srgb,var(--grimoire-highlight) 35%,transparent);transform:translate(5px)}.view-diagram:after{content:"→";font-size:1.2rem}.rune-decoration{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:7rem;color:color-mix(in srgb,var(--grimoire-border) 12%,transparent);pointer-events:none;font-family:serif}.spell-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}.spell-card{background:linear-gradient(165deg,color-mix(in srgb,var(--accent) 18%,transparent),color-mix(in srgb,var(--panel) 85%,transparent),color-mix(in srgb,var(--panel) 70%,#000 30%));border:2px solid color-mix(in srgb,var(--accent) 20%,transparent);border-radius:12px;padding:0;position:relative;overflow:hidden;transition:all .4s ease;box-shadow:0 4px 20px #00000026,inset 0 1px 1px color-mix(in srgb,var(--accent) 20%,transparent);display:flex;flex-direction:column;height:100%}:root.light .spell-card{background:linear-gradient(165deg,color-mix(in srgb,var(--accent) 12%,#fff 88%),color-mix(in srgb,var(--panel) 92%,#fff 8%) 55%,color-mix(in srgb,var(--panel) 85%,#fff 15%));border-color:color-mix(in srgb,var(--accent) 18%,transparent);box-shadow:0 6px 16px #7a99c11f,inset 0 1px 1px color-mix(in srgb,var(--accent) 10%,transparent)}:root.light .spell-card:hover{box-shadow:0 10px 22px #7a99c129,0 0 12px #7a99c11f,inset 0 1px 1px color-mix(in srgb,var(--accent) 18%,transparent)}:root.light .spell-header{background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 12%,#fff 88%),color-mix(in srgb,var(--accent) 4%,#fff 96%));border-bottom:1px solid color-mix(in srgb,var(--accent) 18%,transparent)}:root.light .spell-description{color:color-mix(in srgb,var(--text) 92%,#000 8%)}:root.light .note-tag{background:color-mix(in srgb,var(--accent) 10%,#fff 90%);border-color:color-mix(in srgb,var(--accent) 20%,transparent)}:root.light .read-note{background:color-mix(in srgb,var(--accent) 8%,#fff 92%);border-color:color-mix(in srgb,var(--accent) 22%,transparent)}.spell-card:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 35%,transparent),color-mix(in srgb,var(--accent) 10%,transparent));border-radius:12px;z-index:-1;opacity:0;transition:opacity .3s ease}.spell-card:hover:before{opacity:1}.spell-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px color-mix(in srgb,var(--accent) 25%,transparent),0 0 15px color-mix(in srgb,var(--accent) 15%,transparent),inset 0 1px 1px color-mix(in srgb,var(--accent) 30%,transparent)}.spell-header{padding:1.5rem;background:linear-gradient(135deg,color-mix(in srgb,var(--accent) 15%,transparent),color-mix(in srgb,var(--accent) 5%,transparent));border-bottom:1px solid color-mix(in srgb,var(--accent) 25%,transparent);position:relative}.spell-circle{position:absolute;top:10px;right:10px;width:50px;height:50px;border:2px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:50%;display:flex;align-items:center;justify-content:center}.spell-circle:before{content:"";position:absolute;width:35px;height:35px;border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:50%}.spell-circle:after{content:""}.spell-rune{color:var(--accent);font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center}.spell-rank{display:inline-block;padding:.3rem .8rem;background:color-mix(in srgb,var(--accent) 18%,transparent);border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);border-radius:20px;font-size:.75rem;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-bottom:.8rem}.spell-name{font-size:1.35rem;color:var(--grimoire-highlight);margin-bottom:.5rem;font-weight:400;letter-spacing:.5px}.spell-subtitle{font-size:.95rem;color:var(--muted);font-style:italic;opacity:.85}.spell-body{padding:1.5rem;flex:1;display:flex;flex-direction:column}.spell-description{color:var(--text);line-height:1.7;margin-bottom:1.2rem;font-size:.95rem}.spell-meta{display:flex;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem;padding-top:1rem;border-top:1px solid color-mix(in srgb,var(--accent) 15%,transparent)}.meta-item{display:flex;align-items:center;gap:.4rem;font-size:.85rem;color:var(--muted)}.meta-icon{color:var(--accent);font-size:1rem}.note-detail-meta{display:flex;gap:1rem;flex-wrap:wrap;margin:1.2rem 0 1.6rem;padding-top:1rem;border-top:1px solid color-mix(in srgb,var(--accent) 15%,transparent)}.note-markdown{line-height:1.7;font-size:.95rem;color:var(--text);padding:1.6rem;border-radius:14px;border:1px solid color-mix(in srgb,var(--accent) 18%,transparent);background:color-mix(in srgb,var(--accent) 6%,transparent)}.note-markdown h1,.note-markdown h2,.note-markdown h3{margin:1.4rem 0 .8rem;color:var(--text);line-height:1.2;font-weight:600}.note-markdown h1{font-size:1.8rem}.note-markdown h2{font-size:1.5rem}.note-markdown h3{font-size:1.2rem}.note-markdown h4,.note-markdown h5,.note-markdown h6{margin:1.2rem 0 .6rem;color:var(--text);line-height:1.25;font-weight:600}.note-markdown h4{font-size:1.05rem}.note-markdown h5{font-size:.98rem}.note-markdown h6{font-size:.9rem;text-transform:uppercase;letter-spacing:.04em}.note-markdown p{margin:.6rem 0}.note-markdown a{color:var(--accent);text-decoration:underline}.note-markdown pre{background:color-mix(in srgb,var(--accent) 12%,transparent);padding:.9rem;border-radius:10px;overflow-x:auto}.note-markdown code{font-family:Fira Code,monospace;font-size:.9rem}.note-markdown blockquote{margin:1rem 0;padding-left:1rem;border-left:3px solid color-mix(in srgb,var(--accent) 35%,transparent);color:var(--muted)}.note-callout{margin:1.2rem 0;padding:1rem 1.1rem;border-radius:12px;background:color-mix(in srgb,var(--accent) 8%,transparent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent)}.note-markdown mark{background:color-mix(in srgb,var(--accent) 25%,transparent);color:var(--text);padding:0 .2rem;border-radius:4px}.note-markdown ul,.note-markdown ol{margin:.8rem 0 .8rem 1.2rem}.note-markdown img{max-width:100%;height:auto;margin:1rem 0;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent) 18%,transparent)}.spell-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.2rem}.note-tag{padding:.25rem .7rem;background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:12px;font-size:.8rem;color:var(--accent);letter-spacing:.4px}.read-note{display:inline-flex;align-items:center;gap:.5rem;color:var(--grimoire-highlight);font-size:.95rem;padding:.7rem 1.3rem;border:1px solid color-mix(in srgb,var(--accent) 35%,transparent);border-radius:6px;transition:all .3s;background:color-mix(in srgb,var(--accent) 10%,transparent);width:100%;justify-content:center;margin-top:auto}.note-back{width:auto;padding:.55rem 1.1rem}.note-title{display:block}.read-note:hover{background:color-mix(in srgb,var(--accent) 20%,transparent);border-color:var(--accent);box-shadow:0 0 15px color-mix(in srgb,var(--accent) 25%,transparent)}.read-note:before{content:"◈";font-size:1rem;color:var(--accent)}.note-particles{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.note-particle{position:absolute;width:2px;height:2px;background:var(--accent);border-radius:50%;opacity:0;transition:opacity .3s ease}.spell-card:hover .note-particle{opacity:.35}.note-particle:nth-child(1){bottom:20%;left:20%}.note-particle:nth-child(2){bottom:30%;left:40%}.note-particle:nth-child(3){bottom:25%;left:60%}.note-particle:nth-child(4){bottom:35%;left:80%}.pointer-events-none{pointer-events:none}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.bottom-\[-3px\]{bottom:-3px}.left-0{left:0}.left-1{left:.25rem}.left-\[28px\]{left:28px}.top-1\/2{top:50%}.z-\[1\]{z-index:1}.m-0{margin:0}.mx-auto{margin-left:auto;margin-right:auto}.my-\[0\.6rem\]{margin-top:.6rem;margin-bottom:.6rem}.mb-0{margin-bottom:0}.mb-16{margin-bottom:4rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.mb-\[0\.35rem\]{margin-bottom:.35rem}.ml-auto{margin-left:auto}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.mt-auto{margin-top:auto}.block{display:block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.h-4{height:1rem}.h-5{height:1.25rem}.h-7{height:1.75rem}.h-\[2px\]{height:2px}.w-14{width:3.5rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-full{width:100%}.max-w-\[1080px\]{max-width:1080px}.max-w-\[700px\]{max-width:700px}.max-w-\[720px\]{max-width:720px}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.list-inside{list-style-position:inside}.list-disc{list-style-type:disc}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-\[repeat\(auto-fit\,minmax\(200px\,1fr\)\)\]{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.grid-cols-\[repeat\(auto-fit\,minmax\(240px\,1fr\)\)\]{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.grid-cols-\[repeat\(auto-fit\,minmax\(260px\,1fr\)\)\]{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-7{gap:1.75rem}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.break-all{word-break:break-all}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.border{border-width:1px}.border-0{border-width:0px}.border-b{border-bottom-width:1px}.border-l-2{border-left-width:2px}.border-t{border-top-width:1px}.border-\[var\(--accent\)\]{border-color:var(--accent)}.border-\[var\(--border\)\]{border-color:var(--border)}.bg-\[var\(--accent\)\]{background-color:var(--accent)}.bg-gray-300{--tw-bg-opacity: 1;background-color:rgb(209 213 219 / var(--tw-bg-opacity, 1))}.bg-gray-600{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.px-4{padding-left:1rem;padding-right:1rem}.px-8{padding-left:2rem;padding-right:2rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-8{padding-top:2rem;padding-bottom:2rem}.pb-16{padding-bottom:4rem}.pb-4{padding-bottom:1rem}.pl-4{padding-left:1rem}.pl-5{padding-left:1.25rem}.text-center{text-align:center}.text-right{text-align:right}.font-display{font-family:EB Garamond,serif}.text-\[0\.75rem\]{font-size:.75rem}.text-\[0\.85rem\]{font-size:.85rem}.text-\[0\.95rem\]{font-size:.95rem}.text-\[0\.9rem\]{font-size:.9rem}.text-\[1\.05rem\]{font-size:1.05rem}.text-\[1\.1rem\]{font-size:1.1rem}.text-\[1\.2rem\]{font-size:1.2rem}.text-\[1\.35rem\]{font-size:1.35rem}.text-\[1\.3rem\]{font-size:1.3rem}.text-\[1rem\]{font-size:1rem}.text-\[2\.8rem\]{font-size:2.8rem}.text-\[2rem\]{font-size:2rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xs{font-size:.75rem;line-height:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-relaxed{line-height:1.625}.tracking-\[0\.2em\]{letter-spacing:.2em}.text-\[var\(--accent\)\]{color:var(--accent)}.text-\[var\(--muted\)\]{color:var(--muted)}.text-\[var\(--text\)\]{color:var(--text)}.no-underline{text-decoration-line:none}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-300{transition-duration:.3s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.hover\:scale-\[1\.02\]:hover{--tw-scale-x: 1.02;--tw-scale-y: 1.02;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:bg-\[var\(--accent\)\]:hover{background-color:var(--accent)}.hover\:text-\[var\(--accent\)\]:hover{color:var(--accent)}.hover\:text-\[var\(--bg\)\]:hover{color:var(--bg)}.hover\:underline:hover{text-decoration-line:underline}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-\[var\(--accent\)\]:focus{--tw-ring-color: var(--accent)}.focus\:ring-offset-2:focus{--tw-ring-offset-width: 2px}.focus\:ring-offset-\[var\(--bg\)\]:focus{--tw-ring-offset-color: var(--bg)}@media (min-width: 768px){.md\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.md\:grid-cols-\[minmax\(0\,2fr\)_minmax\(0\,1fr\)\]{grid-template-columns:minmax(0,2fr) minmax(0,1fr)}}
