:root{--bg-dark: #0a0a12;--bg-panel: rgba(15, 12, 25, .92);--bg-panel-hover: rgba(25, 20, 40, .95);--border-gold: #c8a84e;--border-gold-dim: rgba(200, 168, 78, .4);--border-gold-glow: rgba(200, 168, 78, .15);--text-primary: #e8e0d0;--text-secondary: #a09880;--text-gold: #f0d878;--text-dim: #685f50;--accent-red: #c0392b;--accent-blue: #2980b9;--accent-green: #27ae60;--accent-purple: #8e44ad;--hp-bar: linear-gradient(90deg, #8b1a1a, #c0392b);--mp-bar: linear-gradient(90deg, #1a3a8b, #2980b9);--xp-bar: linear-gradient(90deg, #8b7a1a, #c8a84e);--rarity-common: #a0a0a0;--rarity-uncommon: #2ecc71;--rarity-rare: #3498db;--rarity-epic: #9b59b6;--rarity-legendary: #f39c12;--panel-padding: 16px;--panel-radius: 8px;--gap-sm: 4px;--gap-md: 8px;--gap-lg: 16px}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg-dark);color:var(--text-primary);font-family:Inter,sans-serif;overflow:hidden;width:100vw;height:100vh}h1,h2,h3,h4{font-family:MedievalSharp,cursive;color:var(--text-gold);text-shadow:0 0 10px rgba(200,168,78,.3)}#game-container{width:100vw;height:100vh;position:relative}#game-canvas{width:100%;height:100%;display:block}#ui-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}#ui-overlay>*{pointer-events:auto}#ui-overlay>.hud-container{pointer-events:none}.creation-screen{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0a0a12,#1a1428,#0a0a12);display:flex;flex-direction:column;align-items:center;z-index:100;overflow-y:auto}.creation-title{font-size:3rem;margin:30px 0 10px;letter-spacing:3px;animation:titleGlow 3s ease-in-out infinite}@keyframes titleGlow{0%,to{text-shadow:0 0 10px rgba(200,168,78,.3)}50%{text-shadow:0 0 25px rgba(200,168,78,.6),0 0 50px rgba(200,168,78,.2)}}.creation-subtitle{font-family:Inter,sans-serif;color:var(--text-secondary);font-size:.95rem;margin-bottom:25px;font-weight:300}.creation-content{display:flex;gap:30px;width:90%;max-width:1200px;flex:1;padding-bottom:30px}.creation-left,.creation-right{flex:1;display:flex;flex-direction:column;gap:20px}.creation-center{width:280px;display:flex;flex-direction:column;align-items:center;gap:15px}.creation-panel{background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:var(--panel-radius);padding:var(--panel-padding);box-shadow:0 4px 20px #00000080,inset 0 1px #c8a84e1a}.creation-panel h3{font-size:1.2rem;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-gold-dim)}.selector-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.selector-card{background:#14101ecc;border:1px solid rgba(100,90,70,.3);border-radius:6px;padding:12px;cursor:pointer;transition:all .25s ease;text-align:center}.selector-card:hover{border-color:var(--border-gold-dim);background:#1e182de6;transform:translateY(-2px);box-shadow:0 4px 15px #c8a84e1a}.selector-card.selected{border-color:var(--border-gold);background:#282037e6;box-shadow:0 0 15px #c8a84e33,inset 0 0 20px #c8a84e0d}.selector-card .card-icon{font-size:2rem;margin-bottom:6px}.selector-card .card-name{font-family:MedievalSharp,cursive;color:var(--text-gold);font-size:1rem;display:block}.selector-card .card-desc{font-size:.75rem;color:var(--text-secondary);margin-top:4px}.preview-canvas-wrapper{width:250px;height:320px;border:1px solid var(--border-gold-dim);border-radius:var(--panel-radius);overflow:hidden;background:radial-gradient(circle at center,#1e192d,#0a0a12);box-shadow:0 4px 20px #00000080}.preview-canvas-wrapper canvas{width:100%!important;height:100%!important}.stat-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:.85rem}.stat-name{color:var(--text-secondary)}.stat-value{color:var(--text-gold);font-weight:600}.stat-bar-bg{flex:1;height:6px;background:#282432cc;border-radius:3px;margin:0 10px;overflow:hidden}.stat-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.name-input{width:100%;background:#14101ecc;border:1px solid var(--border-gold-dim);border-radius:6px;padding:10px 14px;color:var(--text-primary);font-family:MedievalSharp,cursive;font-size:1.1rem;text-align:center;outline:none;transition:border-color .3s}.name-input:focus{border-color:var(--border-gold);box-shadow:0 0 10px #c8a84e26}.name-input::placeholder{color:var(--text-dim)}.btn-start{width:100%;padding:14px;background:linear-gradient(135deg,#c8a84e,#a08030);border:none;border-radius:6px;color:#1a1428;font-family:MedievalSharp,cursive;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s;letter-spacing:1px;text-shadow:0 1px 0 rgba(255,255,255,.2)}.btn-start:hover{background:linear-gradient(135deg,#d8b85e,#b09040);transform:translateY(-2px);box-shadow:0 6px 20px #c8a84e4d}.btn-start:active{transform:translateY(0)}.btn-start:disabled{opacity:.5;cursor:not-allowed;transform:none}.creation-actions{width:100%;display:flex;gap:8px}.btn-start.btn-secondary{background:#14101ee6;border:1px solid var(--border-gold-dim);color:var(--text-primary);font-size:1rem}.btn-start.btn-secondary:hover{background:#1e182df2;box-shadow:none}.hud-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999}.hud-container>*{pointer-events:auto}.hud-bars{position:absolute;top:15px;left:15px;display:flex;flex-direction:column;gap:6px;width:320px}.worldmap-open .hud-bars{display:none!important}.hud-top-row{display:flex;align-items:center;gap:10px}.hud-bar-wrapper{display:flex;align-items:center;flex:1}.hud-bar{flex:1;height:18px;background:#0a0a12d9;border:1px solid rgba(100,90,70,.3);border-radius:9px;overflow:hidden;position:relative;box-shadow:inset 0 1px #ffffff14}.hud-bar-fill{height:100%;border-radius:8px;transition:width .5s ease;position:relative}.hud-bar-fill:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 100%);border-radius:8px 8px 0 0}.hud-bar-hp .hud-bar-fill{background:var(--hp-bar)}.hud-bar-mp .hud-bar-fill{background:var(--mp-bar)}.hud-bar-xp .hud-bar-fill{background:var(--xp-bar)}.hud-bar-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.65rem;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8);white-space:nowrap}.hud-level{position:relative;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:50%;width:48px;height:48px;display:flex;align-items:center;justify-content:center;flex-direction:column;box-shadow:0 4px 14px #00000059,inset 0 1px #c8a84e1f;flex-shrink:0}.hud-level-label{font-size:.55rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px}.hud-level-value{font-family:MedievalSharp,cursive;font-size:1.2rem;color:var(--text-gold);line-height:1}@media(max-width:760px){.hud-bars{width:min(320px,calc(100vw - 30px))}}.combat-bottom-container{position:absolute;bottom:15px;left:50%;transform:translate(-50%);display:flex;flex-direction:column;align-items:center;gap:6px}.combat-player-hp-wrapper{width:100%;display:flex;align-items:center;gap:8px}.combat-player-hp-bar{flex:1;height:14px;position:relative;background:#14101ecc;border-radius:4px;overflow:hidden;border:1px solid rgba(100,90,70,.3)}.combat-hp-fill{height:100%;background:linear-gradient(90deg,#c0392b,#e74c3c);border-radius:4px;transition:width .3s ease}.combat-hp-text{font-size:.7rem;color:var(--text-secondary);white-space:nowrap}.combat-hp-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.72rem;font-weight:700;color:#f6ead2;text-shadow:0 1px 3px rgba(0,0,0,.9);white-space:nowrap;pointer-events:none}.combat-player-shield-wrapper{width:100%;display:flex;align-items:center;gap:8px;margin-top:3px}.combat-player-shield-bar{flex:1;height:10px;position:relative;background:#14101ecc;border-radius:4px;overflow:hidden;border:1px solid rgba(41,128,185,.4)}.combat-shield-fill{height:100%;background:linear-gradient(90deg,#1a5580,#2980b9);border-radius:4px;transition:width .3s ease}.combat-shield-value{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.65rem;font-weight:700;color:#d6eaf8;text-shadow:0 1px 3px rgba(0,0,0,.9);white-space:nowrap;pointer-events:none}.combat-target-shield-bar{width:100%;height:8px;background:#14101ecc;border-radius:5px;overflow:hidden;margin-top:3px;margin-bottom:4px;border:1px solid rgba(41,128,185,.4)}.combat-target-shield-fill{height:100%;background:linear-gradient(90deg,#1a5580,#2980b9);border-radius:5px;transition:width .3s ease}.hud-hotbar{display:flex;gap:6px;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:8px 12px;box-shadow:0 -4px 20px #0006}.combat-skills-container{background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:8px 12px;box-shadow:0 -4px 20px #0006}.combat-skills-container .combat-skills{display:flex;gap:6px}.hotbar-slot{width:50px;height:50px;background:#14101ecc;border:1px solid rgba(100,90,70,.3);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.5rem;cursor:pointer;position:relative;transition:all .2s}.hotbar-slot>*{pointer-events:none}.hotbar-slot:hover{border-color:var(--border-gold-dim);background:#1e182de6}.hotbar-slot.disabled,.hotbar-slot:disabled{cursor:not-allowed;opacity:.58}.hotbar-slot.disabled:hover,.hotbar-slot:disabled:hover{border-color:#645a464d;background:#14101ecc;transform:none}.hotbar-slot .slot-key{position:absolute;top:2px;left:4px;font-size:.6rem;color:var(--text-dim);font-family:Inter,sans-serif}.hotbar-slot .slot-cooldown{position:absolute;top:0;left:0;width:100%;height:100%;background:#0009;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#fff;font-weight:600}.hotbar-slot.on-cooldown{border-color:#8c96aa73;background:#0c0c12e6}.hotbar-slot.on-cooldown img{filter:grayscale(1) brightness(.45) saturate(.25)}.hotbar-slot.on-cooldown .slot-key{color:#d2d7dcbf}.hotbar-slot.on-cooldown .slot-cooldown{background:radial-gradient(circle at center,#14182380,#06080ee0);color:#f2f4f7;font-size:1.05rem;font-weight:700;text-shadow:0 1px 4px rgba(0,0,0,.85)}.hud-buttons{position:absolute;bottom:15px;right:15px;display:flex;gap:8px}.hud-btn{width:46px;height:46px;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:8px;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-direction:column}.hud-btn:hover{border-color:var(--border-gold);color:var(--text-gold);background:var(--bg-panel-hover);transform:translateY(-2px)}.hud-btn:focus-visible{outline:2px solid var(--border-gold);outline-offset:2px;box-shadow:0 0 0 2px #0c0a14e6,0 0 12px #c8a84e59}.hud-btn:focus:not(:focus-visible){outline:none;box-shadow:none}.hud-btn-neutral{border-color:#5a96b473;color:#9fd8ef}.hud-btn-neutral:hover{border-color:#5aaad2cc;color:#d5f4ff;background:#23465fe6}.hud-btn-danger{border-color:#c0392b73;color:#ffb3ab}.hud-btn-danger:hover{border-color:#dc5041cc;color:#ffd2cd;background:#6e1e19e6}.hud-btn .btn-label{font-size:.5rem;margin-top:2px;text-transform:uppercase;letter-spacing:.5px}.hud-btn-icon{width:17px;height:17px;display:inline-flex;align-items:center;justify-content:center}.hud-btn-icon svg{width:17px;height:17px;fill:currentColor;display:block}.confirm-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:260;display:flex;align-items:center;justify-content:center;background:#06060ab8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.confirm-dialog{width:min(420px,92vw);background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:12px;padding:22px;box-shadow:0 10px 40px #0009}.confirm-dialog h3{margin:0 0 8px;color:var(--text-gold)}.confirm-dialog p{margin:0;color:var(--text-secondary)}.confirm-actions{margin-top:18px;display:flex;justify-content:flex-end;gap:10px}.confirm-btn{border:1px solid transparent;border-radius:8px;padding:8px 12px;font-weight:600;cursor:pointer}.confirm-btn-cancel{background:#50505f59;color:var(--text-primary);border-color:#82829659}.confirm-btn-primary{background:linear-gradient(135deg,#c8a84e,#a08030);color:#20170a}.confirm-btn-danger{background:#c0392b40;color:#ffd1cb;border-color:#c0392b80}.confirm-btn-primary:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6)}.interact-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1400;display:flex;align-items:center;justify-content:center;background:#06060ab8;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.interact-panel{width:min(360px,92vw);background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:var(--panel-radius);box-shadow:0 8px 40px #0009,inset 0 1px #c8a84e1a;animation:panelSlideIn .3s ease}.interact-panel-body{display:flex;flex-direction:column;gap:12px}.interact-desc{color:var(--text-secondary);font-size:13px;line-height:1.4}.interact-req-line{color:var(--text-primary);font-size:13px}.interact-key-status{font-size:12px;line-height:1.4;padding:6px 10px;border-radius:6px}.interact-key-status.has-key{background:#2ecc711f;color:#6fdb9e;border:1px solid rgba(46,204,113,.25)}.interact-key-status.no-key{background:#e74c3c1f;color:#f5a8a0;border:1px solid rgba(231,76,60,.25)}.interact-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.interact-actions .trade-btn:disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.6)}.game-panel{position:absolute;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:var(--panel-radius);box-shadow:0 8px 40px #0009,inset 0 1px #c8a84e1a;z-index:1200;min-width:300px;animation:panelSlideIn .3s ease}@keyframes panelSlideIn{0%{opacity:0;margin-top:20px}to{opacity:1;margin-top:0}}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px var(--panel-padding);border-bottom:1px solid var(--border-gold-dim)}.panel-header h3{font-size:1.1rem;margin:0;padding:0;border:none}.panel-close{background:none;border:none;color:var(--text-secondary);font-size:1.2rem;cursor:pointer;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.panel-close:hover{color:var(--accent-red);background:#c0392b26}.panel-body{padding:var(--panel-padding)}.inventory-panel{top:50%;left:50%;right:auto;transform:translate(-50%,-50%);width:min(900px,calc(100vw - 24px));max-height:calc(100vh - 24px);overflow:hidden}.inventory-panel .panel-body{max-height:calc(100vh - 96px);overflow:auto}.inventory-merged-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(250px,300px);gap:14px;align-items:start}.inventory-main{min-width:0}.inventory-equip{background:#14101e73;border:1px solid rgba(100,90,70,.25);border-radius:8px;padding:10px}.inv-equip-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:8px}.inv-equip-list{display:flex;flex-direction:column;gap:6px}.inv-equip-slot{width:100%;min-height:44px;background:#0e0c16d9;border:1px solid rgba(120,100,70,.3);color:var(--text-primary);border-radius:6px;display:flex;gap:8px;align-items:center;padding:6px 8px;text-align:left;cursor:default}.inv-equip-slot.filled{cursor:pointer}.inv-equip-slot.filled:hover{border-color:var(--border-gold-dim);background:#1e182de6}.inv-equip-slot:not(.filled){opacity:.9}.inv-equip-icon{width:30px;height:30px;border:1px solid rgba(100,90,70,.3);border-radius:5px;background:#0a0910e6;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.inv-equip-meta{display:flex;flex-direction:column;min-width:0}.inv-equip-label{font-size:.62rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-dim)}.inv-equip-name{font-size:.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:900px){.inventory-merged-layout{grid-template-columns:1fr}}.inventory-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;margin-bottom:12px}.inv-slot{aspect-ratio:1;background:#14101ecc;border:1px solid rgba(100,90,70,.25);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;cursor:pointer;position:relative;transition:all .15s}.inv-slot:hover{border-color:var(--border-gold-dim);background:#1e182de6}.inv-slot.has-item{border-color:#645a4680}.inv-slot .item-count{position:absolute;bottom:1px;right:3px;font-size:.6rem;color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.9)}.inv-slot[data-rarity=common]{border-color:var(--rarity-common)}.inv-slot[data-rarity=uncommon]{border-color:var(--rarity-uncommon)}.inv-slot[data-rarity=rare]{border-color:var(--rarity-rare)}.inv-slot[data-rarity=epic]{border-color:var(--rarity-epic)}.inv-slot[data-rarity=legendary]{border-color:var(--rarity-legendary)}.inv-slot.dragging,.equip-slot.dragging,.inv-equip-slot.dragging,.hotbar-slot.dragging{opacity:.35}.inv-slot.drag-over,.equip-slot.drag-over,.inv-equip-slot.drag-over,.hotbar-slot.drag-over{border-color:var(--border-gold);background:#c8aa5026}.inv-gold{display:flex;align-items:center;gap:6px;font-size:.9rem;color:var(--text-gold);padding-top:8px;border-top:1px solid var(--border-gold-dim)}.trade-panel{top:80px;left:50%;transform:translate(-50%);width:min(860px,96vw);max-height:calc(100vh - 120px);overflow:hidden}.trade-body{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 190px);overflow-y:auto}.trade-banner{background:#233c5f8c;border:1px solid rgba(120,180,220,.42);color:#d8f2ff;font-size:.86rem;border-radius:8px;padding:8px 10px}.trade-info{color:var(--text-secondary);font-size:.88rem}.trade-muted{color:var(--text-dim);font-size:.84rem}.trade-nearby-list,.trade-inventory-list{display:flex;flex-direction:column;gap:6px;max-height:260px;overflow-y:auto}.trade-nearby-row{display:flex;justify-content:space-between;align-items:center;gap:8px;background:#14101e99;border:1px solid rgba(100,90,70,.2);border-radius:7px;padding:8px}.trade-nearby-meta{color:var(--text-primary);font-size:.86rem}.trade-active-header{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:2px}.trade-status-pill{border:1px solid rgba(120,100,70,.35);border-radius:999px;padding:3px 8px;font-size:.74rem;color:var(--text-secondary)}.trade-status-pill.ok{border-color:#27ae6080;color:#b6f3cf}.trade-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.trade-offer-box{background:#14101ea6;border:1px solid rgba(100,90,70,.3);border-radius:8px;padding:9px;min-height:220px;display:flex;flex-direction:column;gap:6px}.trade-offer-box.accepted{border-color:#27ae60d9;box-shadow:inset 0 0 0 1px #27ae6040,0 0 16px #27ae602e}.trade-box-title{color:var(--text-gold);font-size:.86rem;margin-bottom:2px}.trade-ok{color:var(--accent-green);font-weight:700;font-size:.72rem}.trade-gold-input-row{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.84rem}.trade-gold-input-row input{width:90px;background:#0a0a12cc;border:1px solid rgba(100,90,70,.3);border-radius:6px;color:var(--text-primary);padding:4px 6px}.trade-gold-line{color:var(--text-secondary);font-size:.84rem}.trade-offer-items{display:flex;flex-direction:column;gap:6px;max-height:150px;overflow-y:auto;padding-right:2px}.trade-offer-item{display:flex;align-items:center;gap:8px;border:1px solid rgba(120,100,70,.25);border-radius:8px;background:#120e1c8c;padding:6px}.trade-offer-item.is-your-offer{cursor:pointer}.trade-offer-item.is-your-offer:hover{border-color:var(--border-gold-dim)}.trade-offer-icon{width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;position:relative;border:1px solid rgba(120,100,70,.35);border-radius:7px;background:#14101ee6}.trade-offer-icon.rarity-common{border-color:var(--rarity-common)}.trade-offer-icon.rarity-uncommon{border-color:var(--rarity-uncommon)}.trade-offer-icon.rarity-rare{border-color:var(--rarity-rare)}.trade-offer-icon.rarity-epic{border-color:var(--rarity-epic)}.trade-offer-icon.rarity-legendary{border-color:var(--rarity-legendary)}.trade-offer-count{position:absolute;right:4px;bottom:2px;font-size:.68rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8)}.trade-offer-name{color:var(--text-primary);font-size:.82rem;line-height:1.25}.trade-empty{color:var(--text-dim);font-size:.82rem}.trade-inventory-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:6px}.trade-inv-cell{width:52px;height:52px;border:1px solid rgba(100,90,70,.25);border-radius:7px;background:#14101e99;display:flex;align-items:center;justify-content:center;position:relative;cursor:pointer;padding:0}.trade-inv-cell:hover{border-color:var(--border-gold-dim)}.trade-inv-cell.selected{border-color:var(--border-gold);background:#282037e6;box-shadow:inset 0 0 0 1px #c8a84e33}.trade-inv-cell.rarity-common{border-color:var(--rarity-common)}.trade-inv-cell.rarity-uncommon{border-color:var(--rarity-uncommon)}.trade-inv-cell.rarity-rare{border-color:var(--rarity-rare)}.trade-inv-cell.rarity-epic{border-color:var(--rarity-epic)}.trade-inv-cell.rarity-legendary{border-color:var(--rarity-legendary)}.trade-item-count{position:absolute;right:4px;bottom:2px;font-size:.68rem;color:#fff;font-weight:700;text-shadow:0 1px 2px rgba(0,0,0,.9)}.trade-offered-count{position:absolute;left:4px;top:2px;font-size:.66rem;color:#b6f3cf;font-weight:700;background:#146e4180;border:1px solid rgba(39,174,96,.45);border-radius:6px;padding:0 4px;line-height:1.3}.trade-qty-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500;background:#06060a94;display:flex;align-items:center;justify-content:center}.trade-qty-modal{width:min(360px,92vw);background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:0 10px 32px #0000008c}.trade-qty-title{color:var(--text-gold);font-weight:700}.trade-qty-item{color:var(--text-secondary);font-size:.86rem}.trade-qty-row{display:grid;grid-template-columns:1fr 90px 1fr;gap:8px}.trade-qty-row input{width:100%;text-align:center;background:#0a0a12cc;border:1px solid rgba(100,90,70,.35);border-radius:7px;color:var(--text-primary);padding:6px 4px}.trade-actions-row{display:flex;gap:8px;position:sticky;bottom:-1px;z-index:4;background:linear-gradient(180deg,#0f0c191a,#0f0c19f2 30%);padding-top:8px;margin-top:2px}.trade-btn{border:1px solid rgba(100,90,70,.3);border-radius:7px;padding:7px 10px;background:#14101ecc;color:var(--text-primary);cursor:pointer;font-size:.83rem}.trade-btn:hover{border-color:var(--border-gold-dim)}.trade-btn-primary{border-color:#27ae6073;color:#b6f3cf}.trade-btn-danger{border-color:#c0392b80;color:#ffb3ab}@media(max-width:920px){.trade-panel{width:min(98vw,98vw);left:50%;transform:translate(-50%)}.trade-grid{grid-template-columns:1fr}}.merchant-panel{top:90px;left:50%;transform:translate(-50%);width:min(860px,96vw);max-height:calc(100vh - 130px);overflow:hidden}.merchant-body{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 210px);overflow-y:auto}.merchant-gold-line{color:var(--text-gold);font-size:.88rem}.merchant-columns{display:grid;grid-template-columns:1fr 1fr;gap:10px}.merchant-col{background:#14101ea6;border:1px solid rgba(100,90,70,.3);border-radius:8px;padding:9px;min-height:240px;display:flex;flex-direction:column;gap:6px}.merchant-col-title{color:var(--text-gold);font-size:.86rem}.merchant-list{display:flex;flex-direction:column;gap:6px;overflow-y:auto}.merchant-item-row{display:flex;align-items:center;gap:8px;border:1px solid rgba(120,100,70,.25);border-radius:8px;background:#120e1c8c;padding:6px}.merchant-item-row.is-disabled{opacity:.6}.merchant-item-icon{width:46px;height:46px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(120,100,70,.35);border-radius:7px;background:#14101ee6}.merchant-item-icon.rarity-common{border-color:var(--rarity-common)}.merchant-item-icon.rarity-uncommon{border-color:var(--rarity-uncommon)}.merchant-item-icon.rarity-rare{border-color:var(--rarity-rare)}.merchant-item-icon.rarity-epic{border-color:var(--rarity-epic)}.merchant-item-icon.rarity-legendary{border-color:var(--rarity-legendary)}.merchant-item-meta{flex:1;min-width:0}.merchant-item-name{color:var(--text-primary);font-size:.82rem}.merchant-item-sub{color:var(--text-secondary);font-size:.78rem}@media(max-width:920px){.merchant-columns{grid-template-columns:1fr}}.stagecoach-panel{top:90px;left:50%;transform:translate(-50%);width:min(460px,94vw);max-height:calc(100vh - 130px);overflow:hidden}.stagecoach-body{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 210px);overflow-y:auto}.stagecoach-intro{color:var(--text-secondary);font-size:.86rem;font-style:italic}.stagecoach-destinations{display:flex;flex-direction:column;gap:6px}.stagecoach-dest-row{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1px solid rgba(120,100,70,.25);border-radius:8px;background:#120e1c8c;padding:10px 12px}.stagecoach-dest-row.is-disabled{opacity:.55}.stagecoach-dest-info{flex:1;min-width:0}.stagecoach-dest-name{color:var(--text-primary);font-size:.88rem;font-weight:600}.stagecoach-dest-price{color:var(--text-gold);font-size:.82rem}.auction-panel{top:76px;left:50%;transform:translate(-50%);width:min(1120px,98vw);max-height:calc(100vh - 110px);overflow:hidden;z-index:11050}.auction-body{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 190px);overflow-y:auto}.auction-topline{display:flex;align-items:center;justify-content:space-between;gap:10px;color:var(--text-secondary);font-size:.86rem}.auction-tabs{display:flex;gap:8px}.auction-tab{border:1px solid rgba(100,90,70,.35);border-radius:8px;padding:7px 10px;background:#14101ecc;color:var(--text-secondary);font-size:.84rem;cursor:pointer}.auction-tab:hover{border-color:var(--border-gold-dim)}.auction-tab.active{border-color:#c8a84ec7;color:var(--text-gold);background:#c8a84e24}.auction-tab-content{min-height:0}.auction-buy-controls{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:.84rem;margin-bottom:8px}.auction-buy-controls select{min-width:190px;border:1px solid rgba(100,90,70,.35);border-radius:7px;background:#0a0a12d9;color:var(--text-primary);padding:6px 8px}.auction-buy-table{display:flex;flex-direction:column;gap:6px}.auction-buy-head,.auction-buy-row{display:grid;grid-template-columns:minmax(230px,2fr) repeat(4,minmax(82px,.75fr)) minmax(200px,1.2fr);gap:8px;align-items:center}.auction-buy-head{border:1px solid rgba(100,90,70,.28);border-radius:8px;background:#14101eb8;padding:8px 10px;color:var(--text-dim);font-size:.76rem;text-transform:uppercase;letter-spacing:.5px}.auction-buy-row{border:1px solid rgba(100,90,70,.28);border-radius:8px;background:#120e1c94;padding:7px 10px}.auction-buy-item{display:flex;align-items:center;gap:8px;min-width:0}.auction-buy-icon{width:42px;height:42px;border:1px solid rgba(120,100,70,.35);border-radius:7px;background:#14101eeb;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.auction-buy-icon.rarity-common{border-color:var(--rarity-common)}.auction-buy-icon.rarity-uncommon{border-color:var(--rarity-uncommon)}.auction-buy-icon.rarity-rare{border-color:var(--rarity-rare)}.auction-buy-icon.rarity-epic{border-color:var(--rarity-epic)}.auction-buy-icon.rarity-legendary{border-color:var(--rarity-legendary)}.auction-buy-meta{min-width:0}.auction-buy-name{color:var(--text-primary);font-size:.84rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.auction-buy-cat{color:var(--text-dim);font-size:.74rem}.auction-price-cell{color:var(--text-secondary);font-size:.82rem;text-align:center}.auction-price-value{color:var(--text-gold)}.auction-price-empty{color:var(--text-dim)}.auction-buy-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end}.auction-buy-actions select{border:1px solid rgba(100,90,70,.35);border-radius:7px;background:#0a0a12d9;color:var(--text-primary);padding:5px 8px}.equipment-upgrade-panel{top:78px;left:50%;transform:translate(-50%);width:min(1080px,98vw);max-height:calc(100vh - 116px);overflow:hidden;z-index:11060}.equipment-upgrade-body{display:flex;flex-direction:column;gap:10px;max-height:calc(100vh - 190px);overflow-y:auto}.equipment-upgrade-intro{color:var(--text-secondary);font-size:.84rem}.equipment-upgrade-layout{display:grid;grid-template-columns:minmax(360px,1.05fr) minmax(320px,.95fr);gap:12px}.equipment-upgrade-main,.equipment-upgrade-inventory{background:#14101ead;border:1px solid rgba(100,90,70,.28);border-radius:10px;padding:12px}.equipment-upgrade-slots{display:grid;grid-template-columns:1fr 1fr;gap:10px}.equipment-upgrade-slot{border:1px solid rgba(120,100,70,.25);border-radius:10px;background:#0f0c18b8;padding:10px;min-height:116px;transition:border-color .15s ease,background .15s ease}.equipment-upgrade-slot.drag-over{border-color:var(--border-gold);background:#c8a84e1f}.equipment-upgrade-slot-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;color:var(--text-gold);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em}.equipment-upgrade-clear{border:1px solid rgba(140,115,76,.35);border-radius:999px;background:#120e1cd9;color:var(--text-secondary);width:24px;height:24px;cursor:pointer}.equipment-upgrade-slot-body{display:flex;align-items:center;gap:10px}.equipment-upgrade-slot-meta{min-width:0}.equipment-upgrade-slot-name{color:var(--text-primary);font-size:.84rem}.equipment-upgrade-slot-sub{color:var(--text-secondary);font-size:.74rem;line-height:1.35}.equipment-upgrade-preview{margin-top:12px;border:1px solid rgba(120,100,70,.22);border-radius:10px;background:#0f0c18b8;padding:12px}.equipment-upgrade-preview-title,.equipment-upgrade-section-title{color:var(--text-gold);font-size:.82rem;margin-bottom:10px}.equipment-upgrade-preview-line{display:flex;justify-content:space-between;gap:12px;color:var(--text-secondary);font-size:.8rem;padding:4px 0}.equipment-upgrade-preview-line strong{color:var(--text-primary);text-align:right}.equipment-upgrade-status{margin-top:10px;padding:10px 12px;border-radius:8px;border:1px solid rgba(178,94,75,.35);background:#4e1c1238;color:#f2bba9;font-size:.8rem}.equipment-upgrade-status.ok{border-color:#5daa7d66;background:#1e4c3047;color:#9ce3b5}.equipment-upgrade-actions{margin-top:12px}.equipment-upgrade-inventory-grid{grid-template-columns:repeat(6,52px);gap:8px}.equipment-upgrade-inventory-slot{width:52px;height:52px;border:1px solid rgba(100,90,70,.25);border-radius:8px;background:#0e0c16d6;display:inline-flex;align-items:center;justify-content:center;position:relative;cursor:pointer;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none}.equipment-upgrade-inventory-slot.filled{border-color:#8c7d5a73}.equipment-upgrade-inventory-slot.is-used{opacity:.45}.equipment-upgrade-inventory-slot.dragging{opacity:.35}@media(max-width:960px){.equipment-upgrade-layout,.equipment-upgrade-slots{grid-template-columns:1fr}}.auction-sell-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.auction-sell-col{border:1px solid rgba(100,90,70,.3);border-radius:8px;background:#14101e9e;padding:9px;display:flex;flex-direction:column;gap:8px}.auction-sell-actions{display:flex;justify-content:flex-start}.auction-section-title{color:var(--text-gold);font-size:.84rem}.auction-sellable-list,.auction-listings-list,.auction-pending-sales,.auction-unsold-list{display:flex;flex-direction:column;gap:6px}.auction-sellable-row{border:1px solid rgba(120,100,70,.25);border-radius:8px;background:#120e1c94;color:var(--text-primary);padding:6px;display:flex;align-items:center;gap:8px;cursor:pointer;text-align:left}.auction-sellable-row:hover{border-color:var(--border-gold-dim)}.auction-sellable-row.active{border-color:#c8a84ed1;background:#c8a84e1f}.auction-sellable-meta{min-width:0;font-size:.82rem}.auction-sellable-lots{color:var(--text-secondary);font-size:.76rem}.auction-sell-form{border-top:1px solid rgba(100,90,70,.28);padding-top:8px;display:flex;flex-direction:column;gap:8px}.auction-form-row{display:grid;grid-template-columns:130px minmax(0,1fr);gap:8px;align-items:center;color:var(--text-secondary);font-size:.82rem}.auction-form-row input,.auction-form-row select{border:1px solid rgba(100,90,70,.35);border-radius:7px;background:#0a0a12d9;color:var(--text-primary);padding:6px 8px}.auction-listing-row,.auction-sale-row,.auction-unsold-row{border:1px solid rgba(120,100,70,.25);border-radius:8px;background:#120e1c94;padding:8px;display:flex;align-items:center;gap:8px}.auction-listing-main,.auction-sale-main,.auction-unsold-main{flex:1;min-width:0}.auction-listing-name{color:var(--text-primary);font-size:.83rem}.auction-listing-sub,.auction-sale-sub{color:var(--text-secondary);font-size:.76rem}.auction-unsold-wrap{display:flex;flex-direction:column;gap:8px}.auction-confirm-modal .trade-actions-row{position:static;background:transparent;padding-top:0}.auction-overlay-high{z-index:12050}.auction-sell-modal{width:min(420px,94vw)}@media(max-width:1120px){.auction-buy-head,.auction-buy-row{grid-template-columns:minmax(190px,2fr) repeat(4,minmax(70px,.7fr)) minmax(160px,1fr)}}@media(max-width:920px){.auction-sell-grid{grid-template-columns:1fr}}@media(max-width:760px){.auction-panel{width:min(99vw,99vw);top:10px;max-height:calc(100vh - 20px)}.auction-body{max-height:calc(100vh - 100px)}.auction-buy-head{display:none}.auction-buy-row{grid-template-columns:1fr;gap:6px}.auction-price-cell{text-align:left;padding-left:50px}.auction-buy-actions{justify-content:flex-start;padding-left:50px}}.equipment-panel{top:50%;left:50%;transform:translate(-50%,-50%);width:min(980px,calc(100vw - 24px));max-height:calc(100vh - 24px);overflow:hidden}.equip-body{padding-top:10px;max-height:calc(100vh - 96px);overflow:auto}.equip-merged-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:14px;align-items:start}.equip-main{min-width:0}.equip-inventory{background:#14101e73;border:1px solid rgba(100,90,70,.25);border-radius:8px;padding:10px}.equip-inventory-title{font-size:.8rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:8px}.equip-inventory-grid{margin-bottom:10px}.equip-layout{--equip-slot-width: 130px;position:relative;height:468px;margin-bottom:10px;border:1px solid rgba(120,100,70,.2);border-radius:12px;background:radial-gradient(circle at 50% 50%,#c8a84e1f,#0c0a1433 55%,#0a0810bf),linear-gradient(180deg,#181224a6,#0c0a12b3);overflow:hidden}.equip-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.equip-character-canvas{pointer-events:auto}.equip-center-ring{position:absolute;width:220px;height:220px;border-radius:50%;border:1px solid rgba(200,168,78,.22);box-shadow:inset 0 0 30px #c8a84e14,0 0 30px #00000059;pointer-events:none}.equip-character{width:200px;height:260px;display:flex;align-items:center;justify-content:flex-end;flex-direction:column;pointer-events:auto}.equip-character-canvas{width:190px;height:190px;border-radius:50%;border:1px solid rgba(200,168,78,.3);background:radial-gradient(circle at 50% 42%,#786e522e,#100e188c);box-shadow:0 10px 28px #00000059;overflow:hidden;cursor:grab;pointer-events:auto;touch-action:none}.equip-character-canvas:active{cursor:grabbing}.equip-character-canvas canvas{width:100%!important;height:100%!important}.equip-character-name{margin-top:8px;font-size:.85rem;color:var(--text-secondary);letter-spacing:.04em;pointer-events:none}.equip-slots{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.equip-slot{position:absolute;pointer-events:auto;width:var(--equip-slot-width);min-height:58px;display:flex;align-items:center;gap:8px;padding:7px 8px;background:#0e0c16db;border:1px solid rgba(120,100,70,.34);border-radius:8px;cursor:default;transition:border-color .15s,background .15s,transform .15s,box-shadow .15s;color:var(--text-primary);font:inherit;text-align:left;-webkit-appearance:none;-moz-appearance:none;appearance:none}.equip-slot.filled{cursor:pointer}.equip-slot:not(.filled){opacity:.92}.equip-slot.filled:hover{border-color:var(--border-gold-dim);background:#1c1628e6;transform:translateY(-1px);box-shadow:0 6px 16px #00000052}.equip-slot:focus-visible{outline:2px solid var(--border-gold);outline-offset:1px}.equip-slot-head{top:14px;left:calc(50% - (var(--equip-slot-width) / 2))}.equip-slot-amulet{top:62px;left:14px}.equip-slot-ring{top:62px;right:14px}.equip-slot-weapon{top:145px;left:14px}.equip-slot-shield{top:145px;right:14px}.equip-slot-chest{bottom:138px;left:78px}.equip-slot-legs{bottom:138px;right:78px}.equip-relics{position:absolute;left:12px;right:12px;bottom:12px;padding:6px 8px 8px;background:linear-gradient(180deg,#120e1ce6,#0c0a14eb);border:1px solid rgba(130,110,76,.35);border-radius:10px;box-shadow:inset 0 1px #c8a84e14}.equip-relics-title{font-size:.58rem;text-transform:uppercase;letter-spacing:.8px;color:var(--text-dim);margin-bottom:4px}.equip-relics-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.equip-slot-relic{position:relative;width:auto;min-height:50px;gap:6px;padding:5px 6px;align-items:center}.equip-slot-relic .equip-slot-icon{width:26px;height:26px}.equip-slot-relic .equip-slot-info{min-width:0}.equip-slot-relic .equip-slot-label{font-size:.52rem;line-height:1.05}.equip-slot-relic .equip-slot-name{font-size:.68rem;line-height:1.05}.equip-slot-icon{width:40px;height:40px;background:#0a0910e6;border:1px dashed rgba(120,100,70,.35);border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.equip-slot-icon.filled{border-style:solid;border-color:#aa915f6b}.equip-placeholder-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--text-dim)}.equip-placeholder-icon svg{width:18px;height:18px;fill:currentColor;display:block}.equip-slot-info{flex:1;min-width:0}.equip-slot-label{font-size:.65rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}.equip-slot-name{font-size:.75rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.equip-stats{display:grid;grid-template-columns:1fr 1fr;gap:4px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-gold-dim)}.equip-stat{font-size:.8rem;display:flex;justify-content:space-between;padding:3px 6px;background:#14101e66;border-radius:3px}.equip-stat-label{color:var(--text-secondary)}.equip-stat-val{color:var(--text-gold);font-weight:600}@media(max-width:720px){.equipment-panel{width:min(96vw,980px)}.equip-merged-grid{grid-template-columns:1fr}.equip-layout{--equip-slot-width: 116px;height:438px}.equip-slot{min-height:54px;padding:6px 7px}.equip-slot-icon{width:34px;height:34px}.equip-slot-label{font-size:.6rem}.equip-slot-name{font-size:.7rem}.equip-slot-amulet,.equip-slot-weapon{left:8px}.equip-slot-ring,.equip-slot-shield{right:8px}.equip-slot-chest{left:44px}.equip-slot-legs{right:44px}.equip-slot-chest,.equip-slot-legs{bottom:118px}.equip-relics{left:10px;right:10px;bottom:10px;padding:6px 7px 7px}.equip-relics-grid{gap:6px}.equip-slot-relic{min-height:46px;padding:4px 5px}.equip-slot-relic .equip-slot-icon{width:24px;height:24px}.equip-slot-relic .equip-slot-label{font-size:.5rem}.equip-slot-relic .equip-slot-name{font-size:.64rem}}.skills-panel{top:20px;bottom:120px;left:50%;transform:translate(-50%);width:min(860px,calc(100vw - 24px));height:auto;overflow:hidden}.skills-panel .panel-body{height:calc(100% - 52px);overflow-y:auto;display:flex;flex-direction:column;gap:10px;padding-right:4px}.skills-specs-wrap{display:flex;flex-direction:column;gap:8px}.skills-spec-header{display:flex;flex-direction:column;gap:2px}.skills-spec-title{font-size:.85rem;color:var(--text-gold);letter-spacing:.04em;text-transform:uppercase}.skills-spec-subtitle{font-size:.72rem;color:var(--text-dim)}.skills-spec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.skills-spec-card{border:1px solid rgba(143,121,80,.35);background:#120e1ce6;border-radius:8px;color:var(--text-main);text-align:left;padding:8px;cursor:pointer;transition:border-color .15s ease,transform .15s ease,background .15s ease}.skills-spec-card:hover{border-color:#dcb66db3;transform:translateY(-1px)}.skills-spec-card.selected{border-color:var(--accent-green);background:#27ae601f}.skills-spec-icon{font-size:1.1rem;margin-bottom:4px}.skills-spec-name{font-family:MedievalSharp,cursive;color:var(--text-gold);font-size:.95rem}.skills-spec-desc{color:var(--text-secondary);font-size:.72rem;margin-top:2px;line-height:1.25}.skills-tree-wrap{display:flex;flex-direction:column;gap:10px;min-height:0}.skills-selected-spec{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;border:1px solid rgba(218,185,104,.4);border-radius:6px;padding:5px 8px;background:#29211059}.skills-selected-label{font-size:.72rem;color:var(--text-dim);text-transform:uppercase}.skills-selected-name{font-size:.82rem;color:var(--text-gold);font-weight:700}.skills-group{border:1px solid rgba(143,121,80,.25);border-radius:8px;background:#0d0a148c;padding:8px}.skills-group-title{font-size:.8rem;color:var(--text-gold);text-transform:uppercase;letter-spacing:.04em;margin-bottom:6px}.skills-list{display:flex;flex-direction:column;gap:8px;overflow:visible}.skills-list::-webkit-scrollbar{width:4px}.skills-list::-webkit-scrollbar-track{background:transparent}.skills-list::-webkit-scrollbar-thumb{background:var(--border-gold-dim);border-radius:2px}.skill-card{display:flex;gap:10px;padding:10px;background:#14101e99;border:1px solid rgba(100,90,70,.25);border-radius:6px;transition:all .15s}.skill-card.dragging{opacity:.45}.skill-card.learned{border-color:var(--accent-green);background:#27ae6014}.skill-card.locked{opacity:.5}.skill-icon{width:40px;height:40px;background:#0f0c19cc;border:1px solid rgba(100,90,70,.3);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}.skill-info{flex:1}.skill-name-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.skill-name{font-family:MedievalSharp,cursive;color:var(--text-gold);font-size:.95rem}.skill-level-badge{font-size:.66rem;color:#f5d98a;border:1px solid rgba(245,217,138,.45);border-radius:999px;padding:2px 7px;background:#54421866;white-space:nowrap}.skill-desc{font-size:.75rem;color:var(--text-secondary);margin-top:2px}.skill-meta{display:flex;gap:10px;margin-top:4px;font-size:.7rem}.skill-meta span{color:var(--text-dim)}.skill-level-tabs{margin-top:6px;display:grid;grid-template-columns:repeat(10,minmax(0,1fr));gap:4px}.skill-level-tab{border:1px solid rgba(120,108,82,.35);background:#130f1ce6;border-radius:4px;color:#9fa2aa;font-size:.62rem;padding:3px 0;cursor:pointer}.skill-level-tab.unlocked{color:#d6e8bc;border-color:#5d84418c;background:#27542a59}.skill-level-tab.selected{color:#1b1204;border-color:#debb71e6;background:linear-gradient(135deg,#eacb84,#c89f46);font-weight:700}.skill-learn-btn{align-self:center;padding:6px 12px;background:linear-gradient(135deg,var(--accent-green),#1e8449);border:none;border-radius:4px;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.skill-learn-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #27ae604d}.skill-learn-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.skill-state-learned,.skill-state-locked,.skill-state-maxed{align-self:center;font-size:.74rem}.skill-state-learned{color:var(--accent-green)}.skill-state-maxed{color:#f3d374}.skill-state-locked{color:var(--accent-red)}.skill-card.maxed{border-color:#f3d37499;background:#5f4c201f}.skill-points-info{text-align:center;font-size:.85rem;color:var(--text-secondary);padding-bottom:10px;border-bottom:1px solid var(--border-gold-dim);margin-bottom:10px}.skill-points-info span{color:var(--text-gold);font-weight:700}.skills-empty-note{border:1px dashed rgba(143,121,80,.5);border-radius:8px;padding:10px;font-size:.8rem;color:var(--text-secondary)}.stats-panel{top:50%;left:50%;right:auto;transform:translate(-50%,-50%);width:min(980px,calc(100vw - 24px));display:flex;flex-direction:column;overflow:visible}.stats-panel .panel-body{overflow:visible;padding-right:var(--panel-padding)}.stats-columns{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:14px;align-items:start}.stats-col{min-width:0}@media(max-width:980px){.stats-columns{grid-template-columns:1fr}}.stats-panel .stats-row{gap:8px}.stats-panel .stats-val{display:inline-flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:4px;text-align:right}.stats-grid{display:flex;flex-direction:column;gap:6px}.stats-section-title{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-top:8px;padding-bottom:4px;border-bottom:1px solid rgba(100,90,70,.15)}.stats-row{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;font-size:.85rem;border-radius:3px;background:#14101e66}.stats-label{color:var(--text-secondary)}.stats-val{color:var(--text-gold);font-weight:600}.stats-bonus{color:var(--accent-green);font-size:.75rem;margin-left:4px}.stats-plus-btn{width:24px;height:24px;border-radius:999px;border:1px solid rgba(200,168,78,.45);background:#1e182de6;color:var(--text-gold);font-size:.95rem;font-weight:700;line-height:1;cursor:pointer}.stats-plus-btn:hover:not(:disabled){border-color:#d7ba6cbf;background:#2d243ef2}.stats-plus-btn:disabled{opacity:.45;cursor:default}.stats-action-btn{background:#1e182df2;border:1px solid rgba(200,168,78,.35);color:var(--text-primary);border-radius:8px;font-size:.76rem;font-weight:700;padding:6px 10px;cursor:pointer}.stats-action-btn:hover{border-color:#d7ba6cbf;color:var(--text-gold)}.stats-action-btn-danger{border-color:#c0392b73;color:#ffccc6}.stats-action-btn-danger:hover{border-color:#dc5041cc;color:#ffd7d2}.stats-alloc-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1500;background:#06060a94;display:flex;align-items:center;justify-content:center}.stats-alloc-modal{width:min(360px,92vw);background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:10px;box-shadow:0 10px 32px #0000008c}.stats-alloc-title{color:var(--text-gold);font-weight:700}.stats-alloc-item{color:var(--text-secondary);font-size:.86rem}.stats-alloc-row{display:grid;grid-template-columns:1fr 90px 1fr;gap:8px}.stats-alloc-row input{width:100%;text-align:center;background:#0a0a12cc;border:1px solid rgba(100,90,70,.35);border-radius:7px;color:var(--text-primary);padding:6px 4px}.stats-alloc-actions{display:flex;gap:8px;justify-content:flex-end}.game-tooltip{position:fixed;background:#0a0812f5;border:1px solid var(--border-gold);border-radius:6px;padding:10px 14px;max-width:250px;z-index:13000;pointer-events:none;box-shadow:0 4px 20px #000000b3;animation:tooltipIn .15s ease}@keyframes tooltipIn{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.tooltip-name{font-family:MedievalSharp,cursive;font-size:1rem;margin-bottom:4px}.tooltip-type{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.tooltip-desc{font-size:.8rem;color:var(--text-secondary);margin-bottom:6px;line-height:1.3}.tooltip-stats{font-size:.8rem;color:var(--accent-green)}.tooltip-stats div{padding:1px 0}.tooltip-upgrade-line{margin-bottom:6px;color:#ffd071;font-size:.74rem;letter-spacing:.04em;text-transform:uppercase}.tooltip-rarity-common .tooltip-name{color:var(--rarity-common)}.tooltip-rarity-uncommon .tooltip-name{color:var(--rarity-uncommon)}.tooltip-rarity-rare .tooltip-name{color:var(--rarity-rare)}.tooltip-rarity-epic .tooltip-name{color:var(--rarity-epic)}.tooltip-rarity-legendary .tooltip-name{color:var(--rarity-legendary)}.context-menu{position:fixed;background:#0a0812f5;border:1px solid var(--border-gold-dim);border-radius:6px;padding:4px 0;z-index:1300;min-width:140px;box-shadow:0 4px 20px #0009}.context-menu-item{padding:8px 16px;font-size:.85rem;color:var(--text-primary);cursor:pointer;transition:all .15s}.context-menu-item:hover{background:#c8a84e1a;color:var(--text-gold)}.context-menu-item.danger{color:#ffd1cb}.context-menu-item.danger:hover{background:#c0392b33;color:#ff8070}.context-menu-separator{height:1px;background:var(--border-gold-dim);margin:4px 0}.worldmap-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#06040cf2;display:flex;flex-direction:column}.worldmap-header{display:flex;align-items:center;justify-content:space-between;padding:10px 18px;background:#0a0812e6;border-bottom:1px solid var(--border-gold-dim)}.worldmap-title{font-family:MedievalSharp,cursive;font-size:1.1rem;color:var(--text-gold);margin:0}.worldmap-close-btn{background:none;border:1px solid rgba(200,168,78,.3);color:var(--text-primary);font-size:1.4rem;width:32px;height:32px;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.worldmap-close-btn:hover{border-color:var(--border-gold);color:var(--text-gold)}#worldmap-canvas{flex:1;display:block;cursor:grab}#worldmap-canvas:active{cursor:grabbing}.worldmap-hint{text-align:center;font-size:.72rem;color:var(--text-dim);padding:6px;background:#0a0812e6;border-top:1px solid rgba(100,90,70,.15)}.minimap{position:absolute;top:40px;right:40px;width:160px;background:#0a0812d9;border:4px solid var(--border-gold-dim);border-radius:12px;overflow:visible;box-shadow:-15px 20px 25px #0009;transform:perspective(1000px) rotateX(60deg) rotate(45deg);transform-style:preserve-3d;transition:all .3s ease;z-index:100}.minimap:hover{transform:perspective(1000px) rotateX(60deg) rotate(45deg) translateZ(15px);box-shadow:-20px 25px 30px #0006}.minimap canvas{width:160px;height:160px;display:block;image-rendering:pixelated;border-radius:8px}.minimap-coords{position:absolute;top:210px;right:40px;width:160px;text-align:center;font-size:11px;color:#e8e0d0;font-family:monospace;font-weight:600;letter-spacing:1px;background:#0a0812bf;border:1px solid var(--border-gold-dim);border-radius:6px;padding:4px 10px;text-shadow:0 1px 2px rgba(0,0,0,.9);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-sizing:border-box;z-index:100}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-gold-dim);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-gold)}.fade-out{animation:fadeOut .5s ease forwards}@keyframes fadeOut{to{opacity:0;pointer-events:none}}.fade-in{animation:fadeIn .5s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.click-indicator{position:absolute;width:20px;height:20px;border:2px solid var(--border-gold);border-radius:50%;pointer-events:none;animation:clickRipple .6s ease forwards;z-index:55}@keyframes clickRipple{0%{transform:scale(.5);opacity:1}to{transform:scale(2);opacity:0}}.combat-ui{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:60}.combat-ui>*{pointer-events:auto}.combat-top-bar{position:absolute;top:12px;right:12px;display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:8px 7px;width:96px;max-height:min(82vh,760px);box-shadow:0 4px 20px #00000080}.combat-turn-info{display:flex;flex-direction:column;align-items:center;gap:1px;width:100%}.combat-turn-timeline{display:flex;flex-direction:column;align-items:center;gap:5px;max-width:100%;width:100%;overflow-y:auto;overflow-x:hidden;padding:2px 0;-ms-overflow-style:none;scrollbar-width:none}.combat-turn-timeline::-webkit-scrollbar{width:0;height:0;display:none}.combat-timeline-node{display:inline-flex;flex-direction:column;align-items:center;gap:4px;width:78px;min-width:78px;padding:4px 4px 5px;border-radius:8px;border:1px solid rgba(100,90,70,.35);background:#14101ebf;color:var(--text-primary);font-size:.62rem;white-space:normal;cursor:pointer;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.combat-timeline-node:hover{transform:translateY(-2px);border-color:#c8a84eb3}.combat-timeline-node:focus-visible{outline:1px solid rgba(200,168,78,.8);outline-offset:1px}.combat-timeline-node.player{border-color:#4fc3f794}.combat-timeline-node.enemy{border-color:#ef535094}.combat-timeline-node.active{border-color:var(--border-gold);box-shadow:0 0 0 1px #c8a84e73 inset,0 0 12px #c8a84e47}.combat-timeline-node.dead{opacity:.4;filter:grayscale(.9)}.combat-timeline-portrait{width:46px;display:inline-flex;flex-direction:column;align-items:center;gap:3px}.combat-timeline-portrait-img,.combat-timeline-portrait-fallback{width:46px;height:46px;border-radius:8px;display:block;object-fit:cover;border:1px solid rgba(255,255,255,.13);background:radial-gradient(circle at 45% 25%,#3e465cf2,#14101ef2)}.combat-timeline-portrait-fallback{display:inline-flex;align-items:center;justify-content:center;color:#f3ead8;font-size:1rem;font-weight:700}.combat-timeline-portrait-fallback.monster{border-radius:8px}.combat-timeline-hp-bar{width:46px;height:5px;background:#08080de6;border-radius:999px;overflow:hidden;border:1px solid rgba(120,110,90,.35)}.combat-timeline-hp-fill{display:block;height:100%;transition:width .25s ease;border-radius:999px}.combat-timeline-hp-fill.high{background:linear-gradient(90deg,#2f8d44,#40b85b)}.combat-timeline-hp-fill.mid{background:linear-gradient(90deg,#b98b2f,#d9a441)}.combat-timeline-hp-fill.low{background:linear-gradient(90deg,#9d2e2e,#d14848)}.combat-timeline-name{width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.combat-turn-label{font-size:.58rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px}.combat-state-label{font-family:MedievalSharp,cursive;font-size:.95rem;color:#4fc3f7;line-height:1}.combat-turn-timer{margin-top:1px;font-size:.68rem;font-weight:700;color:var(--text-gold)}.combat-turn-timer.warning{color:#ef5350}.combat-action-wrapper{display:flex;align-items:center;gap:15px}.combat-ap-bubble,.combat-mp-bubble{width:50px;height:50px;border-radius:50%;display:flex;flex-direction:column;justify-content:center;align-items:center;color:#fff;font-family:MedievalSharp,cursive;box-shadow:0 0 15px #0009,inset 0 0 10px #fff3;border:2px solid rgba(255,255,255,.3);text-shadow:1px 1px 2px black;transition:transform .2s;cursor:default}.combat-ap-bubble:hover,.combat-mp-bubble:hover{transform:scale(1.05)}.combat-ap-bubble{background:radial-gradient(circle at 30% 30%,#3498db,#2980b9,#1c5980);border-color:#5dade2;box-shadow:0 0 15px #3498db66,inset 0 0 15px #ffffff4d}.combat-mp-bubble{background:radial-gradient(circle at 30% 30%,#2ecc71,#27ae60,#186a3b);border-color:#58d68d;box-shadow:0 0 15px #2ecc7166,inset 0 0 15px #ffffff4d}#combat-ap-val,#combat-mp-val{font-size:1.5rem;line-height:1;font-weight:700}.combat-ap-icon,.combat-mp-icon{font-size:.7rem;letter-spacing:1px;opacity:.9}.combat-bottom-bar{position:absolute;bottom:12px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:8px 12px;box-shadow:0 -4px 20px #0006}.combat-skills{display:flex;gap:6px}.combat-skill-btn{display:flex;flex-direction:column;align-items:center;gap:2px;background:#14101ecc;border:1px solid rgba(100,90,70,.3);border-radius:6px;padding:6px 10px;cursor:pointer;transition:all .2s;min-width:60px;color:var(--text-primary)}.combat-skill-btn:hover:not(.disabled){border-color:var(--border-gold-dim);background:#1e182de6;transform:translateY(-2px)}.combat-skill-btn.active{border-color:var(--border-gold);background:#322841e6;box-shadow:0 0 10px #c8a84e33}.combat-skill-btn.disabled{opacity:.4;cursor:not-allowed}.combat-skill-icon{font-size:1.3rem}.combat-skill-name{font-size:.6rem;color:var(--text-secondary)}.combat-skill-cost{font-size:.6rem;color:var(--text-gold)}.combat-end-turn-btn{padding:10px 16px;background:linear-gradient(135deg,#c0392b,#962d22);border:1px solid #e74c3c;border-radius:8px;color:#fff;font-family:MedievalSharp,cursive;font-size:1rem;cursor:pointer;transition:all .2s;white-space:nowrap}.combat-end-turn-btn:hover:not(:disabled){background:linear-gradient(135deg,#e74c3c,#c0392b);transform:translateY(-2px);box-shadow:0 4px 15px #e74c3c4d}.combat-end-turn-btn:disabled{opacity:.4;cursor:not-allowed}.combat-target-info{position:absolute;top:12px;right:118px;width:200px;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:8px;padding:10px;text-align:center}#combat-target-name{font-family:MedievalSharp,cursive;font-size:1rem;color:var(--text-gold);margin-bottom:6px}.combat-target-hp-bar{width:100%;height:10px;background:#14101ecc;border-radius:5px;overflow:hidden;margin-bottom:4px}.combat-target-hp-fill{height:100%;background:var(--hp-bar);border-radius:5px;transition:width .3s ease}#combat-target-hp-text{font-size:.75rem;color:var(--text-secondary)}.victory-screen{position:absolute;top:0;left:0;width:100%;height:100%;background:#000000bd;display:flex;align-items:center;justify-content:center;z-index:200;pointer-events:auto;padding:16px}.victory-panel{background:var(--bg-panel);border:2px solid var(--border-gold-dim);border-radius:12px;box-shadow:0 10px 40px #0000008c,inset 0 1px #c8a84e1a;color:var(--text-primary)}.victory-panel-large{width:min(1180px,96vw);max-height:min(92vh,900px);overflow:auto;padding:18px 20px}.victory-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.victory-title{margin:0;font-family:MedievalSharp,cursive;text-shadow:0 0 10px rgba(200,168,78,.25);color:var(--text-gold);font-size:clamp(.95rem,2vw,1.2rem)}.defeat-title{color:var(--accent-red)}.victory-section{margin-bottom:14px}.victory-section-title{color:var(--text-gold);font-size:1.05rem;margin-bottom:8px;font-weight:600;text-transform:none;letter-spacing:0}.victory-section-table{border:1px solid var(--border-gold-dim);border-radius:8px;background:#14101e73;padding:10px}.victory-table-head,.victory-table-row{display:grid;grid-template-columns:minmax(20ch,1.2fr) minmax(80px,.6fr) minmax(170px,1fr) minmax(90px,.7fr) minmax(280px,2.4fr);gap:8px;align-items:center}.victory-table-head>*:not(:first-child),.victory-table-row>*:not(:first-child){border-left:1px solid rgba(80,140,90,.45);padding-left:8px}.victory-table-head{background:#231e32eb;color:var(--text-gold);border-radius:6px;padding:8px 10px;font-weight:600;font-size:.88rem}.victory-table-body{margin-top:4px}.victory-table-row{padding:8px 10px;font-size:.9rem;border-bottom:1px solid rgba(100,90,70,.2)}.victory-table-row:nth-child(odd){background:#1612229e}.victory-table-row:nth-child(2n){background:#100d1a9e}.victory-table-row:last-child{border-bottom:none}.victory-col-name{font-weight:700;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.victory-col-gold,.victory-col-level,.victory-col-count{font-variant-numeric:tabular-nums}.victory-col-xpbar{display:flex;align-items:center}.victory-table-head:not(.victory-table-head-monsters) .victory-col-level,.victory-table-head:not(.victory-table-head-monsters) .victory-col-xpbar,.victory-table-head:not(.victory-table-head-monsters) .victory-col-gold,.victory-table-row:not(.victory-table-row-monster) .victory-col-level,.victory-table-row:not(.victory-table-row-monster) .victory-col-xpbar,.victory-table-row:not(.victory-table-row-monster) .victory-col-gold{text-align:center;justify-content:center}.victory-xp-mini-bg{width:min(100%,170px);height:10px;background:#0e0c16d9;border-radius:999px;overflow:hidden;border:1px solid rgba(100,90,70,.3);position:relative}.victory-xp-mini-fill{height:100%;background:linear-gradient(90deg,#8b7a1a,#c8a84e);border-radius:999px;transition:width .55s ease}.victory-xp-mini-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.85);pointer-events:none}.victory-col-loot{display:flex;align-items:center;flex-wrap:wrap;gap:6px}.victory-loot-icon-btn{border:1px solid rgba(100,90,70,.3);background:#0e0c16e6;border-radius:5px;width:30px;height:30px;padding:0;position:relative;display:inline-flex;align-items:center;justify-content:center;cursor:default}.victory-loot-icon-img{width:24px;height:24px;object-fit:contain}.victory-loot-icon-fallback{font-size:.85rem;color:var(--text-secondary)}.victory-loot-qty-badge{position:absolute;bottom:-7px;right:-6px;background:#0c0a14f2;color:#fff;border-radius:999px;font-size:.63rem;line-height:1;padding:2px 5px}.victory-empty{color:var(--text-secondary);font-style:italic}.victory-table-head-monsters,.victory-table-row-monster{grid-template-columns:minmax(220px,2.3fr) minmax(100px,.7fr) minmax(100px,.7fr)}.victory-empty-line{color:var(--text-secondary);padding:10px;font-style:italic}.victory-continue-btn{display:block;width:220px;margin:12px auto 0;padding:10px 12px;background:linear-gradient(135deg,#c8a84e,#a08030);border:1px solid rgba(200,168,78,.65);border-radius:8px;color:#1a1428;font-family:MedievalSharp,cursive;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.3px}.victory-continue-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}.defeat-panel{background:var(--bg-panel);border:2px solid var(--accent-red);padding:26px;min-width:340px;max-width:450px;color:var(--text-primary)}.defeat-text{text-align:center;color:var(--text-secondary);margin-bottom:20px;font-size:.95rem}.defeat-btn{background:linear-gradient(135deg,#c0392b,#962d22)!important;color:#fff!important;border-color:#8a251a!important}.defeat-btn:hover{background:linear-gradient(135deg,#e74c3c,#c0392b)!important}@media(max-width:1024px){.victory-panel-large{width:98vw}.victory-table-head,.victory-table-row{grid-template-columns:minmax(18ch,1.15fr) minmax(70px,.55fr) minmax(120px,.9fr) minmax(66px,.6fr) minmax(200px,1.85fr);font-size:.82rem}}@media(max-width:760px){.victory-screen{padding:8px}.victory-panel-large{padding:10px;max-height:95vh}.victory-title{font-size:.92rem}.victory-table-head,.victory-table-row{grid-template-columns:1.3fr .9fr;gap:4px}.victory-col-xpbar,.victory-col-loot,.victory-col-count,.victory-col-level{grid-column:1 / -1}.victory-table-head-monsters,.victory-table-row-monster{grid-template-columns:1fr}.victory-continue-btn{width:100%}}.item-icon-shell{position:relative;display:inline-flex;align-items:center;justify-content:center}.item-icon-shell[data-upgrade-level="1"],.item-icon-shell[data-upgrade-level="2"],.item-icon-shell[data-upgrade-level="3"]{filter:drop-shadow(0 0 8px var(--item-upgrade-glow))}.item-icon-shell[data-upgrade-level="1"]:before,.item-icon-shell[data-upgrade-level="2"]:before,.item-icon-shell[data-upgrade-level="3"]:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:8px;border:1px solid color-mix(in srgb,var(--item-upgrade-color) 70%,white 30%);box-shadow:0 0 0 1px #ffffff14,0 0 12px var(--item-upgrade-glow),inset 0 0 10px #ffffff14;pointer-events:none}.item-upgrade-badge{position:absolute;top:-7px;right:-8px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;background:linear-gradient(180deg,color-mix(in srgb,var(--item-upgrade-color) 84%,white 16%),color-mix(in srgb,var(--item-upgrade-color) 62%,black 38%));color:#140d08;font-size:.56rem;font-weight:800;line-height:18px;text-align:center;letter-spacing:.05em;box-shadow:0 4px 10px #00000059;pointer-events:none}.item-icon-img,.skill-icon-img,.combat-skill-icon-img{width:32px!important;height:32px!important;object-fit:contain;vertical-align:middle;display:inline-block}.hotbar-slot img,.combat-hotbar-slot img{width:32px!important;height:32px!important;object-fit:contain;border-radius:4px}.creation-class-icon img,.creation-race-icon img{width:48px!important;height:48px!important;object-fit:cover;border-radius:50%;margin:0 auto}.stats-panel img.portrait-icon-img{width:64px!important;height:64px!important;border-radius:50%;object-fit:cover}.tooltip-title img,#combat-target-name img{width:24px!important;height:24px!important;margin-right:6px;vertical-align:middle;object-fit:cover;border-radius:4px}.monster-tooltip{position:absolute;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:8px;padding:10px 14px;z-index:200;pointer-events:none;box-shadow:0 4px 20px #00000080;min-width:160px;max-width:280px}.monster-tooltip-title{font-family:MedievalSharp,cursive;color:var(--text-gold);font-size:.9rem;margin-bottom:6px;border-bottom:1px solid var(--border-gold-dim);padding-bottom:4px}.monster-tooltip-list{list-style:none;padding:0;margin:0}.monster-tooltip-list li{margin:2px 0;display:flex;justify-content:space-between;color:var(--text-secondary);font-size:.85rem}.monster-tooltip-level{color:var(--text-gold);font-weight:700}.combat-end-turn-btn{background:linear-gradient(135deg,#c0392b,#962d22);color:#fff;border:none;border-radius:20px;padding:8px 18px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.combat-end-turn-btn:hover:not(:disabled){background:linear-gradient(135deg,#e74c3c,#c0392b);transform:scale(1.05)}.combat-end-turn-btn:disabled{opacity:.5;cursor:not-allowed}.login-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0a0a12,#1a1428,#0a0a12);display:flex;align-items:center;justify-content:center;z-index:200;animation:loginFadeIn .5s ease}.login-overlay.login-fade-out{animation:loginFadeOut .4s ease forwards}@keyframes loginFadeIn{0%{opacity:0}to{opacity:1}}@keyframes loginFadeOut{0%{opacity:1}to{opacity:0}}.login-box{width:380px;background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:12px;padding:40px 32px 28px;box-shadow:0 8px 60px #0009,0 0 40px #c8a84e0d,inset 0 1px #c8a84e1a}.login-logo{text-align:center;margin-bottom:28px}.login-logo-icon{font-size:3rem;display:block;margin-bottom:10px;animation:titleGlow 3s ease-in-out infinite}.login-logo h1{font-size:1.8rem;letter-spacing:2px;margin:0}.login-subtitle{font-family:Inter,sans-serif;color:var(--text-secondary);font-size:.85rem;margin-top:6px;font-weight:300}.login-tabs{display:flex;gap:4px;margin-bottom:24px;background:#14101e99;border-radius:6px;padding:3px}.login-tab{flex:1;padding:8px;background:transparent;border:none;color:var(--text-secondary);font-family:Inter,sans-serif;font-size:.85rem;font-weight:500;cursor:pointer;border-radius:4px;transition:all .25s}.login-tab:hover{color:var(--text-primary)}.login-tab.active{background:#c8a84e26;color:var(--text-gold)}.login-field{margin-bottom:16px}.login-field label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.login-field input{width:100%;background:#14101ecc;border:1px solid rgba(100,90,70,.3);border-radius:6px;padding:11px 14px;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.95rem;outline:none;transition:border-color .3s,box-shadow .3s}.login-field input:focus{border-color:var(--border-gold);box-shadow:0 0 12px #c8a84e26}.login-field input::placeholder{color:var(--text-dim)}.login-error{display:none;font-size:.8rem;color:var(--accent-red);text-align:center;padding:8px;margin-bottom:12px;background:#c0392b14;border-radius:4px}.login-submit{width:100%;padding:13px;background:linear-gradient(135deg,#c8a84e,#a08030);border:none;border-radius:6px;color:#1a1428;font-family:MedievalSharp,cursive;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s;letter-spacing:1px;margin-bottom:16px}.login-submit:hover:not(:disabled){background:linear-gradient(135deg,#d8b85e,#b09040);transform:translateY(-2px);box-shadow:0 6px 20px #c8a84e4d}.login-submit:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-status{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.75rem;color:var(--text-dim)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-red);display:inline-block;animation:statusPulse 2s ease-in-out infinite}.char-select-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:linear-gradient(135deg,#0a0a12,#1a1428,#0a0a12);display:flex;align-items:center;justify-content:center;z-index:180}.char-select-box{width:min(860px,92vw);background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:12px;padding:26px;box-shadow:0 8px 60px #0009,0 0 40px #c8a84e0d,inset 0 1px #c8a84e1a}.char-select-box h2{margin-bottom:6px}.char-select-subtitle{color:var(--text-secondary);margin-bottom:18px;font-size:.9rem}.char-select-slots{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.char-slot{background:#14101eb3;border:1px solid rgba(100,90,70,.3);border-radius:8px;padding:12px;min-height:130px;display:flex;flex-direction:column}.char-slot-empty{border-style:dashed}.char-slot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.char-slot-index{color:var(--text-secondary);font-size:.75rem;text-transform:uppercase}.char-slot-level{color:var(--text-gold);font-size:.8rem;font-weight:600}.char-slot-name{font-family:MedievalSharp,cursive;color:var(--text-gold);font-size:1.15rem;margin-bottom:4px}.char-slot-meta,.char-slot-empty-label{color:var(--text-secondary);font-size:.85rem;margin-bottom:12px}.char-slot-actions{margin-top:auto;display:flex;gap:8px}.char-slot-btn{border:none;border-radius:6px;padding:8px 10px;cursor:pointer;transition:all .2s;font-weight:600}.char-slot-btn.play,.char-slot-btn.create{background:linear-gradient(135deg,#c8a84e,#a08030);color:#1a1428}.char-slot-btn.play:hover,.char-slot-btn.create:hover{transform:translateY(-1px);box-shadow:0 4px 14px #c8a84e40}.char-slot-btn.danger{background:#c0392b33;color:#ffb3ab;border:1px solid rgba(192,57,43,.45)}.char-slot-btn.danger:hover{background:#c0392b59}@media(max-width:760px){.char-select-slots{grid-template-columns:1fr}}.status-dot.connected{background:var(--accent-green);animation:none}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.3}}.chat-container{position:absolute;bottom:15px;left:15px;width:350px;background:#0f0c19bf;border:1px solid rgba(100,90,70,.3);border-radius:8px;display:flex;flex-direction:column;box-shadow:0 4px 15px #00000080;pointer-events:auto;z-index:80}.chat-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;padding:8px 8px 0}.chat-tab{border:1px solid rgba(100,90,70,.3);border-radius:6px;background:#0a0a1299;color:var(--text-secondary);font-size:.78rem;font-weight:700;letter-spacing:.3px;padding:6px 8px;cursor:pointer;transition:all .18s ease}.chat-tab:hover{border-color:var(--border-gold-dim);color:var(--text-primary)}.chat-tab.active{border-color:#c8a84eb3;background:#c8a84e29;color:var(--text-gold)}.chat-panels{min-height:0}.chat-messages{height:200px;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:4px;scrollbar-width:thin;scrollbar-color:rgba(200,168,78,.5) transparent}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-thumb{background:#c8a84e80;border-radius:3px}.chat-message{font-size:.85rem;line-height:1.3;word-wrap:break-word}.chat-time{color:var(--text-dim);font-size:.75rem;margin-right:5px}.chat-sender{color:var(--text-gold);font-weight:700;margin-right:5px}.chat-text{color:var(--text-primary)}.chat-system{color:var(--accent-purple);font-style:italic}.chat-system .chat-sender{color:var(--accent-purple)}.chat-journal-entry{color:var(--text-secondary);font-size:.8rem;line-height:1.45;border-bottom:1px solid rgba(100,90,70,.12);padding:2px 0}.chat-input-wrapper{padding:8px;border-top:1px solid rgba(100,90,70,.3);background:#0a0a12e6;border-radius:0 0 8px 8px}.hidden{display:none!important}.chat-input{width:100%;background:transparent;border:none;color:var(--text-primary);font-family:Inter,sans-serif;font-size:.9rem;outline:none}.chat-input::placeholder{color:var(--text-dim)}.combat-prep-overlay{position:absolute;top:12px;right:12px;z-index:70;pointer-events:auto}.combat-prep-panel{background:var(--bg-panel);border:1px solid var(--border-gold-dim);border-radius:10px;padding:10px 12px;width:min(340px,calc(100vw - 24px));box-shadow:0 8px 40px #0009,inset 0 1px #c8a84e1a;animation:panelSlideIn .3s ease;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.combat-prep-header{display:flex;align-items:center;justify-content:space-between;gap:10px}.combat-prep-panel h3{font-size:.98rem;margin:0;line-height:1}.prep-timer-badge{min-width:54px;text-align:center;font-family:MedievalSharp,cursive;font-size:1rem;color:var(--text-gold);background:#100d1ae6;border:1px solid rgba(200,168,78,.35);border-radius:999px;padding:3px 10px;text-shadow:0 0 10px rgba(200,168,78,.35)}.combat-prep-hint{font-size:.73rem;color:var(--text-secondary);margin:7px 0 8px;line-height:1.25}.combat-prep-footer{display:flex;align-items:center;justify-content:space-between;gap:10px}.prep-ready-info{font-size:.8rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;white-space:nowrap}.combat-ready-btn{width:auto;min-width:112px;padding:7px 14px;background:linear-gradient(135deg,#27ae60,#1e8449);border:none;border-radius:6px;color:#fff;font-family:MedievalSharp,cursive;font-size:.92rem;font-weight:700;cursor:pointer;transition:all .2s;letter-spacing:.4px}.combat-ready-btn:hover:not(:disabled){background:linear-gradient(135deg,#2ecc71,#27ae60);transform:translateY(-1px);box-shadow:0 4px 14px #27ae6047}.combat-ready-btn:disabled{opacity:.7;cursor:not-allowed;background:linear-gradient(135deg,#1e8449,#145a32)}@media(max-width:760px){.combat-prep-overlay{top:10px;left:50%;right:auto;transform:translate(-50%)}.combat-prep-panel{width:min(360px,calc(100vw - 16px));padding:9px 10px}.combat-prep-panel h3{font-size:.9rem}.prep-timer-badge{min-width:48px;font-size:.92rem}.combat-ready-btn{min-width:98px;padding:7px 12px;font-size:.85rem}}.combat-ui{pointer-events:none!important}.combat-top-bar,.combat-target-info,.combat-bottom-container{pointer-events:auto!important}.combat-player-buffs-container,.combat-target-buffs-container{display:flex;gap:4px;margin-bottom:4px;flex-wrap:wrap}.combat-player-buffs-container{justify-content:flex-start}.combat-target-buffs-container{justify-content:center}.combat-status-icon{width:24px;height:24px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;-webkit-user-select:none;user-select:none;cursor:help;position:relative;box-shadow:0 1px 3px #0006}.combat-status-icon.buff{background-color:#2ecc71;border:1px solid #27ae60}.combat-status-icon.debuff{background-color:#e74c3c;border:1px solid #c0392b}.combat-status-icon.poison{background-color:#9b59b6;border:1px solid #8e44ad}.combat-status-icon.passive{background-color:#2c2a1e;border:2px solid #f1c40f;box-shadow:0 0 6px #f1c40f66,0 1px 3px #0006}.combat-status-duration{text-shadow:1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000}#game-canvas{cursor:pointer}
