* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --bg:        #1c1510;
  --bg2:       #221a12;
  --surface:   #221a13;
  --panel:     #281f16;
  --panel2:    #31261b;
  --border:    #3d2d1a;
  --border2:   #5e4526;
  --red:       #c0392b;
  --orange:    #d4580a;
  --gold:      #c9a227;
  --gold2:     #f0c832;
  --text:      #cfc0a0;
  --text2:     #9a8a70;
  --bright:    #f0e2c4;
  --green:     #4a7a4a;
  --blue:      #3a6aa0;
  --sidebar-w: 220px;
}

html, body { height: 100%; }
body { background: var(--bg); color: var(--text); font-family: 'Crimson Text', serif; font-size: 15px; display: flex; flex-direction: column; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }

/* ── HEADER ── */
#header { display: flex; align-items: center; height: 48px; background: var(--bg); border-bottom: 1px solid var(--border2); padding: 0 18px; position: sticky; top: 0; z-index: 300; flex-shrink: 0; }
#hamburger { display: none; flex-direction: column; justify-content: center; gap: 5px; width: 32px; height: 48px; cursor: pointer; background: none; border: none; margin-right: 12px; flex-shrink: 0; padding: 0 3px; }
#hamburger span { display: block; height: 2px; background: var(--text2); transition: all .25s; transform-origin: center; }
#hamburger:hover span { background: var(--gold); }
#hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg);  background: var(--gold); }
#hamburger.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
#hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); background: var(--gold); }
.logo { font-family: 'Cinzel', serif; font-weight: 700; font-size: 16px; color: var(--gold); letter-spacing: 2px; text-shadow: 0 0 16px rgba(201,162,39,.35); user-select: none; white-space: nowrap; }
.logo span { color: var(--red); }
.res-bar { position: fixed; bottom: 0; left: 0; right: 0; z-index: 300; display: flex; justify-content: center; align-items: center; gap: 0; background: var(--bg2); border-top: 1px solid var(--border); height: 40px; }
.res-chip { display: flex; align-items: center; gap: 5px; font-family: 'Cinzel', serif; font-size: 11px; color: var(--text2); padding: 0 20px; height: 40px; border-right: 1px solid var(--border); }
.res-chip:last-child { border-right: none; }
.res-chip .v { color: var(--bright); font-weight: 600; font-size: 13px; }

/* ── BODY WRAP ── */
#body-wrap { display: flex; flex: 1; min-height: 0; }

/* ── SIDEBAR ── */
#sidebar { width: var(--sidebar-w); flex-shrink: 0; background: var(--surface); border-right: 1px solid var(--border); position: sticky; top: 48px; height: calc(100vh - 48px); overflow-y: auto; display: flex; flex-direction: column; }
.nav-section { padding: 14px 0 4px; }
.nav-section-label { font-family: 'Cinzel', serif; font-size: 8px; letter-spacing: 2.5px; color: var(--text2); text-transform: uppercase; padding: 0 16px 4px; opacity: .7; }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 9px 16px; color: var(--text2); font-size: 13px; cursor: pointer; border-left: 3px solid transparent; transition: all .15s; user-select: none; }
.nav-item:hover   { color: var(--text); background: rgba(201,162,39,.05); border-left-color: var(--border2); }
.nav-item.active  { color: var(--gold); background: rgba(201,162,39,.08); border-left-color: var(--gold); }
.nav-item.disabled { opacity: .3; cursor: default; pointer-events: none; }
.nav-icon { font-size: 14px; width: 18px; text-align: center; flex-shrink: 0; }
.nav-soon { margin-left: auto; font-family: 'Cinzel', serif; font-size: 7px; letter-spacing: 1px; color: var(--border2); border: 1px solid var(--border); padding: 1px 4px; }
.quest-nav-dot { margin-left: auto; color: var(--gold); font-size: 10px; animation: quest-pulse 2s ease-in-out infinite; }
.sidebar-footer { margin-top: auto; padding: 16px; font-size: 11px; color: var(--text2); opacity: .35; font-style: italic; border-top: 1px solid var(--border); }

/* ── MAIN ── */
#main { flex: 1; overflow-y: auto; min-width: 0; }
.page-wrap { padding: 28px 28px 48px; max-width: 780px; }
.page { display: none; }
.page.active { display: block; }
.page-title { font-family: 'Cinzel', serif; font-size: 10px; letter-spacing: 3px; color: var(--text2); text-transform: uppercase; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid var(--border); }

/* ════════════════════════════════════════
   DASHBOARD — ADVENTURER STATUS BAR
════════════════════════════════════════ */
.adv-status-bar {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 16px 20px;
  margin-bottom: 20px;
  transition: border-color .3s, box-shadow .3s;
}
.adv-status-bar.st-raiding  { border-color: #5a1a10; box-shadow: 0 0 20px rgba(192,57,43,.07); }
.adv-status-bar.st-returned { border-color: var(--gold); box-shadow: 0 0 24px rgba(201,162,39,.1); animation: bar-glow 2s ease-in-out infinite; }
@keyframes bar-glow { 0%,100%{box-shadow:0 0 16px rgba(201,162,39,.08)} 50%{box-shadow:0 0 32px rgba(201,162,39,.22)} }

.adv-row-top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 10px;
}
.adv-icon { font-size: 22px; flex-shrink: 0; }
.adv-meta { flex: 1; min-width: 0; }
.adv-name-wrap { display: flex; align-items: center; gap: 6px; }
.adv-name  { font-family: 'Cinzel', serif; font-size: 15px; color: var(--bright); font-weight: 700; }
.btn-rename { background: none; border: none; cursor: pointer; font-size: 13px; opacity: 0.5; padding: 0; line-height: 1; transition: opacity .2s; }
.btn-rename:hover { opacity: 1; }
.rename-input { font-family: 'Cinzel', serif; font-size: 14px; background: var(--bg2,#1a1a1a); border: 1px solid var(--border2,#444); color: var(--bright,#eee); border-radius: 3px; padding: 2px 6px; width: 140px; }
.adv-class { font-size: 12px; color: var(--text2); font-style: italic; margin-top: 1px; }
.adv-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.adv-lvl   { font-family: 'Cinzel', serif; font-size: 11px; color: var(--gold); border: 1px solid var(--border2); padding: 3px 10px; white-space: nowrap; }

.status-badge { display: inline-flex; align-items: center; gap: 4px; font-family: 'Cinzel', serif; font-size: 9px; letter-spacing: 1px; padding: 3px 8px; }
.badge-idle     { color: var(--green); border: 1px solid rgba(74,122,74,.4);  background: rgba(74,122,74,.07); }
.badge-raiding  { color: var(--red);   border: 1px solid rgba(192,57,43,.4); background: rgba(192,57,43,.07); }
.badge-returned { color: var(--gold);  border: 1px solid rgba(201,162,39,.5);background: rgba(201,162,39,.09); }

.xp-row  { display: flex; align-items: center; gap: 10px; }
.xp-lbl  { font-family: 'Cinzel', serif; font-size: 9px; color: var(--text2); letter-spacing: 1px; white-space: nowrap; }
.xp-track{ flex: 1; background: var(--bg); border: 1px solid var(--border); height: 4px; }
.xp-fill { height: 100%; background: var(--blue); transition: width .5s; }
.xp-val  { font-family: 'Cinzel', serif; font-size: 10px; color: var(--text2); white-space: nowrap; }

/* Raiding progress inside status bar */
.raid-info { margin-top: 10px; }
.raid-loc  { font-size: 13px; color: var(--text2); font-style: italic; margin-bottom: 7px; }
.prog-track{ background: var(--bg); border: 1px solid var(--border); height: 6px; margin-bottom: 6px; }
.prog-fill { height: 100%; background: linear-gradient(90deg, var(--red), var(--orange)); transition: width .8s linear; }
.raid-time { font-family: 'Cinzel', serif; font-size: 11px; color: var(--text2); }

/* Returned loot + collect inside status bar */
.returned-info { margin-top: 10px; }
.loot-line { font-size: 14px; color: var(--gold2); margin-bottom: 10px; }
.loot-shards-line { font-size: 13px; color: #c090ee; margin-bottom: 10px; }
.btn-collect { display: block; width: 100%; padding: 11px; font-family: 'Cinzel', serif; font-size: 11px; letter-spacing: 2px; text-transform: uppercase; background: rgba(201,162,39,.09); border: 1px solid rgba(201,162,39,.45); color: var(--gold2); cursor: pointer; transition: background .15s; animation: pulse-gold 1.8s ease-in-out infinite; }
.btn-collect:hover { background: rgba(201,162,39,.24); }
@keyframes pulse-gold { 0%,100%{box-shadow:0 0 0 transparent} 50%{box-shadow:0 0 18px rgba(201,162,39,.35)} }

/* ════════════════════════════════════════
   DASHBOARD — CAIN SECTION
════════════════════════════════════════ */
.malakor-section {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border2);
  padding: 16px 18px;
  margin-bottom: 24px;
}
.malakor-portrait { font-size: 32px; flex-shrink: 0; line-height: 1; padding-top: 2px; filter: sepia(.2); }
.malakor-speech { flex: 1; min-width: 0; }
.malakor-speaker { font-family: 'Cinzel', serif; font-size: 9px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; margin-bottom: 7px; }
.malakor-words { font-size: 15px; color: var(--text); font-style: italic; line-height: 1.75; }


/* ════════════════════════════════════════
   ZONES PAGE
════════════════════════════════════════ */
.page-heading { font-family: 'Cinzel', serif; font-size: 20px; color: var(--gold); letter-spacing: 3px; margin-bottom: 4px; font-weight: 700; }
.page-sub     { font-size: 14px; color: var(--text2); font-style: italic; margin-bottom: 24px; }

.zone-card { background: var(--panel); border: 1px solid var(--border); margin-bottom: 12px; transition: border-color .2s; }
.zone-card.available { cursor: pointer; }
.zone-card.available:hover { border-color: var(--border2); }
.zone-card.locked { opacity: .35; pointer-events: none; }

.zone-head { display: flex; align-items: center; gap: 14px; padding: 16px 18px; }
.zone-chevron { margin-left: auto; font-size: 11px; color: var(--text2); transition: transform .25s; flex-shrink: 0; }
.zone-card.expanded .zone-chevron { transform: rotate(180deg); }
.zone-content { display: none; }
.zone-card.expanded .zone-content { display: block; }
.zone-icon { font-size: 26px; flex-shrink: 0; }
.zone-info { flex: 1; }
.zone-name { font-family: 'Cinzel', serif; font-size: 15px; color: var(--bright); font-weight: 600; }
.zone-desc { font-size: 13px; color: var(--text2); font-style: italic; margin-top: 2px; }
.zone-tag  { font-family: 'Cinzel', serif; font-size: 8px; letter-spacing: 1.5px; padding: 3px 8px; flex-shrink: 0; }
.zone-tag.avail  { color: var(--green); border: 1px solid rgba(74,122,74,.4);  background: rgba(74,122,74,.07); }
.zone-tag.soon   { color: var(--text2); border: 1px solid var(--border); }
.zone-tag.active { color: var(--red);   border: 1px solid rgba(192,57,43,.4); background: rgba(192,57,43,.07); }

.zone-body { border-top: 1px solid var(--border); padding: 16px 18px; }
.tiers-label { font-family: 'Cinzel', serif; font-size: 8px; letter-spacing: 2px; color: var(--text2); text-transform: uppercase; margin-bottom: 12px; }

.tier-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.btn-tier {
  padding: 14px 10px;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  cursor: pointer;
  border: 1px solid rgba(212,88,10,.3);
  background: rgba(212,88,10,.05);
  color: var(--text2);
  text-align: center;
  transition: all .15s;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 5px;
}
.btn-tier:hover { background: rgba(212,88,10,.18); border-color: var(--orange); color: var(--bright); }
.t-dur   { font-size: 18px; color: var(--orange); font-weight: 600; }
.t-name  { font-size: 8px; letter-spacing: 1px; text-transform: uppercase; }
.t-div   { width: 100%; height: 1px; background: var(--border); }
.t-gold  { font-size: 11px; color: var(--gold); }
.t-xp    { font-size: 10px; color: #6a9aba; }
.t-shard { font-size: 10px; color: #a070cc; }

.zone-raid-active { display: flex; align-items: center; gap: 14px; }
.z-prog-track { flex: 1; background: var(--bg); border: 1px solid var(--border); height: 5px; }
.z-prog-fill  { height: 100%; background: linear-gradient(90deg, var(--red), var(--orange)); transition: width .8s linear; }
.z-time { font-family: 'Cinzel', serif; font-size: 11px; color: var(--text2); white-space: nowrap; }

/* ════════════════════════════════════════
   KASERNE / LOG
════════════════════════════════════════ */
.info-card { background: var(--panel); border: 1px solid var(--border); padding: 20px; margin-bottom: 12px; }
.info-card-title { font-family: 'Cinzel', serif; font-size: 9px; letter-spacing: 2px; color: var(--text2); text-transform: uppercase; margin-bottom: 14px; padding-bottom: 8px; border-bottom: 1px solid var(--border); }
.stat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 14px; }
.stat-box  { background: var(--bg); border: 1px solid var(--border); padding: 12px 14px; }
.stat-lbl  { font-family: 'Cinzel', serif; font-size: 8px; letter-spacing: 1.5px; color: var(--text2); text-transform: uppercase; }
.stat-val  { font-size: 18px; color: var(--bright); margin-top: 4px; }

.log-entry { padding: 6px 0; border-bottom: 1px solid rgba(42,30,18,.5); font-size: 13px; line-height: 1.5; display: flex; gap: 10px; }
.log-entry:last-child { border-bottom: none; }
.log-ts    { font-family: 'Cinzel', serif; font-size: 10px; color: var(--border2); flex-shrink: 0; padding-top: 2px; }
.log-txt   { color: var(--text); }
.log-empty { color: var(--text2); font-style: italic; font-size: 13px; padding: 8px 0; }

/* ════════════════════════════════════════
   LEVEL-UP
════════════════════════════════════════ */
.levelup-flash { position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%); background: rgba(28,21,16,.97); border: 1px solid var(--gold); padding: 28px 60px; text-align: center; z-index: 500; pointer-events: none; animation: lvlanim 2.8s forwards; }
@keyframes lvlanim { 0%{opacity:0;transform:translate(-50%,-50%) scale(.8)} 12%{opacity:1;transform:translate(-50%,-50%) scale(1.04)} 80%{opacity:1;transform:translate(-50%,-50%) scale(1)} 100%{opacity:0;transform:translate(-50%,-50%) scale(.96)} }
.lvl-title { font-family:'Cinzel',serif; font-size:22px; color:var(--gold); letter-spacing:4px; }
.lvl-sub   { font-size:15px; color:var(--bright); margin-top:8px; }

/* ════════════════════════════════════════
   LOGIN
════════════════════════════════════════ */
#login-screen { position: fixed; inset: 0; background: #000; z-index: 2000; display: none; align-items: center; justify-content: center; padding: 40px 24px; }
#login-screen.visible { display: flex; }
.login-inner { max-width: 360px; width: 100%; text-align: center; }
.login-flame { font-size: 36px; margin-bottom: 18px; animation: flicker 2.5s infinite alternate; }
.login-eyebrow { font-family:'Cinzel',serif; font-size:10px; letter-spacing:4px; color:var(--border2); text-transform:uppercase; margin-bottom:8px; }
.login-title { font-family:'Cinzel',serif; font-size:22px; color:var(--gold); margin-bottom:28px; font-weight:400; letter-spacing:1px; }
#login-error { color:var(--red); font-size:13px; min-height:20px; margin-bottom:8px; font-style:italic; }
.login-field { margin-bottom:12px; }
.login-field input { width:100%; background:var(--panel); border:1px solid var(--border2); color:var(--bright); padding:11px 14px; font-family:'Crimson Text',serif; font-size:16px; outline:none; }
.login-field input:focus { border-color:var(--gold); box-shadow: 0 0 8px rgba(201,162,39,.15); }
.login-field input::placeholder { color:var(--text2); }
.btn-login { width:100%; margin-top:8px; padding:13px; background:transparent; border:1px solid var(--gold); color:var(--gold); font-family:'Cinzel',serif; font-size:12px; letter-spacing:2px; cursor:pointer; transition:all .2s; }
.btn-login:hover { background:rgba(201,162,39,.1); box-shadow:0 0 16px rgba(201,162,39,.2); }
.btn-logout { display:block; width:100%; background:none; border:1px solid var(--border); color:var(--text2); font-family:'Cinzel',serif; font-size:9px; letter-spacing:1px; padding:6px 10px; cursor:pointer; margin-bottom:10px; transition:all .15s; }
.btn-logout:hover { color:var(--red); border-color:var(--red); }

/* ════════════════════════════════════════
   INTRO
════════════════════════════════════════ */
#intro-screen { position: fixed; inset: 0; background: #000; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 40px 24px; transition: opacity .9s; overflow-y: auto; }
#intro-screen.fade-out { opacity: 0; pointer-events: none; }
.intro-inner { max-width: 540px; width: 100%; text-align: center; }
.intro-flame { font-size: 36px; margin-bottom: 18px; animation: flicker 2.5s infinite alternate; }
@keyframes flicker { 0%{text-shadow:0 0 10px #c0392b,0 0 30px #c0392b} 50%{text-shadow:0 0 22px #d4580a,0 0 65px #d4580a} 100%{text-shadow:0 0 8px #c0392b,0 0 22px #8b1a0a} }
.intro-eyebrow { font-family:'Cinzel',serif; font-size:10px; letter-spacing:4px; color:var(--border2); text-transform:uppercase; margin-bottom:24px; }
#intro-text { font-size:17px; line-height:1.85; color:var(--text); min-height:200px; text-align:left; }
#intro-text .intro-p { margin-bottom:14px; opacity:0; transition:opacity .5s; }
#intro-text .intro-p.vis { opacity:1; }
.cursor-blink { display:inline-block; width:2px; height:1em; background:var(--gold); margin-left:2px; vertical-align:text-bottom; animation:blink .7s infinite; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }
.intro-malakor { font-family:'Cinzel',serif; font-size:11px; color:var(--text2); letter-spacing:1px; margin:10px 0 22px; opacity:0; transition:opacity .6s; }
.intro-malakor.vis { opacity:1; }
#btn-enter { display:none; font-family:'Cinzel',serif; font-size:11px; letter-spacing:3px; text-transform:uppercase; background:rgba(201,162,39,.08); border:1px solid rgba(201,162,39,.45); color:var(--gold2); padding:11px 34px; cursor:pointer; transition:background .2s; animation:pulse-gold 2s infinite; }
#btn-enter:hover { background:rgba(201,162,39,.22); }
#btn-enter.show { display:inline-block; }
.intro-skip-wrap { display:none; align-items:center; justify-content:center; gap:8px; margin-top:14px; color:var(--text2); font-size:12px; cursor:pointer; opacity:.7; transition:opacity .2s; }
.intro-skip-wrap:hover { opacity:1; }
.intro-skip-wrap.show { display:flex; }
.intro-skip-wrap input[type="checkbox"] { accent-color:var(--gold); width:13px; height:13px; cursor:pointer; }
.foliant-nav-dot { margin-left:auto; color:var(--red); font-size:10px; animation:quest-pulse 2s ease-in-out infinite; }

/* ── Foliant-Einträge ── */
.foliant-entry { background:var(--panel); border:1px solid var(--border); padding:20px 22px; margin-bottom:16px; }
.foliant-entry.unread { border-color:var(--gold); box-shadow:0 0 12px rgba(201,162,39,.08); }
.foliant-entry-header { display:flex; align-items:center; gap:10px; margin-bottom:14px; padding-bottom:10px; border-bottom:1px solid var(--border); }
.foliant-dot { color:var(--gold); font-size:10px; animation:quest-pulse 2s ease-in-out infinite; }
.foliant-entry-title { font-family:'Cinzel',serif; font-size:13px; color:var(--gold); letter-spacing:1px; }
.foliant-entry-category { margin-left:auto; font-family:'Cinzel',serif; font-size:8px; letter-spacing:2px; color:var(--text2); text-transform:uppercase; }
.foliant-para { font-size:15px; line-height:1.85; color:var(--text); margin-bottom:12px; }
.foliant-para:last-child { margin-bottom:0; }
.foliant-empty { color:var(--text2); font-style:italic; font-size:13px; padding:16px 0; }

/* ════════════════════════════════════════
   LOOT TABLE
════════════════════════════════════════ */
.loot-table-wrap {
  border-top: 1px solid var(--border);
  padding: 16px 18px;
}
.loot-table-title {
  font-family: 'Cinzel', serif;
  font-size: 8px;
  letter-spacing: 2.5px;
  color: var(--text2);
  text-transform: uppercase;
  margin-bottom: 14px;
}
.loot-rarity-group { margin-bottom: 14px; }
.loot-rarity-label {
  font-family: 'Cinzel', serif;
  font-size: 8px;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin-bottom: 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
.loot-rarity-label.r-common    { color: var(--text2); }
.loot-rarity-label.r-rare      { color: var(--blue); }
.loot-rarity-label.r-epic      { color: #8a50ba; }
.loot-rarity-label.r-legendary { color: var(--gold); }

.loot-item-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 5px 0;
}
.loot-item-icon { font-size: 18px; flex-shrink: 0; width: 24px; text-align: center; line-height: 1.3; }
.loot-item-icon.unknown { color: var(--text2); font-size: 16px; }
.loot-item-body { flex: 1; min-width: 0; }
.loot-item-name { font-size: 13px; font-weight: 600; }
.loot-item-name.r-common    { color: var(--text); }
.loot-item-name.r-rare      { color: #6a9aba; }
.loot-item-name.r-epic      { color: #a070cc; }
.loot-item-name.r-legendary { color: var(--gold2); }
.loot-item-name.unknown     { color: var(--text2); font-style: italic; }
.loot-item-desc { font-size: 11px; color: var(--text2); margin-top: 1px; font-style: italic; }
.loot-item-meta { display: flex; gap: 6px; margin-top: 3px; flex-wrap: wrap; }
.loot-tier-tag  { font-family: 'Cinzel', serif; font-size: 7px; letter-spacing: 1px; padding: 1px 5px; border: 1px solid var(--border); color: var(--text2); text-transform: uppercase; }
.loot-loading   { font-size: 12px; color: var(--text2); font-style: italic; }

/* ════════════════════════════════════════
   DIALOGUE
════════════════════════════════════════ */
#dialogue-screen {
  position: fixed; inset: 0; z-index: 900;
  background: rgba(0,0,0,.88);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; pointer-events: none;
  transition: opacity .3s;
}
#dialogue-screen.open { opacity: 1; pointer-events: all; }

.dialogue-box {
  max-width: 560px; width: 100%;
  background: var(--panel);
  border: 1px solid var(--border2);
  border-top: 3px solid var(--gold);
  padding: 28px 32px 24px;
}
.dialogue-npc { display: flex; align-items: center; gap: 12px; margin-bottom: 20px; }
.dialogue-npc-icon { font-size: 32px; }
.dialogue-npc-name { font-family: 'Cinzel', serif; font-size: 11px; letter-spacing: 2px; color: var(--gold); text-transform: uppercase; }
.dialogue-text {
  font-size: 16px; line-height: 1.85; color: var(--text);
  font-style: italic; min-height: 80px;
  margin-bottom: 24px;
}
.dialogue-footer { display: flex; align-items: center; justify-content: space-between; }
.dialogue-pages { font-family: 'Cinzel', serif; font-size: 9px; color: var(--text2); letter-spacing: 1px; }
.btn-dialogue {
  font-family: 'Cinzel', serif; font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  padding: 8px 22px;
  background: rgba(201,162,39,.08); border: 1px solid rgba(201,162,39,.4); color: var(--gold);
  cursor: pointer; transition: background .15s;
}
.btn-dialogue:hover { background: rgba(201,162,39,.2); }
.btn-dialogue.last { background: rgba(201,162,39,.15); border-color: var(--gold); }

/* ════════════════════════════════════════
   QUESTS
════════════════════════════════════════ */
.malakor-portrait { position: relative; }
.quest-dot {
  position: absolute;
  top: -4px; right: -10px;
  background: var(--gold);
  color: #1a1000;
  font-family: 'Cinzel', serif;
  font-size: 10px;
  font-weight: 700;
  width: 17px; height: 17px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  animation: quest-pulse 2s ease-in-out infinite;
  cursor: pointer;
}
@keyframes quest-pulse { 0%,100%{box-shadow:0 0 0 rgba(201,162,39,0)} 50%{box-shadow:0 0 10px rgba(201,162,39,.7)} }

.quest-card {
  background: var(--panel);
  border: 1px solid var(--border);
  padding: 18px 20px;
  margin-bottom: 10px;
  transition: border-color .2s;
}
.quest-card.available { border-left: 3px solid var(--gold); }
.quest-card.active    { border-left: 3px solid var(--orange); }
.quest-card.completed { border-left: 3px solid var(--border2); opacity: .55; }

.quest-head { display: flex; align-items: center; gap: 12px; margin-bottom: 10px; }
.quest-giver-icon { font-size: 24px; flex-shrink: 0; }
.quest-giver-name { font-family: 'Cinzel', serif; font-size: 9px; letter-spacing: 1.5px; color: var(--gold); text-transform: uppercase; }
.quest-title { font-family: 'Cinzel', serif; font-size: 14px; color: var(--bright); font-weight: 600; margin-top: 2px; }
.quest-status-badge { margin-left: auto; font-family: 'Cinzel', serif; font-size: 8px; letter-spacing: 1px; padding: 3px 8px; flex-shrink: 0; }
.quest-status-badge.available { color: var(--gold);  border: 1px solid rgba(201,162,39,.4); background: rgba(201,162,39,.07); }
.quest-status-badge.active    { color: var(--orange); border: 1px solid rgba(212,88,10,.4);  background: rgba(212,88,10,.07); }
.quest-status-badge.completed { color: var(--text2); border: 1px solid var(--border); }

.quest-desc   { font-size: 14px; color: var(--text); line-height: 1.7; margin-bottom: 12px; }
.quest-reward { font-size: 12px; color: var(--text2); font-style: italic; margin-bottom: 14px; }
.quest-reward span { color: var(--gold); }

.btn-quest-accept {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 8px 20px;
  background: rgba(201,162,39,.08);
  border: 1px solid rgba(201,162,39,.4);
  color: var(--gold);
  cursor: pointer;
  transition: background .15s;
}
.btn-quest-accept:hover { background: rgba(201,162,39,.2); }

.quest-collect {
  font-size: 12px;
  color: var(--text2);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.quest-collect strong { color: var(--text1); }
.quest-collect.ready strong { color: var(--green); }
.btn-quest-hand-in {
  font-family: 'Cinzel', serif;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  padding: 6px 16px;
  background: rgba(100,200,80,.08);
  border: 1px solid rgba(100,200,80,.4);
  color: var(--green);
  cursor: pointer;
  transition: background .15s;
}
.btn-quest-hand-in:hover { background: rgba(100,200,80,.2); }

.quest-empty { color: var(--text2); font-style: italic; font-size: 14px; padding: 32px 0; text-align: center; }

.quest-completed-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 14px;
  margin-top: 6px;
  background: var(--panel);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border2);
  cursor: pointer;
  font-family: 'Cinzel', serif;
  font-size: 9px;
  letter-spacing: 1.5px;
  color: var(--text2);
  text-transform: uppercase;
  user-select: none;
  transition: background .15s, color .15s;
}
.quest-completed-toggle:hover { background: var(--panel2); color: var(--text); }
.completed-chevron { font-size: 9px; }

/* ════════════════════════════════════════
   LAGERKISTE / INVENTORY
════════════════════════════════════════ */
.inv-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 8px; }
.inv-card { background: var(--panel); border: 1px solid var(--border); padding: 14px 12px; display: flex; flex-direction: column; align-items: center; gap: 5px; text-align: center; transition: border-color .15s; }
.inv-card:hover { border-color: var(--border2); }
.inv-icon  { font-size: 28px; line-height: 1; margin-bottom: 2px; }
.inv-name  { font-family: 'Cinzel', serif; font-size: 11px; font-weight: 600; line-height: 1.3; }
.inv-name.r-common    { color: var(--text); }
.inv-name.r-rare      { color: #6a9aba; }
.inv-name.r-epic      { color: #a070cc; }
.inv-name.r-legendary { color: var(--gold2); }
.inv-desc  { font-size: 11px; color: var(--text2); font-style: italic; line-height: 1.35; }
.inv-qty-wrap  { width: 100%; margin-top: 4px; }
.inv-qty-track { width: 100%; background: var(--bg); border: 1px solid var(--border); height: 3px; margin-bottom: 4px; }
.inv-qty-fill  { height: 100%; background: var(--border2); transition: width .4s; }
.inv-qty-label { font-family: 'Cinzel', serif; font-size: 9px; color: var(--text2); }
.inv-empty { color: var(--text2); font-style: italic; font-size: 14px; padding: 32px 0; text-align: center; }

/* ── overlay / scrollbar ── */
#overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.6); z-index:250; }
#overlay.open { display:block; }
::-webkit-scrollbar { width: 4px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 2px; }
::-webkit-scrollbar-thumb:hover { background: var(--gold); }

/* ── responsive ── */
@media (max-width: 700px) {
  #hamburger { display: flex; }
  #sidebar { position: fixed; top: 48px; left: 0; bottom: 0; z-index: 260; transform: translateX(calc(-1 * var(--sidebar-w))); transition: transform .28s cubic-bezier(.4,0,.2,1); }
  #sidebar.open { transform: translateX(0); }
  .page-wrap { padding: 18px 16px 32px; }
  .tier-grid { grid-template-columns: 1fr; }
  .stat-grid { grid-template-columns: 1fr; }

  #intro-screen { align-items: flex-start; padding: 24px 20px; }
  .intro-inner { padding: 8px 0 24px; }
  .intro-flame { font-size: 28px; margin-bottom: 12px; }
  #intro-text { font-size: 15px; line-height: 1.7; min-height: unset; }
  .intro-eyebrow { margin-bottom: 16px; }
}
