:root{--bg: #0a0805;--panel: rgba(30, 22, 14, .96);--panel-solid: #1e160e;--border: #7a6035;--border-accent: #c9a257;--border-highlight: #d4b76a;--gold: #d4b060;--gold-bright: #f0d880;--parchment: #e6dcc0;--red: #c0392b;--red-bright: #e84444;--blue: #2c6fa8;--green: #3a7d3a;--dim: #8a8170;--destruction-red: #8b1a1a;--order-blue: #1a3a6b;--font-heading: "Cinzel", "IM Fell English SC", "Trebuchet MS", serif;--font-body: "Crimson Text", "Trebuchet MS", serif;--ornate-shadow: 0 4px 32px rgba(0, 0, 0, .9), 0 0 0 1px rgba(201, 162, 87, .25), 0 0 60px rgba(0, 0, 0, .6), inset 0 1px 0 rgba(201, 162, 87, .12);--ornate-border-image: linear-gradient( 180deg, #8a7040 0%, #c9a257 15%, #e6c570 50%, #c9a257 85%, #8a7040 100% ) 1}*{box-sizing:border-box}.app-root{position:fixed;inset:0;overflow:hidden;background:#0a0805}.panel{background:var(--panel);border:2px solid var(--border);border-radius:4px;box-shadow:var(--ornate-shadow);padding:16px;color:var(--parchment);position:relative}.panel:before,.panel:after{content:"";position:absolute;width:12px;height:12px;border-color:var(--border-accent);pointer-events:none}.panel:before{top:-1px;left:-1px;border-top:2px solid var(--border-accent);border-left:2px solid var(--border-accent)}.panel:after{bottom:-1px;right:-1px;border-bottom:2px solid var(--border-accent);border-right:2px solid var(--border-accent)}.panel h1,.panel h2,.panel h3{color:var(--gold);margin-top:0;font-family:var(--font-heading);font-weight:600;letter-spacing:.06em;text-shadow:0 1px 3px rgba(0,0,0,.8)}button{background:linear-gradient(180deg,#3a2d15,#2a1f0d,#1e1509);border:1px solid var(--border);color:var(--parchment);padding:8px 18px;font-family:var(--font-heading);font-size:13px;cursor:pointer;border-radius:3px;letter-spacing:.06em;text-transform:uppercase;text-shadow:0 1px 2px rgba(0,0,0,.6);transition:all .15s ease}button:hover{border-color:var(--border-accent);color:var(--gold-bright);background:linear-gradient(180deg,#4a3d20,#3a2d15,#2a1f0d);box-shadow:0 0 8px #c9a25733}button:active{background:linear-gradient(180deg,#1e1509,#2a1f0d)}button:disabled{opacity:.5;cursor:not-allowed}input,select{background:#0a0805;border:1px solid var(--border);color:var(--parchment);padding:7px 12px;font-family:var(--font-body);font-size:14px;border-radius:3px;transition:border-color .15s ease}input:focus,select:focus{outline:none;border-color:var(--border-accent);box-shadow:0 0 6px #c9a25726}.fullscreen-centered{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at 30% 15%,rgba(140,60,10,.25),transparent 55%),radial-gradient(ellipse at 70% 85%,rgba(80,15,15,.3),transparent 55%),radial-gradient(ellipse at 50% 50%,rgba(30,20,10,.6),transparent 80%),linear-gradient(180deg,#10080a,#1a0f05 30%,#0a0505 70%,#050308)}.fullscreen-centered:before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(1px 1px at 20% 30%,rgba(255,160,40,.6),transparent),radial-gradient(1px 1px at 45% 70%,rgba(255,120,30,.4),transparent),radial-gradient(1px 1px at 75% 20%,rgba(255,180,50,.5),transparent),radial-gradient(1px 1px at 60% 55%,rgba(255,140,40,.3),transparent),radial-gradient(1px 1px at 35% 85%,rgba(255,100,20,.4),transparent),radial-gradient(1px 1px at 85% 65%,rgba(255,160,60,.3),transparent);animation:ember-drift 8s ease-in-out infinite alternate;pointer-events:none}@keyframes ember-drift{0%{opacity:.5;transform:translateY(0)}to{opacity:.8;transform:translateY(-8px)}}.login-panel{width:min(400px,92vw);text-align:center;position:relative;z-index:1}.login-panel h1{font-family:var(--font-heading);font-size:32px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;background:linear-gradient(180deg,#f0d880,#c9a257,#8a6a30);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:4px;text-shadow:none;filter:drop-shadow(0 2px 4px rgba(0,0,0,.8))}.login-panel .subtitle{font-family:var(--font-heading);font-size:11px;color:var(--dim);letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px}.login-panel form{display:flex;flex-direction:column;gap:10px;text-align:left}.login-panel .field{display:flex;flex-direction:column;gap:4px}.login-panel label{font-family:var(--font-heading);font-size:11px;color:var(--dim);text-transform:uppercase;letter-spacing:.12em}.login-panel .hint{font-size:11px;color:var(--dim);margin-top:8px;text-align:center}.login-panel .backend-tag{font-family:var(--font-heading);font-size:9px;color:var(--border-accent);text-transform:uppercase;letter-spacing:.18em;margin-bottom:12px}.login-divider{height:1px;margin:10px 0;background:linear-gradient(90deg,transparent,var(--border-accent),transparent)}.character-select-panel{width:min(580px,96vw);max-height:85vh;overflow-y:auto;position:relative;z-index:1}.character-select-panel h1{font-family:var(--font-heading);font-size:24px;text-transform:uppercase;letter-spacing:.1em}.character-list{display:flex;flex-direction:column;gap:6px;margin:16px 0}.character-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:linear-gradient(135deg,#0a0805e6,#140f0ab3);border:1px solid var(--border);border-radius:3px;cursor:pointer;transition:all .15s ease}.character-row:hover{border-color:var(--border-accent);background:linear-gradient(135deg,#140f08f2,#1e160ecc);box-shadow:0 0 8px #c9a2571a}.character-row.selected{border-color:var(--gold);background:linear-gradient(135deg,#1e160af2,#281e0fd9);box-shadow:0 0 12px #c9a25733,inset 0 0 0 1px #c9a2571a}.character-row .name{color:var(--gold);font-family:var(--font-heading);font-size:16px;letter-spacing:.04em}.character-row .meta{color:var(--dim);font-size:12px}.character-row .realm-tag{font-family:var(--font-heading);font-size:9px;text-transform:uppercase;letter-spacing:.15em;padding:2px 8px;border-radius:2px}.character-row .realm-tag.order{color:#8ab4e0;background:#1a3a6b66;border:1px solid rgba(44,111,168,.4)}.character-row .realm-tag.destruction{color:#e08a8a;background:#6b1a1a66;border:1px solid rgba(168,44,44,.4)}.character-actions{display:flex;gap:8px;justify-content:flex-end}.create-form{display:flex;flex-direction:column;gap:10px;padding:14px;background:#0a0805b3;border:1px solid var(--border);border-radius:3px;margin-top:12px}.create-form label{font-family:var(--font-heading);font-size:11px;color:var(--dim);text-transform:uppercase;letter-spacing:.1em}.game-root{position:absolute;inset:0}.game-canvas-container{position:absolute;inset:0;touch-action:none}.game-canvas-container canvas{display:block;width:100%;height:100%}.hud{position:absolute;inset:0;pointer-events:none}.hud>*{pointer-events:auto}.player-frame{position:absolute;top:12px;left:12px;width:260px;padding:10px 12px;background:linear-gradient(180deg,#0e0b08eb,#080604e0);border:1px solid var(--border);border-top:2px solid var(--border-accent);box-shadow:0 2px 10px #000000b3,inset 0 1px #c9a25714}.target-frame{position:absolute;top:12px;left:50%;transform:translate(-50%);width:260px;padding:10px 12px;background:linear-gradient(180deg,#0e0b08eb,#080604e0);border:1px solid var(--border);border-top:2px solid var(--red);box-shadow:0 2px 10px #000000b3,inset 0 1px #c0392b1a}.unit-name{font-family:var(--font-heading);font-size:13px;color:var(--gold);margin-bottom:5px;display:flex;justify-content:space-between;letter-spacing:.03em;text-shadow:0 1px 2px rgba(0,0,0,.8)}.unit-level{color:var(--dim);font-family:var(--font-body);font-size:11px}.bar{position:relative;height:16px;background:linear-gradient(180deg,#0a0805,#060403);border:1px solid rgba(90,74,42,.6);border-radius:1px;overflow:hidden;margin-bottom:2px}.bar .fill{position:absolute;inset:0;transform-origin:left center;transition:transform .2s ease-out}.bar .fill.health{background:linear-gradient(180deg,#d44a3a,#b83328 40%,#8a1e15);box-shadow:inset 0 1px #ff967833}.bar .fill.mana{background:linear-gradient(180deg,#5a9aef,#3a7ac8 40%,#1e4a7a);box-shadow:inset 0 1px #96c8ff26}.bar .fill.xp{background:linear-gradient(180deg,#d4b060,#c9a257 40%,#8a7030);height:100%}.bar .label{position:absolute;inset:0;display:flex;justify-content:center;align-items:center;font-size:10px;font-weight:600;color:var(--parchment);text-shadow:1px 1px 0 rgba(0,0,0,.9),-1px -1px 0 rgba(0,0,0,.5);letter-spacing:.03em}.xp-bar{height:5px}.hotbar{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:3px;padding:5px 8px;background:linear-gradient(180deg,#0e0b08eb,#080604e0);border:1px solid var(--border);border-bottom:2px solid var(--border-accent);border-radius:3px;box-shadow:0 3px 12px #0009}.hotbar-slot{width:48px;height:48px;background:linear-gradient(180deg,#12100a,#0a0805);border:1px solid var(--border);border-radius:2px;position:relative;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--gold);cursor:pointer;transition:all .1s ease;box-shadow:inset 0 1px 3px #00000080}.hotbar-slot:hover{border-color:var(--border-accent);box-shadow:inset 0 1px 3px #00000080,0 0 6px #c9a25733}.hotbar-slot:active{background:linear-gradient(180deg,#0a0805,#12100a)}.hotbar-slot .key{position:absolute;bottom:1px;right:3px;font-size:9px;font-family:var(--font-heading);color:var(--dim);text-shadow:0 1px 1px rgba(0,0,0,.8)}.hotbar-slot .cd-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;font-family:var(--font-heading);color:var(--gold)}.chat{position:absolute;bottom:20px;left:12px;width:340px;height:194px;display:flex;flex-direction:column;background:#080604a6;border:1px solid rgba(90,74,42,.5);border-radius:2px;box-shadow:0 2px 8px #0006}.chat-titlebar{display:flex;align-items:center;gap:5px;padding:3px 4px 3px 7px;border-bottom:1px solid rgba(90,74,42,.4);background:#0a08058c;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:none;flex-shrink:0}.chat-titlebar:active{cursor:grabbing}.chat-drag-handle{font-size:14px;color:var(--dim);line-height:1;flex-shrink:0}.chat-title{flex:1;font-family:var(--font-heading);font-size:10px;color:var(--dim);letter-spacing:.12em;text-transform:uppercase}.chat-minimize-btn{background:none;border:1px solid transparent;color:var(--dim);padding:1px 5px;font-size:10px;cursor:pointer;line-height:1;border-radius:2px;flex-shrink:0;text-transform:none;letter-spacing:0;transition:color .1s,border-color .1s}.chat-minimize-btn:hover{color:var(--gold);border-color:var(--border);background:none;box-shadow:none}.chat-minimize-btn:active{background:#1e160ecc}.chat.chat--minimized{height:auto}.chat-log{flex:1;overflow-y:auto;padding:6px 8px;font-size:12px;line-height:1.5;font-family:var(--font-body)}.chat-msg .from{color:var(--gold);margin-right:4px;font-weight:600}.chat-msg.system .from{color:var(--border-accent)}.chat-input-row{display:flex;padding:3px 4px;border-top:1px solid rgba(90,74,42,.4);background:#0a080566}.chat-input-row input{flex:1;background:transparent;border:none;color:var(--parchment);font-family:var(--font-body);font-size:12px;padding:4px 6px}.chat-input-row input:focus{outline:none;box-shadow:none}.inventory{position:absolute;top:50%;right:24px;transform:translateY(-50%);width:280px;padding:12px;background:linear-gradient(180deg,#0e0b08f2,#080604eb)}.inventory h2{margin:0 0 10px;font-size:15px;font-family:var(--font-heading);letter-spacing:.08em;text-transform:uppercase}.inv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px}.inv-slot{aspect-ratio:1;background:linear-gradient(180deg,#12100a,#0a0805);border:1px solid var(--border);border-radius:2px;display:flex;align-items:center;justify-content:center;font-size:22px;position:relative;cursor:pointer;transition:border-color .1s ease;box-shadow:inset 0 1px 3px #00000080}.inv-slot:hover{border-color:var(--border-accent)}.inv-slot.empty{opacity:.3}.inv-slot .qty{position:absolute;bottom:1px;right:3px;font-size:10px;color:var(--parchment);text-shadow:0 1px 1px rgba(0,0,0,.9)}.inv-tooltip{position:absolute;bottom:-32px;left:50%;transform:translate(-50%);white-space:nowrap;background:var(--panel-solid);border:1px solid var(--border-accent);padding:4px 8px;font-size:11px;color:var(--parchment);z-index:10;pointer-events:none;box-shadow:0 2px 6px #0009}.minimap{position:absolute;top:12px;right:12px;width:150px;height:150px;background:#080604cc;border:2px solid var(--border);border-radius:50%;overflow:hidden;box-shadow:0 2px 12px #000000b3,inset 0 0 0 1px #0000004d}.minimap:after{content:"";position:absolute;inset:-4px;border:2px solid rgba(201,162,87,.2);border-radius:50%;pointer-events:none}.minimap canvas{width:100%;height:100%;display:block}.minimap-label{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-family:var(--font-heading);font-size:10px;color:var(--dim);letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}.debug{position:absolute;top:16px;left:50%;transform:translate(-50%,200px);padding:8px 12px;font-family:ui-monospace,monospace;font-size:11px;background:#000000bf;border:1px solid rgba(90,74,42,.4);color:#9ef;white-space:pre}.floating-damage-layer{position:absolute;inset:0;pointer-events:none;overflow:hidden}.floating-damage{position:absolute;font-weight:700;font-family:var(--font-heading);font-size:22px;text-shadow:2px 2px 0 rgba(0,0,0,.9),-1px -1px 0 rgba(0,0,0,.6);transform:translate(-50%);animation:float-up 1.2s ease-out forwards}.floating-damage.damage{color:#fc3}.floating-damage.heal{color:#6f7}.floating-damage.miss{color:#aaa;font-size:16px}@keyframes float-up{0%{opacity:0;transform:translate(-50%) scale(.8)}10%{opacity:1;transform:translate(-50%,-5px) scale(1.1)}20%{transform:translate(-50%,-10px) scale(1)}to{opacity:0;transform:translate(-50%,-65px)}}.enemy-nameplate{position:absolute;transform:translate(-50%,-100%);pointer-events:none;text-align:center}.enemy-nameplate .name{font-family:var(--font-heading);font-size:11px;color:var(--parchment);text-shadow:1px 1px 0 rgba(0,0,0,.9),-1px -1px 0 rgba(0,0,0,.5);margin-bottom:2px;letter-spacing:.03em}.enemy-nameplate .bar{width:80px;height:5px;margin:0 auto;border-radius:1px}.logout-btn{position:absolute;top:12px;right:174px;font-size:11px;padding:4px 10px}.controls-hint{position:absolute;bottom:3px;right:12px;font-size:9px;color:#8a817099;font-family:ui-monospace,monospace}.death-overlay{position:absolute;inset:0;background:radial-gradient(ellipse at center,#50000066,#280000b3);display:flex;align-items:center;justify-content:center;z-index:200;pointer-events:auto}.death-panel{background:linear-gradient(180deg,#140a08f2,#0c0604f2);border:2px solid var(--red);border-radius:4px;padding:40px 60px;text-align:center;box-shadow:0 0 50px #b4141466,0 0 100px #640a0a33}.death-panel h2{font-family:var(--font-heading);color:var(--red-bright);font-size:28px;margin:0 0 10px;letter-spacing:.08em;text-transform:uppercase;text-shadow:0 0 20px rgba(232,68,68,.3)}.death-panel p{color:var(--dim);margin:0 0 24px;font-size:13px;font-family:var(--font-body);font-style:italic}.hotbar-slot.no-mana{opacity:.4}.inv-hint{font-family:var(--font-heading);font-size:9px;color:var(--dim);margin:6px 0 0;text-align:center;letter-spacing:.06em;text-transform:uppercase}.loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,#0a0805,#050304);color:var(--gold);font-family:var(--font-heading);font-size:16px;letter-spacing:.12em;text-transform:uppercase}.loading:after{content:"";display:block;width:120px;height:2px;margin-top:16px;background:linear-gradient(90deg,transparent,var(--border-accent),transparent);animation:loading-pulse 1.5s ease-in-out infinite}@keyframes loading-pulse{0%,to{opacity:.3}50%{opacity:1}}.touch-controls{display:none;position:absolute;inset:0;pointer-events:none}.touch-joystick-base{position:absolute;bottom:10px;left:12px;width:120px;height:120px;border-radius:50%;background:#08060480;border:2px solid var(--border);pointer-events:auto;touch-action:none;user-select:none;-webkit-user-select:none;box-shadow:0 2px 8px #0006}.touch-joystick-knob{position:absolute;top:50%;left:50%;width:48px;height:48px;border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--border-accent),var(--border));border:2px solid var(--gold);transform:translate(-50%,-50%);pointer-events:none;box-shadow:0 2px 8px #000000b3}.touch-jump-btn{position:absolute;bottom:18px;right:12px;width:72px;height:72px;border-radius:50%;font-size:28px;display:flex;align-items:center;justify-content:center;background:#08060499;border:2px solid var(--border);color:var(--gold);pointer-events:auto;touch-action:none;user-select:none;-webkit-user-select:none;padding:0;box-shadow:0 2px 8px #0006}.touch-jump-btn:active{background:#281e0abf;border-color:var(--border-accent)}@media (pointer: coarse){.touch-controls{display:block}.controls-hint{display:none}.player-frame{width:min(46vw,220px);padding:8px 10px}.minimap{width:90px;height:90px}.minimap-label{display:none}.target-frame{top:104px;left:12px;transform:none;width:min(calc(100vw - 24px),260px)}.inventory{left:12px;right:12px;width:auto;max-height:60vh;overflow-y:auto}.logout-btn{top:auto;bottom:98px;right:12px}.hotbar{bottom:138px}.hotbar-slot{width:60px;height:60px;font-size:24px}.chat{bottom:220px;left:12px;width:calc(100vw - 24px);height:134px}}@media (pointer: coarse) and (orientation: landscape){.player-frame{width:min(30vw,200px);padding:5px 8px}.player-frame .bar{height:12px}.player-frame .xp-bar{height:4px}.minimap{width:72px;height:72px}.target-frame{display:none}.touch-joystick-base{width:80px;height:80px;bottom:8px;left:8px}.touch-joystick-knob{width:34px;height:34px}.touch-jump-btn{width:56px;height:56px;bottom:12px;right:8px;font-size:22px}.hotbar{bottom:14px}.hotbar-slot{width:44px;height:44px;font-size:18px}.chat{display:none}.logout-btn{bottom:auto;top:8px;right:88px;font-size:9px;padding:2px 5px}}
