:root{--color-void: #0a0014;--color-deep-purple: #1a0033;--color-mystic-purple: #2d1b4e;--color-arcane-blue: #1e3a8a;--color-ethereal-cyan: #0ea5e9;--color-magic-pink: #ec4899;--color-enchant-violet: #a855f7;--color-celestial-gold: #fbbf24;--color-divine-white: #f8fafc;--bg-gradient-main: linear-gradient(135deg, var(--color-void) 0%, var(--color-deep-purple) 50%, var(--color-mystic-purple) 100%);--bg-gradient-card: linear-gradient(135deg, rgba(26, 0, 51, .8) 0%, rgba(45, 27, 78, .6) 100%);--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-accent: var(--color-celestial-gold);--border-glow: 0 0 20px rgba(168, 85, 247, .5);--border-glow-intense: 0 0 30px rgba(236, 72, 153, .8);font-family:Alegreya,Georgia,serif;line-height:1.6;font-weight:400;--font-sans: "Alegreya Sans", "Helvetica Neue", sans-serif;--font-decorative: "Cinzel Decorative", "Alegreya", serif;color:var(--text-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}*,*:before,*:after{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*,*:before,*:after{-webkit-tap-highlight-color:transparent;-webkit-backface-visibility:hidden;backface-visibility:hidden}.magic-particles-canvas,.radial-stat-glyph,.dice-roller,.chat-box,.interactive-map{contain:layout style paint}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-gradient-main);overflow-x:hidden;will-change:auto;text-rendering:optimizeSpeed}#root,.app{width:100%;min-height:100vh}@keyframes twinkle{0%,to{opacity:.3}50%{opacity:1}}@keyframes float{0%,to{transform:translateY(0) translateZ(0)}50%{transform:translateY(-20px) translateZ(0)}}.animated-star,.floating-element{will-change:opacity,transform;animation-fill-mode:forwards}h1,h2,h3,h4,h5,h6{font-family:Alegreya,Georgia,serif;font-weight:700;color:var(--text-primary);text-shadow:0 0 10px rgba(168,85,247,.5)}h1{font-size:3.5rem;line-height:1.2;background:linear-gradient(135deg,var(--color-enchant-violet),var(--color-magic-pink),var(--color-celestial-gold));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}button{border-radius:12px;border:2px solid var(--color-enchant-violet);padding:.8em 2em;font-size:1.1em;font-weight:600;font-family:Alegreya Sans,Helvetica Neue,sans-serif;background:linear-gradient(135deg,#a855f733,#ec489933);color:var(--text-primary);cursor:pointer;transition:all .3s ease;box-shadow:var(--border-glow);position:relative;overflow:hidden;will-change:transform,box-shadow;transform:translateZ(0)}button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}button:hover:before{left:100%}button:hover{border-color:var(--color-magic-pink);box-shadow:var(--border-glow-intense);transform:translateY(-2px)}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed}input,select,textarea{background:#1a003399;border:2px solid var(--color-mystic-purple);border-radius:8px;padding:.8em 1.2em;color:var(--text-primary);font-family:Alegreya,Georgia,serif;font-size:1em;transition:border-color .3s ease,box-shadow .3s ease;will-change:border-color,box-shadow}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-enchant-violet);box-shadow:var(--border-glow)}::-webkit-scrollbar{width:10px}::-webkit-scrollbar-track{background:var(--color-deep-purple)}::-webkit-scrollbar-thumb{background:var(--color-enchant-violet);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--color-magic-pink)}@media(max-width:1024px){:root{font-size:15px}h1{font-size:2.5rem}button{font-size:1rem;padding:.7em 1.5em}}@media(max-width:768px){:root{font-size:14px}body{min-width:100%}h1{font-size:2rem}h2{font-size:1.5rem}button{font-size:.95rem;padding:.6em 1.2em}input,select,textarea{font-size:.95rem;padding:.7em 1em}}@media(max-width:480px){:root{font-size:13px}h1{font-size:1.75rem}h2{font-size:1.25rem}h3{font-size:1.1rem}button{font-size:.9rem;padding:.5em 1em;width:100%;max-width:100%}input,select,textarea{font-size:.9rem;padding:.6em .9em}}@media(max-width:360px){:root{font-size:12px}h1{font-size:1.5rem}}.app{width:100%;min-height:100vh;position:relative}.stars-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:0}.star{position:absolute;width:2px;height:2px;background:#fff;border-radius:50%;animation:twinkle 3s infinite}.mystical-card{background:var(--bg-gradient-card);border:2px solid var(--color-enchant-violet);border-radius:16px;padding:2rem;box-shadow:var(--border-glow);backdrop-filter:blur(10px);transition:all .3s ease}.mystical-card:hover{box-shadow:var(--border-glow-intense);transform:translateY(-5px)}.glow-text{text-shadow:0 0 10px rgba(168,85,247,.8),0 0 20px rgba(236,72,153,.6),0 0 30px rgba(251,191,36,.4)}@keyframes pulse-glow{0%,to{box-shadow:0 0 20px #a855f780}50%{box-shadow:0 0 40px #ec4899cc}}.pulse-glow{animation:pulse-glow 2s infinite}.float-animation{animation:float 3s ease-in-out infinite}.loading-screen{position:fixed;inset:0;background:linear-gradient(135deg,var(--color-void) 0%,var(--color-deep-purple) 50%,var(--color-mystic-purple) 100%);display:flex;align-items:center;justify-content:center;z-index:9999;overflow:hidden}.loading-content{display:flex;flex-direction:column;align-items:center;gap:2rem;position:relative;z-index:2}.loading-compass{filter:drop-shadow(0 0 20px rgba(168,85,247,.8)) drop-shadow(0 0 40px rgba(236,72,153,.6))}.loading-text{font-size:1.5rem;font-weight:600;background:linear-gradient(90deg,var(--color-enchant-violet),var(--color-magic-pink),var(--color-celestial-gold),var(--color-magic-pink),var(--color-enchant-violet));background-size:200% 100%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:gradient-flow 3s linear infinite;letter-spacing:.1em;text-transform:uppercase}@keyframes gradient-flow{0%{background-position:0% 50%}to{background-position:200% 50%}}.loading-particles{position:absolute;inset:0;pointer-events:none;z-index:1}.loading-particle{position:absolute;width:4px;height:4px;border-radius:50%;background:radial-gradient(circle,var(--color-celestial-gold) 0%,var(--color-magic-pink) 50%,transparent 100%);box-shadow:0 0 10px var(--color-celestial-gold)}.error-boundary{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,var(--color-void),var(--color-deep-purple))}.error-content{max-width:600px;width:100%;padding:3rem;text-align:center}.error-icon{font-size:5rem;margin-bottom:1.5rem;animation:pulse-glow 2s ease-in-out infinite}.error-title{font-size:2.5rem;margin-bottom:1rem;color:var(--color-celestial-gold)}.error-message{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem;line-height:1.6}.error-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.error-btn{padding:.75rem 1.5rem;border-radius:8px;font-family:Alegreya,serif;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;border:2px solid}.error-btn.primary{background:linear-gradient(135deg,var(--color-enchant-violet),var(--color-magic-pink));border-color:var(--color-enchant-violet);color:var(--text-primary);box-shadow:0 0 20px #a855f766}.error-btn.primary:hover{box-shadow:0 0 30px #a855f799}.error-btn.secondary{background:#2a1b4e99;border-color:var(--color-mystic-purple);color:var(--text-primary)}.error-btn.secondary:hover{border-color:var(--color-enchant-violet);box-shadow:0 0 15px #a855f74d}.error-details{margin-top:2rem;text-align:left;background:#0a001480;border:1px solid var(--color-mystic-purple);border-radius:8px;padding:1rem}.error-details summary{cursor:pointer;color:var(--color-ethereal-cyan);font-weight:600;margin-bottom:.5rem}.error-details pre{color:#fca5a5;font-size:.85rem;overflow-x:auto;white-space:pre-wrap;word-wrap:break-word}@media(max-width:768px){.error-content{padding:2rem}.error-title{font-size:2rem}.error-icon{font-size:4rem}.error-actions{flex-direction:column}.error-btn{width:100%}}.connection-status{position:fixed;top:1rem;left:0;right:0;display:flex;justify-content:center;z-index:10000;pointer-events:none;padding:0 1rem;box-sizing:border-box}.status-indicator{display:inline-flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;border-radius:12px;font-family:Alegreya,serif;font-size:.95rem;font-weight:600;box-shadow:0 4px 20px #0000004d;backdrop-filter:blur(10px);white-space:nowrap}.status-indicator.disconnected{background:linear-gradient(135deg,#ef4444f2,#dc2626f2);border:2px solid #ef4444;color:#fff}.status-indicator.reconnecting{background:linear-gradient(135deg,#fbbf24f2,#f59e0bf2);border:2px solid #fbbf24;color:#1a0033}.status-icon{font-size:1.2rem;animation:icon-pulse 2s ease-in-out infinite}.status-indicator.reconnecting .status-icon{animation:icon-spin 1.5s linear infinite}@keyframes icon-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.status-text{text-shadow:0 2px 4px rgba(0,0,0,.2)}@media(max-width:768px){.connection-status{top:.5rem;padding:0 .5rem}.status-indicator{padding:.6rem 1rem;font-size:.85rem}}@media(max-width:480px){.connection-status{top:.25rem;padding:0 .25rem}.status-indicator{padding:.5rem .75rem;font-size:.8rem;gap:.5rem}.status-icon{font-size:1rem}}
