@import"https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,400&family=Spectral:ital,wght@0,300;0,400;0,600;1,400&family=JetBrains+Mono:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box}:root{color-scheme:dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}body{margin:0;padding:0;min-width:320px;min-height:100vh;background-color:#0a0a0f}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0003}::-webkit-scrollbar-thumb{background:#6b668866;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6b668899}*{scrollbar-width:thin;scrollbar-color:rgba(107,102,136,.4) rgba(0,0,0,.2)}:focus-visible{outline:2px solid rgba(201,162,39,.6);outline-offset:2px}::selection{background:#c9a2274d;color:#f0eff4}.grimoire{--abyss: #05080a;--ink: #0a0e12;--shadow: #111820;--slate: #1a242e;--stone: #2a3744;--mist: #4a5a6a;--silver: #8a9aaa;--bone: #c8d0d8;--parchment: #e8ece8;--ember: #e85a30;--flame: #ff8c42;--gold: #d4a855;--honey: #f0c060;--frost: #5ac8e8;--ice: #a0e8ff;--blood: #c83030;--wine: #8a2030;--arcane: #9060d0;--mystic: #c090ff;--font-display: "Cormorant Garamond", serif;--font-body: "Spectral", serif;--font-mono: "JetBrains Mono", monospace;--space-1: .25rem;--space-2: .5rem;--space-3: 1rem;--space-4: 1.5rem;--space-5: 2rem;--space-6: 3rem;--space-8: 5rem}.grimoire{min-height:100vh;background:var(--abyss);color:var(--bone);font-family:var(--font-body);font-size:16px;line-height:1.6;overflow-x:hidden;position:relative}.grimoire:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:1000}.particle-field{position:fixed;inset:0;pointer-events:none;overflow:hidden;z-index:0}.particle{position:absolute;width:3px;height:3px;background:var(--gold);border-radius:50%;left:var(--x);bottom:-10px;opacity:0;animation:float-up 15s ease-in-out infinite;animation-delay:var(--delay);box-shadow:0 0 6px var(--gold),0 0 12px var(--honey)}@keyframes float-up{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:.8}90%{opacity:.6}to{transform:translateY(-100vh) translate(var(--drift));opacity:0}}.hero{position:relative;min-height:70vh;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;padding:var(--space-8) var(--space-6);overflow:hidden}.hero-image{position:absolute;inset:0;z-index:0}.hero-image img{width:100%;height:100%;object-fit:cover;object-position:center 20%;opacity:0;animation:hero-reveal 1.8s cubic-bezier(.22,1,.36,1) .2s forwards;filter:saturate(1.1) contrast(1.05)}@keyframes hero-reveal{0%{opacity:0;transform:scale(1.05);filter:saturate(0) contrast(1.05) blur(8px)}to{opacity:1;transform:scale(1);filter:saturate(1.1) contrast(1.05) blur(0)}}.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 120% 100% at 50% 50%,transparent 30%,rgba(5,8,10,.7) 80%),linear-gradient(0deg,var(--abyss) 0%,rgba(5,8,10,.95) 15%,rgba(5,8,10,.6) 40%,transparent 70%),linear-gradient(90deg,rgba(5,8,10,.7) 0%,rgba(5,8,10,.3) 30%,transparent 60%),radial-gradient(ellipse 60% 40% at 70% 30%,rgba(90,200,232,.08) 0%,transparent 60%),radial-gradient(ellipse 40% 30% at 60% 25%,rgba(144,96,208,.06) 0%,transparent 50%);z-index:1}.hero:after{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent 0%,rgba(90,200,232,.03) 25%,transparent 50%,rgba(144,96,208,.03) 75%,transparent 100%);background-size:400% 400%;animation:aurora-shift 15s ease-in-out infinite;z-index:2;pointer-events:none}@keyframes aurora-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.campaign-whisper{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-3);z-index:10;opacity:0;transform:translate(-20px);animation:slide-in-right 1s ease .8s forwards}.whisper-line{width:40px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}.whisper-text{font-family:var(--font-display);font-size:.75rem;font-weight:400;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);text-shadow:0 0 20px rgba(212,168,85,.5)}.identity{text-align:left;z-index:10;max-width:600px}.ancestry{font-family:var(--font-display);font-size:.9rem;font-weight:300;font-style:italic;color:var(--bone);margin:0 0 var(--space-1);opacity:0;animation:fade-in .8s ease 1s forwards;text-shadow:0 2px 10px rgba(0,0,0,.8)}.name{font-family:var(--font-display);font-weight:300;margin:0;line-height:.85;opacity:0;animation:hero-text-reveal 1.2s cubic-bezier(.22,1,.36,1) 1.1s forwards}@keyframes hero-text-reveal{0%{opacity:0;transform:translateY(30px);filter:blur(4px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.name-first{display:block;font-size:clamp(4.5rem,14vw,9rem);letter-spacing:.02em;color:var(--parchment);text-shadow:0 0 60px rgba(212,168,85,.4),0 0 120px rgba(212,168,85,.2),0 4px 30px rgba(0,0,0,.8),2px 2px 0 rgba(0,0,0,.3)}.name-last{display:block;font-size:clamp(2rem,6vw,4rem);letter-spacing:.35em;color:var(--gold);margin-left:.1em;text-shadow:0 0 40px rgba(212,168,85,.6),0 0 80px rgba(212,168,85,.3),0 2px 20px rgba(0,0,0,.8)}.calling{font-family:var(--font-display);font-size:1.1rem;font-weight:400;letter-spacing:.12em;color:var(--bone);margin:var(--space-3) 0 0;opacity:0;animation:fade-in .8s ease 1.4s forwards;text-shadow:0 2px 15px rgba(0,0,0,.9)}.calling:before{content:"— ";color:var(--gold);opacity:.6}.calling:after{content:" —";color:var(--gold);opacity:.6}.redacted-class{position:relative;display:inline-block;cursor:help}.redacted-glyphs{display:inline-block;font-family:var(--font-mono);letter-spacing:.05em;color:var(--arcane);text-shadow:0 0 8px var(--arcane),0 0 20px rgba(144,96,208,.4);animation:glyph-flicker 4s ease-in-out infinite;filter:blur(.5px)}.redacted-reveal{position:absolute;left:0;top:0;opacity:0;color:var(--mystic);text-shadow:0 0 10px var(--mystic);white-space:nowrap;animation:secret-reveal 6s ease-in-out infinite;pointer-events:none}@keyframes glyph-flicker{0%,to{opacity:1;transform:translate(0)}10%{opacity:.8;transform:translate(-1px)}20%{opacity:1;transform:translate(1px)}30%,70%{opacity:1;transform:translate(0)}72%{opacity:.3;transform:translate(2px) skew(-5deg)}74%{opacity:1;transform:translate(-1px) skew(2deg)}76%{opacity:.7;transform:translate(0) skew(0)}}@keyframes secret-reveal{0%,68%,80%,to{opacity:0;transform:translate(0);filter:blur(4px)}70%,78%{opacity:.9;transform:translate(0);filter:blur(0)}71%,77%{opacity:.4;transform:translate(2px);filter:blur(1px)}}.redacted-class:hover .redacted-glyphs{animation:glyph-scatter .3s ease-out forwards}.redacted-class:hover .redacted-reveal{animation:glitch-text .4s ease-in-out infinite;opacity:1;filter:blur(0)}@keyframes glitch-text{0%,to{transform:translate(0);text-shadow:0 0 10px var(--mystic);opacity:1}10%{transform:translate(-2px) skew(-2deg);text-shadow:-2px 0 var(--arcane),2px 0 var(--frost);opacity:.9}20%{transform:translate(2px) skew(1deg);text-shadow:2px 0 var(--arcane),-2px 0 var(--frost);opacity:1}30%{transform:translate(0);text-shadow:0 0 10px var(--mystic)}50%{transform:translate(1px);opacity:.8}52%{transform:translate(-1px) skew(-3deg);text-shadow:-3px 0 var(--arcane),3px 0 var(--frost);opacity:.6}54%{transform:translate(0) skew(0);opacity:1}80%{transform:translate(-1px);text-shadow:1px 0 var(--arcane),-1px 0 var(--frost)}}@keyframes glyph-scatter{0%{opacity:1;transform:translate(0);filter:blur(.5px)}50%{opacity:.5;transform:translate(-5px);filter:blur(2px)}to{opacity:0;transform:translate(-10px);filter:blur(4px)}}.level-seal{display:inline-flex;align-items:center;gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-2) var(--space-4);background:linear-gradient(135deg,#d4a85533,#d4a8550d);border:1px solid rgba(212,168,85,.4);border-radius:30px;opacity:0;animation:fade-in-scale .8s ease 1.6s forwards;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.level-number{font-family:var(--font-display);font-size:1.75rem;font-weight:600;color:var(--gold);line-height:1;text-shadow:0 0 20px rgba(212,168,85,.5)}.level-word{font-family:var(--font-display);font-size:.7rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--bone);opacity:.8}.constellation{position:absolute;bottom:var(--space-6);right:6%;width:300px;height:300px;z-index:10;opacity:0;animation:constellation-reveal 1.5s ease 1.8s forwards}@keyframes constellation-reveal{0%{opacity:0;transform:scale(.9) rotate(-10deg)}to{opacity:1;transform:scale(1) rotate(0)}}.constellation-lines{position:absolute;inset:0;opacity:0;animation:fade-in 1s ease 2s forwards}.constellation-shape{fill:#d4a85508;stroke:#d4a85533;stroke-width:1;animation:pulse-subtle 4s ease-in-out infinite}.constellation-ray{stroke:#d4a8551a;stroke-width:1;stroke-dasharray:4 4}.constellation-center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:45px;height:45px;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle,rgba(212,168,85,.25) 0%,transparent 70%);border-radius:50%;opacity:0;animation:fade-in-scale 1s ease 2.2s forwards}.center-glyph{font-size:1.5rem;color:var(--gold);text-shadow:0 0 20px var(--gold);animation:rotate-slow 20s linear infinite}.ability-node{position:absolute;top:50%;left:50%;width:65px;height:65px;display:flex;flex-direction:column;align-items:center;justify-content:center;transform:rotate(var(--angle)) translateY(-120px) rotate(calc(var(--angle) * -1));opacity:0;animation:fade-in-scale .6s ease calc(2s + var(--delay)) forwards}.node-ring{position:absolute;inset:0;border:1px solid rgba(212,168,85,.4);border-radius:50%;background:radial-gradient(circle,#0a0e12d9,#0a0e12b3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .3s ease;box-shadow:0 4px 20px #0006}.ability-node:hover .node-ring{border-color:var(--gold);box-shadow:0 0 25px #d4a85566,0 8px 30px #00000080,inset 0 0 20px #d4a8551a;transform:scale(1.1)}.node-mod{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;color:var(--honey);position:relative;z-index:1;text-shadow:0 0 10px rgba(240,192,96,.5)}.node-score{font-family:var(--font-mono);font-size:.75rem;color:var(--mist);position:relative;z-index:1}.node-name{font-family:var(--font-display);font-size:.625rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--silver);position:relative;z-index:1;margin-top:2px}.vitals{display:flex;justify-content:center;align-items:stretch;gap:var(--space-1);padding:var(--space-4) var(--space-6);background:linear-gradient(180deg,var(--shadow) 0%,var(--ink) 100%);border-top:1px solid rgba(212,168,85,.1);border-bottom:1px solid rgba(212,168,85,.1);position:relative;z-index:10}.vital{display:flex;flex-direction:column;align-items:center;padding:var(--space-3) var(--space-4);min-width:80px;position:relative}.vital:after{content:"";position:absolute;right:0;top:20%;height:60%;width:1px;background:linear-gradient(180deg,transparent,rgba(138,154,170,.2),transparent)}.vital:last-child:after{display:none}.vital-icon{position:absolute;top:var(--space-1);font-size:.75rem;color:var(--frost)}.vital-value{font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--parchment)}.vital-label{font-family:var(--font-display);font-size:.75rem;font-weight:300;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);margin-top:var(--space-1)}.vital-prof .vital-value{color:var(--gold)}.vital-ac .vital-value{color:var(--frost)}.vital-hp{min-width:140px}.hp-bar{position:absolute;bottom:0;left:10%;right:10%;height:3px;background:var(--slate);border-radius:2px;overflow:hidden}.hp-fill{height:100%;background:linear-gradient(90deg,var(--wine),var(--blood),var(--ember));border-radius:2px;transition:width .5s ease;box-shadow:0 0 10px var(--blood)}.hp-max{font-size:.875rem;color:var(--mist)}.codex{display:grid;grid-template-columns:220px 1fr 240px;gap:0;min-height:60vh;position:relative;z-index:5}.margin-left,.margin-right{padding:var(--space-5) var(--space-4);background:linear-gradient(90deg,rgba(17,24,32,.8),transparent);border-right:1px solid rgba(138,154,170,.1)}.margin-right{background:linear-gradient(-90deg,rgba(17,24,32,.8),transparent);border-right:none;border-left:1px solid rgba(138,154,170,.1)}.margin-title{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin:0 0 var(--space-3);padding-bottom:var(--space-2);border-bottom:1px solid rgba(212,168,85,.2)}.margin-section{margin-bottom:var(--space-5)}.save-list{display:flex;flex-direction:column;gap:var(--space-1)}.save-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-1) var(--space-2);border-radius:4px;transition:all .2s ease}.save-item:hover{background:#ffffff08}.save-item.trained{background:#d4a85514}.save-ability{font-family:var(--font-mono);font-size:.75rem;color:var(--mist)}.save-mod{font-family:var(--font-mono);font-size:.875rem;color:var(--bone)}.save-item.trained .save-mod{color:var(--gold);text-shadow:0 0 8px rgba(212,168,85,.4)}.margin-notes{margin-top:var(--space-3);padding:var(--space-2);background:#9060d014;border-left:2px solid var(--arcane);border-radius:0 4px 4px 0}.margin-notes p{font-size:.75rem;font-style:italic;color:var(--silver);margin:var(--space-1) 0;line-height:1.4}.sense-item{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.sense-value{font-family:var(--font-mono);font-size:1.125rem;font-weight:600;color:var(--gold);min-width:32px}.sense-label{font-size:.875rem;color:var(--silver)}.special-sense{display:inline-block;font-size:.75rem;color:var(--mystic);padding:var(--space-1) var(--space-2);background:#9060d026;border:1px solid rgba(144,96,208,.3);border-radius:20px;margin-top:var(--space-2)}.defense-badge{display:inline-block;font-size:.8rem;color:var(--frost);padding:var(--space-1) var(--space-2);background:#5ac8e81a;border:1px solid rgba(90,200,232,.3);border-radius:4px}.skill-cascade{display:flex;flex-direction:column;gap:2px}.skill-row{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border-radius:4px;transition:all .2s ease;opacity:0;transform:translate(20px);animation:slide-in-right .4s ease forwards;animation-delay:calc(var(--i) * .03s)}.skill-row:hover{background:#ffffff08;transform:translate(-4px)}.skill-marker{width:6px;height:6px;border:1px solid var(--mist);border-radius:50%;flex-shrink:0;transition:all .2s ease}.skill-row.trained .skill-marker{background:var(--gold);border-color:var(--gold);box-shadow:0 0 6px var(--gold)}.skill-row.expert .skill-marker{background:var(--honey);border-color:var(--honey);box-shadow:0 0 8px var(--honey),0 0 16px #f0c0604d}.skill-name{flex:1;font-size:.8rem;color:var(--silver)}.skill-row.trained .skill-name{color:var(--bone)}.skill-mod{font-family:var(--font-mono);font-size:.875rem;color:var(--mist)}.skill-row.trained .skill-mod{color:var(--gold)}.proficiency-list{margin-top:var(--space-5)}.prof-group{margin-bottom:var(--space-3)}.prof-cat{display:block;font-family:var(--font-display);font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);margin-bottom:var(--space-1)}.prof-items{font-size:.8rem;color:var(--silver);line-height:1.5}.pages{background:var(--ink);display:flex;flex-direction:column}.page-tabs{display:flex;gap:2px;padding:var(--space-3) var(--space-4);background:#0000004d;border-bottom:1px solid rgba(138,154,170,.1)}.page-tab{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:transparent;border:1px solid transparent;border-radius:8px 8px 0 0;cursor:pointer;transition:all .3s ease;opacity:0;transform:translateY(10px);animation:fade-in-up .4s ease forwards;animation-delay:calc(var(--i) * .05s + .5s)}.page-tab:hover{background:#ffffff08}.page-tab.active{background:#d4a8551a;border-color:#d4a8554d;border-bottom-color:transparent}.tab-icon{font-size:1.25rem;color:var(--mist);transition:all .3s ease}.page-tab.active .tab-icon{color:var(--gold);text-shadow:0 0 10px var(--gold)}.tab-label{font-family:var(--font-display);font-size:.7rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);transition:color .3s ease}.page-tab.active .tab-label{color:var(--bone)}.page-content{flex:1;padding:var(--space-4);overflow-y:auto}.page{animation:fade-in .3s ease}.resource-pool{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);margin-bottom:var(--space-5);background:linear-gradient(135deg,#9060d01a,#5ac8e80d);border:1px solid rgba(144,96,208,.2);border-radius:12px;position:relative;overflow:hidden}.resource-pool:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 30% 50%,rgba(144,96,208,.1) 0%,transparent 60%)}.pool-orbs{display:flex;flex-wrap:wrap;gap:6px;max-width:200px}.pool-orb{width:12px;height:12px;background:radial-gradient(circle at 30% 30%,var(--mystic),var(--arcane));border-radius:50%;box-shadow:0 0 8px var(--arcane),inset 0 0 4px #ffffff4d;animation:orb-pulse 2s ease-in-out infinite;animation-delay:calc(var(--i) * .1s)}@keyframes orb-pulse{0%,to{transform:scale(1);opacity:.8}50%{transform:scale(1.1);opacity:1}}.pool-count{font-family:var(--font-mono);font-size:2.5rem;font-weight:600;color:var(--mystic);text-shadow:0 0 20px var(--arcane);position:relative}.pool-name{font-family:var(--font-display);font-size:1rem;font-weight:300;letter-spacing:.1em;color:var(--silver);position:relative}.attack-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-3)}.attack-card{background:linear-gradient(135deg,var(--slate) 0%,var(--shadow) 100%);border:1px solid rgba(138,154,170,.15);border-radius:12px;padding:var(--space-3);transition:all .3s ease;opacity:0;transform:translateY(20px);animation:fade-in-up .5s ease forwards;animation-delay:calc(var(--i) * .08s);position:relative;overflow:hidden}.attack-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--mist);opacity:.3}.attack-card.fire:before{background:linear-gradient(90deg,var(--ember),var(--flame));opacity:1}.attack-card.force:before{background:linear-gradient(90deg,var(--arcane),var(--mystic));opacity:1}.attack-card.piercing:before,.attack-card.slashing:before,.attack-card.bludgeoning:before{background:linear-gradient(90deg,var(--stone),var(--silver));opacity:.5}.attack-card:hover{transform:translateY(-4px);border-color:#d4a8554d;box-shadow:0 8px 32px #0006}.card-header{margin-bottom:var(--space-3)}.attack-name{font-family:var(--font-display);font-size:1.25rem;font-weight:600;color:var(--parchment);margin:0 0 var(--space-1)}.attack-type{font-size:.75rem;color:var(--mist);font-style:italic}.card-stats{display:flex;gap:var(--space-3);margin-bottom:var(--space-2)}.stat-block{flex:1;text-align:center;padding:var(--space-2);background:#0003;border-radius:8px}.stat-label{display:block;font-size:.625rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mist);margin-bottom:var(--space-1)}.stat-value{font-family:var(--font-mono);font-size:1rem;font-weight:600}.stat-value.hit{color:var(--gold)}.stat-value.damage{color:var(--ember)}.attack-card.force .stat-value.damage{color:var(--mystic)}.stat-value.range{color:var(--frost)}.card-notes{font-size:.75rem;color:var(--mist);margin:var(--space-2) 0 0;padding-top:var(--space-2);border-top:1px solid rgba(138,154,170,.1)}.page-spells{animation:fade-in .3s ease}.spell-slots-bar{display:flex;gap:var(--space-4);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-4);background:#9060d014;border:1px solid rgba(144,96,208,.2);border-radius:8px;flex-wrap:wrap}.slot-group{display:flex;align-items:center;gap:var(--space-2)}.slot-level{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:var(--arcane);min-width:16px}.slot-pips{display:flex;gap:4px}.slot-pip{width:14px;height:14px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--mystic),var(--arcane));box-shadow:0 0 6px var(--arcane);cursor:pointer;transition:all .2s ease}.slot-pip:hover{transform:scale(1.2);box-shadow:0 0 12px var(--mystic)}.slot-pip.used{background:var(--stone);box-shadow:none;opacity:.4}.spell-level-section{margin-bottom:var(--space-5)}.spell-level-header{font-family:var(--font-display);font-size:.875rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin:0 0 var(--space-3);padding-bottom:var(--space-1);border-bottom:1px solid rgba(212,168,85,.2)}.spell-list{display:flex;flex-direction:column;gap:var(--space-2)}.spell-card{padding:var(--space-3);background:linear-gradient(135deg,var(--shadow) 0%,rgba(17,24,32,.8) 100%);border:1px solid rgba(138,154,170,.12);border-left:3px solid var(--school-color);border-radius:8px;cursor:pointer;transition:all .2s ease;opacity:0;animation:fade-in-up .3s ease forwards;animation-delay:calc(var(--i) * .03s)}.spell-card:hover{background:linear-gradient(135deg,var(--slate) 0%,var(--shadow) 100%);border-color:#d4a8554d;transform:translate(4px);box-shadow:0 4px 20px #0000004d}.spell-card.conc{background:linear-gradient(135deg,rgba(144,96,208,.08) 0%,var(--shadow) 100%)}.spell-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-1)}.spell-card .spell-name{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--parchment);display:flex;align-items:center;gap:var(--space-2)}.spell-badge{font-size:.6rem;font-weight:600;padding:2px 6px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.spell-badge.spell-c{background:#9060d040;color:var(--mystic);border:1px solid rgba(144,96,208,.4)}.spell-badge.spell-r{background:#5ac8e826;color:var(--frost);border:1px solid rgba(90,200,232,.3)}.spell-school{font-family:var(--font-display);font-size:.7rem;font-weight:400;font-style:italic;color:var(--school-color);opacity:.8}.spell-short-desc{font-size:.8rem;color:var(--silver);margin:0 0 var(--space-2);line-height:1.4}.spell-card-stats{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center}.spell-stat{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:.7rem;color:var(--mist);padding:2px 8px;background:#0003;border-radius:4px}.stat-icon{font-size:.65rem;opacity:.7}.spell-stat-hit{color:var(--gold);background:#d4a8551a}.spell-stat-effect{color:var(--ember);background:#e85a301a;font-weight:500}@media(max-width:768px){.spell-card-stats{flex-wrap:wrap}}@media(max-width:480px){.spell-card{padding:var(--space-2)}.spell-card .spell-name{font-size:.9rem}.spell-short-desc{font-size:.75rem}}.spell-modal-overlay{position:fixed;inset:0;background:#05080ad9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:1000;animation:fade-in .2s ease}.spell-modal{position:relative;width:100%;max-width:560px;max-height:85vh;overflow-y:auto;background:linear-gradient(180deg,var(--shadow) 0%,var(--ink) 100%);border:1px solid rgba(138,154,170,.2);border-top:4px solid var(--school-color);border-radius:12px;box-shadow:0 0 60px #00000080,0 0 100px #9060d01a;animation:modal-enter .3s ease}@keyframes modal-enter{0%{opacity:0;transform:scale(.95) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:50%;color:var(--silver);font-size:1.5rem;cursor:pointer;transition:all .2s ease;z-index:10}.modal-close:hover{background:#ffffff1a;color:var(--parchment);transform:rotate(90deg)}.spell-modal-header{padding:var(--space-4) var(--space-4) var(--space-3);border-bottom:1px solid rgba(138,154,170,.1);background:linear-gradient(180deg,rgba(var(--school-color),.05) 0%,transparent 100%)}.spell-modal-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3);margin-bottom:var(--space-1)}.spell-modal-name{font-family:var(--font-display);font-size:1.75rem;font-weight:600;color:var(--parchment);margin:0;line-height:1.2}.spell-modal-badges{display:flex;gap:var(--space-2);flex-shrink:0}.spell-modal-badges .spell-badge{font-size:.65rem;padding:4px 8px}.spell-modal-subtitle{font-family:var(--font-display);font-size:.9rem;font-style:italic;color:var(--school-color);margin:0}.spell-modal-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-1);padding:var(--space-3) var(--space-4);background:#0003}.spell-modal-stat{display:flex;flex-direction:column;gap:2px}.modal-stat-label{font-size:.65rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mist)}.modal-stat-value{font-family:var(--font-mono);font-size:.85rem;color:var(--bone)}.material-note{color:var(--gold);cursor:help;margin-left:2px}.spell-material-component{padding:var(--space-2) var(--space-4);font-size:.75rem;font-style:italic;color:var(--mist);background:#d4a8550d;border-left:2px solid rgba(212,168,85,.3);margin:0}.spell-material-component strong{color:var(--gold)}.spell-modal-description{padding:var(--space-4)}.spell-modal-description p{font-size:.9rem;line-height:1.7;color:var(--bone);margin:0}.spell-modal-upcast{padding:var(--space-3) var(--space-4);margin:0 var(--space-3) var(--space-3);background:#9060d014;border:1px solid rgba(144,96,208,.2);border-radius:8px}.spell-modal-upcast h4{font-family:var(--font-display);font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--mystic);margin:0 0 var(--space-2)}.spell-modal-upcast p{font-size:.85rem;line-height:1.6;color:var(--silver);margin:0}.spell-modal-footer{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-top:1px solid rgba(138,154,170,.1);background:#00000026}.spell-classes{font-size:.75rem;color:var(--mist)}.spell-source{font-size:.7rem;font-style:italic;color:var(--stone)}@media(max-width:600px){.spell-modal{max-height:90vh}.spell-modal-name{font-size:1.5rem}.spell-modal-stats{grid-template-columns:1fr 1fr}.spell-modal-title-row{flex-direction:column;gap:var(--space-2)}.spell-modal-badges{align-self:flex-start}}.page-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center}.placeholder-sigil{font-size:4rem;color:var(--stone);margin-bottom:var(--space-3);animation:pulse-subtle 3s ease-in-out infinite}.page-placeholder h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--silver);margin:0 0 var(--space-2)}.page-placeholder p{font-size:.875rem;font-style:italic;color:var(--mist);margin:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-down{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in-scale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes slide-in-right{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes rotate-slow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse-subtle{0%,to{opacity:1}50%{opacity:.7}}@media(max-width:1200px){.hero{min-height:auto;align-items:center;justify-content:flex-end;padding:var(--space-6) var(--space-4);padding-bottom:var(--space-4)}.hero-image img{object-position:center 30%}.identity{text-align:center;max-width:100%}.campaign-whisper{justify-content:center}.calling:before,.calling:after{display:none}.constellation{position:relative;right:auto;bottom:auto;margin:var(--space-4) auto 0}}@media(max-width:1024px){.codex{grid-template-columns:1fr}.margin-left,.margin-right{border:none;border-bottom:1px solid rgba(138,154,170,.1);background:var(--shadow)}.margin-right{border-bottom:none;border-top:1px solid rgba(138,154,170,.1)}}@media(max-width:768px){.hero{padding:var(--space-5) var(--space-3);padding-bottom:var(--space-3)}.vitals{flex-wrap:wrap;padding:var(--space-3);gap:0}.vital{min-width:70px;padding:var(--space-2)}.constellation{width:100%;max-width:360px;height:auto;display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-2);background:#0a0e1299;border:1px solid rgba(212,168,85,.15);border-radius:12px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.constellation-lines,.constellation-center{display:none}.ability-node{position:relative;top:auto;left:auto;width:52px;height:60px;transform:none;opacity:1;animation:none}.node-ring{border-radius:8px}.node-mod{font-size:1.1rem}.node-score{font-size:.7rem}.node-name{font-size:.6rem}.attack-cards{grid-template-columns:1fr}.page-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;padding:var(--space-2);gap:0}.page-tab{padding:var(--space-2);min-width:56px}.tab-label{font-size:.6rem}}@media(max-width:480px){.hero{padding:var(--space-4) var(--space-2);padding-bottom:var(--space-2)}.name-first{font-size:3rem}.name-last{font-size:1.5rem;letter-spacing:.25em}.level-seal{margin-top:var(--space-3);padding:var(--space-1) var(--space-3)}.level-number{font-size:1.5rem}.constellation{max-width:320px;gap:var(--space-1);padding:var(--space-2)}.ability-node{width:48px;height:54px}.node-mod{font-size:1rem}.vitals{padding:var(--space-2)}.vital{min-width:60px;padding:var(--space-1) var(--space-2)}.vital-value{font-size:1.25rem}.vital-label{font-size:.65rem}.vital-hp{min-width:100px}.page-tabs{justify-content:flex-start}.page-tab{min-width:50px;padding:var(--space-1) var(--space-2)}.tab-icon{font-size:1rem}.tab-label{font-size:.55rem}}
