/* ============================================================
   AutoBattle — Haupt-Stylesheet
   ============================================================ */


/* ===== BASIS & RESET ===== */
*{box-sizing:border-box;margin:0;padding:0}
:root{--gold:#d4a843;--silver:#a8b8c8;--bronze:#c87941;--surface:rgba(13,13,20,0.85);--surface2:rgba(26,26,42,0.85);--surface3:rgba(34,34,52,0.85);--border:#2a2a40;--text:#e0d8cc;--muted:#6a6a8a;--green:#2d8a4e;--red:#b03030;--blue:#3a6fa0;--sidebar-w:200px}
body{color:var(--text);font-family:'Georgia',serif;min-height:100vh;overflow-x:hidden;font-size:14px;background:#0a0a12}


/* ===== HINTERGRUND ===== */
.login-body{background:url('/assets/bg_login.png') center/cover no-repeat fixed,#0a0a12}
#bg{position:fixed;left:var(--sidebar-w);top:0;right:0;bottom:0;z-index:0;background-size:cover;background-position:center;transition:background-image 1s ease}
#overlay{position:fixed;inset:0;z-index:1;background:rgba(0,0,0,.4)}


/* ===== LOGIN-SZENE ===== */
#loginScreen{display:flex;align-items:center;justify-content:center;min-height:100vh;position:relative;z-index:2}
.lp{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:36px 32px;width:330px;text-align:center;backdrop-filter:blur(6px)}
.lp h1{font-size:1.9em;color:var(--gold);letter-spacing:2px;margin-bottom:2px}
.lp .sub{color:var(--muted);font-size:.8em;margin-bottom:22px;font-style:italic}
.ltabs{display:flex;margin-bottom:20px;border-radius:7px;overflow:hidden;border:1px solid var(--border)}
.ltabs button{flex:1;padding:9px;background:transparent;border:none;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.85em;transition:.2s}
.ltabs button.a{background:var(--surface2);color:var(--text)}
.fld{margin-bottom:12px;text-align:left}
.fld label{font-size:.75em;color:var(--muted);display:block;margin-bottom:3px;letter-spacing:1px;text-transform:uppercase}
.fld input{width:100%;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:7px;padding:9px 11px;color:var(--text);font-family:inherit;font-size:.9em;outline:none;transition:.2s}
.fld input:focus{border-color:var(--gold)}
.bgold{width:100%;background:var(--gold);border:none;border-radius:7px;padding:11px;color:#0a0a12;font-weight:bold;font-family:inherit;font-size:.95em;cursor:pointer;letter-spacing:1px;margin-top:4px;transition:.2s}
.bgold:hover{opacity:.82}
#lmsg{font-size:.82em;margin-top:9px;min-height:1.1em;color:#d05050}
#lmsg.ok{color:#4aaa70}


/* ===== GAME-LAYOUT ===== */
#gameLayout{display:flex;min-height:100vh;position:relative;z-index:2}
#mainContent{margin-left:var(--sidebar-w);flex:1;padding:20px 24px;min-height:100vh;overflow-y:auto}


/* ===== SIDEBAR ===== */
#sidebar{width:var(--sidebar-w);background:rgba(8,8,16,.92);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:12px 0;position:fixed;top:0;left:0;bottom:0;z-index:10;backdrop-filter:blur(10px)}
.sb-logo{text-align:center;font-size:2em;padding:8px 0 16px;border-bottom:1px solid var(--border);margin-bottom:8px}
.sb-btn{display:flex;align-items:center;gap:10px;padding:12px 18px;background:transparent;border:none;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.88em;transition:.2s;width:100%;text-align:left;border-left:3px solid transparent;position:relative}
.sb-btn:hover{color:var(--text);background:rgba(255,255,255,.04)}
.sb-btn.active{color:var(--gold);border-left-color:var(--gold);background:rgba(212,168,67,.08)}
.sb-icon{font-size:1.2em;width:24px;text-align:center}
.sb-label{flex:1}
.sb-spacer{flex:1}
.sb-currency{padding:10px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}
.sb-coin{display:flex;align-items:center;gap:6px;font-size:.85em;font-weight:bold}
.sb-coin img{width:18px;height:18px;object-fit:contain}
.sb-coin:nth-child(1){color:var(--gold)}
.sb-coin:nth-child(2){color:var(--silver)}
.sb-coin:nth-child(3){color:var(--bronze)}
.sb-logout{border-top:1px solid var(--border);margin-top:4px;padding-top:12px;color:#b05050}
.sb-logout:hover{color:#e06060}

/* Event-Badge in der Sidebar */
@keyframes evPulse{0%,100%{box-shadow:0 0 8px var(--ev-color,#f39c12),0 0 0 rgba(0,0,0,0)}50%{box-shadow:0 0 16px var(--ev-color,#f39c12),0 0 4px var(--ev-color,#f39c12)}}
.ev-badge{--ev-color:#f39c12;margin:0 8px 6px;border-radius:8px;border:1px solid var(--ev-color);background:rgba(0,0,0,.45);padding:6px 10px;display:flex;align-items:center;gap:6px;cursor:default;animation:evPulse 2.5s ease-in-out infinite;transition:opacity .3s}
.ev-badge.ev-hidden{display:none}
.ev-icon{font-size:1.1em;line-height:1}
.ev-name{font-size:.72em;color:var(--ev-color);font-weight:bold;letter-spacing:.5px;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ev-extra{font-size:.65em;background:var(--ev-color);color:#000;border-radius:10px;padding:1px 5px;font-weight:bold}

/* Nav-Badge (rote Zahl auf Sidebar-Button) */
.nav-badge{position:absolute;top:2px;right:2px;background:#e05050;color:#fff;border-radius:50%;width:14px;height:14px;font-size:.6em;display:flex;align-items:center;justify-content:center;font-weight:bold}


/* ===== SZENEN (ALLGEMEIN) ===== */
.scene{display:none;animation:fadeScene .3s ease}
.scene.active{display:block}
@keyframes fadeScene{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.scene-header{margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid var(--border)}
.scene-header h2{color:var(--gold);font-size:1.3em;letter-spacing:1px}


/* ===== CHARAKTER-SZENE — 2-Spalten Layout ===== */
.char-layout{display:grid;grid-template-columns:1fr 500px;gap:14px;min-height:calc(100vh - 88px)}
.char-main-col{display:flex;flex-direction:column;gap:10px;min-width:0}
.char-hero-info{display:flex;gap:14px;align-items:center;background:rgba(8,8,18,.8);border:1px solid var(--border);border-radius:10px;padding:12px}
.char-hero-text{display:flex;flex-direction:column;gap:6px;flex:1;min-width:0}
.equip-all-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.char-stats-3{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;width:616px;max-width:100%}
.char-stats-2{display:grid;grid-template-columns:repeat(2,1fr);gap:6px;width:616px;max-width:100%}
.char-stats-3 .attr-block,.char-stats-2 .attr-block{max-width:none;flex:none}
.set-bonus-display{font-size:.85em;padding:7px 12px;border-radius:7px;text-align:center;width:616px;max-width:100%}
.char-inv-col{background:rgba(8,8,18,.8);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;overflow:hidden}
.char-inv-btot{display:flex;flex-wrap:wrap;gap:3px;align-content:flex-start;flex:1;min-height:0;overflow-y:auto;padding-top:4px}

/* Portrait + Equip-Spalten Anordnung */
.char-page{display:flex;flex-direction:column;gap:12px;overflow-y:auto}
.char-top-new{display:grid;grid-template-columns:190px 220px 190px;gap:8px;align-items:start;justify-content:start}
.equip-col-new{display:flex;flex-direction:column;gap:5px}


/* ===== AUSRÜSTUNGS-SLOTS ===== */
.equip-slot-box{
  background:rgba(8,8,22,.85);
  border:2px solid #2a2a50;
  border-radius:8px;
  padding:10px 8px 8px;
  cursor:pointer;
  transition:.2s;
  display:flex;flex-direction:column;
  align-items:center;
  gap:4px;
  min-height:110px;
  position:relative;
}
.equip-slot-box:hover{border-color:var(--gold);background:rgba(50,40,0,.35)}
.equip-slot-box.has-item{border-color:#4a4a70}
.equip-slot-box.has-item .esb-icon{display:none}
.equip-slot-box.has-item .esb-label{display:none}
.equip-slot-box.has-item .esb-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:1em;width:100%}
.equip-slot-empty{opacity:0;pointer-events:none;min-height:110px}
.esb-icon{font-size:1.7em;line-height:1}
.esb-label{font-size:.58em;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;text-align:center}
.esb-item{font-size:.62em;color:var(--text);text-align:center;line-height:1.2;font-weight:bold;max-width:120px}
.esbi-icon{font-size:2.4em;line-height:1;height:2.4em;display:flex;align-items:center;justify-content:center}
.esbi-name{font-size:.62em;font-weight:bold;text-align:center;word-break:break-word;white-space:normal;line-height:1.2;max-width:100%}

/* Qualitätspunkt im Ausrüstungsslot */
.esb-quality-dot{width:7px;height:7px;border-radius:50%;position:absolute;bottom:4px;right:4px}
.esb-quality-dot.qn{background:#888}.esb-quality-dot.qu{background:#1eff00}
.esb-quality-dot.qr{background:#0070dd}.esb-quality-dot.qe{background:#a335ee}
.esb-quality-dot.ql{background:#ff8000}.esb-quality-dot.qk{background:#ff2020}.esb-quality-dot.qm{background:#e8cc00}

/* Qualitäts-Glow auf dem gesamten Ausrüstungsslot (Rahmen + Hintergrund) */
.equip-slot-box.qu{border-color:#1eff0080 !important;box-shadow:0 0 16px #1eff0045,inset 0 0 18px #1eff0018}
.equip-slot-box.qr{border-color:#0070dd80 !important;box-shadow:0 0 16px #0070dd50,inset 0 0 18px #0070dd18}
.equip-slot-box.qe{border-color:#a335ee90 !important;box-shadow:0 0 18px #a335ee60,inset 0 0 20px #a335ee22}
.equip-slot-box.ql{border-color:#ff800090 !important;box-shadow:0 0 20px #ff800065,inset 0 0 22px #ff800025}
.equip-slot-box.qk{border-color:#ff2020a0 !important;box-shadow:0 0 24px #ff202080,inset 0 0 26px #ff202035;animation:slotPulseRed 1.5s ease-in-out infinite}
.equip-slot-box.qm{border-color:#e8cc00a0 !important;box-shadow:0 0 22px #e8cc0075,inset 0 0 24px #e8cc0030;animation:slotPulse 2s ease-in-out infinite}
@keyframes slotPulse{0%,100%{box-shadow:0 0 22px #e8cc0075,inset 0 0 24px #e8cc0030}50%{box-shadow:0 0 34px #e8cc00a0,inset 0 0 32px #e8cc0050}}
@keyframes slotPulseRed{0%,100%{box-shadow:0 0 24px #ff202080,inset 0 0 26px #ff202035}50%{box-shadow:0 0 38px #ff2020b0,inset 0 0 34px #ff202060}}

/* Helm-Zeile über dem Portrait */
.char-helm-row{display:grid;grid-template-columns:190px 220px 190px;gap:8px;width:616px}

/* Bottom-Slots (Platzhalter) */
.char-bottom-slots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:616px}
.equip-slot-future{opacity:.45;cursor:not-allowed !important;border-style:dashed !important;border-color:#3a3a5a !important}
.equip-slot-future:hover{border-color:#3a3a5a !important;background:rgba(8,8,22,.85) !important;box-shadow:none !important;transform:none}
.esb-future-label{font-size:.58em;color:var(--muted);font-style:italic;margin-top:2px}

/* Drag & Drop auf Ausrüstungsslots */
.equip-slot-box.drag-over{border-color:#d4a843 !important;background:rgba(212,168,67,.12) !important;box-shadow:0 0 10px rgba(212,168,67,.35)}


/* ===== PORTRAIT & XP-LEISTE ===== */
.char-center-new{display:flex;flex-direction:column;align-items:center;gap:5px}
.char-portrait-frame{width:200px;height:200px;border-radius:12px;overflow:hidden;border:3px solid var(--gold);background:rgba(10,10,20,.8);box-shadow:0 0 28px rgba(212,168,67,.25);flex-shrink:0}
.char-portrait-frame img{width:100%;height:100%;object-fit:cover}
.char-name{font-size:1.15em;font-weight:bold;color:var(--text);text-shadow:0 2px 6px #000}
.char-level{font-size:.82em;color:var(--gold);letter-spacing:1px}
.char-xp{display:none}

/* XP-Balken mit Hover-Tooltip */
.xpbar-outer{position:relative;display:inline-block}
.xpbar-outer[data-tooltip]:hover::after{content:attr(data-tooltip);position:absolute;bottom:calc(100% + 7px);left:50%;transform:translateX(-50%);background:rgba(8,8,18,.97);border:1px solid var(--border);border-radius:7px;padding:5px 12px;font-size:.78em;color:var(--text);white-space:nowrap;z-index:200;pointer-events:none;box-shadow:0 4px 14px rgba(0,0,0,.6)}
.xpbar-wrap-lg{width:180px;height:22px;background:#1a1a2a;border-radius:11px;overflow:hidden;border:1px solid var(--border);position:relative}
.xpbar{height:100%;background:linear-gradient(90deg,#2a6a2a,#4aaa4a);border-radius:11px;transition:width .4s}
.xpbar-label{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:.72em;font-weight:bold;color:#fff;text-shadow:0 1px 3px #000;pointer-events:none}


/* ===== ATTRIBUTE / STATS ===== */
.char-attrs{display:flex;flex-wrap:wrap;gap:6px;justify-content:start}
.char-attrs-OLD{display:none}
.attr-block{
  background:rgba(8,8,20,.85);
  border:1px solid #2a2a50;
  border-radius:6px;
  padding:10px 14px;
  display:flex;
  align-items:center;
  gap:12px;
  min-height:62px;
}
.attr-block:hover{border-color:#3a3a70}
.attr-left{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.attr-label{font-size:.62em;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.attr-value{font-size:1.35em;font-weight:bold;color:var(--text);line-height:1.1}
.attr-sub-line{font-size:.72em;color:var(--muted);margin-top:1px}
.attr-upgrade-btn{
  background:rgba(212,168,67,.18);
  border:2px solid var(--gold);
  border-radius:7px;
  width:38px;height:38px;
  cursor:pointer;
  font-family:inherit;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:0px;
  transition:.2s;
  flex-shrink:0;
}
.attr-upgrade-btn:hover{background:rgba(212,168,67,.4);transform:scale(1.05)}
.aub-cost{font-size:.55em;color:var(--muted);white-space:nowrap;line-height:1}
.aub-plus{font-size:1.1em;color:var(--gold);font-weight:bold;line-height:1}

/* Upgrade-Buttons (Szene) */
.upg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.upg-btn{background:rgba(10,10,20,.6);border:1px solid var(--border);border-radius:7px;padding:8px;cursor:pointer;color:var(--text);font-family:inherit;font-size:.8em;transition:.2s;text-align:left;width:100%;backdrop-filter:blur(4px)}
.upg-btn:hover{border-color:var(--gold);background:rgba(30,30,48,.8)}
.upg-t{font-weight:bold;margin-bottom:2px;color:var(--gold);font-size:.85em}
.upg-c{font-size:.75em;color:var(--bronze)}
.upg-s{font-size:.72em;color:var(--muted);margin-top:1px}


/* ===== INVENTAR (Charakter-Szene) ===== */
.char-inventory-bottom{background:rgba(8,8,18,.8);border:1px solid var(--border);border-radius:10px;padding:12px}
.inv-panel-header{font-size:.75em;color:var(--gold);letter-spacing:1px;text-transform:uppercase;margin-bottom:8px;font-weight:bold}
.char-inv-grid-bottom{display:grid;grid-template-columns:repeat(10,48px);gap:3px;justify-content:start}

/* Inventar-Slots (Raster) */
.cig-slot{background:rgba(10,10,28,.8);border:1px solid #2a2a40;border-radius:6px;width:82px;height:82px;display:flex;align-items:center;justify-content:center;font-size:1.3em;cursor:pointer;transition:.2s;position:relative;user-select:none;-webkit-user-select:none;touch-action:none}
.cig-slot > *{pointer-events:none}
.cig-drag-ghost{position:fixed;z-index:10000;pointer-events:none;width:82px;height:82px;background:rgba(10,10,28,.92);border:2px solid var(--gold);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.3em;opacity:.88;transform:scale(1.1);box-shadow:0 4px 24px rgba(0,0,0,.8)}
.cig-slot:hover{border-color:var(--gold);background:rgba(40,30,0,.4)}
.cig-slot.empty-inv{cursor:default;color:#2a2a40;font-size:.8em}
.cig-slot.dragging{opacity:.35}
.cig-slot.drag-over{border-color:#d4a843;background:rgba(212,168,67,.18);box-shadow:0 0 8px rgba(212,168,67,.4)}

/* Qualitätspunkt & Klassen-Icon im Inventar-Slot */
.cig-dot{width:6px;height:6px;border-radius:50%;position:absolute;bottom:2px;right:2px}
.cig-dot.qn{background:#888}.cig-dot.qu{background:#1eff00}.cig-dot.qr{background:#0070dd}
.cig-dot.qe{background:#a335ee}.cig-dot.ql{background:#ff8000}.cig-dot.qk{background:#ff2020}.cig-dot.qm{background:#e8cc00}
.cig-class{position:absolute;top:1px;left:3px;font-size:.55em;line-height:1;pointer-events:none}


/* ===== ITEM-QUALITÄT, FARBEN & ICONS ===== */
/* Qualitätsfarben (Text) */
.qn{color:#e0d8cc}.qu{color:#1eff00}.qr{color:#0070dd}.qe{color:#a335ee}.ql{color:#ff8000}.qk{color:#ff2020}.qm{color:#e8cc00}

/* Qualitäts-Glanz (Drop-Shadow für Item-Icons) */
.q-glow-u{filter:drop-shadow(0 0 5px #1eff00)}
.q-glow-r{filter:drop-shadow(0 0 5px #0070dd)}
.q-glow-e{filter:drop-shadow(0 0 6px #a335ee)}
.q-glow-l{filter:drop-shadow(0 0 7px #ff8000)}
.q-glow-k{filter:drop-shadow(0 0 9px #ff2020)}
.q-glow-m{filter:drop-shadow(0 0 11px #e8cc00)}

/* Item-Bild & Emoji Größen je nach Kontext */
.item-img{display:block;width:100%;height:100%;object-fit:contain}
.cig-slot .item-img{width:86%;height:86%}
.equip-slot-box .item-img{width:68px;height:68px;object-fit:contain}
.item-emoji{line-height:1}
.cig-slot .item-emoji{font-size:2.2em}
.equip-slot-box .item-emoji{font-size:1.8em}


/* ===== ITEM TOOLTIP ===== */
.item-tooltip{position:fixed;z-index:9999;pointer-events:none;min-width:210px;max-width:270px;background:linear-gradient(160deg,rgba(12,12,30,.98),rgba(6,6,18,.98));border:1px solid #3a3a60;border-radius:10px;box-shadow:0 8px 32px rgba(0,0,0,.85),0 0 0 1px rgba(255,255,255,.04);font-size:.83em;overflow:hidden}
.item-tooltip.hidden{display:none}
.itt-header{font-size:1.05em;font-weight:bold;padding:11px 14px 4px;letter-spacing:.3px;line-height:1.3}
.itt-meta{padding:0 14px 4px;color:rgba(255,255,255,.5);font-size:.88em}
.itt-level{padding:0 14px 9px;color:rgba(255,255,255,.35);font-size:.82em}
.itt-divider{height:1px;background:rgba(255,255,255,.07)}
.itt-stats{padding:8px 14px 6px;display:flex;flex-direction:column;gap:3px}
.itt-stat{display:flex;justify-content:space-between;align-items:center;gap:10px}
.itt-stat-label{color:rgba(255,255,255,.65)}
.itt-stat-val{color:#7fd17f;font-weight:bold;white-space:nowrap}
.itt-class{margin:6px 14px 4px;padding:4px 8px;border:1px solid;border-radius:5px;font-size:.87em;text-align:center;background:rgba(255,255,255,.04)}
.itt-sell{padding:8px 14px 10px;color:rgba(255,255,255,.45);font-size:.83em}

/* ===== SLOT-PICKER OVERLAY (Item anlegen) ===== */
.slot-picker-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center}
.slot-picker-overlay.hidden{display:none}
.slot-picker-modal{background:#0e0e1e;border:2px solid var(--gold);border-radius:12px;padding:20px;min-width:380px;max-width:480px;max-height:70vh;display:flex;flex-direction:column;gap:10px}
.slot-picker-header{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding-bottom:10px}
.slot-picker-header span{font-size:1em;color:var(--gold);font-weight:bold;letter-spacing:1px}
.slot-picker-close{background:transparent;border:none;color:var(--muted);font-size:1.4em;cursor:pointer}
.slot-picker-close:hover{color:var(--text)}
.slot-picker-list{overflow-y:auto;display:flex;flex-direction:column;gap:6px}
.sp-item{background:rgba(10,10,28,.9);border:1px solid var(--border);border-radius:8px;padding:10px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:.2s}
.sp-item:hover{border-color:var(--gold);background:rgba(40,30,0,.3)}
.sp-item.sp-equipped{border-color:#3a6fa0;background:rgba(10,30,60,.4)}
.sp-icon{font-size:1.5em;width:32px;height:32px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sp-info{flex:1}
.sp-name{font-weight:bold;font-size:.9em;margin-bottom:2px}
.sp-stats{font-size:.75em;color:var(--muted)}
.sp-action{display:flex;flex-direction:column;gap:4px;flex-shrink:0}
.sp-item-sell-row{display:flex;gap:4px}
.btn-sp-equip{background:var(--green);border:none;border-radius:5px;padding:4px 10px;color:#fff;cursor:pointer;font-size:.75em;font-family:inherit;transition:.2s}
.btn-sp-equip:hover{background:#3aaa60}
.btn-sp-unequip{background:rgba(60,80,120,.5);border:1px solid var(--blue);border-radius:5px;padding:4px 10px;color:var(--silver);cursor:pointer;font-size:.75em;font-family:inherit;transition:.2s}
.btn-sp-unequip:hover{background:rgba(60,80,120,.8)}
.btn-sp-sell{background:rgba(120,30,30,.5);border:1px solid #5a2a2a;border-radius:5px;padding:4px 8px;color:#e08080;cursor:pointer;font-size:.72em;font-family:inherit;transition:.2s}
.btn-sp-sell:hover{background:rgba(150,40,40,.8)}
.sp-empty-hint{color:var(--muted);font-size:.85em;text-align:center;padding:20px;font-style:italic}
.sp-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:20000;display:flex;align-items:center;justify-content:center}
.sp-confirm-box{background:#12121e;border:1px solid var(--gold);border-radius:12px;padding:24px 28px;max-width:340px;width:90%;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 40px #000a}
.sp-confirm-title{font-size:1.05em;font-weight:bold;color:var(--text)}
.sp-confirm-body{color:var(--muted);font-size:.9em;line-height:1.5}
.sp-confirm-btns{display:flex;gap:10px;justify-content:flex-end}
.btn-sp-confirm-yes{background:rgba(140,30,30,.7);border:1px solid #7a2a2a;border-radius:7px;padding:7px 16px;color:#f08080;cursor:pointer;font-family:inherit;font-size:.9em;transition:.2s}
.btn-sp-confirm-yes:hover{background:rgba(180,40,40,.9);color:#fff}
.btn-sp-confirm-no{background:rgba(30,50,80,.7);border:1px solid var(--border);border-radius:7px;padding:7px 16px;color:var(--text);cursor:pointer;font-family:inherit;font-size:.9em;transition:.2s}
.btn-sp-confirm-no:hover{background:rgba(40,70,110,.8)}


/* ===== SHOP-SZENE ===== */
.shop-tabs{display:flex;gap:6px;margin-bottom:16px;flex-wrap:wrap}
.shop-tab{background:transparent;border:1px solid var(--border);border-radius:6px;padding:8px 16px;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.85em;transition:.2s}
.shop-tab.a{background:var(--surface3);border-color:var(--gold);color:var(--gold)}
.shop-tab:hover{border-color:var(--muted);color:var(--text)}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.shop-item{background:rgba(10,10,20,.6);border:1px solid var(--border);border-radius:8px;padding:14px;transition:.2s;backdrop-filter:blur(4px)}
.shop-item:hover{border-color:rgba(255,255,255,.15)}
.item-name{font-weight:bold;font-size:.9em;margin-bottom:4px}
.item-desc{font-size:.78em;color:var(--muted);margin-bottom:10px}
.item-foot{display:flex;justify-content:flex-end;align-items:center;gap:6px}
.ibuy{background:var(--green);border:none;border-radius:6px;padding:6px 14px;color:#fff;cursor:pointer;font-family:inherit;font-size:.82em;transition:.2s;white-space:nowrap}
.ibuy:hover{background:#3aaa60}
.ibuy:disabled{background:#2a2a3e;color:var(--muted);cursor:not-allowed}
.ibuy.eq{background:var(--blue)}

/* Shop-Layout (Header + Refresh) */
.shop-layout{display:grid;grid-template-columns:1fr 320px;gap:20px;height:calc(100vh - 60px);overflow:hidden}
.shop-left{display:flex;flex-direction:column;overflow:hidden}
.shop-right{background:rgba(10,10,20,.5);border:1px solid var(--border);border-radius:10px;padding:14px;overflow-y:auto;display:flex;flex-direction:column;gap:8px}
.shop-right h3{color:var(--gold);font-size:.85em;letter-spacing:1px;margin-bottom:4px;text-transform:uppercase;flex-shrink:0}
.shop-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.shop-header-row h2{color:var(--gold);font-size:1.2em;letter-spacing:1px;display:flex;align-items:center;gap:8px}
.shop-info-btn{background:transparent;border:1px solid var(--muted);border-radius:50%;width:22px;height:22px;font-size:.75em;cursor:pointer;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0;vertical-align:middle}
.shop-info-btn:hover{border-color:var(--gold);color:var(--gold)}
.shop-refresh-bar{display:flex;align-items:center;gap:20px;font-size:1.1em;color:var(--muted)}
.refresh-icon{width:18px;height:18px;object-fit:contain}
.btn-refresh{background:rgba(212,168,67,.15);border:1px solid var(--gold);border-radius:9px;padding:11px 22px;color:var(--gold);cursor:pointer;font-family:inherit;font-size:1.05em;font-weight:bold;transition:.2s}
.btn-refresh:hover{background:rgba(212,168,67,.3)}

/* Shop-Filterleiste */
.shop-daily-info{flex:1;text-align:center;font-size:.8em;color:var(--muted)}
.shop-filter-bar{display:flex;gap:10px;margin-bottom:12px;flex-wrap:wrap}
.shop-filter-bar select{background:rgba(10,10,20,.7);border:1px solid var(--border);border-radius:7px;padding:7px 10px;color:var(--text);font-family:inherit;font-size:.82em;cursor:pointer;transition:.2s}
.shop-filter-bar select:hover{border-color:var(--gold)}
.shop-empty{grid-column:1/-1;text-align:center;color:var(--muted);font-size:.9em;padding:40px 0}

/* 6-Item Shop-Grid */
.shop-grid-6{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;overflow-y:auto;padding-bottom:8px}
.shop-card{background:linear-gradient(165deg,rgba(20,18,32,.85),rgba(10,10,20,.75));border:2px solid var(--border);border-radius:12px;padding:16px;display:flex;flex-direction:column;gap:8px;transition:.25s;position:relative;cursor:default;backdrop-filter:blur(4px);min-width:0}
.shop-card:hover{border-color:rgba(255,255,255,.25)}
.shop-card.qn{border-color:#3a3a4a}
.shop-card.qu{border-color:#1eff00}
.shop-card.qr{border-color:#0070dd}
.shop-card.qe{border-color:#a335ee}
.shop-card.ql{border-color:#ff8000}
.shop-card.qk{border-color:#ff2020;box-shadow:0 0 16px #ff202050}
.shop-card.qm{border-color:#e8cc00;box-shadow:0 0 16px #e8cc0050}
.sc-top{display:flex;align-items:center;gap:10px}
.sc-icon{font-size:2.3em;width:52px;height:52px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(0,0,0,.25);border-radius:10px}
.sc-info{flex:1;min-width:0}
.sc-name{font-weight:bold;font-size:.92em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sc-slot{font-size:.7em;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.sc-quality{font-size:.74em;font-weight:bold}
.sc-stats{font-size:.8em;color:#a0c8a0;background:rgba(0,40,0,.3);border-radius:5px;padding:6px 8px}
.sc-footer{display:flex;align-items:center;justify-content:space-between;gap:4px;margin-top:6px}
.sc-price{font-size:.8em;color:var(--bronze);font-weight:bold}
.btn-buy{background:var(--green);border:none;border-radius:6px;padding:6px 14px;color:#fff;cursor:pointer;font-family:inherit;font-size:.8em;transition:.2s;white-space:nowrap}
.btn-buy:hover{background:#3aaa60}
.btn-buy:disabled{background:#2a2a3e;color:var(--muted);cursor:not-allowed}



/* ===== BATTLE-SZENE ===== */
#scene-battle.active{display:flex;flex-direction:column;gap:10px;overflow-y:auto}

/* Dungeon-Karten oben */
.dungeon-card-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;flex-shrink:0}
.dungeon-card{
  position:relative;border-radius:10px;overflow:hidden;
  border:2px solid #2a2a50;cursor:pointer;
  transition:all .22s ease;height:100px;background:#0a0a18;
}
.dungeon-card:hover{border-color:#4a4a80;transform:translateY(-3px);box-shadow:0 6px 20px rgba(0,0,0,.6)}
.dungeon-card.active-dungeon{border-color:var(--gold);box-shadow:0 0 18px rgba(212,168,67,.35)}
.dc-bg{position:absolute;inset:0;background-size:cover;background-position:center;filter:brightness(.4)}
.dungeon-card.active-dungeon .dc-bg{filter:brightness(.55)}
.dc-body{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:space-between;height:100%;padding:8px}
.dc-top{display:flex;align-items:center;gap:5px}
.dc-emoji{font-size:1.3em;line-height:1}
.dc-name{font-size:.72em;font-weight:bold;color:#fff;text-shadow:0 1px 4px #000}
.dc-info{font-size:.6em;color:rgba(255,255,255,.65);text-shadow:0 1px 3px #000}
.dc-pbar-wrap{height:4px;background:rgba(255,255,255,.15);border-radius:2px;overflow:hidden}
.dc-pbar{height:100%;background:var(--gold);border-radius:2px;transition:width .4s}
.dc-active-badge{
  position:absolute;top:5px;right:5px;
  background:var(--gold);color:#000;
  font-size:.5em;font-weight:bold;
  padding:2px 5px;border-radius:3px;letter-spacing:.5px;
}

/* Kampf-Layout: Feld links, Monster-Liste rechts */
.battle-layout{display:grid;grid-template-columns:1fr 220px;gap:10px}
.battle-main{display:flex;flex-direction:column;gap:6px}
.battle-topbar{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:rgba(8,8,18,.7);border-radius:8px;border:1px solid var(--border)}
.dungeon-status{font-size:.8em;color:var(--muted);letter-spacing:.5px}

/* Monster-Liste (rechts) */
.monster-list-panel{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:10px;padding:10px;display:flex;flex-direction:column;gap:6px;overflow-y:auto;max-height:480px}
.monster-list-title{font-size:.68em;color:var(--gold);text-transform:uppercase;letter-spacing:2px;font-weight:bold;padding-bottom:6px;border-bottom:1px solid var(--border);margin-bottom:2px}
.monster-list{display:flex;flex-direction:column;gap:3px}
.mon-entry{display:flex;align-items:center;gap:7px;padding:7px 8px;border-radius:7px;border:1px solid transparent;cursor:pointer;transition:.15s;font-size:.8em}
.mon-entry:hover:not(.mon-locked){background:rgba(255,255,255,.05);border-color:#3a3a60}
.mon-entry.mon-active{background:rgba(212,168,67,.12);border-color:var(--gold)}
.mon-entry.mon-locked{opacity:.4;cursor:not-allowed}
.mon-entry.mon-boss{border-color:#5a2a2a}
.mon-entry.mon-boss.mon-active{background:rgba(120,30,30,.2);border-color:#c04040}
.mon-emoji{font-size:1.2em;width:22px;text-align:center;flex-shrink:0}
.mon-info{flex:1;min-width:0}
.mon-name{font-weight:bold;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mon-stats{font-size:.75em;color:var(--muted)}
.mon-lock-icon{font-size:.9em;color:#5a5a7a}
.mon-unlocked-badge{font-size:.65em;color:#4aaa70}

/* Kampffeld (Held vs. Monster) */
.battle-area{max-width:900px;margin:0 auto;width:100%}
.speed-ctrl{display:flex;align-items:center;gap:8px;font-size:.82em;color:var(--muted)}
.speed-ctrl button{background:rgba(10,10,20,.5);border:1px solid var(--border);border-radius:5px;padding:4px 10px;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.82em;transition:.2s}
.speed-ctrl button.a{border-color:var(--gold);color:var(--gold)}
.battlefield{display:flex;justify-content:center;align-items:center;padding:16px 0;gap:20px}
.combatant{text-align:center;width:220px;position:relative}
.c-title{font-size:1em;color:var(--text);font-weight:bold;margin-bottom:8px;text-shadow:0 2px 6px #000}
.sprite-area{width:160px;height:160px;margin:0 auto 10px;display:flex;align-items:center;justify-content:center;font-size:4em;border-radius:12px;background:rgba(10,10,20,.5);border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(4px);overflow:hidden}
.sprite-area.hit{animation:hitA .18s ease}
.sprite-area.swing{animation:swingA .25s ease}
@keyframes hitA{0%{background:rgba(90,0,0,.7);border-color:#c04040}100%{background:rgba(10,10,20,.5);border-color:rgba(255,255,255,.1)}}
@keyframes swingA{0%{transform:translateX(0)}50%{transform:translateX(-12px)}100%{transform:translateX(0)}}

/* HP-Balken */
.bw{background:rgba(10,10,20,.6);border-radius:5px;height:18px;overflow:hidden;position:relative;border:1px solid var(--border)}
.bf{height:100%;transition:width .35s ease;border-radius:5px}
.bf.hp{background:var(--green)}.bf.hp.low{background:var(--red)}
.blbl{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:bold;color:#fff;text-shadow:0 1px 2px #000}
.vs{font-size:2em;color:rgba(255,255,255,.2);text-shadow:0 2px 8px #000}

/* Kampflog */
#combatLog,#acCombatLog{max-height:180px;overflow-y:auto;background:rgba(10,10,20,.7);border:1px solid var(--border);border-radius:8px;padding:10px 14px;margin-top:12px;font-family:monospace;font-size:12px;backdrop-filter:blur(6px)}
#combatLog div,#acCombatLog div{padding:3px 0;border-bottom:1px solid rgba(42,42,64,.5)}
.lc{color:#e05050;font-weight:bold}.lr{color:#4aaa70}.ll{color:#4a7fc1;font-weight:bold}.ld{color:var(--gold)}.lp2{color:var(--muted);font-style:italic}
.le{color:#f5c542;font-weight:bold;text-shadow:0 0 6px rgba(245,197,66,.4)}


/* ===== RANGLISTE ===== */
#scene-leaderboard{max-width:620px}
.lb-tabs{display:flex;gap:6px;margin-bottom:14px}
.lb-tab{background:transparent;border:1px solid var(--border);border-radius:7px;padding:8px 22px;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.88em;transition:.2s}
.lb-tab:hover{border-color:var(--muted);color:var(--text)}
.lb-tab.active{background:rgba(212,168,67,.12);border-color:var(--gold);color:var(--gold)}
.lb-table{display:flex;flex-direction:column;gap:3px}
.lb-header{display:grid;gap:6px;padding:4px 10px;font-size:.63em;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.lb-header span:not(:first-child):not(:nth-child(2)){text-align:right}
.lb-header.players{grid-template-columns:32px 1fr 55px 65px 70px}
.lb-header.guilds{grid-template-columns:32px 1fr 70px 60px 70px}
.lb-row{display:grid;align-items:center;gap:6px;padding:7px 10px;border-radius:7px;background:rgba(4,4,12,.92);font-size:.83em;transition:.15s;border:1px solid rgba(255,255,255,.04)}
.lb-row:hover{background:rgba(10,10,28,.95)}
.lb-row.players-row{grid-template-columns:32px 1fr 55px 65px 70px}
.lb-row.guilds-row{grid-template-columns:32px 1fr 70px 60px 70px}
.lb-row.lb-self{border:1px solid var(--gold);background:rgba(30,20,0,.92)}
.lb-row.lb-own-guild{border:1px solid var(--gold);background:rgba(30,20,0,.92)}
.lb-row.lb-top1{background:rgba(50,38,4,.92);border-color:rgba(212,168,67,.3)}
.lb-row.lb-top2{background:rgba(30,35,42,.92);border-color:rgba(168,184,200,.2)}
.lb-row.lb-top3{background:rgba(44,24,8,.92);border-color:rgba(200,121,65,.2)}
.lb-rank{font-weight:bold;font-size:.95em;text-align:center}
.lb-rank.r1{color:#d4a843}.lb-rank.r2{color:#a8b8c8}.lb-rank.r3{color:#c87941}
.lb-name{font-weight:bold;color:var(--text)}
.lb-name.lb-self-name{color:var(--gold)}
.lb-val{text-align:right;color:var(--muted);font-size:.8em}
.lb-loading{color:var(--muted);font-size:.82em;font-style:italic;padding:12px 0;text-align:center}


/* ===== ERFOLGE & STATISTIKEN (verschmolzen) ===== */
#achGrid{display:block;padding:4px 0}

/* Gesamt-Fortschritt oben */
.ach-summary{padding:10px 14px;background:rgba(8,8,20,.7);border-radius:8px;margin-bottom:14px;font-size:.9em}
.ach-summary-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}
.ach-summary-bar-wrap{background:rgba(255,255,255,.08);border-radius:3px;height:7px;overflow:hidden}
.ach-summary-bar-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:3px;transition:width .4s ease}

/* Einklappbare Kategorie */
.ach-category{background:rgba(8,8,20,.6);border:1px solid var(--border);border-radius:10px;margin-bottom:10px;overflow:hidden}
.ach-category-header{display:flex;align-items:center;justify-content:space-between;padding:13px 16px;cursor:pointer;user-select:none;transition:.15s}
.ach-category-header:hover{background:rgba(255,255,255,.03)}
.ach-category-title{font-size:.85em;font-weight:bold;color:var(--gold);text-transform:uppercase;letter-spacing:1.5px}
.ach-category-meta{display:flex;align-items:center;gap:12px;font-size:.78em;color:var(--muted)}
.ach-category-progress{display:inline-block;width:80px;height:6px;background:rgba(255,255,255,.08);border-radius:3px;overflow:hidden}
.ach-category-progress-fill{display:block;height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:3px}
.ach-category-chevron{display:inline-block;transition:transform .2s;font-size:.8em}
.ach-category.expanded .ach-category-chevron{transform:rotate(90deg)}
.ach-category-body{display:none;padding:2px 16px 16px}
.ach-category.expanded .ach-category-body{display:block}
.ach-category-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}

/* Einzelne Achievement-Karte */
.ach-category-tracks{display:flex;flex-direction:column;gap:6px}
.ach-track{display:flex;align-items:center;gap:10px;background:rgba(10,10,20,.6);border:1px solid var(--border);border-radius:8px;padding:9px 12px;transition:.2s}
.ach-track-done{border-color:var(--gold);background:rgba(50,40,0,.15)}
.ach-track-icon{font-size:1.4em;width:32px;text-align:center;flex-shrink:0}
.ach-track-body{flex:1;min-width:0}
.ach-track-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px;flex-wrap:wrap}
.ach-track-label{font-weight:bold;font-size:.88em}
.ach-track-tier{font-size:.75em;color:var(--gold);white-space:nowrap}
.ach-bar-wrap{background:rgba(255,255,255,.08);border-radius:3px;height:5px;overflow:hidden;margin-bottom:3px}
.ach-bar-fill{height:100%;background:linear-gradient(90deg,#4f46e5,#7c3aed);border-radius:4px;transition:width .4s ease}
.ach-track-done .ach-bar-fill{background:linear-gradient(90deg,#b8860b,var(--gold))}
.ach-track-prog{font-size:.7em;color:var(--muted)}


/* ===== QUESTS ===== */
.quest-list{display:flex;flex-direction:column;gap:10px;max-width:600px}
.quest-card{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:10px;padding:14px 16px;transition:.2s}
.quest-card:hover{border-color:#3a3a70}
.quest-card.quest-done{border-color:#4aaa70}
.quest-card.quest-claimed{opacity:.6}
.quest-card.quest-epic{border-color:#caa23c;background:rgba(40,28,4,.85);box-shadow:0 0 10px rgba(202,162,60,.25)}
.quest-card.quest-epic.quest-done{border-color:#4aaa70}
.quest-top{display:flex;align-items:center;justify-content:space-between;gap:12px}
.quest-name{font-weight:bold;font-size:.9em;color:var(--text)}
.quest-reward{font-size:.75em;color:var(--gold);margin-top:2px}
.quest-pbar-wrap{height:5px;background:#1a1a2a;border-radius:3px;overflow:hidden;margin-top:8px}
.quest-pbar{height:100%;background:linear-gradient(90deg,#2a6a2a,#4aaa4a);border-radius:3px;transition:width .4s}
.btn-claim{background:var(--gold);border:none;border-radius:6px;padding:6px 14px;color:#000;font-weight:bold;cursor:pointer;font-family:inherit;font-size:.82em;white-space:nowrap}
.btn-claim:hover{background:#e8b830}


/* ===== STAT-KARTEN (in Erfolgs-Kategorien verwendet) ===== */
.stat-card{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:8px;padding:10px 14px;display:flex;align-items:flex-start;gap:10px;transition:.15s}
.stat-card:hover{border-color:#3a3a70}
.stat-icon{font-size:1.6em;flex-shrink:0;margin-top:2px}
.stat-body{flex:1;min-width:0}
.stat-label{font-size:.63em;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.stat-value{font-size:1.05em;font-weight:bold;color:var(--text)}
.stat-sub{font-size:.7em;color:var(--muted);margin-top:1px}


/* ===== ARENA ===== */
.arena-layout{display:flex;flex-direction:column;gap:20px;padding:16px;max-width:900px;margin:0 auto}
.arena-top{display:flex;gap:16px;flex-wrap:wrap}

/* Rang-Karte & Kampf-Karte */
.arena-rank-card{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:12px;padding:28px 20px;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:170px;flex:1;text-align:center}
.arena-rank-icon{font-size:3.2em;line-height:1}
.arena-rank-name{font-size:1.15em;font-weight:bold;letter-spacing:2px;text-transform:uppercase}
.arena-rating{font-size:1.7em;font-weight:bold;color:var(--text)}
.arena-record{font-size:.8em;color:var(--muted);margin-top:2px}
.arena-fight-card{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:12px;padding:24px;display:flex;flex-direction:column;gap:10px;flex:2}
.arena-fight-title{font-size:1.05em;font-weight:bold;color:var(--gold);letter-spacing:1px}
.arena-fight-desc{font-size:.83em;color:var(--muted)}
.btn-arena-fight{background:linear-gradient(135deg,#7c2020,#c14a4a);border:none;border-radius:8px;color:#fff;font-size:.95em;font-weight:bold;padding:13px 20px;cursor:pointer;transition:.2s;letter-spacing:1px;width:100%;font-family:inherit;margin-top:4px}
.btn-arena-fight:hover{transform:translateY(-2px);box-shadow:0 4px 16px rgba(193,74,74,.4)}
.btn-arena-fight:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}

/* Kampf-Ergebnis */
.arena-result{background:rgba(0,0,0,.35);border-radius:8px;padding:14px;display:flex;flex-direction:column;gap:5px;font-size:.88em;border-left:3px solid #555}
.arena-result-win{border-left-color:#4ade80}
.arena-result-loss{border-left-color:#f87171}
.arena-result-headline{font-size:1.25em;font-weight:bold}
.arena-combat-log{font-size:.76em;color:var(--muted);margin-top:4px;line-height:1.6}

/* Verlauf */
.arena-history-section{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:12px;padding:16px}
.arena-hist-title{font-size:.75em;color:var(--gold);text-transform:uppercase;letter-spacing:2px;font-weight:bold;margin-bottom:10px}
.arena-hist-row{display:flex;align-items:center;gap:12px;padding:8px 10px;border-radius:6px;font-size:.86em;border-bottom:1px solid rgba(255,255,255,.04)}
.arena-hist-row:last-child{border-bottom:none}
.arena-win{background:rgba(74,222,128,.04)}
.arena-loss{background:rgba(248,113,113,.04)}
.arena-hist-result{min-width:100px;font-weight:600}
.arena-hist-opp{flex:1;color:var(--muted)}
.arena-hist-delta{min-width:60px;text-align:right;font-weight:bold;font-size:.9em}

/* Gegner-Liste */
.arena-opponents-card{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:10px;flex:2}
.arena-opp-row{display:flex;align-items:center;gap:12px;padding:8px 6px;border-bottom:1px solid rgba(255,255,255,.05)}
.arena-opp-row:last-child{border-bottom:none}
.arena-opp-tier{font-size:1.6em;flex-shrink:0;width:28px;text-align:center}
.arena-opp-info{flex:1;min-width:0}
.arena-opp-name{font-weight:bold;font-size:.92em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.arena-opp-stats{font-size:.75em;color:var(--muted);margin-top:1px}
.btn-challenge{background:linear-gradient(135deg,#1e3a5f,#2a5fa8);border:none;border-radius:7px;color:#fff;font-size:1.4em;font-weight:bold;padding:5px 11px;cursor:pointer;transition:.2s;white-space:nowrap;font-family:inherit}
.btn-challenge:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(42,95,168,.4)}

/* Arena-Kampfansicht */
.arena-combat-wrapper{padding:16px;max-width:860px;margin:0 auto}

/* Schwebendes Schadenszahl-Popup */
.arena-float-dmg{position:absolute;top:55px;left:50%;transform:translateX(-50%);font-weight:bold;pointer-events:none;animation:arenaFloatUp 1.3s ease-out forwards;z-index:20;text-shadow:0 1px 4px rgba(0,0,0,.9);white-space:nowrap}
.arena-float-normal{color:#c0c0c0;font-size:1.3em}
.arena-float-crit{color:#ff4444;font-size:1.7em}
.arena-float-dodge{color:#4fc3f7;font-size:1em;font-style:italic}
@keyframes arenaFloatUp{0%{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}15%{transform:translateX(-50%) translateY(-8px) scale(1.15)}80%{opacity:1}100%{opacity:0;transform:translateX(-50%) translateY(-65px) scale(.9)}}

/* Arena neues Layout (Tabellen + Suche) */
.arena-new-layout{display:flex;flex-direction:column;gap:16px;padding:12px;max-width:700px}
.arena-ticket-bar{background:rgba(10,12,24,.75);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:8px;padding:10px 16px;font-size:.9em;text-align:center}
.arena-desc-section{display:flex;gap:16px;background:rgba(10,12,24,.75);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:10px;padding:14px}
.arena-desc-img{flex-shrink:0;width:120px;height:140px;border-radius:6px;overflow:hidden}
.arena-desc-img img{width:100%;height:100%;object-fit:cover}
.arena-desc-text{font-size:.82em;color:var(--muted);line-height:1.55}
.arena-desc-text p{margin:0 0 6px}
.arena-league-header{background:rgba(10,12,24,.75);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:10px;padding:12px 16px;text-align:center}
.arena-league-title{font-size:1.05em;font-weight:bold}
.arena-league-sub{font-size:.78em;color:var(--muted);margin-top:3px}
.arena-tables{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:stretch}
.arena-table-card{background:rgba(10,12,24,.75);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column}
.arena-table-card .arena-lb-table{flex:1;height:100%}
.arena-table-card .arena-lb-table tbody{display:table-row-group;height:100%}
.arena-table-card .arena-lb-table tbody tr{height:1%}
.arena-table-title{font-size:.9em;font-weight:bold;margin-bottom:8px}
.arena-my-rank{font-weight:normal;font-size:.8em;color:var(--muted)}
.arena-lb-table{width:100%;border-collapse:collapse;font-size:.82em;table-layout:fixed}
.arena-lb-table th{text-align:left;color:var(--muted);font-weight:normal;padding:3px 6px;border-bottom:1px solid var(--border)}
.arena-lb-table td{padding:5px 6px;border-bottom:1px solid rgba(255,255,255,.04)}
.arena-lb-table tr:last-child td{border-bottom:none}
.arena-lb-rank{color:var(--muted);font-size:.78em;width:42px}
.arena-lb-name{max-width:110px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1.15em}
.arena-lb-rating{font-size:1.15em;font-weight:bold;white-space:nowrap}
.arena-me-row td{background:rgba(42,95,168,.2);font-weight:bold}
.arena-search-section{background:rgba(10,12,24,.75);backdrop-filter:blur(6px);border:1px solid var(--border);border-radius:10px;padding:14px}
.arena-search-title{font-size:.9em;font-weight:bold;margin-bottom:4px}
.arena-search-cost{font-weight:normal;color:var(--muted)}
.arena-search-sub{font-size:.78em;color:var(--muted);margin-bottom:10px}
.arena-search-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:.85em}
.arena-search-input{flex:1;min-width:120px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:6px 10px;font-family:inherit;font-size:1em}
.btn-arena-search{background:linear-gradient(135deg,#5a3e1b,#8b5e2a);border:none;border-radius:7px;color:#fff;font-size:.85em;font-weight:bold;padding:7px 18px;cursor:pointer;transition:.2s;font-family:inherit}
.btn-arena-search:hover{transform:translateY(-1px);box-shadow:0 3px 10px rgba(139,94,42,.4)}


/* ===== GILDEN-SZENE ===== */
.guild-layout{display:grid;grid-template-columns:1fr 300px;gap:16px}
.guild-main{display:flex;flex-direction:column;gap:12px}
.guild-sidebar-panel{display:flex;flex-direction:column;gap:12px}

/* Gilde-Header */
.guild-header{background:rgba(8,8,20,.85);border:1px solid var(--gold);border-radius:10px;padding:16px 20px;display:flex;align-items:center;gap:14px}
.guild-header-icon{font-size:2.5em}
.guild-header-info{flex:1}
.guild-header-name{font-size:1.3em;font-weight:bold;color:var(--gold);letter-spacing:1px}
.guild-header-sub{font-size:.8em;color:var(--muted);margin-top:2px}
.guild-header-badge{background:rgba(212,168,67,.2);border:1px solid var(--gold);border-radius:6px;padding:3px 10px;font-size:.75em;color:var(--gold)}

/* Gilde-Panel (allgemein) */
.guild-panel{background:rgba(8,8,20,.85);border:1px solid var(--border);border-radius:10px;padding:14px}
.guild-panel-title{font-size:.72em;color:var(--gold);text-transform:uppercase;letter-spacing:2px;margin-bottom:10px;font-weight:bold;display:flex;align-items:center;justify-content:space-between}

/* Gildenbaum-Event — kompakter Teaser in der Gilde-Szene */
.guild-tree-teaser{padding:0;overflow:hidden;border-color:#caa23c;background-size:cover;background-position:center 30%}
.guild-tree-teaser .guild-tree-overlay{background:linear-gradient(180deg,rgba(8,8,20,.35),rgba(8,8,20,.9));padding:16px;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}
.guild-tree-teaser .btn-build{flex-shrink:0}

/* Gildenbaum-Event — eigene Szene (Hintergrund kommt vom globalen #bg) */
.guild-tree-scene-bg{display:flex;justify-content:center;padding-top:20px}

/* Gildenbaum-Timer */
.guild-tree-timer{text-align:center;padding:6px 0 16px}
.guild-tree-timer-label{font-size:.85em;color:var(--muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:4px}
.guild-tree-timer-countdown{font-size:2.1em;font-weight:bold;color:var(--gold);letter-spacing:1px}

/* Gildenbaum-Startzeit-Auswahl (Dropdowns statt Numpad-Eingabe) */
.guild-tree-time-picker{display:flex;align-items:center;gap:6px}
.guild-tree-time-select{background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:7px;padding:10px 14px;color:var(--text);font-family:inherit;font-size:1.2em;font-weight:bold;cursor:pointer;text-align:center}
.guild-tree-time-select:focus{border-color:var(--gold);outline:none}
.guild-tree-time-sep{font-size:1.3em;color:var(--muted);font-weight:bold}

/* Gildenschatz — ornamentaler Schatztruhen-Look */
.guild-treasury{position:relative;border:1px solid var(--gold);background:linear-gradient(160deg,rgba(24,18,6,.92),rgba(8,8,20,.92));box-shadow:0 0 22px rgba(212,168,67,.16),inset 0 0 36px rgba(212,168,67,.05)}
.guild-treasury-title{font-size:.95em;font-weight:bold;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase;text-align:center;margin-bottom:12px;text-shadow:0 0 10px rgba(212,168,67,.4)}
.guild-treasury-vault{position:relative;overflow:hidden;border:1px solid rgba(212,168,67,.45);border-radius:9px;background:radial-gradient(ellipse at center,rgba(212,168,67,.1),transparent 70%);padding:18px;display:flex;justify-content:center}
.guild-treasury-vault::before{content:'';position:absolute;top:0;left:-150%;width:55%;height:100%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.14),transparent);transition:left .9s ease}
.guild-treasury-vault:hover::before{left:150%}
.guild-bank-divider{height:1px;background:var(--border);margin:14px 0}

/* Gildenbank-Münzanzeige */
.guild-bank{display:flex;gap:12px;align-items:center;flex-wrap:wrap;justify-content:center}
.guild-bank-coins{display:flex;gap:6px;align-items:center;font-size:1.1em;font-weight:bold;background:rgba(0,0,0,.4);border:1px solid rgba(212,168,67,.35);border-radius:7px;padding:7px 14px}
.guild-bank-coins img{width:20px;height:20px;object-fit:contain}
.guild-donate-row{display:flex;gap:6px;align-items:center;flex-wrap:wrap;margin-top:8px}
.guild-donate-row input{width:70px;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:5px;padding:5px 8px;color:var(--text);font-family:inherit;font-size:.82em;text-align:center}
.guild-donate-row input:focus{border-color:var(--gold);outline:none}
.btn-donate{background:var(--green);border:none;border-radius:6px;padding:6px 14px;color:#fff;cursor:pointer;font-family:inherit;font-size:.82em;transition:.2s}
.btn-donate:hover{background:#3aaa60}

/* Gebäude-Karten */
.buildings-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.building-card{background:rgba(10,10,28,.8);border:1px solid var(--border);border-radius:8px;padding:12px;text-align:center;transition:.2s}
.building-card:hover{border-color:#3a3a70}
.building-icon{font-size:1.8em;margin-bottom:4px}
.building-name{font-size:.8em;font-weight:bold;color:var(--text);margin-bottom:2px}
.building-desc{font-size:.7em;color:var(--muted);margin-bottom:6px}
.building-level{font-size:.75em;color:var(--gold);margin-bottom:6px}
.building-stars{color:var(--gold);font-size:.85em;letter-spacing:1px}
.btn-build{background:rgba(212,168,67,.15);border:1px solid var(--gold);border-radius:5px;padding:4px 10px;color:var(--gold);cursor:pointer;font-family:inherit;font-size:.75em;transition:.2s;width:100%}
.btn-build:hover{background:rgba(212,168,67,.3)}
.btn-build:disabled{opacity:.4;cursor:not-allowed}

/* Mitglieder-Liste */
.member-list{display:flex;flex-direction:column;gap:4px;max-height:320px;overflow-y:auto}
.member-row{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;background:rgba(10,10,28,.6);font-size:.83em}
.member-row.is-leader{background:rgba(50,40,0,.3)}
.member-dot{width:8px;height:8px;border-radius:50%;background:#3a3a4a;flex-shrink:0}
.member-dot.online{background:#4aaa70;box-shadow:0 0 5px #4aaa70}
.member-name{flex:1;font-weight:bold}
.member-leader-badge{font-size:.65em;background:rgba(212,168,67,.2);color:var(--gold);border:1px solid var(--gold);border-radius:4px;padding:1px 5px}
.member-level{color:var(--muted);font-size:.8em}
.btn-kick{background:rgba(120,20,20,.4);border:1px solid #5a2a2a;border-radius:4px;padding:2px 7px;color:#e08080;cursor:pointer;font-family:inherit;font-size:.7em}
.btn-kick:hover{background:rgba(150,30,30,.6)}

/* Bewerbungen */
.application-row{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:6px;background:rgba(10,10,28,.6);font-size:.83em;margin-bottom:4px}
.btn-accept{background:var(--green);border:none;border-radius:4px;padding:3px 9px;color:#fff;cursor:pointer;font-size:.75em;font-family:inherit}
.btn-reject{background:rgba(120,20,20,.4);border:1px solid #5a2a2a;border-radius:4px;padding:3px 9px;color:#e08080;cursor:pointer;font-size:.75em;font-family:inherit}

/* Gilde suchen */
.guild-search-list{display:flex;flex-direction:column;gap:6px;margin-top:8px;max-height:300px;overflow-y:auto}
.guild-search-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;background:rgba(10,10,28,.7);border:1px solid var(--border);transition:.2s}
.guild-search-row:hover{border-color:#3a3a70}
.guild-search-name{font-weight:bold;flex:1}
.guild-search-info{font-size:.78em;color:var(--muted)}
.btn-join{background:var(--blue);border:none;border-radius:5px;padding:5px 12px;color:#fff;cursor:pointer;font-family:inherit;font-size:.78em}
.btn-apply{background:rgba(60,80,120,.5);border:1px solid var(--blue);border-radius:5px;padding:5px 12px;color:var(--silver);cursor:pointer;font-family:inherit;font-size:.78em}

/* Kein-Gilden-Screen */
.no-guild-screen{text-align:center;padding:40px 20px}
.no-guild-icon{font-size:4em;margin-bottom:12px}
.no-guild-title{font-size:1.2em;color:var(--gold);margin-bottom:8px}
.no-guild-sub{font-size:.85em;color:var(--muted);margin-bottom:24px}
.guild-create-row{display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap}
.guild-name-input{background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:7px;padding:9px 14px;color:var(--text);font-family:inherit;font-size:.9em;width:220px}
.guild-name-input:focus{border-color:var(--gold);outline:none}
.btn-create-guild{background:var(--gold);border:none;border-radius:7px;padding:9px 20px;color:#000;font-weight:bold;cursor:pointer;font-family:inherit;font-size:.88em}
.guild-bonus-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.bonus-chip{background:rgba(20,80,20,.4);border:1px solid #2a5a2a;border-radius:5px;padding:3px 9px;font-size:.75em;color:#4aaa70}
.toggle-open-btn{font-size:.75em;padding:4px 10px;border-radius:5px;cursor:pointer;font-family:inherit;border:1px solid var(--border);background:transparent;color:var(--muted)}
.toggle-open-btn.is-open{border-color:#4aaa70;color:#4aaa70}

/* Gilden-Chat */
.guild-chat-messages{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-y:auto;padding:4px 0;margin-bottom:6px}
.chat-msg{display:flex;align-items:baseline;gap:6px;font-size:.8em;flex-wrap:wrap;padding:3px 0;border-bottom:1px solid rgba(255,255,255,.04)}
.chat-self .chat-name{color:var(--gold)}
.chat-name{font-weight:bold;color:var(--silver);flex-shrink:0}
.chat-text{color:var(--text);flex:1;word-break:break-word}
.chat-time{font-size:.72em;color:var(--muted);flex-shrink:0;margin-left:auto}
.guild-chat-input-row{display:flex;gap:6px}
.guild-chat-input{flex:1;background:rgba(0,0,0,.4);border:1px solid var(--border);border-radius:6px;padding:6px 10px;color:var(--text);font-family:inherit;font-size:.82em}
.guild-chat-input:focus{border-color:var(--gold);outline:none}


/* ===== EINSTELLUNGEN ===== */
.settings-panel{max-width:500px}
.setting-group{margin-bottom:20px}
.setting-group label{display:block;font-size:.85em;color:var(--muted);margin-bottom:6px;letter-spacing:1px}
.setting-group input[type="range"]{width:100%;accent-color:var(--gold)}
.setting-group select{width:100%;background:rgba(10,10,20,.6);border:1px solid var(--border);border-radius:7px;padding:8px;color:var(--text);font-family:inherit;font-size:.9em}
.btn-danger{background:var(--red);border:none;border-radius:7px;padding:10px 20px;color:#fff;cursor:pointer;font-family:inherit;font-size:.9em;transition:.2s}
.btn-danger:hover{background:#d04040}
.setting-info{margin-top:30px;padding-top:16px;border-top:1px solid var(--border);color:var(--muted);font-size:.82em}
.setting-info p{margin-bottom:4px}

/* Toggle Switch (Ein/Aus) */
.toggle-wrap{display:flex;align-items:center;gap:8px;cursor:pointer}
.toggle-wrap input{display:none}
.toggle-slider{width:40px;height:22px;background:#2a2a40;border-radius:11px;position:relative;transition:.2s;flex-shrink:0;border:1px solid var(--border)}
.toggle-slider::after{content:'';position:absolute;width:16px;height:16px;background:#666;border-radius:50%;top:2px;left:2px;transition:.2s}
.toggle-wrap input:checked + .toggle-slider{background:rgba(212,168,67,.3);border-color:var(--gold)}
.toggle-wrap input:checked + .toggle-slider::after{background:var(--gold);left:20px}


/* ===== ALLGEMEINE UI-ELEMENTE ===== */
/* Vergleichs-Button */
.btn-compare{background:rgba(74,127,193,.2);border:1px solid #4a7fc1;border-radius:5px;padding:4px 8px;color:#4a7fc1;cursor:pointer;font-family:inherit;font-size:.8em;transition:.2s}
.btn-compare:hover{background:rgba(74,127,193,.4)}

/* Drop-Token Animation (Gold/Edelstein-Popup) */
@keyframes tokenDrop{0%{opacity:0;transform:translateY(-20px) scale(.8)}50%{opacity:1;transform:translateY(0) scale(1.2)}100%{opacity:1;transform:scale(1)}}
.token-popup{animation:tokenDrop .5s ease forwards;color:var(--gold);font-weight:bold;position:fixed;pointer-events:none;z-index:999;font-size:1.1em;text-shadow:0 2px 8px #000}


/* ===== REITTIER-MODAL ===== */
.mount-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:200;display:flex;align-items:center;justify-content:center}
.mount-modal{background:#0e0e1e;border:2px solid var(--gold);border-radius:14px;padding:20px;width:min(860px,95vw);max-height:85vh;display:flex;flex-direction:column;gap:12px;overflow:hidden}
.mount-modal-header{display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border);padding-bottom:10px;font-size:1.1em;font-weight:bold;color:var(--gold)}
.mount-food-bar{margin-left:auto;font-size:.85em;color:var(--muted);background:rgba(0,0,0,.3);border:1px solid var(--border);border-radius:6px;padding:3px 10px}
.mount-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;overflow-y:auto;padding-bottom:4px}
.mount-card{background:rgba(10,10,28,.8);border:2px solid var(--border);border-radius:10px;padding:12px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center;transition:.2s}
.mount-card:hover{border-color:#3a3a70}
.mount-card.mount-equipped{border-color:var(--gold);background:rgba(50,40,0,.2)}
.mount-card.mount-locked{opacity:.5}
.mount-card-icon{font-size:2.4em;line-height:1}
.mount-card-img{width:120px;height:90px;object-fit:contain;border-radius:8px;display:block;margin:0 auto}
.mount-card-name{font-weight:bold;font-size:.9em;color:var(--text)}
.mount-card-level{font-size:.75em;color:var(--gold)}
.mount-card-bonus{font-size:.72em;color:var(--muted);min-height:2.2em;line-height:1.4}
.mount-card-actions{display:flex;gap:5px;flex-wrap:wrap;justify-content:center;margin-top:4px}
.btn-mount-equip{background:var(--green);border:none;border-radius:5px;padding:4px 10px;color:#fff;cursor:pointer;font-family:inherit;font-size:.75em;transition:.2s}
.btn-mount-equip:hover{background:#3aaa60}
.btn-mount-buy{background:rgba(212,168,67,.2);border:1px solid var(--gold);border-radius:5px;padding:4px 10px;color:var(--gold);cursor:pointer;font-family:inherit;font-size:.75em;transition:.2s}
.btn-mount-buy:hover{background:rgba(212,168,67,.4)}
.btn-mount-lvup{background:rgba(74,127,193,.3);border:1px solid var(--blue);border-radius:5px;padding:4px 8px;color:#a0c8f0;cursor:pointer;font-family:inherit;font-size:.72em;transition:.2s}
.btn-mount-lvup:hover{background:rgba(74,127,193,.5)}
.btn-mount-lvup.disabled{opacity:.4;cursor:not-allowed}
.mount-badge-active{font-size:.72em;color:var(--gold);font-weight:bold}
.mount-badge-max{font-size:.72em;color:#ff8000;font-weight:bold}
.mount-unlock-hint{font-size:.68em;color:#b05050;font-style:italic;margin-top:2px}
.mount-choice-row{display:flex;flex-direction:column;align-items:center;gap:4px;width:100%}
.mount-choice-row .btn-mount-buy{width:100%}

/* ===== RESPONSIVE ===== */
@media(max-width:900px){
  .char-layout{grid-template-columns:1fr;gap:16px}
}
@media(max-width:700px){
  :root{--sidebar-w:60px}
  .sb-label{display:none}
  .sb-btn{justify-content:center;padding:12px 0}
  .sb-icon{width:auto}
  .sb-currency{padding:8px 4px;align-items:center}
  .sb-coin span{display:none}
  .upg-grid{grid-template-columns:1fr 1fr}
  .battlefield{flex-direction:column;gap:10px}

  /* Charakter: feste 190/220/190-Spalten passen auf keinem Handy */
  .char-top-new{grid-template-columns:1fr;justify-content:center}
  .equip-col-new{flex-direction:row;flex-wrap:wrap;justify-content:center}
  .char-center-new{order:-1}
  .char-bottom-slots{width:100%}

  /* Shop: 3er-Grid zu eng für Karten mit Kaufen/Vergleichen-Button */
  .shop-grid-6{grid-template-columns:1fr}

  /* Battle: Monsterauswahl unter das Kampffeld statt daneben */
  .battle-layout{grid-template-columns:1fr}
  .monster-list-panel{max-height:240px}

  /* Reittier-Modal: 4er-Grid mit 120px-Bildern sprengt schmale Screens */
  .mount-grid{grid-template-columns:repeat(2,1fr)}
  .mount-card-img{width:100%;height:auto}

  /* Rangliste: schmalere feste Spalten gegen Abschneiden am Rand */
  .lb-header.players,.lb-row.players-row{grid-template-columns:22px 1fr 38px 42px 48px;gap:4px;padding:6px 8px;font-size:.78em}
  .lb-header.guilds,.lb-row.guilds-row{grid-template-columns:22px 1fr 46px 40px 46px;gap:4px;padding:6px 8px;font-size:.78em}
}
@media(max-width:600px){
  .arena-tables{grid-template-columns:1fr}
}


/* ===== STADT-SZENE ===== */
.stadt-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px;max-width:900px;margin:0 auto}
.stadt-card{background:rgba(20,20,40,.8);border:1px solid var(--border);border-radius:14px;padding:32px 20px;text-align:center;cursor:pointer;transition:.2s;display:flex;flex-direction:column;align-items:center;gap:12px}
.stadt-card:hover{border-color:var(--gold);background:rgba(30,30,60,.9);transform:translateY(-3px);box-shadow:0 6px 24px rgba(212,168,67,.15)}
.stadt-card-icon{font-size:2.8em}
.stadt-card-name{font-size:1.05em;font-weight:bold;color:var(--gold)}
.stadt-card-desc{font-size:.78em;color:var(--muted);line-height:1.4}

/* ===== DUNGEONKARTE ===== */
.dungeon-map-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:24px;max-width:960px;margin:0 auto}
.dungeon-map-tile{position:relative;border-radius:12px;overflow:hidden;cursor:pointer;border:2px solid #2a2a50;transition:.2s;aspect-ratio:16/9;min-height:140px}
.dungeon-map-tile:hover{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 6px 24px rgba(212,168,67,.2)}
.dungeon-map-tile.dmt-active{border-color:var(--gold);box-shadow:0 0 22px rgba(212,168,67,.4)}
.dmt-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.dmt-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.9) 0%,rgba(0,0,0,.3) 55%,rgba(0,0,0,.05) 100%)}
.dmt-content{position:relative;z-index:1;display:flex;flex-direction:column;justify-content:flex-end;height:100%;padding:12px 14px}
.dmt-emoji{font-size:1.9em;line-height:1;margin-bottom:2px}
.dmt-name{font-weight:bold;font-size:1em;color:#fff}
.dmt-level{font-size:.72em;color:rgba(255,255,255,.5);margin-top:1px}
.dmt-progress{font-size:.72em;margin-top:5px}
.dmt-active-badge{position:absolute;top:8px;right:8px;background:var(--gold);color:#000;border-radius:20px;padding:2px 10px;font-size:.65em;font-weight:bold;letter-spacing:.5px}
.back-btn{background:rgba(20,20,40,.8);border:1px solid var(--border);border-radius:8px;padding:6px 14px;color:var(--muted);cursor:pointer;font-family:inherit;font-size:.85em;transition:.2s}
.back-btn:hover{border-color:var(--gold);color:var(--gold)}
@media(max-width:700px){
  .stadt-grid{grid-template-columns:repeat(2,1fr)}
  .dungeon-map-grid{grid-template-columns:repeat(2,1fr)}
}
