body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}body,html{background:#0d0602;font-family:sans-serif;height:100%;margin:0;padding:0}.App{box-sizing:border-box;display:flex;height:100vh;height:100dvh;overflow:hidden}.mobile-tab-bar{display:none}.left-panel{background:#160c06;border-right:3px solid #9b2515;color:#fff;width:33%}.left-panel,.right-panel{box-sizing:border-box;display:flex;flex-direction:column;overflow:hidden;padding:20px}.right-panel{background:#130c05;color:#f0e6c8;height:100%;width:67%}.chat-window{background:#1a0e06;border:1px solid #9b251533;border-radius:6px;box-sizing:border-box;display:flex;flex:1 1;flex-direction:column;margin-bottom:10px;overflow-y:auto;padding:10px}@keyframes combatPulse{0%,to{border-color:#9b251526;box-shadow:none}50%{border-color:#c8401cbf;box-shadow:0 0 0 2px #9b251533,inset 0 0 24px #9b251514}}.chat-window.combat-active{animation:combatPulse 1.8s ease-in-out infinite}.chat-window::-webkit-scrollbar{width:6px}.chat-window::-webkit-scrollbar-track{background:#0d0602;border-radius:3px}.chat-window::-webkit-scrollbar-thumb{background:#6b2218;border-radius:3px}.chat-window::-webkit-scrollbar-thumb:hover{background:#9b2515}@keyframes messageEnter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dice-message,.gm-message,.user-message{align-items:flex-start;animation:messageEnter .45s ease-out;border-radius:6px;display:flex;gap:10px;margin:8px 0;padding:8px}.user-message{background:#1e1208;border-left:3px solid #64321980;color:#c8b090}.gm-message{background:linear-gradient(90deg,#2a1806,#221408);background-image:url("data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 width=%27200%27 height=%27200%27%3E%3Cfilter id=%27n%27%3E%3CfeTurbulence type=%27fractalNoise%27 baseFrequency=%270.65%27 numOctaves=%273%27 stitchTiles=%27stitch%27/%3E%3CfeColorMatrix type=%27saturate%27 values=%270%27/%3E%3C/filter%3E%3Crect width=%27200%27 height=%27200%27 filter=%27url%28%23n%29%27 opacity=%270.07%27/%3E%3C/filter%3E%3C/svg%3E");border-left:4px solid #9b2515b3;color:#f5e6c8;font-family:Georgia,serif}.gm-message.gm-combat{background:linear-gradient(90deg,#2a0c08,#1e0a06);border-left:4px solid #b42814d9}.gm-message.gm-loot{background:linear-gradient(90deg,#261a04,#1e1404);border-left:4px solid #c8a028cc}.gm-message.gm-reputation{background:linear-gradient(90deg,#160a1e,#100614);border-left:4px solid #8c50c8bf}.gm-message.gm-system{background:linear-gradient(90deg,#0e1218,#0a0e14);border-left:4px solid #648cb4a6;color:#a0aab8;font-style:italic}.gm-em,.gm-message strong{color:#d4af37}.gm-em{font-style:italic}.gm-strong{color:#f0c870;font-style:normal;font-weight:700}.gm-lore-term{border-bottom:1px dotted #d4af3773;color:#d4af37;cursor:pointer;transition:color .15s ease,border-color .15s ease}.gm-lore-term:hover{border-bottom-color:#d4af37d9;color:#f0cc60}.npc-popup{animation:lorePopupIn .2s ease both;padding:28px 28px 22px}.npc-popup-portrait{margin:0 auto 14px}.npc-popup-body{margin:0 0 16px}.gm-npc-term{border-bottom:1px dotted #cd853f73;color:peru;cursor:pointer;transition:color .15s ease,border-color .15s ease}.gm-npc-term:hover{border-bottom-color:#cd853fd9;color:#e8a060}.gm-monster-term{color:#c0392b;font-weight:600}.lore-popup-backdrop{align-items:center;animation:fadeInBackdrop .15s ease;background:#0000008c;display:flex;inset:0;justify-content:center;position:fixed;z-index:1100}@keyframes fadeInBackdrop{0%{opacity:0}to{opacity:1}}.lore-popup{animation:lorePopupEnter .2s ease;background:linear-gradient(160deg,#0d1520,#080c10);border:1px solid #7dd3fc66;border-radius:6px;box-shadow:0 0 40px #7dd3fc1f,0 20px 60px #000000b3;max-width:380px;padding:20px 22px;position:relative;width:90vw}@keyframes lorePopupEnter{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.lore-popup-close{background:none;border:none;color:#7dd3fc;cursor:pointer;font-size:.9rem;opacity:.6;padding:2px 6px;position:absolute;right:12px;top:10px}.lore-popup-close:hover{background:none;opacity:1}.lore-popup-category{color:#7dd3fc;display:inline-block;font-size:.6rem;letter-spacing:.12em;margin-bottom:6px;opacity:.7;text-transform:uppercase}.lore-popup-title{color:#f0e6d2;font-family:Cinzel,serif;font-size:1rem;letter-spacing:.03em;margin:0 0 10px}.lore-popup-body{color:#b0a090;font-size:.78rem;line-height:1.6;margin:0 0 14px}.lore-popup-codex-btn{background:none;border:1px solid #7dd3fc4d;border-radius:3px;color:#7dd3fc;cursor:pointer;font-size:.72rem;letter-spacing:.05em;padding:5px 12px;transition:background .15s ease,border-color .15s ease}.lore-popup-codex-btn:hover{background:#7dd3fc14;border-color:#7dd3fc99}.dice-message{background:#3c140a99;border:1px solid #9b25154d;color:#f0e6c8}.gm-portrait,.user-portrait{border-radius:50%;display:block;flex-shrink:0;height:50px;object-fit:cover;width:50px}.portrait-image{border:2px solid #5a4636;height:160px;object-fit:cover;width:160px}.daily-limit-banner{align-items:center;animation:messageEnter .4s ease-out;background:#1e0f05b3;border:1px solid #d4af374d;border-radius:6px;display:flex;gap:10px;margin-bottom:8px;padding:10px 14px}.daily-limit-icon{flex-shrink:0;font-size:1.1rem}.daily-limit-text{color:#c8a878;flex:1 1;font-family:Georgia,serif;font-size:.85rem;font-style:italic;line-height:1.5}.daily-limit-upgrade-btn{background:linear-gradient(135deg,#3a2a08,#1e1504);border:1px solid #d4af3780;border-radius:4px;color:#d4af37;cursor:pointer;flex-shrink:0;font-family:Cinzel,serif;font-size:.7rem;letter-spacing:.06em;padding:6px 12px;transition:border-color .15s,background .15s;white-space:nowrap}.daily-limit-upgrade-btn:hover{background:linear-gradient(135deg,#4a3810,#2a1e06);border-color:#d4af37d9}.daily-limit-upgrade-fade{animation:limit-btn-fade .6s ease forwards}@keyframes limit-btn-fade{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.input-form{display:flex;flex-shrink:0;gap:10px;margin:0;padding:0}.tavern-action-btn{animation:cutPulse 2.2s ease-in-out infinite;background:#0000;border:1px solid #8250c88c;border-radius:4px;color:#a080d0;cursor:pointer;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.06em;padding:5px 16px;transition:border-color .15s,color .15s,box-shadow .15s}@keyframes cutPulse{0%,to{box-shadow:0 0 4px #a064f04d,0 0 0 #a064f000}50%{box-shadow:0 0 10px #a064f0b3,0 0 18px #a064f040}}.tavern-action-btn:hover{animation:none;border-color:#a080d0;box-shadow:0 0 14px #a064f0cc,0 0 24px #a064f04d;color:#c0a0f0}@keyframes inputPulse{0%,to{border-color:#d4af3759;box-shadow:0 0 6px #d4af3740,0 0 12px #d4af371a}50%{border-color:#d4af37b3;box-shadow:0 0 14px #d4af378c,0 0 28px #d4af3733}}.input-box{animation:inputPulse 2.4s ease-in-out infinite;background:#1a0e06;border:1px solid #d4af3759;border-radius:4px;color:#f0e6c8;flex:1 1;padding:10px;transition:border-color .2s ease,box-shadow .2s ease}.input-box:focus{animation:none;border-color:#d4af37;box-shadow:0 0 0 2px #d4af3733,0 0 20px #d4af3780,0 0 40px #d4af3726;outline:none}@keyframes inputCombatPulse{0%,to{border-color:#c8281480;box-shadow:0 0 6px #c8281466,0 0 14px #c8281426}50%{border-color:#dc3c1ee6;box-shadow:0 0 16px #c82814cc,0 0 32px #c828144d}}.input-box-combat{animation:inputCombatPulse 1.4s ease-in-out infinite!important;border-color:#c8281480!important}.input-box-combat:focus{animation:none!important;border-color:#c82818!important;box-shadow:0 0 0 2px #c8281440,0 0 20px #c8281499,0 0 40px #c8281433!important}.input-box::placeholder{color:#c8a06073}button{background:linear-gradient(180deg,#9b2515 0,#6a1a0e);border:1px solid #9b2515b3;border-radius:4px;color:#f5f0e8;cursor:pointer;font-family:Cinzel,serif;letter-spacing:.04em;padding:10px 14px;transition:background .15s ease,box-shadow .15s ease}button:hover{background:linear-gradient(180deg,#c8401c 0,#8a2510);box-shadow:0 0 10px #9b251559}#dice-box{background:#0000!important;height:100vh!important;inset:0!important;overflow:hidden!important;position:fixed!important;width:100vw!important;z-index:9999!important}#dice-box,#dice-canvas{pointer-events:none!important}#dice-canvas{display:block!important;height:100%!important;left:0!important;opacity:1;top:0!important;transition:opacity 1s ease;width:100%!important}#dice-box.fade-out{opacity:0}.character-panel{color:#f5e6c8;display:flex;flex:1 1;flex-direction:column;font-family:Georgia,serif;gap:6px;min-height:0;overflow:hidden;width:100%}.portrait-section{text-align:center}.build-date{font-size:.75rem;opacity:.7}.character-grid{grid-gap:12px;display:grid;grid-template-columns:1fr 1fr}.stat-box{background:#2a2320;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Cpath filter='url(%23a)' opacity='.11' d='M0 0h200v200H0z'/%3E%3C/svg%3E");border:2px solid #5a4636;border-radius:6px;box-sizing:border-box;padding:8px}.stat-box h3{border-bottom:1px solid #5a4636;color:#e8c88f;font-size:.78rem;letter-spacing:.05em;margin-bottom:6px;margin-top:0;padding-bottom:3px;text-transform:uppercase}.stat-box ul{font-size:.75rem;line-height:1.55;list-style:none;margin:0;padding-left:0}.full-width{grid-column:1/span 2}.reroll-button{background:#7a1f1f;border:none;border-radius:4px;color:#fff;cursor:pointer;margin-top:8px;padding:10px;width:100%}.reroll-button:hover{background:#a72828}.xp-popup{box-shadow:0 0 12px #c084fc80;color:#c084fc;top:20px}.gold-popup,.xp-popup{animation:toastSlideIn 7s ease forwards;background:#2b2b2b;border-radius:8px;font-weight:700;padding:12px 18px;position:fixed;right:20px;z-index:1000}.gold-popup{box-shadow:0 0 12px #ffd70080;color:gold;top:80px}@keyframes toastSlideIn{0%{opacity:0;transform:translateX(60px)}8%{opacity:1;transform:translateX(0)}82%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(30px)}}@keyframes fadeInOut{0%{opacity:0;transform:translateY(-10px)}10%{opacity:1;transform:translateY(0)}90%{opacity:1}to{opacity:0;transform:translateY(-10px)}}.codex-toast{align-items:center;animation:fadeInOut 3s ease;background:linear-gradient(135deg,#080c10,#0d1520);border:1px solid #7dd3fc73;border-radius:6px;box-shadow:0 0 18px #7dd3fc33,0 4px 20px #0009;display:flex;gap:12px;min-width:200px;padding:10px 16px;position:fixed;right:20px;top:20px;z-index:1000}.codex-toast-icon{flex-shrink:0;font-size:1.2rem}.codex-toast-text{display:flex;flex-direction:column;gap:2px}.codex-toast-label{color:#7dd3fc;font-size:.65rem;letter-spacing:.12em;opacity:.75;text-transform:uppercase}.codex-toast-title{color:#f0e6d2;font-family:Cinzel,serif;font-size:.82rem;letter-spacing:.03em}@keyframes cardDeal{0%{opacity:0;transform:translateY(10px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.action-cards-grid{display:flex;flex-direction:row;gap:8px;padding:8px 0 2px}.action-card{align-items:center;animation:cardDeal .3s ease-out both;background:linear-gradient(135deg,#1e0f04,#160a02);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='a'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.65' numOctaves='3' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Cpath filter='url(%23a)' opacity='.09' d='M0 0h200v200H0z'/%3E%3C/svg%3E");border:1px solid #6426108c;border-radius:4px;border-top:2px solid #9b2515a6;cursor:pointer;display:flex;flex:1 1;gap:10px;padding:10px 12px;text-align:left;transition:border-color .15s ease,box-shadow .15s ease,transform .1s ease}.action-card:nth-child(2){animation-delay:.05s}.action-card:nth-child(3){animation-delay:.1s}.action-card:nth-child(4){animation-delay:.15s}.action-card-heroes{border-color:#785a148c}.action-card-heroes:hover{border-color:#d4af37 #b48c28d9 #b48c28d9;box-shadow:0 4px 14px #b48c2838,0 1px 4px #0009}.action-card-heroes .action-card-label{color:#d4b860}.action-card:hover{border-color:#c8401c #9b2515d9 #9b2515d9;box-shadow:0 4px 14px #9b251538,0 1px 4px #0009;transform:translateY(-2px)}.action-card:active{box-shadow:inset 0 2px 6px #00000080;transform:translateY(0)}.action-card-icon{filter:drop-shadow(0 1px 3px rgba(0,0,0,.7));flex-shrink:0;font-size:1.55rem;line-height:1}.action-card-label{color:#d4b896;font-family:Cinzel,serif;font-size:.73rem;letter-spacing:.04em;line-height:1.4}.typing-indicator{font-style:italic;opacity:.9}.typing-dots{align-items:center;display:inline-flex;gap:4px;margin-left:8px;vertical-align:middle}.typing-dots .dot{animation:dot-blink 1.4s infinite;background:#d4af37;border-radius:50%;height:5px;opacity:0;width:5px}.typing-dots .dot:first-child{animation-delay:0s}.typing-dots .dot:nth-child(2){animation-delay:.22s}.typing-dots .dot:nth-child(3){animation-delay:.44s}@keyframes dot-blink{0%,60%,to{opacity:0;transform:translateY(0)}30%{opacity:1;transform:translateY(-2px)}}@keyframes enterValdrisGlow{0%,to{box-shadow:inset 0 1px 0 #ffffff26,0 3px 6px #0009,0 0 8px #d4af3726}50%{box-shadow:inset 0 1px 0 #fff3,0 3px 14px #00000080,0 0 22px #d4af378c,0 0 44px #d4af372e}}.fantasy-button-enter{animation:enterValdrisGlow 2.4s ease-in-out infinite;border-color:#d4af37;color:#ffe9a0;font-size:1.25rem;letter-spacing:.08em;padding:16px 36px}.fantasy-button-enter:hover{animation:none;border-color:#f0cc60;box-shadow:inset 0 1px 0 #ffffff40,0 4px 18px #000000b3,0 0 28px #d4af37b3;color:#fff5cc}.fantasy-button{background:linear-gradient(180deg,#5b4636 0,#3e2f23);border:2px solid #a68a64;border-radius:6px;box-shadow:inset 0 1px 0 #ffffff26,0 3px 6px #0009;color:#f5f1e6;cursor:pointer;font-family:Cinzel,Georgia,serif;font-size:.95rem;letter-spacing:.04em;margin:6px 0;padding:10px 16px;transition:all .15s ease-in-out}.fantasy-button:hover{background:linear-gradient(180deg,#6a523f 0,#4a3729);box-shadow:inset 0 1px 0 #fff3,0 4px 10px #000c}.fantasy-button:active{box-shadow:inset 0 2px 4px #0009;transform:translateY(2px)}.fantasy-button:disabled{cursor:not-allowed;opacity:.5}@keyframes founderShimmer{0%{background-position:-180%,0 0}60%,to{background-position:260%,0 0}}@keyframes founderBorderPulse{0%,to{box-shadow:inset 0 1px 0 #d4af371f,0 4px 16px #000000bf,0 0 10px #d4af371f}50%{box-shadow:inset 0 1px 0 #d4af3733,0 4px 16px #000000bf,0 0 22px #d4af374d,0 0 44px #d4af3714}}.fantasy-button-secondary{animation:founderShimmer 4s ease-in-out infinite,founderBorderPulse 3.5s ease-in-out infinite;background-image:linear-gradient(108deg,#0000 38%,#d4af372e 50%,#0000 62%),linear-gradient(160deg,#1e1608,#0d0a04 55%,#1e1608);background-position:-180%,0 0;background-size:280% 100%,100% 100%;border:1px solid #d4af37a6;border-radius:6px;color:#d4af37;cursor:pointer;font-family:Cinzel,Georgia,serif;font-size:1.1rem;letter-spacing:.08em;margin:6px 0;padding:16px 36px;transition:color .2s ease,border-color .2s ease}.fantasy-button-secondary:hover{animation:none;background-image:linear-gradient(160deg,#2a1e08,#160f04 55%,#2a1e08);background-size:100% 100%;border-color:#d4af37;box-shadow:inset 0 1px 0 #d4af3733,0 4px 18px #000c,0 0 24px #d4af3759;color:#ffe9a0;transform:translateY(-1px)}.dice-button{background:linear-gradient(180deg,#7a1e1e 0,#4f1212);border-color:#d4af37;color:#fff6d6;text-shadow:0 0 6px #ffd77899}.dice-button:hover{box-shadow:0 0 12px #ffd778cc,0 4px 10px #000c}.reply-button{background:linear-gradient(180deg,#1f4f2f 0,#143420);border-color:#7fbf9a}.auth-button{background:linear-gradient(180deg,#2c2c2c 0,#1a1a1a);border-color:#888;font-size:.85rem}.dice-fallback{align-items:center;display:flex;flex-direction:column;gap:8px}.dice-fallback-icon{font-size:3rem;line-height:1;transition:transform .2s}.dice-fallback-icon.rolling{animation:diceSpin .18s linear infinite}@keyframes diceSpin{0%{transform:rotate(0deg) scale(1)}25%{transform:rotate(90deg) scale(1.15)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.15)}to{transform:rotate(1turn) scale(1)}}.dm-typing{align-items:center;display:flex;gap:10px;opacity:.9}.dm-typing .gm-portrait{animation:dm-glow 1.6s ease-in-out infinite}.dm-typing .typing-indicator{font-style:italic;letter-spacing:.04em}@keyframes dm-glow{0%{filter:drop-shadow(0 0 4px rgba(255,215,120,.3));opacity:.8}50%{filter:drop-shadow(0 0 10px rgba(255,215,120,.8));opacity:1}to{filter:drop-shadow(0 0 4px rgba(255,215,120,.3));opacity:.8}}.modal-backdrop{align-items:center;background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}.modal-panel{background:#1e1a14;border:2px solid #a68a64;border-radius:8px;max-height:90vh;max-width:900px;overflow-y:auto;padding:24px;width:90%}@keyframes levelUpOverlayFlash{0%{background:radial-gradient(ellipse at center,#ffd70080 0,#000000e0 65%);opacity:0}6%{background:radial-gradient(ellipse at center,#ffd700e6 0,#000000e0 55%);opacity:1}18%{background:radial-gradient(ellipse at center,#ffd7001a 0,#000000e0 70%)}82%{background:radial-gradient(ellipse at center,#0000 0,#000000e0 70%);opacity:1}to{opacity:0}}.level-up-overlay{align-items:center;animation:levelUpOverlayFlash 6s ease-in-out forwards;display:flex;inset:0;justify-content:center;pointer-events:none;position:fixed;z-index:2000}@keyframes levelUpParticle{0%{opacity:1;transform:translate(0) scale(1)}60%{opacity:.6}to{opacity:0;transform:translate(var(--tx),var(--ty)) scale(0)}}.level-up-particles{inset:0;pointer-events:none;position:absolute}.level-up-particle{animation:levelUpParticle 1.4s cubic-bezier(.2,.8,.4,1) forwards;border-radius:50%;left:50%;position:absolute;top:50%}@keyframes levelUpCard{0%{opacity:0;transform:scale(.7) translateY(30px)}10%{opacity:1;transform:scale(1.06) translateY(0)}17%{transform:scale(1)}82%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.94) translateY(-10px)}}.level-up-popup{animation:levelUpCard 6s ease-in-out forwards;background:radial-gradient(ellipse at 50% 0,#5a2e0a 0,#1e0a02 55%),linear-gradient(180deg,#2a1006,#0d0502);border:2px solid #ffd700d9;border-radius:16px;box-shadow:0 0 40px #ffd70080,0 0 100px #ffd70033,inset 0 0 50px #ffd7000a;max-width:460px;padding:40px 52px;pointer-events:auto;position:relative;text-align:center;width:90%}@keyframes levelUpNumber{0%{filter:brightness(4);opacity:0;transform:scale(.5)}12%{filter:brightness(1.6);opacity:1;transform:scale(1.12)}22%{filter:brightness(1);transform:scale(1)}82%{opacity:1}to{opacity:0}}.level-up-number{animation:levelUpNumber 6s ease-in-out forwards;color:gold;font-family:Cinzel,serif;font-size:4.8rem;font-weight:900;letter-spacing:6px;line-height:1;margin:10px 0 6px;text-shadow:0 0 24px #ffd700e6,0 0 60px #ffd70066,2px 3px 6px #000000e6}.level-up-ascended{color:#c8a84a;font-family:Cinzel,serif;font-size:.65rem;letter-spacing:5px;margin:2px 0;opacity:.85}.level-up-deco{color:#ffd70080;font-size:.75rem;letter-spacing:2px;margin-bottom:10px}.level-up-divider{background:linear-gradient(90deg,#0000,#ffd70080,#0000);height:1px;margin:16px 0}@keyframes rewardAppear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.level-up-rewards{list-style:none;margin:0 0 20px;padding:0}.level-up-rewards li{animation:rewardAppear .55s ease-out forwards;color:#ffe9a3;font-family:Georgia,serif;font-size:.92rem;margin:7px 0;opacity:0}.level-up-continue{animation:rewardAppear .5s ease-out forwards;animation-delay:1.6s;opacity:0}.location-image-container{margin-bottom:16px;width:100%}.location-image{border-radius:10px;box-shadow:0 12px 35px #000000a6;display:block;height:auto;width:100%}.location-caption{color:#d6c08d;font-size:.85rem;margin-top:6px;opacity:.85;padding-left:4px}.location-image{animation:fadeIn .8s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.right-panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:4px}.right-panel-header h2{font-size:1.1rem;margin:0;text-shadow:0 0 14px #d4af3759}.right-panel-header h2,.shop-open-btn{color:#d4af37;font-family:Cinzel,serif;letter-spacing:.06em}.shop-open-btn{background:#d4af371a;border:1px solid #d4af3759;border-radius:2px;cursor:pointer;flex-shrink:0;font-size:.75rem;padding:5px 12px;transition:background .15s,border-color .15s}.shop-open-btn:hover{background:#d4af3733;border-color:#d4af37}.quest-badge{align-items:center;background:#f3c26b;border-radius:50%;color:#0d1b2a;display:inline-flex;font-family:system-ui,sans-serif;font-size:.6rem;font-weight:700;height:14px;justify-content:center;margin-left:4px;vertical-align:middle;width:14px}.right-panel-btns{display:flex;flex-shrink:0;gap:6px}@keyframes locationCardFade{0%{opacity:0}18%{opacity:1}72%{opacity:1}to{opacity:0}}@keyframes locationNameReveal{0%{opacity:0;transform:scale(.9)}28%{opacity:1;transform:scale(1)}72%{opacity:1}to{opacity:0}}@keyframes locationRuneFade{0%,10%{opacity:0}32%{opacity:1}72%{opacity:1}to{opacity:0}}.location-title-card{align-items:center;animation:locationCardFade 3.2s ease-in-out forwards;display:flex;inset:0;justify-content:center;pointer-events:none;position:fixed;z-index:1500}.location-title-card-bg{background-image:var(--loc-img);background-position:50%;background-size:cover;filter:blur(5px) brightness(.25);inset:-8px;position:absolute}.location-title-card-content{padding:0 32px;position:relative;text-align:center}.location-title-name{animation:locationNameReveal 3.2s ease-in-out forwards;color:#f0e8d0;font-family:Cinzel,serif;font-size:3.6rem;font-weight:700;letter-spacing:5px;margin:10px 0;text-shadow:0 0 28px #d4af3773,2px 3px 8px #000000f2}.location-title-type{color:#d4af37;font-family:Cinzel,serif;font-size:.68rem;letter-spacing:6px;margin:0 0 4px;text-transform:uppercase}.location-title-rune,.location-title-type{animation:locationRuneFade 3.2s ease-in-out forwards}.location-title-rune{color:#d4af3773;font-size:.72rem;letter-spacing:2px}@media (max-width:600px){.location-title-name{font-size:2.4rem;letter-spacing:3px}}@media (max-width:768px){.App{flex-direction:column}.left-panel{border-bottom:1px solid #333;border-right:none;display:none;flex:1 1;overflow-y:auto;width:100%!important}.left-panel.mobile-visible{display:flex}.right-panel{flex:1 1;padding:12px;width:100%!important}.right-panel.mobile-hidden{display:none}.character-panel{overflow-y:auto}.right-panel-btns{flex-wrap:wrap;gap:4px}.shop-open-btn{font-size:.68rem;padding:4px 8px}.right-panel-header h2{display:none}.mobile-tab-bar{background:#0d0602;border-top:1px solid #9b251559;display:flex;flex-shrink:0;height:54px}.mobile-tab{align-items:center;background:#0000;border:none;color:#666;cursor:pointer;display:flex;flex:1 1;font-family:Cinzel,serif;font-size:.75rem;gap:6px;justify-content:center;letter-spacing:.06em;transition:color .15s,background .15s}.mobile-tab.active{background:#d4af3712;border-top:2px solid #d4af37;color:#d4af37}.mobile-tab:hover:not(.active){background:#ffffff0a;color:#999}}.tier-badge{align-items:center;border-radius:50%;display:flex;font-size:.65rem;height:20px;justify-content:center;left:4px;line-height:1;pointer-events:none;position:absolute;top:4px;width:20px;z-index:2}.tier-badge-premium{background:#140e02d9;border:1px solid #d4af37b3;box-shadow:0 0 6px #d4af3766;color:#d4af37}.tier-badge-legend{background:#0f0819d9;border:1px solid #a855f7b3;box-shadow:0 0 6px #a855f766;color:#c084fc}.dungeon-hud{display:flex;justify-content:center;padding:6px 0 2px}.action-card-dungeon{background:linear-gradient(160deg,#1a0804,#120502)!important;border-color:#9b251599!important}.action-card-dungeon:hover{background:linear-gradient(160deg,#2a1008,#1c0806)!important;border-color:#c83c1ed9!important}.action-card-dungeon-exit{background:linear-gradient(160deg,#121008,#0c0a06)!important;border-color:#64502880!important;color:#9b8060!important}.action-card-dungeon-exit:hover{border-color:#8c6e3ccc!important}.inventory{display:flex;flex-direction:column;width:100%}.inv-header{align-items:center;display:flex;gap:8px;justify-content:space-between;margin-bottom:8px}.inv-filters{display:flex;flex-wrap:wrap;gap:4px}.inv-filter-btn{background:#ffffff0d;border:1px solid #444;border-radius:4px;color:#999;cursor:pointer;font-size:.78rem;padding:3px 8px;transition:background .12s,color .12s,border-color .12s}.inv-filter-btn:hover{background:#ffffff1a;color:#ddd}.inv-filter-btn[data-tooltip]{position:relative}.inv-filter-btn[data-tooltip]:after{background:#140c05f5;border:1px solid #c2a56d80;border-radius:4px;bottom:calc(100% + 6px);color:#f0e6d2;content:attr(data-tooltip);font-family:Cinzel,serif;font-size:.72rem;left:50%;letter-spacing:.5px;opacity:0;padding:4px 9px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s ease;white-space:nowrap;z-index:100}.inv-filter-btn[data-tooltip]:hover:after{opacity:1}.inv-filter-btn.active{background:#d4af372e;border-color:#d4af37;color:#d4af37}.inv-gold{color:#d4af37;cursor:default;font-size:.82rem;font-weight:600;position:relative;white-space:nowrap}.inv-gold[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;bottom:calc(100% + 6px);color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.7rem;left:auto;line-height:1.5;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;right:0;transition:opacity .15s ease;white-space:normal;width:210px;z-index:200}.inv-gold[data-tooltip]:hover:after{opacity:1}.inv-list{display:flex;flex:1 1;flex-direction:column;gap:3px;min-height:0;overflow-y:auto}.inv-empty{color:#666;font-size:.82rem;font-style:italic;padding:8px 0;text-align:center}.inv-item-wrapper{border:1px solid #0000;border-radius:5px;overflow:hidden;transition:border-color .15s}.inv-item-wrapper:has(.inv-row.equipped){border-color:#d4af3740}.inv-row{align-items:center;background:#ffffff0a;cursor:pointer;display:flex;gap:7px;padding:5px 8px;transition:background .12s;-webkit-user-select:none;user-select:none}.inv-row.open,.inv-row:hover{background:#ffffff17}.inv-row.equipped{background:#d4af3714}.inv-type-icon{flex-shrink:0;font-size:.9rem;text-align:center;width:18px}.inv-name{flex:1 1;font-size:.83rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rarity-common{color:#c8bfa8}.rarity-uncommon{color:#52c47f}.rarity-rare{color:#4d9de0}.rarity-legendary{color:#e8a838}.inv-row-right{align-items:center;display:flex;flex-shrink:0;gap:5px}.inv-badge{border-radius:3px;font-size:.65rem;font-weight:700;letter-spacing:.5px;padding:1px 5px}.equipped-badge{background:#d4af3740;border:1px solid #d4af3766;color:#d4af37}.inv-qty{color:#888;font-size:.75rem}.inv-chevron{color:#666;font-size:.55rem}.inv-detail{background:#0000004d;border-top:1px solid #ffffff0f;padding:8px 10px 10px}.inv-detail-meta{align-items:center;display:flex;flex-wrap:wrap;gap:6px;margin-bottom:6px}.inv-rarity-tag{font-size:.7rem;font-weight:600;letter-spacing:.4px;text-transform:uppercase}.inv-detail-type{color:#888;font-size:.72rem}.inv-stat{background:#ffffff12;border-radius:3px;color:#bbb;font-size:.75rem;padding:2px 6px}.inv-description{color:#a89878;font-size:.78rem;font-style:italic;line-height:1.4;margin:0 0 8px}.inv-actions{display:flex;gap:6px}.inv-action-btn{background:#ffffff12;border:1px solid #555;border-radius:3px;color:#ccc;cursor:pointer;font-size:.75rem;padding:4px 12px;transition:background .12s,color .12s}.inv-action-btn:hover{background:#ffffff24;color:#fff}.inv-action-btn.use{border-color:#7a2f2f;color:#e08080}.inv-action-btn.use:hover{background:#7a2f2f40;color:#f5aaaa}.inv-action-btn.drop{border-color:#555;color:#888;margin-left:auto}.inv-action-btn.drop:hover{background:#7a2f2f26;border-color:#7a2f2f;color:#e08080}.character-creation-container{min-height:100vh}.left-section,.right-section{background-color:#111010;flex:1 1}.middle-section{align-items:center;background-color:initial;display:flex;flex-direction:column;max-width:900px;padding:20px}.creation-title{text-align:center}.character-form{padding-bottom:8px;width:100%}.character-portrait{align-items:center;display:flex;flex-direction:column;margin:20px 0}.portrait-navigation{align-items:center;display:flex;gap:8px;margin-top:8px}.portrait-upload-btn{background:#00000080;border:1px solid #6b4c1e;border-radius:4px;color:#c8a96e;cursor:pointer;font-size:.75rem;letter-spacing:.04em;margin-top:6px;padding:4px 12px;transition:background .15s,color .15s,opacity .2s}.portrait-upload-btn:hover{background:#6b4c1e59;color:#ffe4a0}.portrait-overlay-wrap .portrait-upload-btn{bottom:6px;left:50%;margin-top:0;opacity:0;pointer-events:none;position:absolute;transform:translateX(-50%)}.portrait-overlay-wrap:hover .portrait-upload-btn{opacity:1;pointer-events:auto}.portrait-nav-btn{font-size:1.2rem;line-height:1;min-width:36px;padding:6px 14px}.gender-toggle{display:flex;gap:4px}.gender-btn{background:#00000073;border:1px solid #555;border-radius:4px;color:#aaa;cursor:pointer;font-size:1.2rem;height:36px;transition:background .15s,color .15s,border-color .15s;width:36px}.gender-btn:hover{background:#ffffff14;border-color:#888;color:#f0e6d2}.gender-btn.active{background:#d4af3733;border-color:#d4af37;color:#d4af37}.portrait-image{height:auto;margin-bottom:10px;max-width:240px;width:100%}.character-creation-container{background:radial-gradient(circle at top,#1c1c1c,#0e0e0e);color:#f0e6d2;display:flex;justify-content:center;padding:40px}.middle-section{max-width:500px;text-align:center;width:100%}.creation-title{font-family:Cinzel,serif;letter-spacing:1px;margin-bottom:20px}.character-form{margin-top:20px}.name-label{display:block;font-size:.9rem;margin-bottom:5px;opacity:.8}.name-input-row{display:flex;gap:8px;margin-bottom:20px}.name-input{background:#111;border:1px solid #444;color:#f0e6d2;flex:1 1;padding:10px}.name-input::placeholder{color:#666;font-style:italic}.name-input.name-error{animation:nameShake .35s ease;border-color:#c94040;box-shadow:0 0 0 2px #c9404059}@keyframes nameShake{0%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}to{transform:translateX(0)}}.name-random-button{background:#222;border:1px solid #555;color:#ccc;cursor:pointer;font-family:Cinzel,serif;font-size:.85rem;letter-spacing:.5px;padding:10px 12px;white-space:nowrap}.name-random-button:hover{background:#333;border-color:#888;color:#f0e6d2}.backstory-section{margin-top:0}.backstory-row{align-items:flex-start;display:flex;gap:6px}.backstory-input{background:#111;border:1px solid #444;color:#f0e6d2;flex:1 1;font-family:Georgia,serif;font-size:.82rem;line-height:1.5;padding:8px 10px;resize:vertical}.backstory-input::placeholder{color:#555;font-style:italic}.backstory-generate-btn{background:#222;border:1px solid #555;border-radius:4px;color:#ccc;cursor:pointer;flex-shrink:0;font-size:1.1rem;padding:8px 10px;transition:background .12s,border-color .12s}.backstory-generate-btn:hover{background:#333;border-color:#d4af37}.creation-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:minmax(0,1fr) minmax(0,1fr);margin-top:20px}.ability-scores,.character-meta{background:#0000004d;border:1px solid #333;padding:12px}.ability-scores ul{list-style:none;margin:10px 0 20px;padding:0}.ability-scores li{display:flex;justify-content:space-between;padding:4px 0}.themed-button{border:none;cursor:pointer;font-family:Cinzel,serif;letter-spacing:1px;margin-top:10px;padding:12px;width:100%}.themed-button.primary{background:linear-gradient(145deg,#7a2f2f,#4a1414);color:#f0e6d2}.themed-button.secondary{background:#222;color:#bbb}.themed-button:hover{filter:brightness(1.1)}.stat-list{list-style:none;padding:0}.stat-row{grid-gap:10px;align-items:center;display:grid;gap:10px;grid-template-columns:1fr 40px auto;padding:6px 0}.stat-name{text-align:left}.stat-value{font-weight:700;text-align:center}.stat-value.stat-flash{animation:statFlash .4s ease}@keyframes statFlash{0%{color:#f0e6d2;transform:scale(1)}35%{color:#d4af37;transform:scale(1.35)}to{color:#f0e6d2;transform:scale(1)}}.stat-roll-button{background:none;border:1px solid #555;color:#ccc;cursor:pointer;padding:4px 8px}.stat-roll-button:hover{background:#222}.stat-roll-button:disabled{cursor:not-allowed;opacity:.4}.character-meta{background:#0000004d;border:1px solid #333;margin:20px 0;padding:10px}.character-meta label{display:block;font-size:.85rem;margin-top:10px;opacity:.8}.character-meta select{background:#111;border:1px solid #444;color:#f0e6d2;padding:6px;width:100%}.meta-readonly{color:#ddd;font-size:.85rem;margin-top:10px}.meta-list{list-style:none;margin:0;padding:0}.meta-list li{color:#ddd;display:flex;font-size:.9rem;justify-content:space-between;padding:4px 0}.character-creation-root{position:relative}.character-close-button{background:#0000;border:none;color:#d4af37;cursor:pointer;font-size:1.4rem;font-weight:700;opacity:.85;position:absolute;right:12px;top:12px}.character-close-button:hover{opacity:1;text-shadow:0 0 6px #ffd778cc}.creation-actions{display:flex;gap:12px;justify-content:space-between;margin-top:16px}.creation-actions button{flex:1 1}@keyframes statGlow{0%{box-shadow:0 0 0 #ffd70000}30%{box-shadow:0 0 14px #ffd700cc}to{box-shadow:0 0 0 #ffd70000}}.stat-highlight{animation:statGlow 1.6s ease-out;border-radius:4px}.character-panel{border-left:5px solid #9b2515;border-right:5px solid #9b2515;padding-left:4px;padding-right:4px}.sb-rule{background:linear-gradient(90deg,#3a0a04 0,#9b2515 15%,#c8401c 45%,#c8401c 55%,#9b2515 85%,#3a0a04);border:none;border-radius:3px;flex-shrink:0;height:7px;margin:0}.character-name{border-bottom:none;color:#f5e8c8;flex-shrink:0;font-family:Cinzel,serif;font-size:1.3rem;letter-spacing:1.5px;margin:0;padding-bottom:2px;text-align:center;text-shadow:0 1px 4px #000c,0 0 20px #c8401c26}.portrait-scores-row{align-items:stretch;display:flex;flex-shrink:0;gap:8px}.portrait-col{flex:0 0 42%;width:42%}.portrait-col .portrait-image{aspect-ratio:1/1;border-radius:6px;cursor:pointer;height:auto;margin-bottom:0;object-fit:cover;transition:box-shadow .25s ease;width:100%}.portrait-col:hover .portrait-image{box-shadow:0 0 0 3px #d4af3799,0 0 20px #d4af374d}.portrait-overlay-wrap{position:relative}.portrait-overlay-controls{align-items:center;display:flex;inset:0;justify-content:space-between;opacity:0;padding:4px;pointer-events:none;position:absolute;transition:opacity .2s ease}.portrait-overlay-wrap:hover .portrait-overlay-controls{opacity:1;pointer-events:auto}.portrait-overlay-btn{align-items:center;align-self:center;background:#00000080;border:1px solid #d4af374d;border-radius:3px;color:#d4af37;cursor:pointer;display:flex;font-size:1.3rem;height:38px;justify-content:center;line-height:1;padding:0;transition:background .15s,border-color .15s;width:24px}.portrait-overlay-btn:hover{background:#000000bf;border-color:#d4af37}.portrait-overlay-gender{bottom:36px;display:flex;gap:4px;left:50%;position:absolute;transform:translateX(-50%)}.portrait-overlay-gender-btn{align-items:center;background:#00000080;border:1px solid #d4af3740;border-radius:3px;color:#a08040;cursor:pointer;display:flex;font-size:.75rem;height:20px;justify-content:center;padding:0;transition:background .15s,border-color .15s,color .15s;width:22px}.portrait-overlay-gender-btn.active,.portrait-overlay-gender-btn:hover{background:#000000bf;border-color:#d4af37;color:#d4af37}.portrait-col[data-tooltip]{cursor:default;position:relative}.portrait-col[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.7rem;left:calc(100% + 10px);line-height:1.5;opacity:0;padding:8px 11px;pointer-events:none;position:absolute;top:0;transition:opacity .15s ease;white-space:normal;width:200px;z-index:200}.portrait-col[data-tooltip]:hover:after{opacity:1}.identity-col{display:flex;flex:1 1;flex-direction:column;gap:5px;justify-content:center;min-width:0;padding:4px 2px}.identity-subtitle{color:#c8a880;font-size:.82rem;font-style:italic;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.identity-align{color:#9a8a6a;font-size:.72rem;font-style:italic}.identity-badges{display:flex;flex-wrap:wrap;gap:3px}.ib-badge{align-items:center;background:#1e0f08b3;border:1px solid #7a30204d;border-radius:3px;cursor:default;display:flex;flex:1 1;flex-direction:column;min-width:0;padding:5px 4px 4px;position:relative}.ib-label{color:#9b2020;font-size:.58rem;letter-spacing:.06em}.ib-label,.ib-val{font-family:Cinzel,serif;font-weight:700;line-height:1}.ib-val{color:#f0e6c8;font-size:1.4rem}.ib-badge[data-tooltip]{position:relative}.ib-badge[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;bottom:calc(100% + 5px);color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.68rem;left:50%;line-height:1.45;opacity:0;padding:5px 8px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s ease;white-space:normal;width:150px;z-index:200}.ib-badge[data-tooltip]:hover:after{opacity:1}.stat-box li[data-tooltip]{cursor:default;position:relative}.stat-box li[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;bottom:calc(100% + 6px);color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.7rem;left:50%;line-height:1.45;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s ease;white-space:normal;width:200px;z-index:200}.stat-box li[data-tooltip]:hover:after{opacity:1}.sb-ability-grid{grid-gap:3px;background:#120c06;border:1px solid #7a3020;border-radius:4px;box-sizing:border-box;display:grid;gap:3px;grid-template-columns:repeat(3,1fr);padding:4px;width:100%}.sb-ability-box{align-items:center;background:#1e0f08b3;border:1px solid #7a30204d;border-radius:3px;cursor:default;display:flex;flex-direction:column;gap:2px;padding:8px 2px 6px;position:relative}.sb-ability-box.stat-highlight{animation:statGlow 1.6s ease-out}.sb-ability-abbr{color:#9b2020;font-size:.58rem;letter-spacing:.06em;text-transform:uppercase}.sb-ability-abbr,.sb-ability-score{font-family:Cinzel,serif;font-weight:700;line-height:1}.sb-ability-score{color:#f0e6c8;font-size:1.4rem}.sb-ability-box.stat-highlight .sb-ability-score{color:gold}.sb-ability-mod{background:#7a302033;border:1px solid #7a302066;border-radius:2px;color:#c8a060;font-size:.72rem;font-weight:600;line-height:1.5;min-width:26px;padding:0 4px;text-align:center}.sb-ability-box[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.68rem;left:50%;line-height:1.45;opacity:0;padding:5px 8px;pointer-events:none;position:absolute;top:calc(100% + 6px);transform:translateX(-50%);transition:opacity .15s ease;white-space:normal;width:160px;z-index:200}.sb-ability-box[data-tooltip]:hover:after{opacity:1}.attrs-combat-row{grid-gap:6px;display:grid;flex-shrink:0;gap:6px;grid-template-columns:1fr 1fr}.panel-scroll-area{display:flex;flex:1 1;flex-direction:column;gap:6px;min-height:0;overflow-y:auto;padding-right:2px}.panel-scroll-area::-webkit-scrollbar{width:4px}.panel-scroll-area::-webkit-scrollbar-track{background:#0000}.panel-scroll-area::-webkit-scrollbar-thumb{background:#d4af3733;border-radius:2px}.panel-scroll-area::-webkit-scrollbar-thumb:hover{background:#d4af3766}.col-section-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:0;-webkit-user-select:none;user-select:none}.col-chevron{color:#7a6a50;flex-shrink:0;font-size:.65rem;transition:transform .22s ease}.col-chevron.collapsed{transform:rotate(-90deg)}.col-body{display:grid;grid-template-rows:1fr;transition:grid-template-rows .22s ease}.col-body.col-body-hidden{grid-template-rows:0fr}.col-inner{overflow:hidden;padding-top:6px}.col-section .col-section-header,.col-section:not(.col-body-hidden) .col-section-header{margin-bottom:0}.inventory-section{flex-shrink:0}.inventory-section .inventory{display:flex;flex-direction:column}.xp-bar-wrap{margin-top:8px}.xp-bar-labels{color:#888;display:flex;font-size:.68rem;justify-content:space-between;margin-bottom:4px}.xp-bar-track{background:#00000073;border:1px solid #ffffff0f;border-radius:3px;height:6px;overflow:hidden}.xp-bar-fill{background:#c084fc;border-radius:3px;box-shadow:0 0 6px #c084fc66;height:100%;transition:width .6s ease}.hp-bar-wrap{margin-top:10px}.hp-bar-labels{color:#aaa;display:flex;font-size:.72rem;justify-content:space-between;margin-bottom:4px}.hp-bar-track{background:#00000073;border:1px solid #ffffff0f;border-radius:3px;height:6px;overflow:hidden}.hp-bar-fill{border-radius:3px;height:100%;transition:width .6s ease,background .6s ease}.faction-rep-box{margin-top:6px}.faction-rep-row{grid-gap:8px;align-items:center;border-bottom:1px solid #5a28102e;display:grid;gap:8px;grid-template-columns:96px 1fr 68px;padding:5px 0}.faction-rep-row:last-child{border-bottom:none}.faction-rep-label{color:#c8b890;font-family:Cinzel,serif;font-size:.64rem;letter-spacing:.04em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.faction-rep-bar-track{background:#140802b3;border:1px solid #5a281066;border-radius:2px;height:8px;overflow:hidden;position:relative}.faction-rep-bar{border-radius:2px;box-shadow:0 0 6px currentColor;height:100%;opacity:.85;position:absolute;top:0;transition:width .6s ease,margin-left .6s ease}.faction-rep-tier{font-family:Cinzel,serif;font-size:.6rem;letter-spacing:.04em;text-align:right}.faction-rep-row[data-tooltip]{cursor:default;position:relative}.faction-rep-row[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;bottom:calc(100% + 6px);color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.7rem;left:50%;line-height:1.5;opacity:0;padding:6px 10px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s ease;white-space:normal;width:220px;z-index:200}.faction-rep-row[data-tooltip]:hover:after{opacity:1}.prof-bonus-tag{color:#7a6a50;font-family:Georgia,serif;font-size:.65rem;font-weight:400;letter-spacing:0;margin-left:6px}.skills-grid{grid-column-gap:8px;grid-row-gap:0;column-gap:8px;display:grid;grid-template-columns:1fr 1fr;row-gap:0}.skill-row{align-items:center;border-radius:2px;cursor:default;display:flex;font-size:.68rem;gap:4px;padding:2px 3px}.skill-row[data-tooltip]{position:relative}.skill-row[data-tooltip]:after{background:#0e0904f7;border:1px solid #c2a56d73;border-radius:4px;bottom:calc(100% + 5px);color:#f0e6d2;content:attr(data-tooltip);font-family:Georgia,serif;font-size:.68rem;left:50%;line-height:1.45;opacity:0;padding:5px 8px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .15s ease;white-space:normal;width:160px;z-index:200}.skill-row[data-tooltip]:hover:after{opacity:1}.skill-dot{color:#3a2c1e;flex-shrink:0;font-size:.5rem;line-height:1}.skill-row.proficient .skill-dot{color:#d4af37}.skill-name{color:#7a6a50;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.skill-row.proficient .skill-name{color:#c8b89a}.skill-val{color:#8a7a60;font-size:.72rem;font-weight:700;min-width:20px;text-align:right}.skill-row.proficient .skill-val{color:#e8d8a0}.party-slots{display:flex;flex-direction:column;gap:8px}.party-slot{background:#c084fc12;border:1px solid #c084fc33;border-radius:8px;cursor:pointer;gap:10px;padding:7px 10px;transition:background .15s,border-color .15s}.party-slot:hover{background:#c084fc24;border-color:#c084fc66}.party-slot-empty{cursor:default;opacity:.3;pointer-events:none}.party-slot-portrait{border:1px solid #c084fc4d;border-radius:6px;flex-shrink:0;height:38px;overflow:hidden;width:38px}.party-slot-portrait img{height:100%;object-fit:cover;width:100%}.party-slot-placeholder,.party-slot-portrait-empty{align-items:center;background:#c084fc1a;color:#c084fc99;display:flex;font-family:Cinzel,serif;font-size:1rem;height:100%;justify-content:center;width:100%}.party-slot-info{display:flex;flex-direction:column;gap:2px;min-width:0}.party-slot-name{color:#e5e7eb;font-size:.82rem;font-weight:600}.party-slot-class{color:#9ca3af;font-size:.72rem;font-weight:400}.party-slot-abilities{color:#a0aec0;font-size:.67rem}.party-slot-abilities,.party-slot-skills{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-slot-skills{color:#7a8fa6;font-size:.64rem}.character-panel .stat-box{background:#0000!important;background-image:none!important;border:none!important;border-radius:0;padding:0}.character-panel .col-section-header,.character-panel .stat-box h3{border-bottom:1px solid #c8401c80!important;border-top:1px solid #c8401c80!important;color:#c8401c!important;font-family:Cinzel,serif!important;font-size:.75rem!important;letter-spacing:.1em;margin-bottom:6px!important;margin-top:4px!important;padding:4px 0!important;text-transform:uppercase}.character-panel .stat-box ul{font-family:Georgia,serif;font-size:.76rem;line-height:1.75;list-style:none!important;margin:0!important;padding:0!important}.character-panel .stat-box ul li strong{color:#c8a060;font-style:italic;font-weight:700;margin-right:2px}.character-panel .stat-box ul li{color:#f0e6c8;padding:0 2px}.attrs-combat-row{gap:0 10px!important}.character-panel .skill-dot{color:#5a463280;font-size:.6rem}.character-panel .skill-row.proficient .skill-dot{color:#c8401c;text-shadow:0 0 4px #c8401c80}.character-panel .skill-name{color:#8a7a60;font-family:Georgia,serif;font-size:.7rem}.character-panel .skill-row.proficient .skill-name{color:#d4c090}.character-panel .skill-val{color:#8a7a60}.character-panel .skill-row.proficient .skill-val{color:#f0e6c8;font-weight:700}.character-panel .prof-bonus-tag{color:#c8401c;font-size:.62rem}.character-panel .faction-rep-box h3{color:#c8401c!important}.character-panel .faction-rep-label{color:#c8b890}.character-panel .faction-rep-tier{font-size:.65rem}.character-panel .party-slots{width:100%}.character-panel .party-slot{align-items:flex-start;background:#96281414;border:1px solid #9628144d;box-sizing:border-box;display:flex;flex-direction:row;width:100%}.character-panel .party-slot-info{flex:1 1;min-width:0;overflow:hidden}.character-panel .party-slot:hover{background:#96281429;border-color:#c8401c80}.character-panel .party-slot-portrait{border-color:#c8401c59;flex-shrink:0}.character-panel .party-slot-placeholder,.character-panel .party-slot-portrait-empty{background:#9628141a;color:#c8401c99}.character-panel .col-chevron{color:#9b2515}.character-panel .inventory-section h3{color:#c8401c!important}.panel-scroll-area::-webkit-scrollbar-thumb{background:#c8401c40!important}.panel-scroll-area::-webkit-scrollbar-thumb:hover{background:#c8401c73!important}@keyframes defeatBleed{0%{background:radial-gradient(ellipse at center,#6e0000bf 0,#0000 55%);opacity:0}18%{background:radial-gradient(ellipse at center,#46000066 0,#000000f2 65%);opacity:1}to{background:radial-gradient(ellipse at center,#14000026 0,#000000ed 70%);opacity:1}}.defeat-overlay{align-items:center;animation:defeatBleed 2.2s ease-out forwards;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}@keyframes ashFall{0%{opacity:0;transform:translateY(0) translateX(0)}8%{opacity:.75}to{opacity:0;transform:translateY(var(--fall-dist)) translateX(var(--drift))}}.defeat-particles{inset:0;overflow:hidden;pointer-events:none;position:absolute}.defeat-particle{animation:ashFall 3s ease-in forwards;border-radius:50%;left:var(--start-x);position:absolute;top:-4px}@keyframes defeatPanelRise{0%{opacity:0;transform:translateY(44px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.defeat-panel{animation:defeatPanelRise 1s ease-out .6s both;background:radial-gradient(ellipse at 50% 0,#2a0606 0,#0d0202 60%),linear-gradient(180deg,#180404,#080101);border:1px solid #a01e1e73;border-radius:4px;box-shadow:0 0 60px #8c000040,0 0 120px #6400001a,0 0 0 4px #000000b3,inset 0 0 60px #6400000a;max-width:480px;padding:44px 40px 40px;position:relative;text-align:center;width:90vw}@keyframes skullAppear{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes skullGlow{0%,to{text-shadow:0 0 18px #a0000080}50%{text-shadow:0 0 40px #b40000e6,0 0 80px #78000066}}.defeat-skull-wrap{align-items:center;animation:skullAppear .8s ease-out 1.2s both;display:flex;flex-direction:column;gap:6px;margin-bottom:24px}.defeat-skull{animation:skullGlow 3.5s ease-in-out 2s infinite;color:#8b0000;display:block;font-size:3.2rem}.defeat-skull-rune{color:#a01e1e73;font-size:.7rem;letter-spacing:2px}@keyframes defeatFadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.defeat-tombstone{margin-bottom:22px}.defeat-here-fell{animation:defeatFadeUp .7s ease-out 1.8s both;color:#8b0000;font-size:.65rem;letter-spacing:5px}.defeat-here-fell,.defeat-name{font-family:Cinzel,serif;margin:0 0 8px}.defeat-name{animation:defeatFadeUp .8s ease-out 2s both;color:#e8d8b8;font-size:2.2rem;font-weight:700;letter-spacing:2px;text-shadow:1px 2px 6px #000000e6}.defeat-meta{animation:defeatFadeUp .7s ease-out 2.2s both;color:#6a5a4a;font-size:.75rem;letter-spacing:.1em;margin:0;text-transform:uppercase}.defeat-epitaph{animation:defeatFadeUp .7s ease-out 2.5s both;background:#6400000f;border-left:2px solid #8c000059;border-radius:0 2px 2px 0;color:#9a8878;font-family:Georgia,serif;font-size:.88rem;font-style:italic;line-height:1.7;margin:0 0 28px;padding:12px 16px;text-align:left}.defeat-stats{grid-gap:14px 20px;animation:defeatFadeUp .7s ease-out 2.9s both;border-bottom:1px solid #8c000033;border-top:1px solid #8c000033;display:grid;gap:14px 20px;grid-template-columns:repeat(3,1fr);margin-bottom:32px;padding:18px 0}.defeat-stat{display:flex;flex-direction:column;gap:4px}.defeat-stat-label{color:#4a3a3a;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase}.defeat-stat-value{color:#c8a0a0;font-family:Cinzel,serif;font-size:1.15rem}.defeat-actions{animation:defeatFadeUp .7s ease-out 3.3s both;display:flex;flex-direction:column;gap:10px}.defeat-btn{border-radius:2px;cursor:pointer;font-family:Cinzel,serif;font-size:.8rem;letter-spacing:.1em;padding:12px;transition:filter .15s,box-shadow .15s;width:100%}.defeat-btn:hover{box-shadow:0 0 12px #8c00004d;filter:brightness(1.2)}.defeat-btn-primary{background:linear-gradient(145deg,#5a1a1a,#2a0808);border:1px solid #a0282880;color:#e8d0d0}.defeat-btn-secondary{background:#0000;border:1px solid #ffffff1a;color:#5a4a4a}@keyframes chronicleFadeIn{0%{opacity:0}to{opacity:1}}.chronicle-overlay{align-items:center;animation:chronicleFadeIn .6s ease forwards;background:#000000e0;display:flex;inset:0;justify-content:center;position:fixed;z-index:2000}@keyframes chroniclePanelRise{0%{opacity:0;transform:translateY(32px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.chronicle-panel{animation:chroniclePanelRise .7s ease .2s both;background:radial-gradient(ellipse at 50% 0,#2a1e08 0,#0d0a04 60%),linear-gradient(180deg,#1a1206,#080602);border:1px solid #d4af3766;border-radius:4px;box-shadow:0 0 50px #d4af371f,0 0 120px #d4af370f,0 0 0 4px #0009;max-width:460px;padding:44px 40px 36px;text-align:center;width:90vw}@keyframes chronicleItemFade{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.chronicle-deco{animation:chronicleItemFade .5s ease .4s both;color:#d4af3759;font-size:.72rem;letter-spacing:2px;margin:8px 0}.chronicle-subtitle{animation:chronicleItemFade .5s ease .45s both;color:#9a8050;font-family:Cinzel,serif;font-size:.62rem;letter-spacing:5px;margin:0 0 10px}.chronicle-location{animation:chronicleItemFade .6s ease .5s both;color:#f0e8d0;font-family:Cinzel,serif;font-size:2rem;font-weight:700;letter-spacing:2px;margin:0 0 6px;text-shadow:1px 2px 8px #000000e6}.chronicle-meta{animation:chronicleItemFade .5s ease .55s both;color:#5a4a30;font-size:.75rem;letter-spacing:.08em;margin:0 0 10px;text-transform:uppercase}.chronicle-stats{grid-gap:12px 16px;animation:chronicleItemFade .5s ease .7s both;border-bottom:1px solid #d4af3726;border-top:1px solid #d4af3726;display:grid;gap:12px 16px;grid-template-columns:repeat(3,1fr);margin:20px 0;padding:18px 0}.chronicle-stat{display:flex;flex-direction:column;gap:5px}.chronicle-stat-value{color:#d4af37;font-family:Cinzel,serif;font-size:1.3rem}.chronicle-stat-label{color:#4a3a20;font-size:.62rem;letter-spacing:.12em;text-transform:uppercase}.chronicle-levelup{animation:chronicleItemFade .5s ease .85s both;margin:4px 0 16px}.chronicle-levelup-text{color:#c084fc;font-family:Cinzel,serif;font-size:.82rem;letter-spacing:2px;text-shadow:0 0 12px #c084fc66}.chronicle-character{animation:chronicleItemFade .5s ease .9s both;display:flex;flex-direction:column;gap:5px;margin:16px 0 24px}.chronicle-char-name{color:#c8b890;font-family:Cinzel,serif;font-size:1.1rem;letter-spacing:1px}.chronicle-char-meta{color:#4a3a20;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase}.chronicle-btn{animation:chronicleItemFade .5s ease 1s both;background:linear-gradient(145deg,#3a2a0a,#1e1504);border:1px solid #d4af3766;border-radius:2px;color:#d4af37;cursor:pointer;font-family:Cinzel,serif;font-size:.8rem;letter-spacing:.1em;padding:12px 32px;transition:filter .15s,box-shadow .15s}.chronicle-btn:hover{box-shadow:0 0 16px #d4af3733;filter:brightness(1.2)}.shop-overlay{align-items:center;animation:shopFadeIn .18s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:900}@keyframes shopFadeIn{0%{opacity:0}to{opacity:1}}.shop-panel{animation:shopSlideUp .32s ease;background:linear-gradient(160deg,#0d1117,#080c10);border:1px solid #d4af374d;border-radius:4px;box-shadow:0 0 0 4px #00000080,0 32px 100px #000000b3;display:flex;flex-direction:column;max-height:88vh;overflow:hidden;width:min(780px,96vw)}@keyframes shopSlideUp{0%{opacity:0;transform:translateX(120px)}to{opacity:1;transform:translateX(0)}}.shop-header{border-bottom:1px solid #d4af3733;flex-shrink:0;padding:16px 20px 12px;position:relative}.shop-title-row{align-items:baseline;display:flex;gap:16px}.shop-title{color:#d4af37;font-size:1.1rem;letter-spacing:.06em}.shop-gold,.shop-title{font-family:Cinzel,serif}.shop-gold{color:#f0e6d2;font-size:1rem}.shop-close{background:none;border:none;color:#666;cursor:pointer;font-size:1rem;padding:4px 6px;position:absolute;right:16px;top:14px;transition:color .15s}.shop-close:hover{color:#d4af37}.shop-tabs{border-bottom:1px solid #ffffff12;display:flex;flex-shrink:0}.shop-tab{background:none;border:none;border-bottom:2px solid #0000;color:#666;cursor:pointer;flex:1 1;font-family:Cinzel,serif;font-size:.8rem;letter-spacing:.08em;padding:10px;transition:color .15s,border-bottom .15s}.shop-tab.active{border-bottom-color:#d4af37;color:#d4af37}.shop-tab:hover:not(.active){color:#aaa}.shop-filters{display:flex;flex-shrink:0;flex-wrap:wrap;gap:6px;padding:10px 16px}.shop-filter{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:20px;color:#888;cursor:pointer;font-size:.75rem;padding:4px 12px;transition:background .12s,color .12s,border-color .12s}.shop-filter.active,.shop-filter:hover{background:#d4af371f;border-color:#d4af3766;color:#d4af37}.shop-grid{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));min-height:0;overflow-y:auto;padding:12px 16px 16px}.shop-card{background:#ffffff0a;border:1px solid #ffffff14;border-radius:4px;display:flex;flex-direction:column;gap:6px;padding:12px;transition:border-color .15s}.shop-card:hover{border-color:#d4af3740}.shop-card-unaffordable{opacity:.5}.shop-card-header{align-items:flex-start;display:flex;gap:6px;justify-content:space-between}.shop-card-name{color:#f0e6d2;font-size:.85rem;font-weight:600;line-height:1.3}.shop-card-tier{flex-shrink:0;font-size:.65rem;letter-spacing:.1em;margin-top:2px;text-transform:uppercase}.shop-card-desc{color:#888;flex:1 1;font-size:.75rem;line-height:1.45;margin:0}.shop-card-stats{color:#7dd3fc;font-size:.75rem;margin:0}.shop-card-footer{align-items:center;display:flex;justify-content:space-between;margin-top:4px}.shop-card-price{color:#d4af37;font-family:Cinzel,serif;font-size:.82rem}.shop-btn{border-radius:2px;cursor:pointer;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.06em;padding:5px 14px;transition:filter .12s}.shop-btn:hover:not(:disabled){filter:brightness(1.15)}.shop-btn-buy{background:linear-gradient(145deg,#2a5a2a,#1a3a1a);border:1px solid #4caf5066;color:#a8d5a8}.shop-btn-sell{background:linear-gradient(145deg,#5a3a1a,#3a2010);border:1px solid #d4af3766;color:#d4af37}.shop-btn-disabled{background:#ffffff0d;border:1px solid #ffffff14;color:#444;cursor:not-allowed}.shop-feedback{animation:shopFadeIn .15s ease;border-radius:3px;flex-shrink:0;font-size:.8rem;margin:0 16px;padding:8px 12px}.shop-feedback-success{background:#4caf5026;border:1px solid #4caf504d;color:#a8d5a8}.shop-feedback-error{background:#c0392b26;border:1px solid #c0392b4d;color:#e88}.shop-empty{font-size:.85rem;font-style:italic;padding:32px 16px}.shop-anon-note,.shop-empty{color:#555;text-align:center}.shop-anon-note{border-top:1px solid #ffffff0d;flex-shrink:0;font-size:.72rem;margin:0;padding:8px 16px}.shop-card-classes{color:#7c6ea0;font-size:.68rem;line-height:1.4;margin:0}.shop-card-expand{background:none;border:none;color:#555;cursor:pointer;font-size:.65rem;padding:2px 0;text-align:left;transition:color .12s}.shop-card-expand:hover{color:#aaa}.shop-card-extra{border-top:1px solid #ffffff0f;display:flex;flex-direction:column;gap:4px;padding-top:6px}.shop-card-effect{color:#7dd3fc;font-size:.72rem;line-height:1.4;margin:0}.shop-card-lore{color:#665040;font-size:.7rem;font-style:italic;line-height:1.45;margin:0}.journal-overlay{align-items:center;animation:journalFadeIn .18s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000b8;display:flex;inset:0;justify-content:center;position:fixed;z-index:900}@keyframes journalFadeIn{0%{opacity:0}to{opacity:1}}.journal-panel{animation:journalSlideUp .32s ease;background:linear-gradient(160deg,#0f0a06,#08060300),linear-gradient(160deg,#100a04,#0a0604);border:1px solid #b4823c59;border-radius:3px;box-shadow:0 0 0 4px #00000080,0 32px 100px #000000b3;display:flex;flex-direction:column;max-height:88vh;overflow:hidden;width:min(820px,96vw)}@keyframes journalSlideUp{0%{opacity:0;transform:translateX(120px)}to{opacity:1;transform:translateX(0)}}.journal-header{align-items:center;border-bottom:1px solid #b4823c33;display:flex;flex-shrink:0;justify-content:space-between;padding:14px 18px}.journal-title{color:#c8a84a;font-family:Cinzel,serif;font-size:1rem;letter-spacing:.06em}.journal-share-toggle{align-items:center;color:#c8a84ab3;cursor:pointer;display:flex;font-family:Crimson Text,serif;font-size:.8rem;gap:7px;-webkit-user-select:none;user-select:none}.journal-share-toggle input[type=checkbox]{accent-color:#c8a84a;cursor:pointer;height:14px;width:14px}.journal-close{background:none;border:none;color:#666;cursor:pointer;font-size:1rem;padding:4px 6px;transition:color .15s}.journal-close:hover{color:#c8a84a}.journal-body{display:flex;flex:1 1;min-height:0;overflow:hidden}.journal-list{border-right:1px solid #b4823c26;flex-shrink:0;overflow-y:auto;padding:8px 0;width:220px}.journal-entry-btn{background:none;border:none;border-left:3px solid #0000;cursor:pointer;display:flex;flex-direction:column;gap:2px;padding:10px 14px;text-align:left;transition:background .12s,border-color .12s;width:100%}.journal-entry-btn:hover{background:#c8a84a0f}.journal-entry-btn.active{background:#c8a84a1a;border-left-color:#c8a84a}.jeb-location{color:#c8a84a;font-size:.65rem;letter-spacing:.1em;opacity:.7;text-transform:uppercase}.jeb-title{color:#e8dcc8;font-family:Georgia,serif;font-size:.8rem;line-height:1.3}.jeb-date{color:#555;font-size:.65rem;margin-top:2px}.journal-detail{display:flex;flex:1 1;flex-direction:column;overflow-y:auto;padding:0}.journal-img{display:block;flex-shrink:0;max-height:180px;object-fit:cover;object-position:center;width:100%}.journal-detail-location{color:#c8a84a;font-size:.68rem;letter-spacing:.14em;margin:16px 20px 4px;opacity:.7;text-transform:uppercase}.journal-detail-title{color:#f0e6d2;font-family:Cinzel,serif;font-size:1.1rem;font-weight:400;line-height:1.3;margin:0 20px 4px}.journal-detail-date{color:#555;font-size:.72rem;margin:0 20px 16px}.journal-detail-body{color:#c8bfb0;font-family:Georgia,Times New Roman,serif;font-size:.92rem;font-style:italic;line-height:1.8;margin:0 20px 24px}.journal-empty{color:#555;font-family:Georgia,serif;font-size:.85rem;font-style:italic;padding:40px 24px;text-align:center}@media (max-width:560px){.journal-list{width:160px}.journal-img{max-height:120px}}.codex-overlay{align-items:center;animation:codexFadeIn .18s ease;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#000000bf;display:flex;inset:0;justify-content:center;position:fixed;z-index:900}@keyframes codexFadeIn{0%{opacity:0}to{opacity:1}}.codex-panel{animation:codexSlideUp .32s ease;background:linear-gradient(160deg,#080c10,#060809);border:1px solid #7dd3fc38;border-radius:3px;box-shadow:0 0 0 4px #00000080,0 32px 100px #000000b3;display:flex;flex-direction:column;max-height:88vh;overflow:hidden;width:min(920px,96vw)}@keyframes codexSlideUp{0%{opacity:0;transform:translateX(120px)}to{opacity:1;transform:translateX(0)}}.codex-header{align-items:center;border-bottom:1px solid #7dd3fc1f;display:flex;flex-shrink:0;gap:12px;padding:14px 18px}.codex-title{color:#7dd3fc;font-family:Cinzel,serif;font-size:1rem;letter-spacing:.06em}.codex-progress{color:#444;font-size:.72rem;letter-spacing:.06em;margin-left:auto}.codex-close{background:none;border:none;color:#555;cursor:pointer;font-size:1rem;padding:4px 6px;transition:color .15s}.codex-close:hover{color:#7dd3fc}.codex-tabs{border-bottom:1px solid #ffffff0f;display:flex;flex-shrink:0}.codex-tab{background:none;border:none;border-bottom:2px solid #0000;color:#555;cursor:pointer;flex:1 1;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.08em;padding:9px 6px;transition:color .15s,border-color .15s}.codex-tab.active{border-bottom-color:#7dd3fc;color:#7dd3fc}.codex-tab:hover:not(.active){color:#888}.codex-body{display:flex;flex:1 1;min-height:0;overflow:hidden}.codex-grid{grid-gap:12px;align-content:start;display:grid;flex:1 1;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));overflow-y:auto;padding:16px;transition:flex .2s ease}.codex-grid.codex-grid-narrow{flex:0 0 320px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.codex-tile{background:none;border:1px solid #ffffff12;border-radius:4px;cursor:pointer;display:flex;flex-direction:column;overflow:hidden;padding:0;text-align:center;transition:border-color .15s,transform .12s}.codex-tile:hover{border-color:#7dd3fc66;transform:translateY(-2px)}.codex-tile.active{border-color:#7dd3fc;box-shadow:0 0 0 1px #7dd3fc}.codex-tile.locked{cursor:pointer}.codex-tile-img-wrap{aspect-ratio:16/9;overflow:hidden;position:relative;width:100%}.codex-tile-img{display:block;height:100%;object-fit:cover;object-position:center;transition:filter .2s;width:100%}.codex-tile.locked .codex-tile-img{filter:grayscale(1) brightness(.3)}.codex-tile-fallback{background:linear-gradient(135deg,#1a1a2e,#0d0d1a)}.codex-tile-lock{align-items:center;display:flex;font-size:1.4rem;inset:0;justify-content:center;opacity:.5;position:absolute}.codex-tile-label{background:#0006;color:#c8bfb0;display:block;font-family:Georgia,serif;font-size:.72rem;line-height:1.3;padding:6px 6px 8px}.codex-tile.locked .codex-tile-label{color:#3a3a3a;font-style:italic}.codex-detail{animation:detailSlideIn .18s ease;border-left:1px solid #7dd3fc1f;display:flex;flex:1 1;flex-direction:column;min-width:0;overflow-y:auto;position:relative}@keyframes detailSlideIn{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}.codex-detail-close{background:none;border:none;color:#444;cursor:pointer;font-size:.9rem;padding:4px 6px;position:absolute;right:10px;top:10px;transition:color .15s;z-index:1}.codex-detail-close:hover{color:#7dd3fc}.codex-detail-img{aspect-ratio:16/7;display:block;flex-shrink:0;object-fit:cover;object-position:center;width:100%}.codex-detail-img-locked{filter:grayscale(1) brightness(.25)}.codex-detail-content{padding:16px 18px 24px}.codex-detail-category{color:#7dd3fc;display:block;font-size:.65rem;letter-spacing:.16em;margin-bottom:6px;opacity:.7;text-transform:uppercase}.codex-detail-title{border-bottom:1px solid #7dd3fc1f;color:#f0e6d2;font-family:Cinzel,serif;font-size:1rem;font-weight:400;line-height:1.3;margin:0 0 14px;padding-bottom:10px;padding-right:24px}.codex-detail-title-locked{color:#444}.codex-detail-body p{color:#a8a098;font-family:Georgia,serif;font-size:.82rem;line-height:1.78;margin:0 0 14px}.codex-locked-detail{display:flex;flex-direction:column}.codex-locked-icon{display:block;font-size:1.6rem;margin-bottom:10px;margin-top:4px;opacity:.25}.codex-locked-hint{color:#444;font-family:Georgia,serif;font-size:.82rem;font-style:italic;line-height:1.6;margin:0}@media (max-width:640px){.codex-grid.codex-grid-narrow{flex:1 1}.codex-detail{display:none}}.hero-popup-backdrop{align-items:center;background:#000000b8;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1200}.hero-popup{background:#0f1a2a;border:1px solid #d4af3759;border-radius:12px;box-shadow:0 8px 40px #0009;max-height:90vh;max-width:480px;overflow-y:auto;padding:0;position:relative;width:100%}.hero-popup-drag-bar{align-items:center;background:#00000059;border-bottom:1px solid #d4af371a;border-radius:12px 12px 0 0;cursor:grab;display:flex;justify-content:space-between;padding:8px 14px;position:-webkit-sticky;position:sticky;top:0;-webkit-user-select:none;user-select:none;z-index:2}.hero-popup-drag-bar:active{cursor:grabbing}.hero-drag-grip{color:#d4af3738;font-size:1rem;letter-spacing:3px;pointer-events:none}.hero-popup-close{background:none;border:none;color:#888;cursor:pointer;font-size:1rem;line-height:1;padding:2px 4px}.hero-popup-close:hover{color:#ccc}.hero-popup-abilities,.hero-popup-actions,.hero-popup-description,.hero-popup-header,.hero-popup-role,.hero-popup-skills{margin-left:24px;margin-right:24px}.hero-popup-header{margin-top:18px}.hero-popup-actions{margin-bottom:24px}.hero-popup-header{align-items:flex-start;display:flex;gap:16px;margin-bottom:18px}.hero-popup-portrait{border:1px solid #d4af374d;border-radius:10px;cursor:pointer;display:block;flex-shrink:0;height:288px;overflow:hidden;position:relative;text-decoration:none;transition:border-color .15s;width:288px}.hero-popup-portrait:hover{border-color:#d4af37b3}.hero-popup-portrait img{display:block;height:100%;object-fit:cover;width:100%}.hero-popup-portrait-overlay{align-items:center;background:#0000008c;color:#d4af37;display:flex;font-size:.78rem;inset:0;justify-content:center;letter-spacing:1px;opacity:0;position:absolute;transition:opacity .18s}.hero-popup-portrait:hover .hero-popup-portrait-overlay{opacity:1}.hero-popup-portrait-placeholder{align-items:center;background:#d4af371a;color:#d4af3799;display:flex;font-family:Cinzel,serif;font-size:3rem;height:100%;justify-content:center;width:100%}.hero-popup-title{display:flex;flex-direction:column;gap:3px}.hero-popup-name{color:#f3c26b;font-family:Cinzel,serif;font-size:1.15rem;margin:0}.hero-popup-class{color:#c084fc;font-size:.82rem;font-weight:600}.hero-popup-race{color:#9ca3af;font-size:.78rem}.hero-popup-tavern{color:#6b7280;font-size:.75rem;margin-top:2px}.hero-popup-abilities{grid-gap:6px;background:#0000004d;border:1px solid #b48c3c26;border-radius:8px;display:grid;gap:6px;grid-template-columns:repeat(6,1fr);margin-bottom:14px;padding:10px;text-align:center}.hero-ability-cell{display:flex;flex-direction:column;gap:1px}.ha-label{color:#6b7280;font-size:.6rem;letter-spacing:.05em;text-transform:uppercase}.ha-score{color:#e5e7eb;font-size:.95rem;font-weight:700}.ha-mod{color:#9ca3af;font-size:.7rem}.hero-popup-skills{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.hero-skill-pill{background:#c084fc1f;border:1px solid #c084fc4d;border-radius:20px;color:#c084fc;font-size:.72rem;padding:2px 8px}.hero-popup-description{color:#d1d5db;font-size:.83rem;line-height:1.55;margin:0 0 10px}.hero-popup-role{color:#9ca3af;font-size:.78rem;line-height:1.5;margin:0 0 18px}.hero-popup-role em{color:#f3c26b;font-style:normal}.hero-popup-actions{align-items:flex-start;display:flex;flex-direction:column;gap:8px}.hero-btn{border:1px solid;border-radius:6px;cursor:pointer;font-family:Cinzel,serif;font-size:.82rem;letter-spacing:.05em;padding:9px 20px;transition:all .15s}.hero-btn-recruit{background:#d4af371a;border-color:#d4af3780;color:#f3c26b}.hero-btn-recruit:hover:not(:disabled){background:#d4af3733;border-color:#f3c26b}.hero-btn-recruit:disabled{cursor:not-allowed;opacity:.45}.hero-btn-dismiss{background:#ef444414;border-color:#ef444459;color:#f87171}.hero-btn-dismiss:hover:not(:disabled){background:#ef444426}.hero-popup-hint{color:#6b7280;font-size:.73rem;margin:0}.gm-hero-term{border-bottom:1px dotted #c084fc80;color:#c084fc;cursor:pointer;transition:color .12s}.gm-hero-term:hover{color:#e0aaff}.party-hud{align-items:center;background:linear-gradient(180deg,#1a1208,#110e06);border-bottom:1px solid #2a1e08;border-top:1px solid #4a3a1a;display:flex;gap:6px;justify-content:center;padding:8px 40px 8px 10px;position:relative;transition:padding .2s}.party-hud-collapsed{padding:6px 40px 6px 10px}.party-hud-label{color:#5a4520;font-family:Cinzel,serif;font-size:.65rem;letter-spacing:.12em;text-transform:uppercase}.party-hud-collapse-btn{align-items:center;background:none;border:1px solid #3a2c10;border-radius:3px;color:#6a5020;cursor:pointer;display:flex;font-size:.6rem;height:22px;justify-content:center;line-height:1;padding:0;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:border-color .15s,color .15s;width:22px}.party-hud-collapse-btn:hover{border-color:#c9a227;color:#c9a227}.party-slot{align-items:center;background:#0e0b05;border:1px solid #3a2c10;border-radius:4px;display:flex;flex-direction:column;flex-shrink:0;gap:4px;padding:6px 4px;transition:border-color .15s,background .15s;width:132px}.party-slot-filled{border-color:#5a4520;cursor:pointer}.party-slot-filled:hover{background:#1a1408;border-color:#c9a227}.party-slot-empty{border-color:#2a2010;border-style:dashed;opacity:.45}.party-portrait-wrap{border:1px solid #6a5020;border-radius:3px;flex-shrink:0;height:120px;overflow:hidden;position:relative;width:120px}.party-portrait{display:block;height:100%;object-fit:cover;width:100%}.party-portrait-fallback{align-items:center;background:linear-gradient(135deg,#2a1e08,#1a1208);color:#c9a227;font-family:Cinzel,serif;font-size:2rem;font-weight:700;height:100%;justify-content:center;width:100%}.party-hp-bar-track{background:#ffffff0f;border-radius:3px;height:5px;margin-top:3px;overflow:hidden;width:100%}.party-hp-bar-fill{border-radius:3px;height:100%;transition:width .3s ease,background .3s ease}.party-info{align-items:center;display:flex;justify-content:center;margin-top:2px;min-width:0;width:100%}.party-name-class{font-size:.62rem;font-weight:600;letter-spacing:.01em;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-empty-inner{color:#3a2c10;font-size:2rem;font-weight:300;height:120px;width:120px}.cut-overlay,.party-empty-inner{align-items:center;display:flex;justify-content:center}.cut-overlay{background:#000000db;inset:0;position:fixed;z-index:2000}.cut-modal{background:#111118;border:1px solid #4a3010;border-radius:12px;max-width:440px;padding:36px 48px;position:relative;text-align:center;z-index:1}.cut-modal--win{animation:cutWinGlow 1.8s ease-in-out infinite;border-color:#c8a84b;box-shadow:0 0 32px #c8a84b73,0 0 80px #c8a84b26;z-index:2002}@keyframes cutWinGlow{0%,to{box-shadow:0 0 24px #c8a84b59,0 0 60px #c8a84b1a}50%{box-shadow:0 0 48px #c8a84ba6,0 0 100px #c8a84b40}}.cut-gold-reward{animation:cutGoldPop .55s cubic-bezier(.34,1.56,.64,1) both;color:gold;font-size:2.6rem;font-weight:700;letter-spacing:3px;margin:0 0 18px;text-shadow:0 0 18px #ffd700d9,0 0 40px #ffa50073}@keyframes cutGoldPop{0%{opacity:0;transform:scale(.2)}to{opacity:1;transform:scale(1)}}.cut-title{color:#c8a84b;font-size:2rem;letter-spacing:4px;margin:0 0 16px;text-transform:uppercase}.cut-intro{color:#aaa;font-size:.9rem;line-height:1.6;margin:0 0 28px}.cut-menu-btns{align-items:center;display:flex;flex-direction:column;gap:10px}.cut-btn-primary{background:#1e1408;border:1px solid #8b6914;border-radius:8px;color:#c8a84b;cursor:pointer;font-family:inherit;font-size:.95rem;letter-spacing:1px;padding:11px 32px;transition:background .15s}.cut-btn-primary:hover{background:#2e2010}.cut-btn-secondary{background:none;border:1px solid #333;border-radius:8px;color:#666;cursor:pointer;font-family:inherit;font-size:.85rem;padding:8px 24px;transition:border-color .15s,color .15s}.cut-btn-secondary:hover{border-color:#555;color:#999}.cut-board{background:#0b0b14;border:1px solid #2a1e10;border-radius:12px;display:flex;flex-direction:column;font-family:inherit;height:min(860px,96vh);overflow:hidden;position:relative;width:min(920px,98vw);z-index:1}.cut-header{align-items:center;background:#13101e;border-bottom:1px solid #2a1e10;display:flex;flex-shrink:0;gap:12px;min-height:36px;padding:6px 14px}.cut-header-title{color:#c8a84b;font-size:.9rem;font-weight:700;letter-spacing:3px;text-transform:uppercase}.cut-targeting-msg{align-items:center;color:#70b0d0;display:flex;font-size:.78rem;font-style:italic;gap:8px}.cut-cancel-btn{background:#2a1010;border:1px solid #703030;border-radius:4px;color:#e08080;cursor:pointer;font-family:inherit;font-size:.72rem;padding:2px 10px}.cut-cancel-btn:hover{background:#3a1818}.cut-status{animation:pulse 1s infinite alternate;color:#c8a84b;font-size:.75rem;font-style:italic}@keyframes pulse{0%{opacity:.5}to{opacity:1}}.cut-close{background:none;border:none;border-radius:4px;color:#555;cursor:pointer;font-size:1rem;padding:2px 6px;transition:color .15s}.cut-close:hover{color:#ccc}.cut-close--board{margin-left:auto}.cut-player-strip{display:flex;flex-direction:column;flex-shrink:0;gap:4px;padding:6px 12px}.cut-opponent-strip{background:#5014142e;border-bottom:1px solid #1e1010}.cut-player-strip--you{background:#1414502e;border-top:1px solid #10101e}.cut-player-info{align-items:center;color:#bbb;display:flex;font-size:.82rem;gap:16px}.cut-player-info strong{color:#e0e0e0}.cut-deck-label,.cut-hp-label,.cut-res-label{color:#888;font-size:.75rem}.cut-hp{color:#e06060}.cut-hp,.cut-res{font-size:.9rem;font-weight:700}.cut-res{color:#6090e0}.cut-end-turn{background:#1c1408;border:1px solid #7a5810;border-radius:6px;color:#c8a84b;cursor:pointer;font-family:inherit;font-size:.78rem;letter-spacing:.5px;margin-left:auto;padding:4px 18px;transition:background .15s}.cut-end-turn:hover:not(:disabled){background:#2c2010}.cut-end-turn:disabled{cursor:not-allowed;opacity:.35}.cut-hand{display:flex;gap:6px;justify-content:center;overflow-x:auto;padding:2px 0 4px;scrollbar-color:#333 #0000;scrollbar-width:thin}.cut-battlefield{display:flex;flex:1 1;flex-direction:column;min-height:0}.cut-field{align-items:center;display:flex;flex:1 1;gap:8px;justify-content:center;min-height:0;padding:6px 12px;position:relative;z-index:10}.cut-field--opponent{align-items:flex-end}.cut-field--player{align-items:flex-start}.cut-field-empty{color:#333;font-size:.7rem;font-style:italic;letter-spacing:1px}.cut-face-zone{align-items:center;border-bottom:1px solid #141420;border-top:1px solid #141420;color:#2a2a3a;cursor:default;display:flex;flex-shrink:0;font-size:.65rem;height:26px;justify-content:center;letter-spacing:3px;transition:background .2s,color .2s}.cut-face-zone--active{background:#c8a84b1a;border-color:#4a3a10;color:#c8a84b;cursor:pointer}.cut-face-zone--active:hover{background:#c8a84b38}.cut-log{background:#07070e;border-top:1px solid #141420;display:flex;flex-direction:column;flex-shrink:0;gap:1px;height:72px;overflow-y:auto;padding:5px 12px;scrollbar-color:#222 #0000;scrollbar-width:thin}.cut-log-line{color:#666;font-size:.72rem;line-height:1.5}.cut-card,.cut-log-line--latest{color:#ccc}.cut-card{background:#181228;border:1px solid #302040;border-radius:8px;display:flex;flex-direction:column;flex-shrink:0;font-size:.82rem;height:220px;overflow:hidden;padding:6px;position:relative;transition:transform .12s,box-shadow .12s,border-color .12s;-webkit-user-select:none;user-select:none;width:132px}.cut-card--facedown{background:#16102a;border-color:#2a1a40;cursor:default;padding:0}.cut-card-back-img{border-radius:6px;display:block;height:100%;object-fit:cover;width:100%}.cut-card--spell{background:#101828;border-color:#20304a}.cut-card--selected{border-color:#c8a84b!important;box-shadow:0 0 10px #c8a84b80;transform:translateY(-4px)}.cut-card--can-attack{border-color:#903030;cursor:pointer}.cut-card--can-attack:hover{border-color:#d04040;box-shadow:0 0 8px #c83c3c66;transform:translateY(-3px)}.cut-card--playable{border-color:#305030;cursor:pointer}.cut-card--playable:hover{border-color:#50a050;box-shadow:0 0 10px #50a05059;transform:translateY(-5px)}.cut-card--targetable{animation:target-pulse .9s ease-in-out infinite alternate;border-color:#205880;box-shadow:0 0 8px #3278c866;cursor:pointer}@keyframes target-pulse{0%{box-shadow:0 0 6px #3278c84d}to{box-shadow:0 0 14px #3278c8b3}}.cut-card--targetable:hover{border-color:#4090c0;transform:translateY(-3px)}.cut-card-header{gap:4px;margin-bottom:2px}.cut-card-cost,.cut-card-header{align-items:center;display:flex;flex-shrink:0}.cut-card-cost{background:#201838;border:1px solid #604090;border-radius:50%;color:#c8a84b;font-size:.8rem;font-weight:700;height:24px;justify-content:center;width:24px}.cut-card-name{color:#eee;font-size:.74rem;font-weight:700;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cut-card-art{background:#0e0a1c;border-radius:3px;flex-shrink:0;height:88px;margin-bottom:2px;overflow:hidden;width:100%}.cut-card-art-img{display:block;height:100%;object-fit:cover;object-position:top;width:100%}.cut-card-typebadge{color:#666;font-size:.63rem;letter-spacing:.5px;margin:2px 0;text-align:center;text-transform:uppercase}.cut-card-text{color:#888;flex:1 1;font-size:.68rem;line-height:1.3;overflow:hidden;padding:0 2px;text-align:center}.cut-card-stats{align-items:center;border-top:1px solid #25183a;display:flex;font-size:.95rem;font-weight:700;gap:4px;justify-content:center;margin-top:auto;padding:4px 0 2px}.cut-card-atk{color:#e06060}.cut-card-sep{color:#555;font-size:.65rem}.cut-card-def{color:#60a0e0}.cut-modal--menu{max-height:90vh;max-width:520px;overflow-y:auto;scrollbar-color:#333 #0000;scrollbar-width:thin}.cut-rules{border-top:1px solid #2a1e10;margin-top:28px;padding-top:20px;text-align:left}.cut-rules-heading{color:#c8a84b;font-size:.75rem;letter-spacing:2px;margin:0 0 14px;text-transform:uppercase}.cut-rule{grid-gap:6px 12px;display:grid;font-size:.8rem;gap:6px 12px;grid-template-columns:90px 1fr;line-height:1.5;margin-bottom:10px}.cut-rule-heading{color:#c8a84b;font-weight:700;padding-top:1px}.cut-rule-body{color:#aaa}.cut-help-btn{align-items:center;background:none;border:1px solid #3a2a4a;border-radius:50%;color:#8060b0;cursor:pointer;display:flex;font-size:.8rem;font-weight:700;height:22px;justify-content:center;padding:0;transition:border-color .15s,color .15s;width:22px}.cut-help-btn:hover{border-color:#9070c0;color:#c0a0e0}.cut-help-panel{background:#111118;border:1px solid #3a2a4a;border-radius:8px;box-shadow:0 8px 24px #000000b3;position:absolute;right:48px;top:36px;width:320px;z-index:10}.cut-help-inner{padding:14px 16px}.cut-help-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.cut-help-header strong{color:#c8a84b;font-size:.8rem;letter-spacing:2px;text-transform:uppercase}.dr-overlay{align-items:center;background:#000000c7;display:flex;inset:0;justify-content:center;position:fixed;z-index:3000}.dr-modal{background:#110d07;border:1px solid #6a4510;border-radius:12px;box-shadow:0 0 40px #c88c1e2e,0 8px 32px #000000b3;padding:28px 32px 32px;position:relative;text-align:center;width:min(520px,94vw)}.dr-header{align-items:center;display:flex;justify-content:center;margin-bottom:4px;position:relative}.dr-title{color:#c8a84b;font-size:1.3rem;font-weight:700;letter-spacing:4px;text-transform:uppercase}.dr-close{background:none;border:none;border-radius:4px;color:#555;cursor:pointer;font-size:1rem;padding:2px 6px;position:absolute;right:0;transition:color .15s}.dr-close:hover{color:#ccc}.dr-reset-notice{color:#a05030;font-size:.78rem;font-style:italic;margin:6px 0 0}.dr-streak-line{color:#999;font-size:.82rem;margin:10px 0 20px}.dr-streak-line strong{color:#c8a84b}.dr-calendar{display:flex;gap:6px;justify-content:center;margin-bottom:24px}.dr-day{align-items:center;background:#1a120a;border:1px solid #2a1e10;border-radius:8px;display:flex;flex-direction:column;font-size:.7rem;gap:3px;padding:8px 4px;position:relative;width:56px}.dr-day--past{background:#141008;border-color:#3a2a10;opacity:.7}.dr-day--current{background:#211808;border-color:#c8a84b;box-shadow:0 0 12px #c8a84b59}.dr-day--future{opacity:.35}.dr-day-num{color:#666;font-size:.6rem;letter-spacing:1px;text-transform:uppercase}.dr-day--current .dr-day-num{color:#c8a84b}.dr-day-coin{color:#7a5a20;font-size:1.1rem;line-height:1}.dr-day--past .dr-day-coin{color:#5a4418}.dr-day--current .dr-day-coin{color:#c8a84b}.dr-day-gold{color:#9a7830;font-size:.68rem;font-weight:700}.dr-day--current .dr-day-gold{color:#e0c060}.dr-day-check{color:#508050;font-size:.6rem;position:absolute;right:5px;top:4px}.dr-day-arrow{color:#c8a84b;font-size:.55rem;left:50%;position:absolute;top:-14px;transform:translateX(-50%)}.dr-reward-amount{margin-bottom:8px}.dr-gold-num{color:#c8a84b;font-size:2rem;font-weight:700;letter-spacing:1px}.dr-gold-unit{color:#9a7830;font-size:1rem;margin-left:4px}.dr-flavour{color:#666;font-size:.78rem;font-style:italic;line-height:1.5;margin:0 0 22px}.dr-claim-btn{background:linear-gradient(180deg,#2e1c08,#1e1206);border:1px solid #8b6914;border-radius:8px;color:#c8a84b;cursor:pointer;font-family:inherit;font-size:.9rem;letter-spacing:2px;padding:10px 40px;text-transform:uppercase;transition:background .15s,box-shadow .15s}.dr-claim-btn:hover{background:linear-gradient(180deg,#3e2610,#2a1a08);box-shadow:0 0 10px #c8a84b40}.qom-backdrop{align-items:center;animation:qomFadeIn .2s ease;background:#000000c7;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1400}@keyframes qomFadeIn{0%{opacity:0}to{opacity:1}}.qom-modal{animation:qomSlideIn .22s ease;background:#0d1b2a;border:1px solid #d4af3773;border-radius:12px;box-shadow:0 0 40px #d4af371f,0 8px 40px #000000b3;max-width:460px;padding:28px 28px 22px;width:100%}@keyframes qomSlideIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.qom-header{align-items:flex-start;display:flex;gap:14px;margin-bottom:16px}.qom-icon{font-size:2rem;line-height:1;margin-top:2px}.qom-offered-by{color:#9ca3af;font-size:.74rem;margin:0 0 4px}.qom-offered-by em{color:#d4af37;font-style:normal}.qom-title{color:#f3c26b;font-family:Cinzel,serif;font-size:1.2rem;line-height:1.2;margin:0}.qom-description{color:#d1d5db;font-size:.85rem;line-height:1.6;margin:0 0 18px}.qom-steps{background:#0000004d;border:1px solid #d4af371f;border-radius:8px;margin-bottom:18px;padding:12px 14px}.qom-steps-label{color:#6b7280;font-size:.7rem;letter-spacing:.08em;margin:0 0 8px;text-transform:uppercase}.qom-steps-list{display:flex;flex-direction:column;gap:6px;margin:0;padding-left:18px}.qom-step{color:#e5e7eb;font-size:.82rem;line-height:1.4}.qom-step-hint{color:#9ca3af;font-style:italic}.qom-reward{align-items:center;background:#d4af370f;border:1px solid #d4af372e;border-radius:8px;display:flex;gap:12px;margin-bottom:22px;padding:10px 14px}.qom-reward-label{color:#6b7280;font-size:.7rem;letter-spacing:.08em;margin-right:4px;text-transform:uppercase}.qom-reward-gold{color:#f3c26b;font-size:.9rem;font-weight:600}.qom-reward-xp{color:#86efac;font-size:.9rem;font-weight:600}.qom-actions{align-items:center;display:flex;gap:10px}.qom-btn{border:1px solid;border-radius:6px;cursor:pointer;font-family:Cinzel,serif;font-size:.82rem;letter-spacing:.05em;padding:10px 22px;transition:all .15s}.qom-btn:disabled{cursor:not-allowed;opacity:.45}.qom-btn-accept{background:#d4af371f;border-color:#d4af3780;color:#f3c26b}.qom-btn-accept:hover:not(:disabled){background:#d4af3738;border-color:#f3c26b}.qom-btn-decline{background:none;border-color:#6b728066;color:#6b7280;font-family:inherit;font-size:.82rem}.qom-btn-decline:hover:not(:disabled){border-color:#9ca3af;color:#9ca3af}.ql-overlay{align-items:flex-start;background:#000000b8;display:flex;inset:0;justify-content:center;padding:20px 16px;position:fixed;z-index:1300}.ql-panel{background:#0d1b2a;border:1px solid #d4af374d;border-radius:12px;box-shadow:0 8px 40px #000000b3;display:flex;flex-direction:column;max-height:calc(100vh - 40px);max-width:560px;overflow:hidden;width:100%}.ql-header{align-items:center;border-bottom:1px solid #d4af3726;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 20px}.ql-header-title{color:#f3c26b;font-family:Cinzel,serif;font-size:1.05rem}.ql-close{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1rem;line-height:1;padding:2px 4px}.ql-close:hover{color:#ccc}.ql-tabs{display:flex;flex-shrink:0;gap:4px;padding:12px 16px 0}.ql-tab{align-items:center;background:none;border:1px solid #0000;border-bottom:none;border-radius:6px 6px 0 0;color:#6b7280;cursor:pointer;display:flex;font-family:Cinzel,serif;font-size:.75rem;gap:6px;letter-spacing:.04em;padding:7px 14px;transition:all .15s}.ql-tab:hover{color:#9ca3af}.ql-tab--active{background:#d4af3714;border-color:#d4af3733;color:#f3c26b}.ql-tab-count{background:#d4af3733;border-radius:10px;color:#f3c26b;font-family:system-ui,sans-serif;font-size:.65rem;font-weight:700;padding:1px 6px}.ql-body{border-top:1px solid #d4af3726;flex:1 1;min-height:0;overflow-y:auto;padding:16px}.ql-empty{color:#6b7280;font-size:.84rem;font-style:italic;padding:40px 20px;text-align:center}.ql-quest-list{display:flex;flex-direction:column;gap:8px}.ql-quest-card{background:#0003;border:1px solid #d4af3726;border-radius:8px;cursor:pointer;overflow:hidden;transition:border-color .15s}.ql-quest-card:hover{border-color:#d4af374d}.ql-quest-card--open{border-color:#d4af3759}.ql-quest-card--completed{border-color:#86efac2e}.ql-quest-card--completed:hover{border-color:#86efac59}.ql-quest-card--failed{border-color:#ef44442e}.ql-quest-card--failed:hover{border-color:#ef44444d}.ql-quest-card-header{align-items:center;display:flex;gap:10px;padding:12px 14px}.ql-quest-status-icon{flex-shrink:0;font-size:1.1rem}.ql-quest-card-title-block{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.ql-quest-title{color:#f3c26b;font-family:Cinzel,serif;font-size:.88rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ql-quest-card--completed .ql-quest-title{color:#86efac}.ql-quest-card--failed .ql-quest-title{color:#f87171}.ql-quest-npc{color:#6b7280;font-size:.7rem}.ql-quest-progress{background:#0000004d;border-radius:10px;color:#9ca3af;flex-shrink:0;font-size:.72rem;padding:2px 7px}.ql-quest-chevron{color:#6b7280;flex-shrink:0;font-size:.6rem}.ql-quest-body{border-top:1px solid #ffffff0d;display:flex;flex-direction:column;gap:12px;padding:14px 14px 14px 38px}.ql-quest-description{color:#d1d5db;font-size:.82rem;line-height:1.6;margin:0}.ql-quest-steps{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.ql-step{align-items:flex-start;color:#9ca3af;display:flex;font-size:.8rem;gap:8px}.ql-step--done{color:#6b7280}.ql-step--current{color:#e5e7eb}.ql-step-dot{color:inherit;flex-shrink:0;font-size:.65rem;margin-top:2px}.ql-step--done .ql-step-dot{color:#86efac}.ql-step--current .ql-step-dot{color:#f3c26b}.ql-step-text{line-height:1.45}.ql-step-hint{color:#6b7280;font-style:italic}.ql-quest-reward{align-items:center;background:#d4af370d;border:1px solid #d4af371f;border-radius:6px;display:flex;gap:10px;padding:8px 12px}.ql-reward-label{color:#6b7280;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}.ql-reward-gold{color:#f3c26b}.ql-reward-gold,.ql-reward-xp{font-size:.82rem;font-weight:600}.ql-reward-xp{color:#86efac}.dungeon-map-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#060402d9;border:1px solid #9b251566;border-radius:8px;opacity:.75;padding:8px 10px 6px;position:fixed;right:40px;top:72px;z-index:200}.dungeon-map-panel{align-items:center;display:inline-flex;flex-direction:column;gap:6px;-webkit-user-select:none;user-select:none}.dungeon-map-title{color:#9b6020;font-family:Cinzel,serif;font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;white-space:nowrap}.dungeon-map-wrap{height:288px;line-height:0;overflow:hidden;pointer-events:none;position:relative;width:288px}.dm-zoom-controls{display:flex;gap:3px;line-height:1;pointer-events:auto;position:absolute;right:6px;top:6px;z-index:10}.dm-zoom-btn{align-items:center;background:#140a04d9;border:1px solid #9b783280;border-radius:3px;color:#c8a060;cursor:pointer;display:flex;font-size:14px;height:20px;justify-content:center;line-height:1;padding:0;transition:background .1s,border-color .1s;width:20px}.dm-zoom-btn:hover:not(:disabled){background:#7a302099;border-color:#d4af3799;color:#f0e6c8}.dm-zoom-btn:disabled{cursor:default;opacity:.3}.dungeon-map-inner{left:0;position:absolute;top:0;will-change:transform}.dungeon-map-grid{grid-gap:0;background:#000;display:grid;gap:0;image-rendering:pixelated}.dm-cell{box-sizing:border-box;height:64px;width:64px}.dm-fog{background:#000}.dm-wall{background:#100c07}.dm-floor{background:repeating-linear-gradient(0deg,#0000,#0000 15px,#0000001a 0,#0000001a 16px),repeating-linear-gradient(90deg,#0000,#0000 15px,#0000001a 0,#0000001a 16px),#221a12}.dm-room{background:repeating-linear-gradient(0deg,#0000,#0000 15px,#0000001a 0,#0000001a 16px),repeating-linear-gradient(90deg,#0000,#0000 15px,#0000001a 0,#0000001a 16px),#2a1f0e;box-shadow:inset 0 0 10px #b4781e40;position:relative}.dm-room:before{background:#c8922a;border-radius:50%;box-shadow:0 0 5px 2px #c8922ab3;content:"";height:8px;left:6px;position:absolute;top:6px;width:8px;z-index:1}.dm-room-label{bottom:4px;color:#c8922a;font-family:Cinzel,serif;font-size:9px;left:5px;letter-spacing:.02em;line-height:1.25;overflow:hidden;overflow-wrap:break-word;right:5px;text-transform:uppercase;top:18px;word-break:break-word;z-index:2}.dm-player,.dm-room-label{pointer-events:none;position:absolute}.dm-player{align-items:center;display:flex;justify-content:center}.dm-player:after{background:#d4af37;box-shadow:0 0 8px 3px #d4af37cc,0 0 16px 6px #d4af3766;position:relative;z-index:2}.dm-player:after,.dm-player:before{border-radius:50%;content:"";height:14px;width:14px}.dm-player:before{animation:dmPlayerPulse 1.8s ease-out infinite;border:2px solid #d4af37b3;position:absolute;z-index:1}@keyframes dmPlayerPulse{0%{opacity:.8;transform:scale(1)}70%{opacity:0;transform:scale(2.8)}to{opacity:0;transform:scale(2.8)}}.dungeon-map-compass{grid-gap:1px;color:#6b5030;display:grid;font-family:Cinzel,serif;font-size:.55rem;gap:1px;grid-template-areas:". n ." "w . e" ". s .";grid-template-columns:1fr 1fr 1fr;line-height:1}.dc-n{grid-area:n}.dc-n,.dc-s{text-align:center}.dc-s{grid-area:s}.dc-e{grid-area:e;text-align:right}.dc-w{grid-area:w;text-align:left}.combat-ui-overlay{left:16px;position:fixed;top:72px;z-index:210}.combat-ui{background:#080402f7;border:1px solid #9b251599;border-radius:8px;color:#f0e6c8;display:flex;flex-direction:column;font-family:Cinzel,serif;gap:10px;max-width:95vw;padding:12px 14px;width:320px}.combat-header{align-items:center;border-bottom:1px solid #9b25154d;cursor:grab;display:flex;justify-content:space-between;padding-bottom:6px;-webkit-user-select:none;user-select:none}.combat-header:active{cursor:grabbing}.combat-round{color:#9b6020;font-size:.75rem;letter-spacing:.08em;text-transform:uppercase}.combat-whose-turn{color:#d4af37;font-size:.7rem;letter-spacing:.04em}.combat-dismiss-btn{background:none;border:none;color:#4a3520;cursor:pointer;font-size:.75rem;line-height:1;padding:0 2px;transition:color .1s}.combat-dismiss-btn:hover{color:#9b6020}.cui-enemies{border-bottom:1px solid #9b251540;display:flex;flex-direction:column;gap:8px;padding-bottom:4px}.cui-enemy-card{align-items:center;border:1px solid #9b251533;border-radius:5px;display:flex;gap:12px;padding:6px;transition:border-color .15s}.cui-enemy-card.cui-enemy-active{background:#9b251512;border-color:#dc3c1e8c}.cui-enemy-card.cui-enemy-down{opacity:.4}.cui-enemy-portrait-wrap{border:1px solid #9b251573;border-radius:4px;flex-shrink:0;height:72px;overflow:hidden;position:relative;width:72px}.cui-enemy-portrait{display:block;height:100%;object-fit:cover;width:100%}.cui-enemy-portrait-fallback{font-size:1.8rem;font-weight:700;height:100%;width:100%}.cui-enemy-down-overlay,.cui-enemy-portrait-fallback{align-items:center;display:flex;font-family:Cinzel,serif;justify-content:center}.cui-enemy-down-overlay{background:#000000a6;color:#c04030;font-size:.55rem;inset:0;letter-spacing:.1em;position:absolute}.cui-enemy-info{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0}.cui-enemy-name{color:#e05050;font-size:.82rem;letter-spacing:.03em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cui-enemy-hp-text{color:#9b6060;font-family:Georgia,serif;font-size:.62rem}.cui-hp-track{background:#ffffff14;border-radius:3px;height:6px;overflow:hidden;width:100%}.cui-hp-fill{border-radius:3px;height:100%;transition:width .3s ease,background .3s ease}.cui-party{border-bottom:1px solid #9b251526;display:flex;flex-direction:column;gap:5px;padding-bottom:4px}.cui-party-row{grid-gap:7px;align-items:center;border:1px solid #0000;border-radius:4px;display:grid;gap:7px;grid-template-columns:22px 1fr auto;padding:3px 4px}.cui-party-row.cui-party-active{background:#d4af3712;border-color:#d4af3740}.cui-party-row.cui-party-down{opacity:.35}.cui-party-icon{color:#6b5030;font-size:.75rem;text-align:center}.cui-party-name{color:#c8a870;font-size:.68rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cui-party-hp-wrap{align-items:flex-end;display:flex;flex-direction:column;gap:2px;min-width:90px}.cui-party-hp-text{color:#7a6040;font-family:Georgia,serif;font-size:.58rem}.combat-hp-bar{background:#ffffff1a;border-radius:3px;height:5px;overflow:hidden;width:80px}.combat-hp-fill{border-radius:3px;height:100%;transition:width .3s ease}.combatant-hp-text{color:#9b8060;font-family:Georgia,serif;font-size:.6rem}.combat-log{background:#0006;border:1px solid #ffffff0f;border-radius:4px;display:flex;flex-direction:column;gap:3px;max-height:110px;overflow-y:auto;padding:6px 8px}.combat-log::-webkit-scrollbar{width:4px}.combat-log::-webkit-scrollbar-thumb{background:#9b251566;border-radius:2px}.combat-log-entry{color:#c8b890;font-family:Crimson Text,Georgia,serif;font-size:.78rem;line-height:1.4;margin:0}.combat-actions{display:flex;flex-direction:column;gap:6px}.combat-attack-buttons,.combat-utility-buttons{display:flex;flex-wrap:wrap;gap:5px}.combat-btn{border:1px solid;border-radius:4px;cursor:pointer;font-family:Cinzel,serif;font-size:.65rem;letter-spacing:.04em;padding:5px 10px;transition:background .12s,border-color .12s}.attack-btn{background:#9b251540;border-color:#9b251580;color:#f0a080}.attack-btn:hover{background:#9b251573;border-color:#d45032b3;color:#fff}.item-btn{background:#1e50324d;border-color:#4caf7666;color:#7ec8a0}.item-btn:hover{background:#1e503280}.flee-btn{background:#3232144d;border-color:#b4a03c59;color:#b0a060;margin-left:auto}.flee-btn:hover{background:#50461466}.combat-dice-area{align-items:center;display:flex;flex-direction:column;gap:6px}.combat-dice-label{color:#c8b890}.combat-dice-label,.combat-waiting{font-family:Crimson Text,serif;font-size:.78rem;font-style:italic;margin:0}.combat-waiting{color:#6b5030;padding:4px 0;text-align:center}.fb-backdrop{align-items:center;background:#000000a6;display:flex;inset:0;justify-content:center;position:fixed;z-index:900}.fb-modal{background:#130e08;border:1px solid #d4af3759;border-radius:8px;box-shadow:0 12px 40px #000c,0 0 24px #d4af370f;padding:28px 28px 24px;position:relative;width:min(460px,92vw)}.fb-close{background:none;border:none;color:#6a5a3a;cursor:pointer;font-size:1rem;line-height:1;padding:4px 6px;position:absolute;right:14px;top:12px;transition:color .15s}.fb-close:hover,.fb-title{color:#d4af37}.fb-title{font-family:Cinzel,serif;font-size:1.1rem;letter-spacing:.05em;margin:0 0 4px}.fb-context{color:#5a4a2a;font-size:.78rem;letter-spacing:.02em;margin:0 0 18px}.fb-type-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}.fb-type-pill{background:#0000;border:1px solid #d4af3740;border-radius:20px;color:#8a7a5a;cursor:pointer;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.04em;padding:6px 14px;transition:all .15s}.fb-type-pill:hover{border-color:#d4af3780;color:#c0a84a}.fb-type-pill.active{background:#d4af371a;border-color:#d4af37;color:#d4af37}.fb-textarea{background:#ffffff0a;border:1px solid #d4af3733;border-radius:4px;box-sizing:border-box;color:#d4c49a;font-family:Crimson Text,serif;font-size:.95rem;line-height:1.6;outline:none;padding:10px 12px;resize:vertical;transition:border-color .15s;width:100%}.fb-textarea:focus{border-color:#d4af3780}.fb-textarea::placeholder{color:#4a3c24}.fb-char-count{color:#4a3c24;font-size:.7rem;margin-bottom:12px;margin-top:4px;text-align:right}.fb-error{color:#c0392b;font-size:.82rem;margin:0 0 10px}.fb-actions{display:flex;gap:10px;justify-content:flex-end}.fb-btn-cancel{background:none;border:1px solid #d4af3733;border-radius:4px;color:#6a5a3a;cursor:pointer;font-family:Cinzel,serif;font-size:.75rem;letter-spacing:.05em;padding:8px 18px;transition:all .15s}.fb-btn-cancel:hover{border-color:#d4af3766;color:#a08040}.fb-btn-primary{background:linear-gradient(160deg,#1e1608,#0d0a04);border:1px solid #d4af378c;border-radius:4px;color:#d4af37;cursor:pointer;font-family:Cinzel,serif;font-size:.75rem;letter-spacing:.06em;padding:8px 22px;transition:all .15s}.fb-btn-primary:hover:not(:disabled){border-color:#d4af37;box-shadow:0 0 10px #d4af3733;color:#ffe9a0}.fb-btn-primary:disabled{cursor:not-allowed;opacity:.4}.fb-done{padding:16px 0 8px;text-align:center}.fb-done-icon{color:#4caf50;display:block;font-size:2rem;margin-bottom:10px}.fb-done p{color:#b0a07a;font-family:Crimson Text,serif;font-size:1rem;margin:0 0 20px}.mp-backdrop{align-items:center;background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:900}.mp-panel{background:#130e08;border:1px solid #b43c2866;border-radius:6px;box-shadow:0 12px 40px #000000d9,0 0 20px #b43c280f;display:flex;flex-direction:column;padding:0;width:min(560px,94vw)}.mp-drag-bar{align-items:center;background:#0006;border-bottom:1px solid #b43c2833;border-radius:6px 6px 0 0;cursor:grab;display:flex;justify-content:space-between;padding:8px 14px;-webkit-user-select:none;user-select:none}.mp-drag-bar:active{cursor:grabbing}.mp-drag-grip{color:#b43c2840;font-size:1rem;letter-spacing:3px;pointer-events:none}.mp-close{background:none;border:none;color:#5a3a2a;cursor:pointer;font-size:.9rem;padding:2px 6px;transition:color .15s}.mp-close:hover{color:#c0392b}.mp-body{display:flex;gap:22px;padding:22px}.mp-portrait-wrap{flex-shrink:0;position:relative;width:192px}.mp-portrait{display:block;object-fit:cover}.mp-portrait,.mp-portrait-fallback{border:1px solid #b43c2859;border-radius:4px;height:192px;width:192px}.mp-portrait-fallback{align-items:center;display:flex;font-family:Cinzel,serif;font-size:5rem;font-weight:700;justify-content:center}.mp-threat-badge{border:1px solid;border-radius:10px;bottom:-8px;font-family:Cinzel,serif;font-size:.58rem;left:50%;letter-spacing:.08em;padding:2px 7px;position:absolute;transform:translateX(-50%);white-space:nowrap}.mp-threat-badge[data-tier=Minion]{background:#0d0a06;border-color:#8a704080;color:#8a7040}.mp-threat-badge[data-tier=Standard]{background:#0d0806;border-color:#c0802a80;color:#c0802a}.mp-threat-badge[data-tier=Elite]{background:#0d0806;border-color:#c0482080;color:#c04820}.mp-threat-badge[data-tier=Boss]{background:#0d0606;border-color:#c0202080;color:#c02020}.mp-info{display:flex;flex:1 1;flex-direction:column;gap:5px;min-width:0;padding-top:2px}.mp-name{color:#c0392b;font-family:Cinzel,serif;font-size:1rem;letter-spacing:.04em;margin:0}.mp-location{color:#5a3a2a;font-size:.72rem;letter-spacing:.03em}.mp-desc{color:#c0a87a;flex:1 1;font-family:Crimson Text,serif;font-size:.92rem;line-height:1.6;margin:4px 0 6px}.mp-lore-link{align-self:flex-start;color:#8a4030;font-family:Cinzel,serif;font-size:.68rem;letter-spacing:.06em;text-decoration:none;transition:color .15s}.mp-lore-link:hover{color:#c0392b}.gm-monster-term{border-bottom:1px dotted #c0392b73;cursor:pointer;transition:color .15s,border-color .15s}.gm-monster-term:hover{border-bottom-color:#c0392bd9;color:#e05040}.npc-popup-backdrop{align-items:center;background:#000000b8;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:1200}.npc-popup{animation:npcPopupIn .2s ease both;background:linear-gradient(160deg,#110a02,#080502);border:1px solid #d4af3773;border-radius:10px;max-width:360px;padding:0;position:relative;text-align:center;width:90vw}@keyframes npcPopupIn{0%{opacity:0}to{opacity:1}}.npc-popup-drag-bar{align-items:center;background:#00000059;border-bottom:1px solid #d4af371a;border-radius:10px 10px 0 0;cursor:grab;display:flex;justify-content:space-between;padding:8px 14px;-webkit-user-select:none;user-select:none}.npc-popup-drag-bar:active{cursor:grabbing}.npc-drag-grip{color:#d4af3738;font-size:1rem;letter-spacing:3px;pointer-events:none}.npc-popup-close{background:none;border:none;color:#888;cursor:pointer;font-size:1rem;line-height:1;padding:2px 4px}.npc-popup-close:hover{color:#ccc}.npc-popup-portrait{border:2px solid #d4af3780;border-radius:50%;box-shadow:0 0 20px #d4af372e,0 4px 16px #000000b3;display:block;height:180px;margin:18px auto 14px;object-fit:cover;object-position:center top;width:180px}.npc-popup-occupation{color:#7a6a50;display:block;font-size:.65rem;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}.npc-popup-name{color:#d4af37;font-family:Cinzel,serif;font-size:1.2rem;letter-spacing:.04em;margin:0 0 12px}.npc-popup-body{color:#9a8870;font-family:Georgia,serif;font-size:.84rem;line-height:1.65;margin:0 28px 16px}.npc-popup-actions{align-items:center;display:flex;flex-direction:column;gap:8px;padding:0 28px 22px}.npc-popup-link{border:1px solid #d4af374d;border-radius:4px;color:#d4af37;display:inline-block;font-size:.78rem;padding:6px 14px;text-decoration:none;transition:border-color .15s,color .15s}.npc-popup-link:hover{border-color:#d4af37b3;color:#f0cc60}.npc-popup-quest-btn{background:#d4af371a;border:1px solid #d4af3766;border-radius:4px;color:#f3c26b;cursor:pointer;display:inline-block;font-family:Cinzel,serif;font-size:.78rem;letter-spacing:.05em;padding:8px 14px;transition:background .15s,border-color .15s;width:100%}.npc-popup-quest-btn:hover{background:#d4af3733;border-color:#d4af37}.char-select-overlay{align-items:center;background:#0e0a05;display:flex;flex-direction:column;justify-content:center;min-height:100vh;padding:24px 16px}.char-select-title{color:#c8a96e;font-family:Cinzel,serif;font-size:1.8rem;letter-spacing:.05em;margin-bottom:8px;text-align:center}.char-select-subtitle{color:#7a6a55;font-size:.9rem;margin-bottom:36px;text-align:center}.char-slots-row{align-items:stretch;flex-direction:row;flex-wrap:nowrap;gap:16px;max-width:740px;width:100%}.char-slot-card,.char-slots-row{display:flex;justify-content:center}.char-slot-card{align-items:center;background:#1a130a;border:1px solid #3a2e1e;border-radius:8px;flex:1 1;flex-direction:column;max-width:220px;min-height:300px;min-width:0;padding:20px 12px;position:relative;transition:border-color .2s}.char-slot-card.filled{border-color:#5a4520}.char-slot-card.filled:hover{border-color:#c8a96e}.char-slot-card.empty{border-color:#2a2015;border-style:dashed;cursor:pointer}.char-slot-card.empty:hover{border-color:#5a4520}.char-slot-portrait{background:#2a1f10;border:2px solid #5a4520;border-radius:50%;flex-shrink:0;height:160px;margin-bottom:14px;overflow:hidden;width:160px}.char-slot-portrait-img{display:block;height:100%;object-fit:cover;object-position:top;width:100%}.char-slot-name{color:#d4b888;font-family:Cinzel,serif;font-size:1.05rem}.char-slot-meta,.char-slot-name{margin-bottom:4px;text-align:center}.char-slot-meta{color:#8a7a60;font-size:.78rem}.char-slot-level{color:#c8a96e;font-size:.82rem;font-weight:600;margin-bottom:18px}.char-slot-play-btn{background:#3a2a10;border:1px solid #c8a96e;border-radius:4px;color:#c8a96e;cursor:pointer;font-family:Cinzel,serif;font-size:.85rem;padding:8px 24px;transition:background .2s;width:100%}.char-slot-play-btn:hover{background:#c8a96e;color:#0e0a05}.char-slot-delete-btn{background:none;border:none;border-radius:3px;color:#5a4520;cursor:pointer;font-size:.75rem;padding:2px 6px;position:absolute;right:10px;top:10px;transition:color .2s}.char-slot-delete-btn:hover{color:#c04a4a}.char-slot-empty-icon{color:#3a2e1e;font-size:2.5rem;margin-bottom:14px}.char-slot-empty-label{color:#5a4520;font-family:Cinzel,serif;font-size:.85rem}.char-slot-loading{color:#5a4520;font-size:.85rem;margin-top:40px}.char-creation-modal-bg{align-items:flex-start;background:#000000d9;display:flex;inset:0;justify-content:center;overflow-y:auto;padding:20px;position:fixed;z-index:200}.char-slot-creating-label{color:#7a6a55;font-size:.8rem;margin-top:8px}.char-select-error{color:#c04a4a;font-size:.85rem;margin-top:16px}@media (max-width:500px){.char-slots-row{align-items:center;flex-direction:column;flex-wrap:wrap}.char-slot-card{max-width:85vw;min-height:220px;width:85vw}}.leaflet-image-layer,.leaflet-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane,.leaflet-pane>canvas,.leaflet-pane>svg,.leaflet-tile,.leaflet-tile-container,.leaflet-zoom-box{left:0;position:absolute;top:0}.leaflet-container{overflow:hidden}.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-tile{-webkit-user-drag:none;-webkit-user-select:none;user-select:none}.leaflet-tile::selection{background:#0000}.leaflet-safari .leaflet-tile{image-rendering:-webkit-optimize-contrast}.leaflet-safari .leaflet-tile-container{height:1600px;-webkit-transform-origin:0 0;width:1600px}.leaflet-marker-icon,.leaflet-marker-shadow{display:block}.leaflet-container .leaflet-overlay-pane svg{max-height:none!important;max-width:none!important}.leaflet-container .leaflet-marker-pane img,.leaflet-container .leaflet-shadow-pane img,.leaflet-container .leaflet-tile,.leaflet-container .leaflet-tile-pane img,.leaflet-container img.leaflet-image-layer{max-height:none!important;max-width:none!important;padding:0;width:auto}.leaflet-container img.leaflet-tile{mix-blend-mode:plus-lighter}.leaflet-container.leaflet-touch-zoom{touch-action:pan-x pan-y}.leaflet-container.leaflet-touch-drag{touch-action:none;touch-action:pinch-zoom}.leaflet-container.leaflet-touch-drag.leaflet-touch-zoom{touch-action:none}.leaflet-container{-webkit-tap-highlight-color:transparent}.leaflet-container a{-webkit-tap-highlight-color:rgba(51,181,229,.4)}.leaflet-tile{filter:inherit;visibility:hidden}.leaflet-tile-loaded{visibility:inherit}.leaflet-zoom-box{box-sizing:border-box;height:0;width:0;z-index:800}.leaflet-overlay-pane svg{-moz-user-select:none}.leaflet-pane{z-index:400}.leaflet-tile-pane{z-index:200}.leaflet-overlay-pane{z-index:400}.leaflet-shadow-pane{z-index:500}.leaflet-marker-pane{z-index:600}.leaflet-tooltip-pane{z-index:650}.leaflet-popup-pane{z-index:700}.leaflet-map-pane canvas{z-index:100}.leaflet-map-pane svg{z-index:200}.leaflet-vml-shape{height:1px;width:1px}.lvml{behavior:url(#default#VML);display:inline-block;position:absolute}.leaflet-control{pointer-events:visiblePainted;pointer-events:auto;position:relative;z-index:800}.leaflet-bottom,.leaflet-top{pointer-events:none;position:absolute;z-index:1000}.leaflet-top{top:0}.leaflet-right{right:0}.leaflet-bottom{bottom:0}.leaflet-left{left:0}.leaflet-control{clear:both;float:left}.leaflet-right .leaflet-control{float:right}.leaflet-top .leaflet-control{margin-top:10px}.leaflet-bottom .leaflet-control{margin-bottom:10px}.leaflet-left .leaflet-control{margin-left:10px}.leaflet-right .leaflet-control{margin-right:10px}.leaflet-fade-anim .leaflet-popup{opacity:0;transition:opacity .2s linear}.leaflet-fade-anim .leaflet-map-pane .leaflet-popup{opacity:1}.leaflet-zoom-animated{transform-origin:0 0}svg.leaflet-zoom-animated{will-change:transform}.leaflet-zoom-anim .leaflet-zoom-animated{transition:transform .25s cubic-bezier(0,0,.25,1)}.leaflet-pan-anim .leaflet-tile,.leaflet-zoom-anim .leaflet-tile{transition:none}.leaflet-zoom-anim .leaflet-zoom-hide{visibility:hidden}.leaflet-interactive{cursor:pointer}.leaflet-grab{cursor:grab}.leaflet-crosshair,.leaflet-crosshair .leaflet-interactive{cursor:crosshair}.leaflet-control,.leaflet-popup-pane{cursor:auto}.leaflet-dragging .leaflet-grab,.leaflet-dragging .leaflet-grab .leaflet-interactive,.leaflet-dragging .leaflet-marker-draggable{cursor:move;cursor:grabbing}.leaflet-image-layer,.leaflet-marker-icon,.leaflet-marker-shadow,.leaflet-pane>svg path,.leaflet-tile-container{pointer-events:none}.leaflet-image-layer.leaflet-interactive,.leaflet-marker-icon.leaflet-interactive,.leaflet-pane>svg path.leaflet-interactive,svg.leaflet-image-layer.leaflet-interactive path{pointer-events:visiblePainted;pointer-events:auto}.leaflet-container{background:#ddd;outline-offset:1px}.leaflet-container a{color:#0078a8}.leaflet-zoom-box{background:#ffffff80;border:2px dotted #38f}.leaflet-container{font-family:Helvetica Neue,Arial,Helvetica,sans-serif;font-size:12px;font-size:.75rem;line-height:1.5}.leaflet-bar{border-radius:4px;box-shadow:0 1px 5px #000000a6}.leaflet-bar a{background-color:#fff;border-bottom:1px solid #ccc;color:#000;display:block;height:26px;line-height:26px;text-align:center;text-decoration:none;width:26px}.leaflet-bar a,.leaflet-control-layers-toggle{background-position:50% 50%;background-repeat:no-repeat;display:block}.leaflet-bar a:focus,.leaflet-bar a:hover{background-color:#f4f4f4}.leaflet-bar a:first-child{border-top-left-radius:4px;border-top-right-radius:4px}.leaflet-bar a:last-child{border-bottom:none;border-bottom-left-radius:4px;border-bottom-right-radius:4px}.leaflet-bar a.leaflet-disabled{background-color:#f4f4f4;color:#bbb;cursor:default}.leaflet-touch .leaflet-bar a{height:30px;line-height:30px;width:30px}.leaflet-touch .leaflet-bar a:first-child{border-top-left-radius:2px;border-top-right-radius:2px}.leaflet-touch .leaflet-bar a:last-child{border-bottom-left-radius:2px;border-bottom-right-radius:2px}.leaflet-control-zoom-in,.leaflet-control-zoom-out{font:700 18px Lucida Console,Monaco,monospace;text-indent:1px}.leaflet-touch .leaflet-control-zoom-in,.leaflet-touch .leaflet-control-zoom-out{font-size:22px}.leaflet-control-layers{background:#fff;border-radius:5px;box-shadow:0 1px 5px #0006}.leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABoAAAAaCAQAAAADQ4RFAAACf0lEQVR4AY1UM3gkARTePdvdoTxXKc+qTl3aU5U6b2Kbkz3Gtq3Zw6ziLGNPzrYx7946Tr6/ee/XeCQ4D3ykPtL5tHno4n0d/h3+xfuWHGLX81cn7r0iTNzjr7LrlxCqPtkbTQEHeqOrTy4Yyt3VCi/IOB0v7rVC7q45Q3Gr5K6jt+3Gl5nCoDD4MtO+j96Wu8atmhGqcNGHObuf8OM/x3AMx38+4Z2sPqzCxRFK2aF2e5Jol56XTLyggAMTL56XOMoS1W4pOyjUcGGQdZxU6qRh7B9Zp+PfpOFlqt0zyDZckPi1ttmIp03jX8gyJ8a/PG2yutpS/Vol7peZIbZcKBAEEheEIAgFbDkz5H6Zrkm2hVWGiXKiF4Ycw0RWKdtC16Q7qe3X4iOMxruonzegJzWaXFrU9utOSsLUmrc0YjeWYjCW4PDMADElpJSSQ0vQvA1Tm6/JlKnqFs1EGyZiFCqnRZTEJJJiKRYzVYzJck2Rm6P4iH+cmSY0YzimYa8l0EtTODFWhcMIMVqdsI2uiTvKmTisIDHJ3od5GILVhBCarCfVRmo4uTjkhrhzkiBV7SsaqS+TzrzM1qpGGUFt28pIySQHR6h7F6KSwGWm97ay+Z+ZqMcEjEWebE7wxCSQwpkhJqoZA5ivCdZDjJepuJ9IQjGGUmuXJdBFUygxVqVsxFsLMbDe8ZbDYVCGKxs+W080max1hFCarCfV+C1KATwcnvE9gRRuMP2prdbWGowm1KB1y+zwMMENkM755cJ2yPDtqhTI6ED1M/82yIDtC/4j4BijjeObflpO9I9MwXTCsSX8jWAFeHr05WoLTJ5G8IQVS/7vwR6ohirYM7f6HzYpogfS3R2OAAAAAElFTkSuQmCC);height:36px;width:36px}.leaflet-retina .leaflet-control-layers-toggle{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADQAAAA0CAQAAABvcdNgAAAEsklEQVR4AWL4TydIhpZK1kpWOlg0w3ZXP6D2soBtG42jeI6ZmQTHzAxiTbSJsYLjO9HhP+WOmcuhciVnmHVQcJnp7DFvScowZorad/+V/fVzMdMT2g9Cv9guXGv/7pYOrXh2U+RRR3dSd9JRx6bIFc/ekqHI29JC6pJ5ZEh1yWkhkbcFeSjxgx3L2m1cb1C7bceyxA+CNjT/Ifff+/kDk2u/w/33/IeCMOSaWZ4glosqT3DNnNZQ7Cs58/3Ce5HL78iZH/vKVIaYlqzfdLu8Vi7dnvUbEza5Idt36tquZFldl6N5Z/POLof0XLK61mZCmJSWjVF9tEjUluu74IUXvgttuVIHE7YxSkaYhJZam7yiM9Pv82JYfl9nptxZaxMJE4YSPty+vF0+Y2up9d3wwijfjZbabqm/3bZ9ecKHsiGmRflnn1MW4pjHf9oLufyn2z3y1D6n8g8TZhxyzipLNPnAUpsOiuWimg52psrTZYnOWYNDTMuWBWa0tJb4rgq1UvmutpaYEbZlwU3CLJm/ayYjHW5/h7xWLn9Hh1vepDkyf7dE7MtT5LR4e7yYpHrkhOUpEfssBLq2pPhAqoSWKUkk7EDqkmK6RrCEzqDjhNDWNE+XSMvkJRDWlZTmCW0l0PHQGRZY5t1L83kT0Y3l2SItk5JAWHl2dCOBm+fPu3fo5/3v61RMCO9Jx2EEYYhb0rmNQMX/vm7gqOEJLcXTGw3CAuRNeyaPWwjR8PRqKQ1PDA/dpv+on9Shox52WFnx0KY8onHayrJzm87i5h9xGw/tfkev0jGsQizqezUKjk12hBMKJ4kbCqGPVNXudyyrShovGw5CgxsRICxF6aRmSjlBnHRzg7Gx8fKqEubI2rahQYdR1YgDIRQO7JvQyD52hoIQx0mxa0ODtW2Iozn1le2iIRdzwWewedyZzewidueOGqlsn1MvcnQpuVwLGG3/IR1hIKxCjelIDZ8ldqWz25jWAsnldEnK0Zxro19TGVb2ffIZEsIO89EIEDvKMPrzmBOQcKQ+rroye6NgRRxqR4U8EAkz0CL6uSGOm6KQCdWjvjRiSP1BPalCRS5iQYiEIvxuBMJEWgzSoHADcVMuN7IuqqTeyUPq22qFimFtxDyBBJEwNyt6TM88blFHao/6tWWhuuOM4SAK4EI4QmFHA+SEyWlp4EQoJ13cYGzMu7yszEIBOm2rVmHUNqwAIQabISNMRstmdhNWcFLsSm+0tjJH1MdRxO5Nx0WDMhCtgD6OKgZeljJqJKc9po8juskR9XN0Y1lZ3mWjLR9JCO1jRDMd0fpYC2VnvjBSEFg7wBENc0R9HFlb0xvF1+TBEpF68d+DHR6IOWVv2BECtxo46hOFUBd/APU57WIoEwJhIi2CdpyZX0m93BZicktMj1AS9dClteUFAUNUIEygRZCtik5zSxI9MubTBH1GOiHsiLJ3OCoSZkILa9PxiN0EbvhsAo8tdAf9Seepd36lGWHmtNANTv5Jd0z4QYyeo/UEJqxKRpg5LZx6btLPsOaEmdMyxYdlc8LMaJnikDlhclqmPiQnTEpLUIZEwkRagjYkEibQErwhkTAKCLQEbUgkzJQWc/0PstHHcfEdQ+UAAAAASUVORK5CYII=);background-size:26px 26px}.leaflet-touch .leaflet-control-layers-toggle{height:44px;width:44px}.leaflet-control-layers .leaflet-control-layers-list,.leaflet-control-layers-expanded .leaflet-control-layers-toggle{display:none}.leaflet-control-layers-expanded .leaflet-control-layers-list{display:block;position:relative}.leaflet-control-layers-expanded{background:#fff;color:#333;padding:6px 10px 6px 6px}.leaflet-control-layers-scrollbar{overflow-x:hidden;overflow-y:scroll;padding-right:5px}.leaflet-control-layers-selector{margin-top:2px;position:relative;top:1px}.leaflet-control-layers label{display:block;font-size:13px;font-size:1.08333em}.leaflet-control-layers-separator{border-top:1px solid #ddd;height:0;margin:5px -10px 5px -6px}.leaflet-default-icon-path{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABkAAAApCAYAAADAk4LOAAAFgUlEQVR4Aa1XA5BjWRTN2oW17d3YaZtr2962HUzbDNpjszW24mRt28p47v7zq/bXZtrp/lWnXr337j3nPCe85NcypgSFdugCpW5YoDAMRaIMqRi6aKq5E3YqDQO3qAwjVWrD8Ncq/RBpykd8oZUb/kaJutow8r1aP9II0WmLKLIsJyv1w/kqw9Ch2MYdB++12Onxee/QMwvf4/Dk/Lfp/i4nxTXtOoQ4pW5Aj7wpici1A9erdAN2OH64x8OSP9j3Ft3b7aWkTg/Fm91siTra0f9on5sQr9INejH6CUUUpavjFNq1B+Oadhxmnfa8RfEmN8VNAsQhPqF55xHkMzz3jSmChWU6f7/XZKNH+9+hBLOHYozuKQPxyMPUKkrX/K0uWnfFaJGS1QPRtZsOPtr3NsW0uyh6NNCOkU3Yz+bXbT3I8G3xE5EXLXtCXbbqwCO9zPQYPRTZ5vIDXD7U+w7rFDEoUUf7ibHIR4y6bLVPXrz8JVZEql13trxwue/uDivd3fkWRbS6/IA2bID4uk0UpF1N8qLlbBlXs4Ee7HLTfV1j54APvODnSfOWBqtKVvjgLKzF5YdEk5ewRkGlK0i33Eofffc7HT56jD7/6U+qH3Cx7SBLNntH5YIPvODnyfIXZYRVDPqgHtLs5ABHD3YzLuespb7t79FY34DjMwrVrcTuwlT55YMPvOBnRrJ4VXTdNnYug5ucHLBjEpt30701A3Ts+HEa73u6dT3FNWwflY86eMHPk+Yu+i6pzUpRrW7SNDg5JHR4KapmM5Wv2E8Tfcb1HoqqHMHU+uWDD7zg54mz5/2BSnizi9T1Dg4QQXLToGNCkb6tb1NU+QAlGr1++eADrzhn/u8Q2YZhQVlZ5+CAOtqfbhmaUCS1ezNFVm2imDbPmPng5wmz+gwh+oHDce0eUtQ6OGDIyR0uUhUsoO3vfDmmgOezH0mZN59x7MBi++WDL1g/eEiU3avlidO671bkLfwbw5XV2P8Pzo0ydy4t2/0eu33xYSOMOD8hTf4CrBtGMSoXfPLchX+J0ruSePw3LZeK0juPJbYzrhkH0io7B3k164hiGvawhOKMLkrQLyVpZg8rHFW7E2uHOL888IBPlNZ1FPzstSJM694fWr6RwpvcJK60+0HCILTBzZLFNdtAzJaohze60T8qBzyh5ZuOg5e7uwQppofEmf2++DYvmySqGBuKaicF1blQjhuHdvCIMvp8whTTfZzI7RldpwtSzL+F1+wkdZ2TBOW2gIF88PBTzD/gpeREAMEbxnJcaJHNHrpzji0gQCS6hdkEeYt9DF/2qPcEC8RM28Hwmr3sdNyht00byAut2k3gufWNtgtOEOFGUwcXWNDbdNbpgBGxEvKkOQsxivJx33iow0Vw5S6SVTrpVq11ysA2Rp7gTfPfktc6zhtXBBC+adRLshf6sG2RfHPZ5EAc4sVZ83yCN00Fk/4kggu40ZTvIEm5g24qtU4KjBrx/BTTH8ifVASAG7gKrnWxJDcU7x8X6Ecczhm3o6YicvsLXWfh3Ch1W0k8x0nXF+0fFxgt4phz8QvypiwCCFKMqXCnqXExjq10beH+UUA7+nG6mdG/Pu0f3LgFcGrl2s0kNNjpmoJ9o4B29CMO8dMT4Q5ox8uitF6fqsrJOr8qnwNbRzv6hSnG5wP+64C7h9lp30hKNtKdWjtdkbuPA19nJ7Tz3zR/ibgARbhb4AlhavcBebmTHcFl2fvYEnW0ox9xMxKBS8btJ+KiEbq9zA4RthQXDhPa0T9TEe69gWupwc6uBUphquXgf+/FrIjweHQS4/pduMe5ERUMHUd9xv8ZR98CxkS4F2n3EUrUZ10EYNw7BWm9x1GiPssi3GgiGRDKWRYZfXlON+dfNbM+GgIwYdwAAAAASUVORK5CYII=)}.leaflet-container .leaflet-control-attribution{background:#fff;background:#fffc;margin:0}.leaflet-control-attribution,.leaflet-control-scale-line{color:#333;line-height:1.4;padding:0 5px}.leaflet-control-attribution a{text-decoration:none}.leaflet-control-attribution a:focus,.leaflet-control-attribution a:hover{text-decoration:underline}.leaflet-attribution-flag{display:inline!important;height:.6669em;vertical-align:initial!important;width:1em}.leaflet-left .leaflet-control-scale{margin-left:5px}.leaflet-bottom .leaflet-control-scale{margin-bottom:5px}.leaflet-control-scale-line{background:#fffc;border:2px solid #777;border-top:none;box-sizing:border-box;line-height:1.1;padding:2px 5px 1px;text-shadow:1px 1px #fff;white-space:nowrap}.leaflet-control-scale-line:not(:first-child){border-bottom:none;border-top:2px solid #777;margin-top:-2px}.leaflet-control-scale-line:not(:first-child):not(:last-child){border-bottom:2px solid #777}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-attribution,.leaflet-touch .leaflet-control-layers{box-shadow:none}.leaflet-touch .leaflet-bar,.leaflet-touch .leaflet-control-layers{background-clip:padding-box;border:2px solid #0003}.leaflet-popup{margin-bottom:20px;position:absolute;text-align:center}.leaflet-popup-content-wrapper{border-radius:12px;padding:1px;text-align:left}.leaflet-popup-content{font-size:13px;font-size:1.08333em;line-height:1.3;margin:13px 24px 13px 20px;min-height:1px}.leaflet-popup-content p{margin:1.3em 0}.leaflet-popup-tip-container{height:20px;left:50%;margin-left:-20px;margin-top:-1px;overflow:hidden;pointer-events:none;position:absolute;width:40px}.leaflet-popup-tip{height:17px;margin:-10px auto 0;padding:1px;pointer-events:auto;transform:rotate(45deg);width:17px}.leaflet-popup-content-wrapper,.leaflet-popup-tip{background:#fff;box-shadow:0 3px 14px #0006;color:#333}.leaflet-container a.leaflet-popup-close-button{background:#0000;border:none;color:#757575;font:16px/24px Tahoma,Verdana,sans-serif;height:24px;position:absolute;right:0;text-align:center;text-decoration:none;top:0;width:24px}.leaflet-container a.leaflet-popup-close-button:focus,.leaflet-container a.leaflet-popup-close-button:hover{color:#585858}.leaflet-popup-scrolled{overflow:auto}.leaflet-oldie .leaflet-popup-content-wrapper{-ms-zoom:1}.leaflet-oldie .leaflet-popup-tip{-ms-filter:"progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678, M12=0.70710678, M21=-0.70710678, M22=0.70710678)";filter:progid:DXImageTransform.Microsoft.Matrix(M11=0.70710678,M12=0.70710678,M21=-0.70710678,M22=0.70710678);margin:0 auto;width:24px}.leaflet-oldie .leaflet-control-layers,.leaflet-oldie .leaflet-control-zoom,.leaflet-oldie .leaflet-popup-content-wrapper,.leaflet-oldie .leaflet-popup-tip{border:1px solid #999}.leaflet-div-icon{background:#fff;border:1px solid #666}.leaflet-tooltip{background-color:#fff;border:1px solid #fff;border-radius:3px;box-shadow:0 1px 3px #0006;color:#222;padding:6px;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;white-space:nowrap}.leaflet-tooltip.leaflet-interactive{cursor:pointer;pointer-events:auto}.leaflet-tooltip-bottom:before,.leaflet-tooltip-left:before,.leaflet-tooltip-right:before,.leaflet-tooltip-top:before{background:#0000;border:6px solid #0000;content:"";pointer-events:none;position:absolute}.leaflet-tooltip-bottom{margin-top:6px}.leaflet-tooltip-top{margin-top:-6px}.leaflet-tooltip-bottom:before,.leaflet-tooltip-top:before{left:50%;margin-left:-6px}.leaflet-tooltip-top:before{border-top-color:#fff;bottom:0;margin-bottom:-12px}.leaflet-tooltip-bottom:before{border-bottom-color:#fff;margin-left:-6px;margin-top:-12px;top:0}.leaflet-tooltip-left{margin-left:-6px}.leaflet-tooltip-right{margin-left:6px}.leaflet-tooltip-left:before,.leaflet-tooltip-right:before{margin-top:-6px;top:50%}.leaflet-tooltip-left:before{border-left-color:#fff;margin-right:-12px;right:0}.leaflet-tooltip-right:before{border-right-color:#fff;left:0;margin-left:-12px}@media print{.leaflet-control{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.noticeboard-overlay{align-items:center;animation:nbFadeIn .18s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b8;display:flex;inset:0;justify-content:center;position:fixed;z-index:1000}@keyframes nbFadeIn{0%{opacity:0}to{opacity:1}}.noticeboard-panel{animation:nbSlideUp .22s ease;background:radial-gradient(circle at top left,#b478281f,#0000 50%),linear-gradient(160deg,#1e140a,#140e06);border:1px solid #d4af3759;border-radius:4px;box-shadow:0 0 0 4px #0009,0 24px 80px #000000b3,inset 0 1px 0 #ffdc6414;max-height:90vh;overflow-y:auto;padding:28px 28px 20px;position:relative;width:min(660px,94vw)}@keyframes nbSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.noticeboard-close{background:none;border:none;color:#888;cursor:pointer;font-size:1rem;line-height:1;padding:4px 6px;position:absolute;right:14px;top:12px;transition:color .15s}.noticeboard-close:hover{color:#d4af37}.noticeboard-header{border-bottom:1px solid #d4af3733;margin-bottom:22px;padding-bottom:16px;text-align:center}.noticeboard-location{color:#d4af37;display:block;font-size:.72rem;letter-spacing:.18em;margin-bottom:4px;opacity:.7;text-transform:uppercase}.noticeboard-title{color:#f0e6d2;font-family:Cinzel,serif;font-size:1.25rem;letter-spacing:.04em;margin:0}.noticeboard-nails{display:flex;flex-direction:column;gap:12px}.notice-pin{background:none;border:none;cursor:pointer;padding:0;position:relative;text-align:left;width:100%}.notice-pin-head{background:radial-gradient(circle at 35% 35%,#e8c84a,#8b6914);border-radius:50%;box-shadow:0 1px 3px #0009;height:10px;left:50%;position:absolute;top:-5px;transform:translateX(-50%);width:10px;z-index:1}.notice-paper{background:linear-gradient(160deg,#e8dfc4,#d6c9a0);border:1px solid #00000026;border-radius:1px;box-shadow:0 2px 8px #00000059,inset 0 1px 0 #ffffff4d;color:#2a1f0e;padding:14px 16px 12px;transition:transform .12s ease,box-shadow .12s ease}.notice-pin:first-child .notice-paper{transform:rotate(-.6deg)}.notice-pin:nth-child(2) .notice-paper{transform:rotate(.4deg)}.notice-pin:nth-child(3) .notice-paper{transform:rotate(-.3deg)}.notice-pin:focus .notice-paper,.notice-pin:hover .notice-paper{box-shadow:0 6px 20px #00000073,0 0 0 2px #d4af3766;outline:none;transform:rotate(0) scale(1.01)}.notice-title{color:#5c3d11;display:block;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.12em;margin-bottom:6px;text-transform:uppercase}.notice-body{color:#2a1f0e;font-family:Georgia,serif;font-size:.82rem;line-height:1.55;margin:0 0 10px}.notice-cta{color:#8b4513;display:block;font-size:.72rem;font-style:italic;text-align:right}.noticeboard-footer{align-items:center;display:flex;flex-direction:column;gap:8px;margin-top:20px}.noticeboard-cardgame{background:#0000;border:1px solid #8250c873;color:#a080d0;cursor:pointer;font-family:Cinzel,serif;font-size:.75rem;letter-spacing:.08em;padding:6px 20px;transition:border-color .15s,color .15s}.noticeboard-cardgame:hover{border-color:#a080d0;color:#c0a0f0}.noticeboard-enter{background:#0000;border:1px solid #d4af3766;color:#aaa;cursor:pointer;font-family:Cinzel,serif;font-size:.8rem;letter-spacing:.08em;padding:8px 24px;transition:border-color .15s,color .15s}.noticeboard-enter:hover{border-color:#d4af37;color:#d4af37}.vignette-overlay{align-items:center;background:#000;display:flex;inset:0;justify-content:center;opacity:0;position:fixed;transition:opacity 1.2s ease;z-index:800}.vignette-overlay.vignette-visible{opacity:1}.vignette-panel{animation:vignetteRise 1.4s ease .3s both;max-width:560px;padding:0 24px;text-align:center;width:90vw}@keyframes vignetteRise{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.vignette-image{border-radius:4px;display:block;height:260px;margin-bottom:32px;-webkit-mask-image:linear-gradient(180deg,#000 55%,#0000);mask-image:linear-gradient(180deg,#000 55%,#0000);object-fit:cover;width:100%}.vignette-destination{color:#d4af37;font-family:Cinzel,serif;font-size:.72rem;letter-spacing:.22em;margin:0 0 28px;opacity:.7;text-transform:uppercase}.vignette-text{color:#c8bfb0;font-family:Georgia,Times New Roman,serif;font-size:1.05rem;font-style:italic;line-height:1.85;margin:0 0 40px}.vignette-btn{background:#0000;border:1px solid #d4af3759;color:#d4af37;cursor:pointer;font-family:Cinzel,serif;font-size:.78rem;letter-spacing:.1em;padding:9px 28px;transition:border-color .2s,color .2s,background .2s}.vignette-btn:hover{background:#d4af3714;border-color:#d4af37}.world-map-container{height:100vh;overflow:hidden;position:relative;width:100vw}.world-map-container:after{box-shadow:inset 0 0 120px #000000d9;content:"";inset:0;pointer-events:none;position:absolute;z-index:999}.map-breadcrumb-btn{background:#0a1423d9;border:1px solid #d4af3766;border-radius:4px;color:#d4af37;cursor:pointer;font-family:Cinzel,serif;font-size:.78rem;left:16px;letter-spacing:.08em;padding:7px 14px;position:absolute;top:16px;transition:background .15s,border-color .15s;z-index:1001}.map-breadcrumb-btn:hover{background:#0a1423f2;border-color:#d4af37cc}.map-title{animation:mapTitlePulse 3.5s ease-in-out infinite;color:#d4af37;font-family:Cinzel,serif;font-size:2rem;left:50%;letter-spacing:.25em;margin:0;pointer-events:none;position:absolute;text-transform:uppercase;top:28px;white-space:nowrap;z-index:1000}@keyframes mapTitlePulse{0%,to{text-shadow:0 0 12px #d4af3759,0 2px 4px #000000e6;transform:translateX(-50%) scale(1)}50%{text-shadow:0 0 28px #d4af37e6,0 0 55px #d4af3766,0 2px 4px #000000e6;transform:translateX(-50%) scale(1.04)}}.map-icon{filter:drop-shadow(0 0 6px rgba(0,0,0,.8));transition:transform .2s ease}.map-icon:hover{transform:scale(1.15)}.leaflet-tooltip.map-tooltip{background:#281c12f2;border:1px solid #c2a56d;border-radius:6px;box-shadow:0 0 20px #000c;color:#f5e9d3;font-family:Cinzel,serif;font-size:14px;max-width:320px;padding:10px 14px;white-space:pre-line;width:-webkit-max-content;width:max-content}.leaflet-tooltip:before{display:none}.leaflet-container{background:#0000!important;border-radius:6px;box-shadow:0 40px 80px #000c,0 0 0 6px #3c2d1ee6}.candlelight{animation:candleFlicker 1s ease-in-out infinite;background:radial-gradient(circle at 30% 40%,#ff8c2859,#0000 55%),radial-gradient(circle at 70% 60%,#ffb45040,#0000 60%);inset:0;pointer-events:none;position:absolute;z-index:10}@keyframes candleFlicker{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.map-dice-overlay{bottom:28px;height:260px;pointer-events:auto;position:absolute;right:28px;width:260px;z-index:1200}#dice-canvas{position:absolute!important;z-index:1200!important}#dice-box{bottom:28px;height:260px;pointer-events:auto;position:absolute;right:28px;width:260px;z-index:2001}.dice-layer{inset:0;pointer-events:none;position:absolute;z-index:2000}.dice-layer #dice-box,.dice-layer button{pointer-events:auto}#dice-box:hover{filter:brightness(1.05)}.leaflet-popup-content{white-space:pre-line}.leaflet-popup-content strong{color:#e7cfa1;display:block;font-size:16px;margin-bottom:6px}.leaflet-tooltip.map-label{background:#281c1299;border:1px solid #c2a56d99;border-radius:6px;box-shadow:0 0 8px #0009;color:#f5e6c8;font-family:Cinzel,serif;font-size:13px;font-weight:600;padding:4px 8px}.leaflet-popup.map-tooltip .leaflet-popup-content-wrapper{background:#281c12f2;border:1px solid #c2a56d;border-radius:8px;box-shadow:0 0 20px #000c,inset 0 0 12px #0006;color:#f5e6c8;font-family:Cinzel,serif;font-size:14px;line-height:1.6}.leaflet-popup.map-tooltip .leaflet-popup-tip{background:#281c12f2}.leaflet-tooltip.map-label{pointer-events:none}.leaflet-tooltip.map-label-locked{background:#140e09bf;border-color:#c2a56d73;color:#c8a878}.map-premium-crown-pin{color:#d4af37;font-size:1rem;line-height:1;pointer-events:none;text-shadow:0 0 8px #d4af37e6}.leaflet-tooltip.map-label-premium{background:#140c02d1;border-color:#d4af3780;color:#d4af37;line-height:1.2;padding:3px 8px;text-align:center}.map-label-sublevel{color:#d4af37b3;font-size:.6rem;letter-spacing:.06em;margin-top:1px}.map-icon-locked{align-items:center;cursor:not-allowed;display:flex;filter:drop-shadow(0 0 6px rgba(0,0,0,.8));flex-direction:column;opacity:.6}.lock-emoji{font-size:1.5rem;line-height:1}.lock-level{background:#0009;border-radius:3px;color:#bbb;font-family:Cinzel,serif;font-size:.6rem;margin-top:3px;padding:1px 4px;white-space:nowrap}.map-pin-premium{align-items:center;cursor:pointer;display:flex;flex-direction:column;gap:2px}.map-premium-crown-top{color:#d4af37;font-size:.9rem;line-height:1;text-shadow:0 0 8px #d4af37e6}.map-pin-premium-img-wrap{flex-shrink:0;height:42px;width:42px}.map-pin-premium-img{filter:drop-shadow(0 2px 4px rgba(0,0,0,.6));height:42px;object-fit:contain;width:42px}.map-premium-label{background:#140c02d1;border:1px solid #d4af3780;border-radius:3px;color:#d4af37;font-family:Cinzel,serif;font-size:.55rem;letter-spacing:.05em;padding:1px 5px;text-shadow:0 0 4px #d4af3766;white-space:nowrap}.map-popup-level{color:#aaa;margin-top:2px}.map-popup-level,.map-popup-premium{display:block;font-family:Cinzel,serif;font-size:.7rem;letter-spacing:.05em}.map-popup-premium{color:#d4af37;margin-top:1px;text-shadow:0 0 6px #d4af3766}.map-tavern-pin{align-items:center;background:#140a0373;border:1px solid #d4af378c;border-radius:50%;cursor:default;display:flex;filter:drop-shadow(0 2px 4px rgba(0,0,0,.7));font-size:13px;height:26px;justify-content:center;line-height:1;transition:transform .15s,border-color .15s;width:26px}.map-tavern-pin:hover{border-color:#d4af37e6;transform:scale(1.15)}.leaflet-tooltip.map-tavern-label{background:#1e1206e0;border:1px solid #d4af3780;border-radius:5px;color:#d4af37;font-family:Cinzel,serif;font-size:.65rem;font-weight:700;letter-spacing:.05em;padding:3px 8px;pointer-events:none;white-space:nowrap}.leaflet-tooltip.map-tavern-label:before{border-top-color:#d4af3780}.locked-toast{animation:toastFadeIn .2s ease;background:#1e120af5;border:1px solid #c2a56d;border-radius:6px;bottom:80px;box-shadow:0 0 24px #000c;color:#f5e6c8;font-family:Cinzel,serif;font-size:.9rem;left:50%;padding:10px 24px;pointer-events:none;position:absolute;transform:translateX(-50%);z-index:1500}@keyframes toastFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(8px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.premium-modal-backdrop{align-items:center;background:#0000008c;display:flex;inset:0;justify-content:center;position:absolute;z-index:2000}.premium-modal{animation:premiumModalIn .2s ease;background:#120a04f7;border:1px solid #d4af378c;border-radius:12px;box-shadow:0 0 60px #000000e6,0 0 30px #d4af3714;max-width:340px;padding:2rem 2rem 1.6rem;text-align:center;width:calc(100% - 2rem)}@keyframes premiumModalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.premium-modal-crown{color:#d4af37;font-size:2rem;line-height:1;margin-bottom:.5rem}.premium-modal-title{color:#f5e6c8;font-family:Cinzel,serif;font-size:1.3rem;letter-spacing:.04em;margin:0 0 .75rem}.premium-modal-desc{color:#b0a07a;font-size:.9rem;line-height:1.65;margin:0 0 1rem}.premium-modal-notice{color:#d4af37;font-size:.78rem;letter-spacing:.06em;margin:0 0 1.4rem;text-transform:uppercase}.premium-modal-actions{display:flex;gap:.6rem;justify-content:center}.premium-modal-btn-primary{background:linear-gradient(135deg,#d4af37,#a07c20);border:none;border-radius:6px;color:#0d0800;cursor:pointer;font-family:Cinzel,serif;font-size:.85rem;font-weight:700;letter-spacing:.04em;padding:.55rem 1.2rem;transition:opacity .15s}.premium-modal-btn-primary:hover{opacity:.88}.premium-modal-btn-close{background:#0000;border:1px solid #d4af3759;border-radius:6px;color:#b0a07a;cursor:pointer;font-family:Cinzel,serif;font-size:.85rem;padding:.55rem 1.2rem;transition:border-color .15s,color .15s}.premium-modal-btn-close:hover{border-color:#d4af3799;color:#f5e6c8}.modal-panel{position:relative}.modal-close-button{background:#0000;border:none;color:#d4af37;cursor:pointer;font-size:1.4rem;position:absolute;right:10px;top:10px}.modal-close-button:hover{text-shadow:0 0 6px #ffd778cc}.map-pin-current{height:42px;position:relative;width:42px}.map-pin-img{filter:drop-shadow(0 0 6px rgba(212,175,55,.9)) drop-shadow(0 0 12px rgba(212,175,55,.5));height:42px;inset:0;position:absolute;width:42px;z-index:2}.map-pin-ring{background:#d4af372e;border:2px solid #d4af37;border-radius:50%;box-shadow:0 0 10px 4px #d4af3780,inset 0 0 8px #d4af3733;inset:-8px;position:absolute;z-index:1}.map-pin-ring:after{animation:pinPulse 1.8s ease-out infinite;border:2px solid #d4af3799;border-radius:50%;content:"";inset:-6px;position:absolute}@keyframes pinPulse{0%{opacity:.8;transform:scale(1)}70%{opacity:0;transform:scale(2)}to{opacity:0;transform:scale(2)}}.logo{filter:drop-shadow(0 12px 20px rgba(0,0,0,.6));left:50%;pointer-events:none;position:fixed;top:2vh;transform:translateX(-50%);width:min(840px,90vw);z-index:2}.logo--glow{position:relative}.logo--glow:after{background:radial-gradient(circle,#ffc85073,#0000 40%);content:"";filter:blur(18px);inset:-18%;left:50%;pointer-events:none;position:absolute;transform:translateX(-50%);z-index:-1}@keyframes glowPulse{0%{filter:drop-shadow(0 10px 18px rgba(255,190,70,.35));width:min(840px,90vw)}50%{filter:drop-shadow(0 30px 50px rgba(255,210,90,.75));width:min(880px,95vw)}to{filter:drop-shadow(0 10px 18px rgba(255,190,70,.35));width:min(840px,90vw)}}.logo-pulse{animation:glowPulse 4s ease-in-out infinite;width:min(880px,95vw);will-change:filter,transform;z-index:2}.logo-advanced,.logo-pulse{left:50%;position:fixed;top:2vh}.logo-advanced{pointer-events:none;transform:translateX(-50%);width:min(840px,90vw);z-index:22}.logo-advanced:after,.logo-advanced:before{content:"";left:50%;pointer-events:none;position:absolute;transform:translateX(-50%);z-index:-1}.logo-advanced:before{background:radial-gradient(circle,#ffdc788c,#0000 65%);filter:blur(18px);height:30%;top:20%;width:60%}.logo-advanced:after{background:radial-gradient(circle,#ffb4284d,#0000 60%);bottom:-8%;filter:blur(28px);height:60%;width:130%}.logo-image{display:block;filter:drop-shadow(0 10px 20px rgba(0,0,0,.6));width:100%}.tavern-nav-link{color:#d4af37;font-family:Cinzel,serif;font-size:1.15rem;letter-spacing:.08em;opacity:.9;text-decoration:none;text-shadow:0 0 8px #d4af3780;transition:opacity .2s,text-shadow .2s}.tavern-nav-link:hover{opacity:1;text-shadow:0 0 12px #d4af37e6,0 0 24px #d4af3766}.tavern-nav-plans{opacity:1;text-shadow:0 0 10px #d4af37b3}.tavern-nav-btn{background:none;border:none;cursor:pointer;font:inherit;padding:0}.tavern-cta-row{display:flex;flex-wrap:wrap;gap:24px;justify-content:center;left:50%;position:fixed;top:60%;transform:translateX(-50%);width:min(700px,90vw);z-index:10}@media (max-width:520px){.tavern-cta-row{align-items:center;flex-direction:column;gap:14px;top:55%}.tavern-cta-row .fantasy-button-enter,.tavern-cta-row .fantasy-button-secondary{font-size:1rem;padding:13px 20px;text-align:center;width:80vw}}.tavern-features{bottom:0;max-height:32vh;max-width:90vw;width:auto;z-index:2}.activity-feed,.tavern-features{left:50%;pointer-events:none;position:fixed;transform:translateX(-50%)}.activity-feed{align-items:center;animation:activity-cycle 8s ease forwards;background:#0a0602b8;border:1px solid #b4823c66;border-radius:4px;color:#e6cd9bf2;display:flex;font-family:Crimson Text,serif;font-size:1.15rem;gap:12px;letter-spacing:.02em;padding:9px 20px;text-align:center;text-shadow:0 1px 6px #000c;top:69%;white-space:normal;width:min(780px,90vw);z-index:11}@media (max-width:600px) and (orientation:portrait){.activity-feed{font-size:.88rem;gap:8px;padding:8px 14px;top:72%;width:88vw}.tavern-features{max-height:18vh;width:auto}@keyframes activity-cycle{0%{opacity:0;transform:translateX(-50%) translateY(6px)}10%{opacity:1;transform:translateX(-50%) translateY(0)}80%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(-4px)}}}@keyframes activity-cycle{0%{opacity:0;transform:translateX(-50%) translateY(6px)}10%{opacity:1;transform:translateX(-50%) translateY(0)}80%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(-4px)}}.activity-dot{animation:pulse-dot 2s infinite;background:#c8a84a;border-radius:50%;flex-shrink:0;height:7px;opacity:.8;width:7px}@keyframes pulse-dot{0%,to{opacity:.8}50%{opacity:.3}}.activity-text strong{color:#d4af37}.activity-text em{color:#b8a070;font-style:italic}.activity-time{color:#b4965a8c;flex-shrink:0;font-size:.75rem;margin-left:4px}.legends-page{background:radial-gradient(circle at top,#1a0e05,#0a0502);color:#f5e6b3;display:flex;flex-direction:column;min-height:100vh}.legends-banner{flex-shrink:0;max-height:320px;overflow:hidden;position:relative;width:100%}.legends-banner-img{display:block;height:320px;object-fit:cover;object-position:center top;width:100%}.legends-banner:after{background:linear-gradient(180deg,#0a050226 0,#0a05028c 60%,#0a0502);content:"";inset:0;position:absolute}.legends-banner-overlay{bottom:0;left:0;padding:0 20px 24px;position:absolute;right:0;text-align:center;z-index:1}.legends-title{color:#ffe97a;font-family:Cinzel,serif;font-size:2.6rem;letter-spacing:2px;margin:0 0 6px;text-shadow:0 0 24px #ffd700b3,0 2px 6px #000000e6}.legends-subtitle{color:#d8c68c;font-size:1rem;font-style:italic;margin:0;text-shadow:0 1px 4px #000c}.legends-content{display:flex;flex:1 1;flex-direction:column;gap:20px;margin:0 auto;max-width:820px;padding:28px 24px 40px;width:100%}.legends-scroll{background:#0a0502b3;border:1px solid #b48c3c66;border-radius:10px;box-shadow:inset 0 0 30px #00000080;flex:1 1;overflow-y:auto;padding:16px}.legends-scroll::-webkit-scrollbar{width:8px}.legends-scroll::-webkit-scrollbar-thumb{background:#ffd77880;border-radius:4px}.legends-scroll::-webkit-scrollbar-track{background:#0003}.legend-entry{align-items:center;background:#ffffff0a;border:1px solid #b48c3c33;border-radius:10px;display:flex;margin-bottom:10px;padding:14px 18px;transition:transform .18s ease,box-shadow .18s ease,background .18s ease}.legend-entry:last-child{margin-bottom:0}.legend-entry:hover{background:#ffd7000f;border-color:#ffd70059;box-shadow:0 0 16px #ffd70033;transform:translateX(4px)}.rank-1{border-color:#ffd70080}.rank-2{border-color:#c0c0c066}.rank-3{border-color:#cd7f3266}.legend-left{align-items:center;display:flex;flex-shrink:0;gap:14px}.legend-rank{font-size:1.6rem;min-width:44px;text-align:center}.rank-1 .legend-rank{text-shadow:0 0 12px #ffd700cc}.legend-portrait{border:2px solid #ffd70059;border-radius:8px;height:54px;object-fit:cover;width:54px}.rank-1 .legend-portrait{border-color:#ffd700b3}.rank-2 .legend-portrait{border-color:#c0c0c099}.rank-3 .legend-portrait{border-color:#cd7f3299}.legend-details{flex:1 1;margin-left:18px;min-width:0}.legend-header-row{align-items:baseline;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:2px}.legend-name{color:#ffe9a3;font-family:Cinzel,serif;font-size:1.1rem;margin:0}.legend-alignment{color:#a89060;font-size:.68rem;letter-spacing:.06em;opacity:.85;text-transform:uppercase;white-space:nowrap}.legend-meta{color:#c4b07a;font-size:.82rem;margin-bottom:4px;text-transform:capitalize}.legend-bottom-row{align-items:center;display:flex;flex-wrap:nowrap;gap:12px}.legend-resources{display:flex;flex-shrink:0;gap:10px}.legend-xp{color:#c084fc;font-size:.8rem}.legend-gold{color:#d4af37;font-size:.8rem}.legend-stats{display:flex;flex-shrink:0;gap:3px}.legend-stat{align-items:center;background:#ffffff0a;border:1px solid #b48c3c33;border-radius:3px;display:flex;flex-direction:column;min-width:28px;padding:2px 5px}.legend-stat-label{color:#8a7a5a;font-size:.54rem;letter-spacing:.06em;text-transform:uppercase}.legend-stat-val{color:#e8d8a0;font-size:.76rem;font-weight:700}.legend-error,.legend-loading{color:#a89060;font-style:italic;padding:40px 20px;text-align:center}.legend-error{color:#c87070}.legends-btn-row{display:flex;flex-wrap:wrap;gap:12px;justify-content:center}.legends-lore-link-btn{background:#0000;border:1px solid #b48c3c80;border-radius:6px;color:#c4a85a;cursor:pointer;font-family:Cinzel,serif;font-size:.9rem;letter-spacing:1px;padding:10px 28px;transition:background .15s,color .15s,border-color .15s}.legends-lore-link-btn:hover{background:#ffd70014;border-color:#ffd70080;color:#ffe97a}.legends-back-btn{align-self:center;background:#0000;border:1px solid #b48c3c80;border-radius:6px;color:#c4a85a;cursor:pointer;font-family:Cinzel,serif;font-size:.9rem;letter-spacing:1px;padding:10px 28px;transition:background .15s,color .15s,border-color .15s}.legends-back-btn:hover{background:#ffd70014;border-color:#ffd70080;color:#ffe97a}.legends-lore-page{align-items:center;background:radial-gradient(circle at top,#0f0a05,#070402);color:#d4c49a;display:flex;flex-direction:column;font-family:Georgia,Times New Roman,serif;min-height:100vh}.legends-lore-header{border-bottom:1px solid #b48c3c40;max-width:820px;padding:64px 32px 48px;text-align:center;width:100%}.legends-lore-eyebrow{color:#8a7a5a;font-size:.72rem;letter-spacing:.2em;margin:0 0 12px;text-transform:uppercase}.legends-lore-title{color:#ffe97a;font-family:Cinzel,serif;font-size:2.4rem;letter-spacing:.06em;margin:0 0 24px;text-shadow:0 0 30px #ffd7004d,0 2px 6px #000000e6}.legends-lore-intro{color:#b0a07a;font-size:1rem;font-style:italic;line-height:1.85;margin:0 auto;max-width:580px}.legends-lore-main{display:flex;flex-direction:column;gap:0;max-width:820px;padding:48px 32px;width:100%}.legends-lore-loading{color:#8a7a5a;font-style:italic;padding:40px 0;text-align:center}.legend-lore-entry{border-bottom:1px solid #b48c3c2e;padding:52px 0}.legend-lore-entry:last-child{border-bottom:none}.legend-lore-rank{color:#7a6a4a;font-size:.68rem;letter-spacing:.18em;margin-bottom:24px;text-transform:uppercase}.legend-lore-body{align-items:flex-start;display:flex;gap:36px}.legend-lore-portrait-col{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:12px;width:180px}.legend-lore-portrait{border:1px solid #d4af3773;border-radius:8px;box-shadow:0 6px 32px #000000b3,0 0 16px #d4af371a;height:180px;object-fit:cover;width:180px}.legend-lore-epithet{color:#c8a84a;font-size:.65rem;letter-spacing:.08em;line-height:1.4;text-align:center;text-transform:uppercase}.legend-lore-meta{color:#6a5a3a;font-size:.72rem;letter-spacing:.04em;text-align:center;text-transform:capitalize}.legend-lore-info{flex:1 1;min-width:0;padding-top:4px}.legend-lore-name{color:#ffe9a3;font-family:Cinzel,serif;font-size:1.8rem;letter-spacing:.03em;margin:0 0 20px;text-shadow:0 0 20px #ffd70026}.legend-lore-backstory{color:#c0b08a;font-size:1rem;font-style:italic;line-height:1.9;margin:0 0 20px}.legend-lore-xp{color:#7a6a4a;font-size:.82rem;letter-spacing:.02em;line-height:1.6;margin:0}.legends-lore-footer{border-top:1px solid #b48c3c2e;max-width:820px;padding:32px 32px 64px;text-align:center;width:100%}.legends-lore-footer-text{color:#5a4a2a;font-size:.82rem;font-style:italic;margin:0 0 24px}.legends-lore-nav{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.legends-lore-btn{background:#0000;border:1px solid #d4af374d;color:#a08040;cursor:pointer;font-family:Cinzel,serif;font-size:.75rem;letter-spacing:.08em;padding:9px 22px;transition:border-color .2s,color .2s}.legends-lore-btn:hover{background:#0000;border-color:#d4af37;color:#d4af37}@media (max-width:600px){.legend-lore-body{align-items:center;flex-direction:column}.legend-lore-info{text-align:center}}.plans-page{align-items:center;background:radial-gradient(circle at top,#0f0a05,#070402);color:#d4c49a;display:flex;flex-direction:column;font-family:Georgia,Times New Roman,serif;min-height:100vh;padding-bottom:64px}.plans-header{max-width:640px;padding:64px 24px 48px;text-align:center}.plans-eyebrow{color:#8a7a5a;font-size:.7rem;letter-spacing:.22em;margin:0 0 12px;text-transform:uppercase}.plans-title{color:#ffe97a;font-family:Cinzel,serif;font-size:clamp(1.8rem,4vw,2.6rem);letter-spacing:.05em;margin:0 0 18px;text-shadow:0 0 30px #ffd70040}.plans-subtitle{color:#b0a07a;font-family:Crimson Text,serif;font-size:1.05rem;font-style:italic;line-height:1.8;margin:0}.plans-grid{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:repeat(3,1fr);width:min(calc(100% - 48px),1060px)}.plan-card{background:#120b04d9;border:1px solid #b48c3c40;border-radius:6px;display:flex;flex-direction:column;overflow:hidden;position:relative;transition:border-color .2s}.plan-card:hover{border-color:#b48c3c80}.plan-card-premium{border-color:#d4af3780;box-shadow:0 0 32px #d4af3714}.plan-card-locked{opacity:.55}.plan-card-locked,.plan-card-locked .plan-btn{pointer-events:none}.plan-badge{background:#d4af3726;border:1px solid #d4af3780;border-radius:3px;color:#d4af37;font-family:Cinzel,serif;font-size:.6rem;letter-spacing:.1em;padding:3px 9px;position:absolute;right:12px;text-transform:uppercase;top:12px;z-index:1}.plan-badge-soon{background:#503c5026;border-color:#a090a066;color:#a090a0}.plan-badge-legend{background:#581c8733;border-color:#c084fc73;color:#c084fc}.plan-img{aspect-ratio:1;border-bottom:1px solid #b48c3c33;display:block;object-fit:cover;width:100%}.plan-body{display:flex;flex-direction:column;gap:0;padding:20px 20px 24px}.plan-name{color:#c8b87a;font-family:Cinzel,serif;font-size:1.25rem;letter-spacing:.04em;margin:0 0 4px}.plan-name-premium{color:#ffe97a}.plan-name-legend{color:#c084fc}.plan-price{align-items:baseline;display:flex;gap:4px;margin:0 0 18px}.plan-price-amount{color:#c8b87a;font-family:Cinzel,serif;font-size:1.5rem;letter-spacing:.02em}.plan-card-premium .plan-price-amount{color:#ffe97a}.plan-card-legend .plan-price-amount{color:#c084fc}.plan-price-period{color:#6a5a3a;font-size:.72rem;letter-spacing:.05em}.plan-features{display:flex;flex-direction:column;gap:9px;list-style:none;margin:0 0 24px;padding:0}.plan-features li{align-items:baseline;border-bottom:1px solid #b48c3c1a;display:flex;font-size:.82rem;gap:8px;justify-content:space-between;padding-bottom:9px}.plan-features li:last-child{border-bottom:none;padding-bottom:0}.plan-feat-label{color:#7a6a4a;flex-shrink:0;letter-spacing:.03em}.plan-feat-value{color:#c0b08a;text-align:right}.plan-feat-highlight .plan-feat-value{color:#d4af37;font-weight:600}.plan-btn{border:1px solid;border-radius:4px;cursor:pointer;font-family:Cinzel,serif;font-size:.78rem;letter-spacing:.1em;margin-top:auto;padding:11px 0;transition:all .2s;width:100%}.plan-btn-free{background:#0000;border-color:#b48c3c59;color:#a08040}.plan-btn-free:hover{border-color:#d4af37;color:#d4af37}.plan-btn-premium{background:#d4af371f;border-color:#d4af3799;color:#ffe97a}.plan-btn-premium:hover:not(:disabled){background:#d4af3738;border-color:#d4af37;box-shadow:0 0 16px #d4af3733}.plan-btn-premium:disabled{cursor:not-allowed;opacity:.6}.plan-btn-legend{background:#0000;border-color:#c084fc4d;color:#c084fc;cursor:pointer}.plan-btn-legend:hover:not(:disabled){background:#c084fc1f;border-color:#c084fcb3}.plan-btn-legend:disabled{cursor:not-allowed;opacity:.6}.plan-error{color:#e05050;font-size:.78rem;margin:0 0 10px;text-align:center}.plans-nav{margin-top:48px}.plans-back-btn{background:#0000;border:1px solid #d4af3747;color:#a08040;cursor:pointer;font-family:Cinzel,serif;font-size:.75rem;letter-spacing:.08em;padding:9px 22px;transition:color .2s,border-color .2s}.plans-back-btn:hover{border-color:#d4af37;color:#d4af37}@media (max-width:780px){.plans-grid{grid-template-columns:1fr;max-width:420px}}
/*# sourceMappingURL=main.1da4b141.css.map*/