*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{color:#fff;-webkit-font-smoothing:antialiased;background:#0f0c29;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}body,#root{min-height:100vh}.form-group{margin-bottom:1rem}.form-group label{color:#a8a4cc;margin-bottom:.3rem;font-size:.85rem;display:block}.form-group input{color:#fff;background:#ffffff0f;border:1px solid #ffffff26;border-radius:8px;outline:none;width:100%;padding:.75rem;font-size:1rem;transition:border-color .2s}.form-group input:focus{border-color:gold}.btn{color:#fff;cursor:pointer;text-align:center;background:#ffffff14;border:1px solid #ffffff26;border-radius:8px;padding:.65rem 1.25rem;font-size:.9rem;transition:all .2s}.btn:active{transform:scale(.97)}.btn-primary{color:#1a1740;background:linear-gradient(135deg,gold,#e6a800);border:none;font-weight:600}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-danger{color:#e74c3c;background:#e74c3c33;border-color:#e74c3c66}.btn-link{color:#a8a4cc;cursor:pointer;background:0 0;border:none;padding:.5rem;font-size:.85rem;text-decoration:underline}.btn-small{padding:.35rem .75rem;font-size:.75rem}.btn-large{width:100%;padding:.85rem;font-size:1rem}.error-message{color:#e74c3c;text-align:center;background:#e74c3c26;border:1px solid #e74c3c4d;border-radius:8px;margin-bottom:1rem;padding:.6rem;font-size:.85rem}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:2px}.login-page{background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);justify-content:center;align-items:center;min-height:100vh;padding:1rem;display:flex}.login-container{width:100%;max-width:400px}.login-header{text-align:center;margin-bottom:2rem}.game-title{color:gold;text-shadow:0 0 20px #ffd70066;margin:0;font-family:Georgia,serif;font-size:2.2rem}.game-subtitle{color:#a8a4cc;margin:.5rem 0 0;font-size:.95rem}.beta-badge{color:#ff8a50;letter-spacing:.1em;background:#ff643233;border:1px solid #ff643280;border-radius:12px;margin-top:.5rem;padding:.2rem .8rem;font-size:.7rem;font-weight:700;display:inline-block}.login-form{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff12;border:1px solid #ffffff1f;border-radius:16px;padding:2rem}.login-form h2{color:#fff;text-align:center;margin:0 0 1.5rem}.char-select-page{color:#fff;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);min-height:100vh;padding:1rem}.char-select-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1.5rem;display:flex}.char-select-header h1{color:gold;margin:0;font-family:Georgia,serif;font-size:1.5rem}.user-info{color:#a8a4cc;align-items:center;gap:.75rem;font-size:.9rem;display:flex}.char-select-page h2{margin-bottom:1rem;font-size:1.2rem}.character-list{flex-direction:column;gap:1rem;display:flex}.character-card{cursor:pointer;background:#ffffff12;border:1px solid #ffffff1f;border-radius:12px;padding:1rem;transition:all .2s}.character-card:active{transform:scale(.98)}.character-card:hover{border-color:gold}.char-card-top{align-items:center;gap:.75rem;margin-bottom:.75rem;display:flex}.class-icon{font-size:2rem}.char-info h3{margin:0;font-size:1.1rem}.char-class{color:#a8a4cc;font-size:.85rem}.char-stats-bar{flex-direction:column;gap:.4rem;margin-bottom:.75rem;display:flex}.char-card-footer{color:#a8a4cc;justify-content:space-between;align-items:center;font-size:.8rem;display:flex}.create-card{color:#a8a4cc;border-style:dashed;flex-direction:column;justify-content:center;align-items:center;min-height:100px;display:flex}.plus{margin-bottom:.25rem;font-size:2rem}.create-modal{z-index:100;background:#000000d9;justify-content:center;align-items:flex-start;padding:1rem;display:flex;position:fixed;inset:0;overflow-y:auto}.create-form{background:#1a1740;border:1px solid #ffffff1f;border-radius:16px;width:100%;max-width:500px;margin-top:2rem;padding:1.5rem}.create-form h2{color:gold;margin:0 0 1rem}.class-grid{grid-template-columns:1fr 1fr;gap:.75rem;margin-top:.5rem;display:grid}.class-option{cursor:pointer;text-align:center;background:#ffffff0d;border:2px solid #ffffff1a;border-radius:10px;padding:.75rem;transition:all .2s}.class-option.selected{background:#ffd7001a;border-color:gold}.class-icon-large{margin-bottom:.3rem;font-size:2rem;display:block}.class-option strong{color:#fff;margin-bottom:.25rem;display:block}.class-option p{color:#a8a4cc;margin:0 0 .4rem;font-size:.7rem}.base-stats{color:#88b;flex-wrap:wrap;justify-content:center;gap:.3rem;font-size:.65rem;display:flex}.form-actions{gap:.75rem;margin-top:1rem;display:flex}.game-page{color:#fff;background:linear-gradient(#0f0c29,#1a1740);flex-direction:column;max-width:600px;min-height:100vh;margin:0 auto;display:flex}.game-header{background:#0000004d;border-bottom:1px solid #ffffff14;align-items:center;gap:.75rem;padding:.75rem 1rem;display:flex}.header-info{flex-direction:column;flex:1;line-height:1.2;display:flex}.header-info span{color:#a8a4cc;text-transform:capitalize;font-size:.75rem}.header-gold{color:gold;font-size:1rem;font-weight:700}.status-bars{flex-direction:column;gap:.3rem;padding:.5rem 1rem;display:flex}.stat-bar{align-items:center;gap:.4rem;font-size:.75rem;display:flex}.stat-bar span:first-child{color:#a8a4cc;width:22px;font-weight:700}.stat-bar span:last-child{text-align:right;color:#ccc;width:70px;font-size:.7rem}.stat-bar .bar{background:#ffffff1a;border-radius:5px;flex:1;height:10px;overflow:hidden}.stat-bar.hp .bar div{background:linear-gradient(90deg,#e74c3c,#2ecc71);border-radius:5px;height:100%;transition:width .3s}.stat-bar.mp .bar div{background:linear-gradient(90deg,#3498db,#9b59b6);border-radius:5px;height:100%;transition:width .3s}.stat-bar.enemy-hp .bar div{background:linear-gradient(90deg,#e74c3c,#c0392b);border-radius:5px;height:100%;transition:width .3s}.xp-bar{align-items:center;gap:.4rem;font-size:.7rem;display:flex}.xp-bar span:first-child{color:#a8a4cc;width:22px;font-weight:700}.xp-bar span:last-child{text-align:right;color:#ccc;width:70px;font-size:.7rem}.xp-bar .bar{background:#ffffff1a;border-radius:3px;flex:1;height:6px;overflow:hidden}.xp-bar .bar div{background:linear-gradient(90deg,#f1c40f,#e67e22);border-radius:3px;height:100%;transition:width .3s}.message-banner{color:gold;text-align:center;background:#ffd70026;border:1px solid #ffd7004d;border-radius:8px;margin:0 1rem;padding:.5rem;font-size:.85rem;animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.tab-nav{-webkit-overflow-scrolling:touch;gap:2px;padding:.5rem 1rem 0;display:flex;overflow-x:auto}.tab{color:#a8a4cc;cursor:pointer;white-space:nowrap;background:#ffffff0d;border:none;border-radius:8px 8px 0 0;flex:1;min-width:60px;padding:.5rem .3rem;font-size:.75rem;font-weight:600;transition:all .2s}.tab.active{color:gold;background:#ffd70026}.tab-content{flex:1;padding:1rem;overflow-y:auto}.location-info{background:#ffffff0d;border-radius:10px;margin-bottom:1rem;padding:1rem}.location-info h2{color:gold;margin:0 0 .5rem;font-size:1.2rem}.location-info p{color:#a8a4cc;margin:0;font-size:.85rem;line-height:1.4}.ward-indicator{color:#64c8ff;background:#64c8ff26;border:1px solid #64c8ff4d;border-radius:6px;margin-top:.5rem;padding:.4rem .75rem;font-size:.8rem}.explore-tab h3{color:#ddd;margin:1rem 0 .5rem;font-size:.95rem}.travel-grid{flex-direction:column;gap:.5rem;display:flex}.travel-btn{color:#fff;cursor:pointer;text-align:left;background:#ffffff12;border:1px solid #ffffff1a;border-radius:10px;justify-content:space-between;align-items:center;padding:.75rem 1rem;transition:all .2s;display:flex}.travel-btn:hover:not(.locked){border-color:gold}.travel-btn:active:not(.locked){transform:scale(.98)}.travel-btn.locked{opacity:.5;cursor:not-allowed}.travel-btn strong{font-size:.9rem}.travel-btn span{color:#a8a4cc;font-size:.75rem}.monster-display{text-align:center;background:#c832321a;border:1px solid #c8323233;border-radius:12px;margin-bottom:.75rem;padding:1rem}.monster-display h2{color:#e74c3c;margin:0 0 .5rem;font-size:1.3rem}.monster-tier-1{border-color:#ffffff40}.monster-tier-2{background:#2ecc710f;border-color:#2ecc7166}.monster-tier-3{background:#3498db0f;border-color:#3498db66}.monster-tier-4{background:#9b59b614;border-color:#9b59b680}.monster-tier-5{background:#ffd70014;border-color:#ffd70080}.monster-name-modified.tier-1{color:#ccc}.monster-name-modified.tier-2{color:#2ecc71}.monster-name-modified.tier-3{color:#3498db}.monster-name-modified.tier-4{color:#9b59b6}.monster-name-modified.tier-5{color:gold;text-shadow:0 0 10px #ffd70066}.monster-modifier-badge{border-radius:4px;margin-bottom:.5rem;padding:.15rem .5rem;font-size:.7rem;display:inline-block}.monster-modifier-badge.tier-1{color:#aaa;background:#ffffff14}.monster-modifier-badge.tier-2{color:#2ecc71;background:#2ecc711f}.monster-modifier-badge.tier-3{color:#3498db;background:#3498db1f}.monster-modifier-badge.tier-4{color:#9b59b6;background:#9b59b626}.monster-modifier-badge.tier-5{color:gold;background:#ffd70026}.combat-log{background:#0000004d;border-radius:8px;max-height:180px;margin-bottom:.75rem;padding:.75rem;font-size:.8rem;line-height:1.6;overflow-y:auto}.log-entry.player{color:#3498db}.log-entry.enemy{color:#e74c3c}.log-entry.heal{color:#2ecc71}.log-entry.buff{color:#9b59b6}.log-entry.evade{color:#64b5f6;font-style:italic}.log-entry.system{color:#a8a4cc}.log-entry.reward{color:gold;font-weight:700}.log-entry.loot{color:#2ecc71;font-weight:600}.log-entry.loot-modified{color:#9b59b6;font-weight:600}.log-entry.levelup{color:#f1c40f;font-size:.95rem;font-weight:700}.log-entry.defeat{color:#e74c3c;font-weight:700}.ability-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.ability-btn{color:#fff;cursor:pointer;background:#3498db26;border:1px solid #3498db4d;border-radius:10px;flex-direction:column;align-items:center;padding:.6rem;transition:all .2s;display:flex}.ability-btn:active:not(:disabled){transform:scale(.95)}.ability-btn:disabled{opacity:.4;cursor:not-allowed}.ability-btn strong{font-size:.85rem}.ability-btn span{color:#a8a4cc;font-size:.7rem}.flee-btn{background:#e74c3c26;border-color:#e74c3c4d}.inventory-tab h2,.equip-tab h2,.stats-tab h2,.shop-tab h2,.storage-tab h2{color:gold;margin:0 0 1rem;font-size:1.2rem}.slot-counter{color:#a8a4cc;font-size:.85rem;font-weight:400}.slot-counter.slot-full{color:#f44;font-weight:700}.empty-msg{color:#666;text-align:center;padding:2rem}.item-list{flex-direction:column;gap:.5rem;display:flex}.item-card{background:#ffffff0d;border:1px solid #ffffff14;border-radius:10px;justify-content:space-between;align-items:center;gap:.5rem;padding:.75rem;display:flex}.item-info{flex-direction:column;flex:1;gap:.15rem;display:flex}.item-info strong{font-size:.9rem}.item-desc{color:#a8a4cc;font-size:.7rem}.item-price{color:gold;font-size:.75rem}.item-actions{gap:.4rem;display:flex}.equip-slot{background:#ffffff0d;border:1px solid #ffffff14;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem;display:flex}.slot-label{color:#a8a4cc;width:80px;font-size:.85rem;font-weight:700}.equipped-item{flex:1;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.equipped-item-info{flex-direction:column;gap:.15rem;display:flex}.equipped-item-name{font-size:.85rem;font-weight:600}.equipped-item-mods{color:#2ecc71;letter-spacing:.3px;font-size:.72rem}.equipped-item-bonus{color:#9b59b6;letter-spacing:.3px;font-size:.72rem}.modified-name{color:#9b59b6!important}.item-modified{background:#9b59b60f!important;border-color:#9b59b64d!important}.item-bonus{color:#9b59b6;letter-spacing:.3px;font-size:.72rem}.stat-positive{color:#2ecc71!important}.stat-negative{color:#e74c3c!important}.empty-slot{color:#555;font-size:.8rem}.equip-tab h3,.shop-tab h3,.storage-tab h3{color:#ddd;margin:1rem 0 .5rem;font-size:.95rem}.stats-grid{grid-template-columns:1fr 1fr 1fr;gap:.5rem;display:grid}.stat-item{text-align:center;background:#ffffff0d;border-radius:8px;padding:.5rem}.stat-item span{color:#a8a4cc;font-size:.7rem;display:block}.stat-item strong{color:gold;font-size:1.1rem}.char-class-label{color:#a8a4cc;text-transform:capitalize;margin:0 0 1rem;font-size:.9rem}.detail-stats{flex-direction:column;gap:.4rem;margin-bottom:1.5rem;display:flex}.detail-stats>div{background:#ffffff0a;border-radius:6px;justify-content:space-between;padding:.4rem .75rem;font-size:.85rem;display:flex}.detail-stats span{color:#a8a4cc}.detail-stats strong{color:#fff}.abilities-list{flex-direction:column;gap:.5rem;display:flex}.ability-detail{background:#ffffff0d;border-radius:8px;flex-direction:column;gap:.15rem;padding:.6rem .75rem;display:flex}.ability-detail strong{font-size:.9rem}.ability-detail span{color:#a8a4cc;font-size:.75rem}.mp-cost{color:#9b59b6!important}.shop-tab h3{margin-top:1.5rem}.battle-summary-overlay{z-index:1000;background:#0a081ef2;justify-content:center;align-items:center;animation:.5s ease-out summaryFadeIn;display:flex;position:fixed;inset:0}@keyframes summaryFadeIn{0%{opacity:0}to{opacity:1}}.battle-summary-content{text-align:center;width:90%;max-width:380px;padding:2rem;animation:.6s ease-out .2s both summarySlideUp}@keyframes summarySlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.battle-summary-title{color:gold;text-shadow:0 0 30px #ffd70066;letter-spacing:2px;text-transform:uppercase;margin:0 0 .3rem;font-family:Georgia,serif;font-size:2.2rem}.battle-summary-monster{color:#a8a4cc;margin:0 0 1.2rem;font-size:.95rem}.battle-summary-rewards{flex-direction:column;gap:.5rem;margin-bottom:1.2rem;display:flex}.battle-reward{background:#ffd70014;border:1px solid #ffd70026;border-radius:8px;justify-content:space-between;padding:.5rem 1rem;font-size:.85rem;display:flex}.battle-reward span{color:#a8a4cc}.battle-reward strong{color:#4ade80}.battle-summary-loot{text-align:left;margin-bottom:1.2rem}.battle-summary-loot h3{color:gold;text-transform:uppercase;letter-spacing:1px;margin:0 0 .5rem;font-size:.85rem}.battle-loot-item{text-align:left;color:#fff;background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;flex-direction:column;width:100%;margin-bottom:.3rem;padding:.4rem .75rem;font-size:.85rem;display:flex}.battle-loot-item.loot-clickable{cursor:pointer;transition:background .15s,border-color .15s,transform .1s}.battle-loot-item.loot-clickable:hover:not(:disabled){background:#ffd7001a;border-color:#ffd7004d;transform:translate(3px)}.battle-loot-item.loot-modified{background:#9333ea1f;border:1px solid #9333ea40}.battle-loot-item.loot-modified.loot-clickable:hover:not(:disabled){background:#9333ea33;border-color:#9333ea66}.battle-loot-item .item-bonus{color:#a78bfa;margin-top:.15rem;font-size:.75rem}.battle-no-loot{color:#666;margin:0 0 1.2rem;font-size:.8rem;font-style:italic}.battle-levelup{color:gold;background:#ffd7001a;border:1px solid #ffd70040;border-radius:8px;margin-bottom:1.2rem;padding:.6rem 1rem;font-size:1.1rem;font-weight:700;animation:1.5s ease-in-out infinite levelupGlow}@keyframes levelupGlow{0%,to{text-shadow:0 0 10px #ffd7004d}50%{text-shadow:0 0 25px #ffd70099}}.death-overlay{z-index:1000;background:#0a0008;justify-content:center;align-items:center;animation:1s ease-out deathFadeIn;display:flex;position:fixed;inset:0}@keyframes deathFadeIn{0%{opacity:0;background:#c800004d}30%{opacity:1;background:#c8000026}to{opacity:1;background:#0a0008}}.death-content{text-align:center;max-width:360px;padding:2rem;animation:.8s ease-out .3s both deathSlideUp}@keyframes deathSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.death-skull{filter:grayscale(.5);margin-bottom:.5rem;font-size:4rem;animation:2s ease-in-out infinite skullPulse}@keyframes skullPulse{0%,to{opacity:.8;transform:scale(1)}50%{opacity:1;transform:scale(1.08)}}.death-title{color:#c0392b;text-shadow:0 0 30px #c0392b80;letter-spacing:3px;text-transform:uppercase;margin:0 0 .5rem;font-family:Georgia,serif;font-size:2.5rem}.death-message{color:#a8a4cc;margin:0 0 1.5rem;font-size:.95rem}.death-message strong{color:#e74c3c}.death-penalties{flex-direction:column;gap:.5rem;margin-bottom:1.5rem;display:flex}.death-penalty{background:#c0392b1a;border:1px solid #c0392b33;border-radius:8px;justify-content:space-between;padding:.5rem 1rem;font-size:.85rem;display:flex}.death-penalty span{color:#a8a4cc}.death-penalty strong{color:#e74c3c}.death-revive{color:#666;margin:0 0 1.5rem;font-size:.8rem;font-style:italic}.travel-overlay{z-index:1000;background:#0f0c29;justify-content:center;align-items:center;animation:.4s ease-out travelFadeIn;display:flex;position:fixed;inset:0}@keyframes travelFadeIn{0%{opacity:0}to{opacity:1}}.travel-animation{text-align:center;animation:1.5s ease-in-out infinite travelPulse}@keyframes travelPulse{0%,to{transform:scale(1)}50%{transform:scale(1.03)}}.travel-text{color:#a8a4cc;letter-spacing:1px;text-transform:uppercase;margin:0 0 .3rem;font-size:.9rem}.travel-dest{color:gold;text-shadow:0 0 20px #ffd7004d;margin:0;font-family:Georgia,serif;font-size:1.6rem}.travel-dots{color:gold;margin-top:1rem;font-size:1.5rem}.travel-dots span{animation:1.2s ease-in-out infinite dotBounce;display:inline-block}.travel-dots span:nth-child(2){animation-delay:.2s}.travel-dots span:nth-child(3){animation-delay:.4s}@keyframes dotBounce{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-8px)}}.travel-particles{height:80px;margin-bottom:1rem;position:relative}.travel-particles span{background:gold;border-radius:50%;width:4px;height:4px;animation:1.5s ease-out infinite particleFly;position:absolute;left:50%}.travel-particles span:first-child{animation-delay:0s;transform:rotate(0)}.travel-particles span:nth-child(2){animation-delay:.25s;transform:rotate(60deg)}.travel-particles span:nth-child(3){animation-delay:.5s;transform:rotate(120deg)}.travel-particles span:nth-child(4){animation-delay:.75s;transform:rotate(180deg)}.travel-particles span:nth-child(5){animation-delay:1s;transform:rotate(240deg)}.travel-particles span:nth-child(6){animation-delay:1.25s;transform:rotate(300deg)}@keyframes particleFly{0%{opacity:1;transform:translate(0)scale(1)}to{opacity:0;transform:translate(var(--tx,30px), var(--ty,-40px)) scale(0)}}.travel-particles span:first-child{--tx:-25px;--ty:-35px}.travel-particles span:nth-child(2){--tx:30px;--ty:-30px}.travel-particles span:nth-child(3){--tx:-35px;--ty:10px}.travel-particles span:nth-child(4){--tx:20px;--ty:25px}.travel-particles span:nth-child(5){--tx:-15px;--ty:-45px}.travel-particles span:nth-child(6){--tx:35px;--ty:-15px}.loading{color:gold;background:#0f0c29;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;display:flex}.market-tab h3{color:#ddd;margin:1rem 0 .5rem;font-size:.95rem}.market-tab h3:first-child{margin-top:0}.market-section{margin-bottom:1rem}.market-card{background:#ffffff0a;border:1px solid #ffffff14;border-radius:6px;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.4rem;padding:.6rem .75rem;display:flex}.market-card.expired-card{background:#ffc1070d;border-color:#ffc1074d}.market-item-info{flex-direction:column;flex:1;gap:.15rem;min-width:0;display:flex}.market-item-info strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.market-seller{color:#888;font-size:.7rem}.market-meta{color:#666;font-size:.65rem}.market-price{color:gold;white-space:nowrap;font-size:.9rem;font-weight:700}.market-buy-col{flex-direction:column;align-items:center;gap:.3rem;display:flex}.market-sell-form{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.market-select{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;flex:1;min-width:140px;padding:.4rem;font-size:.8rem}.market-price-input{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:90px;padding:.4rem;font-size:.8rem}.market-duration{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:85px;padding:.4rem;font-size:.8rem}.market-tax-preview{color:#ff9800;font-size:.75rem}.quests-tab h2{color:gold;margin:0 0 .75rem;font-size:1.1rem}.quest-card{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:8px;margin-bottom:.5rem;padding:.75rem}.quest-card.quest-ready{background:#4caf500f;border-color:#4caf5066}.quest-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.quest-header strong{color:#e0d0ff}.quest-level{color:#888;font-size:.7rem}.quest-repeatable{color:#64b5f6;background:#64b5f626;border-radius:3px;padding:.1rem .3rem;font-size:.65rem}.quest-complete-badge{color:#4caf50;background:#4caf5033;border-radius:3px;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.quest-desc{color:#a8a4cc;margin:.25rem 0;font-size:.8rem}.quest-objectives{margin:.4rem 0}.quest-obj{color:#ccc;align-items:center;gap:.4rem;padding:.15rem 0;font-size:.8rem;display:flex}.quest-obj.obj-done{color:#4caf50;opacity:.8;text-decoration:line-through}.quest-obj-bullet{text-align:center;width:1rem;font-weight:700}.quest-obj-progress{color:#888;margin-left:auto;font-family:monospace;font-size:.75rem}.quest-rewards-line{color:#aaa;margin:.3rem 0;font-size:.75rem}.quest-actions{gap:.5rem;margin-top:.4rem;display:flex}.chat-panel{z-index:500;pointer-events:none;flex-direction:column;width:100%;max-width:600px;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.chat-panel>*{pointer-events:auto}.chat-toggle{color:gold;cursor:pointer;background:#1e1b3cf2;border:1px solid #ffd70033;border-bottom:none;border-radius:8px 8px 0 0;align-self:flex-end;margin-right:1rem;padding:.35rem 1rem;font-size:.8rem;font-weight:700;position:relative}.chat-toggle:hover{background:#28254bf2}.chat-badge{color:#fff;background:#e74c3c;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;font-size:.65rem;font-weight:700;display:flex;position:absolute;top:-6px;right:-6px}.chat-open{animation:.2s ease-out chatSlideUp}@keyframes chatSlideUp{0%{transform:translate(-50%)translateY(100%)}to{transform:translate(-50%)translateY(0)}}.chat-log{background:#0f0c29f2;border-top:1px solid #ffd70026;flex-direction:column;gap:.2rem;height:180px;padding:.5rem .75rem;display:flex;overflow-y:auto}.chat-entry{word-break:break-word;font-size:.8rem;line-height:1.3}.chat-system-msg{color:#666;font-size:.75rem;font-style:italic}.chat-sender{color:#a8a4cc;margin-right:.3rem;font-weight:700}.chat-text{color:#ddd}.chat-class{font-size:.7rem;font-weight:400}.chat-class-warrior{color:#e74c3c}.chat-class-mage{color:#3498db}.chat-class-rogue{color:#2ecc71}.chat-class-cleric{color:#f1c40f}.chat-empty{color:#555;text-align:center;padding:2rem 0;font-size:.8rem;font-style:italic}.chat-input-row{background:#0f0c29fa;border-top:1px solid #ffffff0f;gap:.4rem;padding:.4rem .5rem;display:flex}.chat-input{color:#fff;background:#ffffff14;border:1px solid #ffffff1a;border-radius:6px;outline:none;flex:1;padding:.4rem .6rem;font-size:.8rem}.chat-input:focus{border-color:#ffd7004d}.chat-input-row .btn{flex-shrink:0}.qty-picker-overlay{z-index:1000;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qty-picker-modal{text-align:center;background:#1a1740;border:1px solid #ffd7004d;border-radius:8px;min-width:260px;padding:1.2rem}.qty-picker-modal h3{color:gold;margin:0 0 .8rem;font-size:1rem}.qty-picker-controls{justify-content:center;align-items:center;gap:.4rem;margin-bottom:1rem;display:flex}.qty-picker-input{text-align:center;color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:60px;padding:.4rem;font-size:1rem}.qty-picker-actions{justify-content:center;gap:.5rem;display:flex}.market-qty-input{color:#fff;text-align:center;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:55px;padding:.4rem;font-size:.8rem}.admin-page{color:#fff;background:linear-gradient(#0a0820,#151030);max-width:900px;min-height:100vh;margin:0 auto;padding:1rem}.admin-header{justify-content:space-between;align-items:center;margin-bottom:1rem;display:flex}.admin-header h1{color:gold;margin:0;font-size:1.4rem}.admin-message{color:#2ecc71;background:#2ecc7126;border:1px solid #2ecc714d;border-radius:6px;margin-bottom:.75rem;padding:.5rem 1rem;font-size:.85rem}.admin-tabs{gap:.3rem;margin-bottom:1rem;display:flex;overflow-x:auto}.admin-tabs .tab{white-space:nowrap;padding:.4rem .8rem;font-size:.8rem}.admin-content{background:#ffffff08;border-radius:10px;min-height:400px;padding:1rem}.stat-cards{grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.75rem;margin-bottom:1.5rem;display:grid}.stat-card{text-align:center;background:#ffffff0f;border-radius:8px;flex-direction:column;gap:.3rem;padding:.75rem;display:flex}.stat-card span{color:#a8a4cc;text-transform:uppercase;letter-spacing:.5px;font-size:.75rem}.stat-card strong{color:gold;font-size:1.5rem}.activity-list{flex-wrap:wrap;gap:.4rem;display:flex}.activity-item{background:#ffffff0d;border-radius:6px;align-items:center;gap:.4rem;padding:.3rem .6rem;font-size:.8rem;display:flex}.admin-table{border-collapse:collapse;width:100%;margin-bottom:1rem;font-size:.8rem}.admin-table th{text-align:left;color:#a8a4cc;text-transform:uppercase;border-bottom:1px solid #ffffff1a;padding:.5rem;font-size:.75rem}.admin-table td{border-bottom:1px solid #ffffff0a;padding:.4rem .5rem}.row-banned{opacity:.5}.clickable{cursor:pointer;color:#64b5f6;text-decoration:underline}.clickable:hover{color:#90caf9}.admin-badge{color:#000;background:gold;border-radius:3px;margin-left:.4rem;padding:.1rem .35rem;font-size:.6rem;font-weight:700}.banned-label{color:#e74c3c;background:#e74c3c33;border-radius:3px;padding:.15rem .4rem;font-size:.7rem;font-weight:700}.active-label{color:#2ecc71;font-size:.7rem}.action-cell{gap:.3rem;display:flex}.btn-tiny{cursor:pointer;color:#ddd;background:#ffffff1a;border:1px solid #ffffff26;border-radius:4px;padding:.2rem .5rem;font-size:.7rem}.btn-tiny:hover{background:#ffffff26}.btn-tiny.btn-danger{color:#e74c3c;background:#e74c3c33;border-color:#e74c3c4d}.btn-tiny.btn-danger:hover{background:#e74c3c4d}.btn-tiny.btn-primary{color:#64b5f6;background:#64b5f633;border-color:#64b5f64d}.btn-tiny.btn-primary:hover{background:#64b5f64d}.player-detail h2{margin:.75rem 0 .25rem}.detail-meta{color:#888;margin:0 0 1rem;font-size:.8rem}.char-detail-card{background:#ffffff0d;border-radius:8px;margin-bottom:.75rem;padding:.75rem}.char-detail-info{flex-direction:column;gap:.2rem;margin-bottom:.5rem;font-size:.8rem;display:flex}.char-detail-info strong{color:gold;font-size:.9rem}.char-detail-info span{color:#a8a4cc}.char-detail-actions{flex-direction:column;gap:.5rem;display:flex}.adjust-row{align-items:center;gap:.3rem;display:flex}.adjust-row input{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:70px;padding:.25rem .4rem;font-size:.75rem}.filter-row{align-items:center;gap:.5rem;margin-bottom:.75rem;display:flex}.filter-row select{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:6px;padding:.35rem .5rem;font-size:.8rem}.event-list{flex-direction:column;gap:.25rem;max-height:500px;display:flex;overflow-y:auto}.event-row{background:#ffffff08;border-radius:4px;flex-wrap:wrap;align-items:center;gap:.4rem;padding:.35rem .5rem;font-size:.75rem;display:flex}.event-type-badge{color:#64b5f6;white-space:nowrap;background:#64b5f626;border-radius:3px;padding:.1rem .4rem;font-size:.7rem;font-weight:700}.event-user{color:gold;white-space:nowrap}.event-data{color:#888;word-break:break-all;flex:1;min-width:100px}.event-ip{color:#666;white-space:nowrap;font-size:.7rem}.event-time{color:#555;white-space:nowrap;margin-left:auto;font-size:.7rem}.chat-log-list{flex-direction:column;gap:.2rem;max-height:500px;display:flex;overflow-y:auto}.chat-log-row{background:#ffffff08;border-radius:4px;align-items:baseline;gap:.4rem;padding:.3rem .5rem;font-size:.8rem;display:flex}.chat-log-location{color:#666;white-space:nowrap;font-size:.7rem}.chat-log-sender{color:#a8a4cc;white-space:nowrap;font-size:.75rem;font-weight:700}.chat-log-msg{color:#ddd;word-break:break-word;flex:1}.chat-log-time{color:#555;white-space:nowrap;margin-left:auto;font-size:.7rem}.suspicious-tab h3{color:#e74c3c;margin:1rem 0 .5rem}.suspicious-count{color:#e74c3c;font-weight:700}.empty-msg{color:#2ecc71;font-size:.85rem;font-style:italic}.gd-sub-tabs{flex-wrap:wrap;gap:.25rem;margin-bottom:.75rem;display:flex}.gd-sub-tabs .tab{padding:.3rem .6rem;font-size:.75rem}.gd-form{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;margin-bottom:1rem;padding:1rem}.gd-form h3{color:gold;margin:0 0 .75rem;font-size:.9rem}.gd-form-fields{flex-direction:column;gap:.5rem;display:flex}.gd-field{align-items:center;gap:.5rem;font-size:.8rem;display:flex}.gd-field>span{color:#a8a4cc;text-transform:uppercase;min-width:90px;font-size:.75rem}.gd-field input,.gd-field select{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;flex:1;padding:.3rem .5rem;font-size:.8rem}.gd-field select{appearance:auto}.gd-field-label{color:#a8a4cc;text-transform:uppercase;margin-top:.25rem;font-size:.75rem}.gd-form-actions{gap:.5rem;margin-top:.75rem;display:flex}.stat-editor{flex-direction:column;gap:.3rem;display:flex}.stat-editor-row{align-items:center;gap:.3rem;display:flex}.stat-editor-row select{color:#fff;appearance:auto;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:90px;padding:.2rem .3rem;font-size:.75rem}.stat-editor-row input{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:60px;padding:.2rem .3rem;font-size:.75rem}.tag-input{flex-direction:column;flex:1;gap:.3rem;display:flex}.tag-list{flex-wrap:wrap;gap:.25rem;display:flex}.tag{color:#64b5f6;background:#64b5f626;border-radius:3px;align-items:center;gap:.2rem;padding:.15rem .4rem;font-size:.7rem;display:flex}.tag button{color:#e74c3c;cursor:pointer;background:0 0;border:none;padding:0;font-size:.7rem}.tag-add-row{gap:.3rem;display:flex}.tag-add-row input{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;flex:1;padding:.2rem .4rem;font-size:.75rem}.autocomplete-wrap{position:relative}.autocomplete-wrap input{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:100%;padding:.25rem .4rem;font-size:.75rem}.autocomplete-dropdown{z-index:50;background:#1a1740;border:1px solid #ffffff26;border-radius:0 0 4px 4px;max-height:180px;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #0006}.autocomplete-option{cursor:pointer;border-bottom:1px solid #ffffff0d;align-items:center;gap:.5rem;padding:.35rem .5rem;font-size:.75rem;display:flex}.autocomplete-option:hover,.autocomplete-option.highlighted{background:#64b5f626}.autocomplete-option .ac-id{color:#64b5f6;min-width:80px;font-family:monospace;font-weight:700}.autocomplete-option .ac-label{color:#a8a4cc;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.quest-admin-card{background:#ffffff0a;border:1px solid #ffffff1a;border-radius:6px;margin-bottom:.5rem;padding:.75rem}.quest-admin-header{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.quest-admin-header strong{color:gold}.quest-admin-desc{color:#a8a4cc;margin:.3rem 0;font-size:.8rem}.quest-status-badge{border-radius:3px;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.quest-status-badge.active{color:#4caf50;background:#4caf5033}.quest-status-badge.inactive{color:#ff5252;background:#ff525233}.quest-meta{color:#888;font-size:.7rem}.quest-admin-objectives{margin:.3rem 0}.quest-obj-row{align-items:center;gap:.5rem;padding:.15rem 0;font-size:.75rem;display:flex}.quest-obj-type{color:#64b5f6;text-transform:uppercase;background:#64b5f626;border-radius:3px;padding:.1rem .4rem;font-size:.65rem;font-weight:700}.quest-admin-rewards{color:#aaa;font-size:.75rem}.quest-obj-editor{align-items:center;gap:.3rem;margin-bottom:.3rem;display:flex}.quest-reward-editor{border:1px solid #ffffff0f;border-radius:4px;flex-direction:column;gap:.2rem;margin-bottom:.4rem;padding:.3rem;display:flex}.quest-reward-row{align-items:center;gap:.3rem;display:flex}.quest-reward-modifier-row{align-items:center;gap:.3rem;padding-left:.3rem;display:flex}.quest-reward-modifier-row label{color:#aaa;align-items:center;gap:.3rem;font-size:.75rem;display:flex}.quest-reward-row select,.quest-reward-modifier-row select,.quest-obj-editor select,.quest-obj-editor input,.quest-reward-row input{color:#fff;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;padding:.25rem .4rem;font-size:.75rem}.quest-obj-editor select{width:90px}.gd-form-fields h4{color:gold;margin:.75rem 0 .3rem;font-size:.9rem}.loot-entry-editor{align-items:center;gap:.3rem;margin-bottom:.3rem;display:flex}.loot-rate-label{white-space:nowrap;align-items:center;gap:.25rem;display:flex}.loot-rate-label input{color:#fff;text-align:right;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;width:65px;padding:.25rem .3rem;font-size:.75rem}.loot-rate-label span{color:#888;min-width:30px;font-size:.7rem}.beta-gen-row{align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.beta-gen-row input{color:#fff;text-align:center;background:#ffffff14;border:1px solid #ffffff1f;border-radius:4px;padding:.3rem .5rem}.beta-gen-row label{color:#aaa;font-size:.85rem}.beta-keys-stats{color:#aaa;gap:1.5rem;margin-bottom:1rem;font-size:.85rem;display:flex}.beta-key-code{letter-spacing:.05em;color:gold;font-family:monospace;font-size:.85rem}.beta-key-used .beta-key-code{color:#666}.beta-key-available{background:#64ff6408}.beta-key-used{opacity:.6}.guide-page{color:#e0dce8;background:linear-gradient(135deg,#0f0c29,#302b63,#24243e);min-height:100vh;padding:2rem 1rem}.guide-container{max-width:800px;margin:0 auto}.guide-container h1{color:gold;text-align:center;text-shadow:0 0 16px #ffd7004d;margin-bottom:2rem;font-family:Georgia,serif;font-size:2rem}.guide-back{color:#ccc;cursor:pointer;background:#ffffff1a;border:1px solid #fff3;border-radius:8px;margin-bottom:1rem;padding:.4rem 1rem;font-size:.85rem;transition:background .2s}.guide-back:hover{color:#fff;background:#fff3}.guide-section{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.guide-section h2{color:gold;border-bottom:1px solid #ffd70033;margin:0 0 .75rem;padding-bottom:.5rem;font-size:1.3rem}.guide-section p{margin:.5rem 0;line-height:1.6}.guide-section ul{padding-left:1.5rem;line-height:1.8}.guide-section li{margin-bottom:.3rem}.guide-classes{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1rem;margin-top:1rem;display:grid}.guide-class-card{background:#0000004d;border:1px solid #ffffff1a;border-radius:10px;padding:1.2rem}.guide-class-card h3{color:gold;margin:0 0 .3rem;font-size:1.15rem}.guide-class-desc{color:#a8a4cc;font-size:.9rem;font-style:italic;margin:0 0 .6rem!important}.guide-stats{flex-wrap:wrap;gap:.4rem;margin-bottom:.8rem;display:flex}.guide-stats span{background:#ffffff14;border-radius:6px;padding:.2rem .5rem;font-family:monospace;font-size:.8rem}.guide-stats .stat-high{color:#6fec6f;border:1px solid #6fec6f4d}.guide-stats .stat-low{color:#ff8a8a;border:1px solid #ff8a8a4d}.guide-playstyle,.guide-abilities{font-size:.9rem;line-height:1.5}.guide-abilities{color:#b8b4d0;font-size:.85rem}.guide-stat-table{flex-direction:column;gap:.6rem;display:flex}.guide-stat-row{background:#0003;border-radius:8px;align-items:baseline;gap:1rem;padding:.6rem .8rem;display:flex}.guide-stat-name{color:gold;flex-shrink:0;min-width:130px;font-size:.9rem;font-weight:700}.guide-stat-effect{color:#ccc;font-size:.88rem;line-height:1.5}.guide-tier-table{flex-direction:column;gap:.4rem;margin-top:.8rem;display:flex}.guide-tier-table>div{align-items:center;gap:.8rem;padding:.3rem 0;font-size:.9rem;display:flex}.tier{text-align:center;border-radius:6px;min-width:50px;padding:.15rem .6rem;font-size:.8rem;font-weight:700;display:inline-block}.tier-1{color:#ccc;background:#9696964d}.tier-2{color:#6fec6f;background:#50b45040}.tier-3{color:#6ab4ff;background:#3c78dc40}.tier-4{color:#d08aff;background:#b450dc40}.tier-5{color:gold;background:#ffb40040}.guide-locations{flex-direction:column;gap:.5rem;margin-top:.5rem;display:flex}.guide-loc{background:#0003;border-radius:8px;flex-wrap:wrap;align-items:center;gap:.5rem;padding:.5rem .8rem;font-size:.9rem;line-height:1.5;display:flex}.loc-name{color:gold;min-width:180px;font-weight:700}.loc-level{color:#aaa;background:#ffffff1a;border-radius:4px;padding:.1rem .5rem;font-family:monospace;font-size:.75rem}.loc-type{border-radius:4px;padding:.1rem .5rem;font-size:.75rem;font-weight:700}.guide-loc .loc-type{color:#6fec6f;background:#50b45033}.btn-guide{color:gold;cursor:pointer;background:#ffd7001a;border:1px solid #ffd7004d;border-radius:10px;width:100%;margin-top:1rem;padding:.6rem;font-size:.9rem;transition:background .2s;display:block}.btn-guide:hover{background:#ffd70033}@media (width<=600px){.guide-classes{grid-template-columns:1fr}.guide-stat-row{flex-direction:column;gap:.3rem}.guide-stat-name{min-width:unset}.loc-name{min-width:unset;width:100%}}
