/* ── Reset & base ── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --parchment:  #f2e8ce;
  --parchment2: #ead9b0;
  --parchment3: #d4c080;
  --ink:        #120d06;
  --ink2:       #1e1208;
  --ink-faded:  #4a3318;
  --ink-ghost:  #6b5030;
  --gold:       #8b6a14;
  --gold2:      #b08820;
  --red-seal:   #7a1a0a;
  --teal:       #1a5a52;
  --border:     #c4a84a;
  --shadow:     rgba(26,18,8,0.28);
}

html, body {
  height: 100%;
  font-family: 'Nunito', sans-serif;
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
}

* { scrollbar-width: thin; scrollbar-color: rgba(196,168,74,0.3) transparent; }
*::-webkit-scrollbar { width: 6px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb { background: rgba(196,168,74,0.3); border-radius: 3px; }

/* ── Shared header classes (used inside dmg-page) ── */
.hdr-sigil { font-size: 26px; margin-bottom: 6px; opacity: .6; animation: float 5s ease-in-out infinite; }
.hdr-eye {
  font-family: 'Nunito', sans-serif; font-size: 13px; letter-spacing: .06em;
  color: var(--ink-ghost); margin-bottom: 8px;
}
.hdr-title {
  font-family: 'Cinzel', serif; font-weight: 700;
  font-size: clamp(20px,3.5vw,32px); color: var(--ink2);
  letter-spacing: .03em; line-height: 1.25;
}
.hdr-sub {
  font-size: 13px; color: var(--ink-faded);
  margin-top: 8px; line-height: 1.8;
}
.hdr-rule { display: flex; align-items: center; gap: 10px; margin: 16px auto 0; max-width: 340px; }
.hdr-rule::before, .hdr-rule::after { content: ''; flex: 1; height: 1px; background: linear-gradient(to right,transparent,var(--parchment3),transparent); }
.hdr-rule span { color: var(--gold); font-size: 13px; }

@keyframes float { 0%,100% { transform: translateY(0) } 50% { transform: translateY(-5px) } }

/* Shared back button */
.nav-back {
  display: inline-flex; align-items: center; gap: 12px;
  font-family: 'Cinzel', serif; font-size: 13px; font-weight: 600; letter-spacing: .06em;
  color: var(--ink-ghost); background: transparent;
  border: 1px solid var(--parchment3); padding: 11px 22px;
  cursor: pointer; transition: all .2s; margin-bottom: 20px;
}
.nav-back:hover { color: var(--ink2); border-color: var(--gold2); background: rgba(196,168,74,.07); }
.nav-back-arrow { font-size: 16px; transition: transform .2s; }
.nav-back:hover .nav-back-arrow { transform: translateX(-3px); }


/* ══════════════════════════════════════════
   DMG CALC — WAR CHRONICLE RPG THEME
   Direction: ancient war tome, ink + gold,
   corner-cut panels, rune accents
══════════════════════════════════════════ */

/* ── Page ── */
#dmg-page {
  height: 100vh;
  /* Dark mystical dungeon/battlefield palette */
  background: #1a140a;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(139, 106, 20, 0.1) 0%, transparent 50%),
    radial-gradient(circle at 80% 70%, rgba(122, 26, 10, 0.08) 0%, transparent 50%),
    linear-gradient(180deg, #1a140a 0%, #2e2416 100%);
  overflow-y: auto;
  color: var(--parchment);
  position: relative;
}
/* ── Particle canvas (injected by JS) ── */
#dmg-particles {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none;
}

/* ── Mystical Fog Layer ── */
.dmg-fog-layer {
  position: fixed;
  inset: -50%;
  z-index: 0;
  pointer-events: none;
  background: 
    radial-gradient(circle at 30% 40%, rgba(139, 106, 20, 0.06) 0%, transparent 60%),
    radial-gradient(circle at 70% 60%, rgba(122, 26, 10, 0.05) 0%, transparent 60%);
  filter: blur(60px);
  animation: dmg-fogFloat 30s ease-in-out infinite alternate;
  opacity: 0.6;
}

/* ── Vignette ── */
.dmg-vignette {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background: radial-gradient(circle at 50% 50%, transparent 40%, rgba(0, 0, 0, 0.6) 100%);
}

#dmg-page::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='0.055'/%3E%3C/svg%3E");
  background-size: 300px 300px; mix-blend-mode: screen;
}
.dmg-inner {
  position: relative; z-index: 1;
  max-width: 1100px; margin: 0 auto;
  padding: 0 44px 80px;
  box-sizing: border-box;
  /* Entrance animation */
  animation: dmg-fadeInUp 0.8s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
@media(max-width:680px) { .dmg-inner { padding: 0 14px 60px; } }

/* ── Overrides for header on dark bg ── */
#dmg-page .hdr { border-bottom: 1px solid rgba(196,168,74,.2); }
#dmg-page .hdr-sigil { color: rgba(220,192,100,.8); text-shadow: 0 0 15px rgba(220,192,100,0.4); }
#dmg-page .hdr-eye { color: rgba(220,192,100,.55); }
#dmg-page .hdr-title { color: #faecc8; text-shadow: 0 0 30px rgba(196, 168, 74, .25); position: relative; overflow: hidden; }
#dmg-page .hdr-title::after {
  content: '';
  position: absolute;
  top: 0; left: -100%;
  width: 50%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.1), transparent);
  animation: dmg-shimmer 4s infinite linear;
}
#dmg-page .hdr-sub { color: rgba(250,236,200,.65); }
#dmg-page .hdr-rule::before,
#dmg-page .hdr-rule::after { background: linear-gradient(to right,transparent,rgba(196,168,74,.35),transparent); }
#dmg-page .hdr-rule span { color: rgba(220,192,100,.65); }
#dmg-page .nav-back {
  color: rgba(220,192,100,.8); border-color: rgba(196,168,74,.25);
  background: rgba(196,168,74,.06);
  backdrop-filter: blur(4px);
}
#dmg-page .nav-back:hover { color: #faecc8; border-color: rgba(196,168,74,.6); background: rgba(196,168,74,0.12); }

/* ── Action bar ── */
.dmg-action-bar {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  margin-bottom: 22px; padding-bottom: 16px;
  border-bottom: 1px solid rgba(196,168,74,.15);
}

/* ── Layout ── */
.dmg-layout {
  display: grid; grid-template-columns: 220px 1fr;
  gap: 20px; align-items: start;
}
@media(max-width:860px) { .dmg-layout { grid-template-columns: 1fr; } }
.dmg-center { display: flex; flex-direction: column; gap: 16px; }

/* ══ RPG PANEL — left skills ══ */
.dmg-panel {
  background: rgba(58, 44, 24, 0.75);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(196,168,74,.35);
  box-shadow: inset 0 0 30px rgba(0,0,0,.4), 0 4px 20px rgba(0,0,0,0.5);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.dmg-panel:hover { transform: translateY(-2px); box-shadow: inset 0 0 30px rgba(0,0,0,.4), 0 8px 30px rgba(0,0,0,0.6); }
.dmg-panel::before {
  content: ''; position: absolute; inset: 3px;
  border: 1px solid rgba(196,168,74,.1); pointer-events: none;
}
.dmg-panel-title {
  font-family: 'Cinzel', serif; font-size: 10px; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: rgba(220,192,100,.85); padding: 9px 14px;
  border-bottom: 1px solid rgba(196,168,74,.2);
  background: rgba(196,168,74,.06);
  display: flex; align-items: center; gap: 8px;
}
.dmg-panel-title::before { content: '⚔'; font-size: 11px; opacity: .6; }
.dmg-panel-subtitle {
  font-family: 'Nunito', sans-serif; font-size: 9px;
  color: rgba(250,236,200,.35); letter-spacing: .06em;
  text-transform: uppercase; padding: 5px 14px 0;
  text-align: center;
}

/* Level row */
.dmg-level-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 9px 14px; border-bottom: 1px solid rgba(196,168,74,.12); gap: 8px;
}
.dmg-level-label {
  font-family: 'Nunito', sans-serif; font-size: 11px;
  color: rgba(250,236,200,.7); flex: 1; letter-spacing: .04em; text-transform: uppercase;
}
.dmg-level-val {
  font-family: 'Cinzel', serif; font-size: 16px; font-weight: 700;
  color: #faecc8; min-width: 28px; text-align: center;
}
input.dmg-level-val {
  background: transparent; border: none;
  border-bottom: 1px solid rgba(196,168,74,.4);
  width: 38px; outline: none; padding: 1px 2px; text-align: center;
  -moz-appearance: textfield; appearance: none; color: #faecc8;
}
input.dmg-level-val::-webkit-inner-spin-button,
input.dmg-level-val::-webkit-outer-spin-button { -webkit-appearance: none; }
input.dmg-level-val:focus { border-bottom-color: #d4b85a; }
.dmg-pts {
  font-family: 'Nunito', sans-serif; font-size: 13px; color: rgba(250,236,200,.65);
  text-align: center; padding: 5px 0 9px;
  border-bottom: 1px solid rgba(196,168,74,.12);
}
.dmg-pts span { color: #d4b85a; font-weight: 800; font-size: 14px; }

/* Skill rows */
.dmg-skill-row {
  display: flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-bottom: 1px solid rgba(196,168,74,.08);
  transition: background .12s;
}
.dmg-skill-row:hover { background: rgba(196,168,74,.04); }
.dmg-skill-row:last-child { border-bottom: none; }
.dmg-skill-icon { font-size: 12px; width: 16px; text-align: center; flex-shrink: 0; }
.dmg-skill-name {
  font-family: 'Nunito', sans-serif; font-size: 11px;
  color: rgba(250,236,200,.8); flex: 1;
}
.dmg-skill-val {
  font-family: 'Cinzel', serif; font-size: 12px; font-weight: 700;
  color: #d4b85a; min-width: 30px; text-align: right;
}
.dmg-skill-locked { font-size: 9px; color: rgba(250,236,200,.35); }
.dmg-prog { display: flex; gap: 2px; margin-top: 3px; }
.dmg-pb {
  width: 7px; height: 7px;
  border: 1px solid rgba(196,168,74,.2); background: transparent; flex-shrink: 0;
}
.dmg-pb.active        { background: #c4a84a;  border-color: #d4b85a; }
.dmg-pb.active-red    { background: #a83020; border-color: #c43828; }
.dmg-pb.active-green  { background: #1a5a52; border-color: #1a7a6a; }
.dmg-pb.active-blue   { background: #1a3a7a; border-color: #1a4a9a; }
.dmg-pb.active-yellow { background: #7a6010; border-color: #a88020; }

/* Small +/- buttons */
.dmg-btn-sm {
  font-size: 13px; font-weight: 700; line-height: 1;
  background: rgba(196,168,74,.15); color: #d4b85a;
  border: 1px solid rgba(196,168,74,.3);
  width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .15s; flex-shrink: 0;
}
.dmg-btn-sm:hover:not(:disabled) {
  background: rgba(196,168,74,.3); color: #faecc8; border-color: #d4b85a;
}
.dmg-btn-sm:disabled {
  background: transparent; color: rgba(196,168,74,.2);
  border-color: rgba(196,168,74,.1); cursor: not-allowed;
}

/* ══ RPG CARD — center column ══ */
.dmg-card {
  background: rgba(54, 42, 22, 0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(196, 168, 74, .3);
  box-shadow: inset 0 0 20px rgba(0,0,0,.35), 0 2px 12px rgba(0,0,0,.45);
  position: relative;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.dmg-card:hover { transform: translateY(-1px); box-shadow: inset 0 0 20px rgba(0,0,0,.35), 0 4px 18px rgba(0,0,0,0.5); }
/* Corner ornaments */
.dmg-card::before, .dmg-card::after {
  content: ''; position: absolute; width: 10px; height: 10px;
  border-color: rgba(220,192,100,.65); border-style: solid;
  pointer-events: none;
}
.dmg-card::before { top: 3px; left: 3px; border-width: 1px 0 0 1px; }
.dmg-card::after  { bottom: 3px; right: 3px; border-width: 0 1px 1px 0; }
.dmg-card-hdr {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid rgba(196,168,74,.18);
  background: rgba(196,168,74,.08);
  font-family: 'Cinzel', serif; font-size: 10px; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; color: rgba(220,192,100,.8);
}
.dmg-card-body { padding: 14px 16px; }

/* ── RPG Character Stats ── */
.rpg-stat-card { overflow: hidden; }

/* Header: star ornaments + title */
.rpg-stat-header {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px 14px 8px;
  border-bottom: 1px solid rgba(196,168,74,.22);
  background: linear-gradient(180deg, rgba(196,168,74,.12) 0%, rgba(196,168,74,.04) 100%);
  position: relative;
}
.rpg-stat-title {
  font-family: 'Cinzel Decorative', 'Cinzel', serif;
  font-size: 11px; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: rgba(220,192,100,.95);
  text-shadow: 0 0 18px rgba(220,192,100,.35);
}
.rpg-stat-header-ornament { opacity: .85; flex-shrink: 0; }
.rpg-stat-header-ornament.right svg { transform: scaleX(-1); }

/* HP / Hunger bars */
.rpg-bars {
  display: flex; flex-direction: column; gap: 12px;
  padding: 16px 14px 14px;
  border-bottom: 1px solid rgba(196,168,74,.15);
}
.rpg-bar-row { display: flex; align-items: center; gap: 10px; }
.rpg-bar-icon { flex-shrink: 0; width: 22px; display: flex; align-items: center; justify-content: center; }
.rpg-bar-label {
  font-family: 'Cinzel', serif;
  font-size: 10px; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(250,236,200,.8);
  width: 48px; flex-shrink: 0; font-weight: 600;
}
.rpg-bar-track {
  flex: 1; height: 16px;
  background: rgba(0,0,0,.6);
  border: 1px solid rgba(196,168,74,.25);
  position: relative; overflow: hidden;
  clip-path: polygon(5px 0%, 100% 0%, calc(100% - 5px) 100%, 0% 100%);
  box-shadow: inset 0 2px 4px rgba(0,0,0,.4);
}
.rpg-bar-fill {
  height: 100%; transition: width .4s ease;
  position: relative; box-shadow: inset -1px 0 3px rgba(0,0,0,.3);
}
.rpg-health { background: linear-gradient(90deg, #6b1a1a 0%, #c03030 60%, #e05050 100%); }
.rpg-hunger { background: linear-gradient(90deg, #6b3a10 0%, #b86020 60%, #d88030 100%); }
.rpg-bar-shine {
  position: absolute; top: 0; left: 0; right: 0; height: 40%;
  background: rgba(255,255,255,.08); pointer-events: none;
}
.rpg-bar-text {
  font-family: 'MedievalSharp', 'Cinzel', serif;
  font-size: 12px; color: #d4b85a;
  min-width: 56px; text-align: right; flex-shrink: 0; font-weight: 600;
}

/* Divider */
.rpg-divider {
  display: flex; align-items: center; gap: 8px;
  padding: 0 14px; margin: 4px 0;
}
.rpg-divider-line {
  flex: 1; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(196,168,74,.35), transparent);
}

/* Stat grid */
.rpg-stats-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1px; background: rgba(196,168,74,.1);
  border-top: 1px solid rgba(196,168,74,.1);
}
@media(max-width:500px) { .rpg-stats-grid { grid-template-columns: repeat(2,1fr); } }

.rpg-stat-item {
  background: linear-gradient(160deg, #2e2310 0%, #231c0c 100%);
  padding: 10px 10px 8px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  position: relative; transition: background .15s;
}
.rpg-stat-item:hover { background: linear-gradient(160deg, #3a2c14 0%, #2e2410 100%); }
.rpg-stat-attack { grid-column: span 3; align-items: center; justify-content: center; }
.rpg-stat-item-header {
  display: flex; align-items: center; gap: 5px; width: 100%; justify-content: center;
}
.rpg-stat-svg-icon { color: rgba(196,168,74,.7); display: flex; align-items: center; flex-shrink: 0; }
.rpg-stat-name {
  font-family: 'Cinzel', serif; font-size: 8.5px;
  letter-spacing: .1em; text-transform: uppercase; color: rgba(250,236,200,.55);
}
.rpg-stat-number {
  font-family: 'MedievalSharp', 'Cinzel', serif;
  font-size: 22px; font-weight: 400; color: #e8d898; line-height: 1;
  text-shadow: 0 0 12px rgba(220,192,100,.25);
}
.rpg-stat-number.gold {
  color: #d4b85a; font-size: 26px;
  text-shadow: 0 0 16px rgba(212,184,90,.4);
}

/* Attack breakdown */
.rpg-stat-eff { font-size: 10px; color: #7ecfff; opacity: 0.85; margin-top: 1px; letter-spacing: 0.02em; }
.rpg-breakdown { display: flex; flex-wrap: wrap; gap: 2px 10px; margin-top: 3px; }
.rpg-breakdown-row {
  font-family: 'Nunito', sans-serif; font-size: 10px;
  color: rgba(250,236,200,.45); white-space: nowrap;
}
.rpg-breakdown-row strong { color: rgba(250,236,200,.75); font-weight: 700; }

/* ── Equipment ── */
.dmg-equip-grid {
  display: flex; flex-direction: row; flex-wrap: nowrap;
  gap: 6px; align-items: flex-end; width: 100%;
}
.dmg-slot-wrap {
  display: flex; flex-direction: column; gap: 3px; align-items: center;
  flex: 1; min-width: 0; max-width: 72px;
}
.dmg-equip-slot {
  width: 100%; aspect-ratio: 1;
  border: 1px solid rgba(196,168,74,.22);
  background: rgba(0,0,0,.35);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; color: rgba(196,168,74,.22);
  position: relative; cursor: pointer; transition: all .15s;
}
.dmg-equip-slot img { width: 72%; height: 72%; object-fit: contain; }
.dmg-equip-slot:hover {
  border-color: rgba(212, 184, 90, 0.7);
  background: rgba(196, 168, 74, 0.12);
  box-shadow: 0 0 15px rgba(212, 184, 90, 0.25);
  transform: scale(1.02);
}
.dmg-equip-slot.equipped {
  border-color: var(--tier-col);
  background: rgba(196, 168, 74, 0.07);
  box-shadow: 0 0 10px var(--tier-col);
}
.dmg-equip-label {
  font-family: 'Nunito', sans-serif; font-size: 9px; font-weight: 600;
  color: rgba(250,236,200,.4); text-align: center;
  text-transform: uppercase; letter-spacing: .04em; white-space: nowrap;
}

/* ── Inventory ── */
.dmg-inv-grid { display: flex; flex-wrap: wrap; gap: 5px; }
.dmg-inv-item {
  width: 50px; height: 50px;
  border: 1px solid rgba(196,168,74,.18);
  background: rgba(0,0,0,.35);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; transition: all .15s; position: relative; font-size: 20px;
}
.dmg-inv-item:hover {
  border-color: #d4b85a; background: rgba(196,168,74,.1);
  transform: translateY(-2px); box-shadow: 0 4px 12px rgba(0,0,0,.4);
}
.dmg-inv-item img { width: 78%; height: 78%; object-fit: contain; }
.dmg-inv-item.tier-gray   { border-color: rgba(138,138,138,.35); }
.dmg-inv-item.tier-green  { border-color: rgba(42,122,42,.4); }
.dmg-inv-item.tier-blue   { border-color: rgba(26,74,138,.45); }
.dmg-inv-item.tier-purple { border-color: rgba(106,26,138,.45); }
.dmg-inv-item.tier-golden { border-color: rgba(196,168,74,.65); }
.dmg-inv-item.tier-red    { border-color: rgba(200,30,30,.65); }
.dmg-inv-item-large {
  width: 66px; height: 66px;
  border-color: rgba(196,168,74,.18) !important;
}
.dmg-tier-sep {
  width: 100%; font-family: 'Nunito', sans-serif; font-size: 11px; font-weight: 600;
  letter-spacing: .08em; text-transform: uppercase;
  color: rgba(220,192,100,.65); padding: 8px 0 4px;
  border-top: 1px solid rgba(196,168,74,.15); margin-top: 6px;
}

/* ── Armor Level Slider ── */
input[type="range"] { accent-color: #d4b85a; height: 3px; }

/* ── Tier colors ── */
.tier-gray   { --tier-col: rgba(138,138,138,.7); }
.tier-green  { --tier-col: rgba(42,180,42,.7); }
.tier-blue   { --tier-col: rgba(42,100,220,.7); }
.tier-purple { --tier-col: rgba(160,42,220,.7); }
.tier-golden { --tier-col: rgba(212,184,90,.9); }
.tier-red    { --tier-col: rgba(220,40,40,.9); }

/* ── Ammo/Buff ── */
.dmg-buff-row { display: flex; flex-wrap: wrap; gap: 6px; }
.dmg-buff-btn {
  display: flex; align-items: center; gap: 6px;
  padding: 5px 11px; border: 1px solid rgba(196,168,74,.22);
  background: rgba(0,0,0,.3); cursor: pointer; transition: all .15s;
  font-family: 'Nunito', sans-serif; font-size: 12px; font-weight: 600;
  color: rgba(250,236,200,.85);
}
.dmg-buff-btn:hover { border-color: #d4b85a; background: rgba(196,168,74,.1); color: #faecc8; }
.dmg-buff-btn.active-buff { border-color: #1a7a6a; background: rgba(26,90,80,.2); color: #20c090; }
.dmg-buff-btn:disabled { opacity: .35; cursor: not-allowed; }

/* ── Item Config Panel (compact) ── */
.dmg-config-panel {
  border: 1px solid rgba(196,168,74,.35);
  background: linear-gradient(135deg,#1e160a,#161008);
  padding: 12px 14px; display: none; margin-top: 10px;
  box-shadow: inset 0 0 20px rgba(0,0,0,.4);
}
.dmg-config-panel.open { display: block; }
.dmg-config-title {
  font-family: 'Cinzel', serif; font-size: 12px; font-weight: 700;
  color: #faecc8; margin-bottom: 10px;
  display: flex; align-items: center; gap: 8px;
  padding-bottom: 8px; border-bottom: 1px solid rgba(196,168,74,.15);
}
.dmg-config-row {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 7px; flex-wrap: wrap;
}
.dmg-config-row label {
  font-family: 'Nunito', sans-serif; font-size: 11px;
  color: rgba(250,236,200,.75); width: 100px; flex-shrink: 0;
}
.dmg-config-row .cfg-val {
  font-family: 'Cinzel', serif; font-size: 12px; font-weight: 700;
  color: #d4b85a; min-width: 36px; text-align: right;
}
.dmg-config-row input[type=range] { flex: 1; min-width: 80px; accent-color: #d4b85a; height: 3px; }
.dmg-config-actions { display: flex; gap: 6px; margin-top: 11px; flex-wrap: wrap; }
.dmg-config-equip {
  font-family: 'Cinzel', serif; font-size: 10px; font-weight: 600; letter-spacing: .08em;
  background: rgba(196,168,74,.18); color: #faecc8;
  border: 1px solid rgba(196,168,74,.45);
  padding: 6px 16px; cursor: pointer; transition: all .15s;
}
.dmg-config-equip:hover { background: rgba(196,168,74,.3); border-color: #d4b85a; }
.dmg-config-cancel {
  font-family: 'Nunito', sans-serif; font-size: 11px;
  background: transparent; border: 1px solid rgba(196,168,74,.2);
  color: rgba(250,236,200,.65); padding: 6px 12px; cursor: pointer; transition: all .15s;
}
.dmg-config-cancel:hover { border-color: rgba(220,192,100,.65); color: rgba(250,236,200,.92); }

/* ── Simulation ── */
.dmg-sim-row { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 4px; }
.dmg-sim-btn {
  font-family: 'Cinzel', serif; font-size: 10px; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; padding: 8px 16px; cursor: pointer; transition: all .2s;
  display: inline-flex; align-items: center; gap: 6px;
}
.dmg-sim-btn.primary {
  background: rgba(196,168,74,.18); color: #faecc8;
  border: 1px solid rgba(196,168,74,.45);
}
.dmg-sim-btn.primary:hover {
  background: rgba(196, 168, 74, 0.28);
  border-color: #ffd700;
  box-shadow: 0 0 20px rgba(196, 168, 74, 0.35);
  transform: translateY(-1px);
}
.dmg-sim-btn.secondary {
  background: transparent; border: 1px solid rgba(196,168,74,.2);
  color: rgba(250,236,200,.7);
}
.dmg-sim-btn.secondary:hover { border-color: rgba(220,192,100,.65); color: #faecc8; }

/* ── Food/Runs ── */
.dmg-food-sel, .dmg-runs-sel {
  font-family: 'Nunito', sans-serif; font-size: 13px;
  background: rgba(0,0,0,.4); border: 1px solid rgba(196,168,74,.25);
  color: rgba(250,236,200,.9); padding: 6px 10px; outline: none; cursor: pointer;
}
.dmg-food-sel option, .dmg-runs-sel option { background: #1c1510; color: #faecc8; }

/* ── Results ── */
.dmg-results-title {
  font-family: 'Cinzel', serif; font-size: 11px; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: rgba(220,192,100,.8); margin-bottom: 12px;
  display: flex; align-items: center; gap: 8px;
}
.dmg-results-title::before {
  content: ''; display: inline-block; width: 18px; height: 1px;
  background: rgba(196,168,74,.4);
}
.dmg-results-title::after {
  content: ''; display: inline-block; flex: 1; height: 1px;
  background: linear-gradient(to right,rgba(196,168,74,.3),transparent);
}
.dmg-kpi-grid {
  display: grid; grid-template-columns: repeat(auto-fill,minmax(105px,1fr)); gap: 7px;
  margin-bottom: 12px;
}
.dmg-kpi {
  border: 1px solid rgba(196,168,74,.18);
  background: rgba(0,0,0,.3); padding: 9px 10px; text-align: center; position: relative;
}
.dmg-kpi::before {
  content: ''; position: absolute; top: 2px; left: 2px; right: 2px;
  height: 1px; background: linear-gradient(to right,transparent,rgba(196,168,74,.2),transparent);
}
.dmg-kpi-label {
  font-family: 'Nunito', sans-serif; font-size: 9px; text-transform: uppercase;
  letter-spacing: .06em; color: rgba(250,236,200,.5); margin-bottom: 4px;
}
.dmg-kpi-val { font-family: 'Cinzel', serif; font-size: 21px; font-weight: 700; color: #faecc8; }
.dmg-kpi-val.gold { color: #d4b85a; }
.dmg-kpi-val.teal { color: #20c090; }
.dmg-kpi-range {
  font-family: 'Nunito', sans-serif; font-size: 9px;
  color: rgba(250,236,200,.4); margin-top: 2px;
}
.dmg-factor-row {
  font-family: 'Nunito', sans-serif; font-size: 13px; color: rgba(250,236,200,.65);
  padding: 8px 0; border-top: 1px solid rgba(196,168,74,.14); margin-top: 4px;
  display: flex; gap: 14px; flex-wrap: wrap;
}
.dmg-factor-row span { color: rgba(250,236,200,.92); font-weight: 600; }

/* ── Compare ── */
.dmg-cmp-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-bottom: 12px; }
@media(max-width:560px) { .dmg-cmp-grid { grid-template-columns: 1fr; } }
.dmg-cmp-build { border: 1px solid rgba(196,168,74,.2); background: rgba(0,0,0,.3); padding: 10px; }
.dmg-cmp-build-title {
  font-family: 'Cinzel', serif; font-size: 11px; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  color: rgba(220,192,100,.75); margin-bottom: 7px;
  display: flex; align-items: center; justify-content: space-between;
}
.dmg-cmp-loaded { font-size: 9px; color: var(--teal); font-weight: 400; text-transform: none; letter-spacing: 0; }
.dmg-cmp-kpi { font-family: 'Nunito', sans-serif; font-size: 13px; color: rgba(250,236,200,.7); padding: 3px 0; }
.dmg-cmp-kpi span { font-weight: 700; color: rgba(250,236,200,.92); }
.dmg-cmp-diff-pos { color: #20c090; font-weight: 700; }
.dmg-cmp-diff-neg { color: #c04040; font-weight: 700; }

/* ── Presets ── */
.dmg-preset-list { display: flex; flex-direction: column; gap: 5px; }
.dmg-preset-item {
  display: flex; align-items: center; gap: 8px;
  border: 1px solid rgba(196,168,74,.18); padding: 7px 10px;
  background: rgba(0,0,0,.25);
}
.dmg-preset-name {
  font-family: 'Nunito', sans-serif; font-size: 12px; font-weight: 600;
  color: rgba(250,236,200,.9); flex: 1;
}
.dmg-preset-level { font-family: 'Cinzel', serif; font-size: 10px; color: rgba(220,192,100,.55); }
.dmg-preset-btn-load {
  font-family: 'Cinzel', serif; font-size: 9px; letter-spacing: .06em;
  background: rgba(196,168,74,.14); color: #faecc8;
  border: 1px solid rgba(196,168,74,.35);
  padding: 3px 9px; cursor: pointer; transition: all .15s;
}
.dmg-preset-btn-load:hover { background: rgba(196,168,74,.25); }
.dmg-preset-btn-del {
  font-family: 'Nunito', sans-serif; font-size: 13px;
  background: transparent; border: none; color: rgba(220,192,100,.4);
  cursor: pointer; padding: 2px 5px; transition: color .15s;
}
.dmg-preset-btn-del:hover { color: #c04040; }
.dmg-empty-presets {
  font-family: 'Nunito', sans-serif; font-size: 11px; color: rgba(250,236,200,.35);
  text-align: center; padding: 10px 0; font-style: italic;
}
.dmg-preset-row { display: flex; gap: 7px; align-items: center; flex-wrap: wrap; }
.dmg-preset-input {
  font-family: 'Nunito', sans-serif; font-size: 12px;
  background: rgba(0,0,0,.35); border: 1px solid rgba(196,168,74,.25);
  color: rgba(250,236,200,.92); padding: 7px 10px; flex: 1; min-width: 110px; outline: none;
}
.dmg-preset-input:focus { border-color: #d4b85a; }
.dmg-preset-input::placeholder { color: rgba(220,192,100,.4); }

/* ── API Load bar ── */
.dmg-api-input {
  flex: 1; font-family: 'Nunito', sans-serif; font-size: 13px; font-weight: 600;
  background: rgba(0,0,0,.35); border: 1px solid rgba(196,168,74,.3);
  border-right: none; padding: 8px 12px; color: rgba(250,236,200,.92); outline: none;
}
.dmg-api-input::placeholder { color: rgba(220,192,100,.4); font-weight: 400; }
.dmg-api-input:focus { border-color: #d4b85a; }
.dmg-api-btn {
  font-family: 'Cinzel', serif; font-size: 11px; font-weight: 600; letter-spacing: .05em;
  background: rgba(196,168,74,.18); color: #faecc8;
  border: 1px solid rgba(196,168,74,.35); border-left: none;
  padding: 8px 16px; cursor: pointer; transition: all .15s; white-space: nowrap;
}
.dmg-api-btn:hover { background: rgba(196,168,74,.3); border-color: #d4b85a; }
.dmg-api-btn:disabled { opacity: .4; cursor: not-allowed; }
.dmg-api-status {
  font-family: 'Nunito', sans-serif; font-size: 11px;
  color: rgba(250,236,200,.5); margin-top: 5px; min-height: 16px; flex-basis: 100%;
}
.dmg-api-status.err { color: #c04040; }
.dmg-api-status.ok  { color: #20c090; }

/* ── Tick/MC/CMP result panels ── */
#dc-tick-results, #dc-mc-results, #dc-cmp-results { display: none; margin-top: 14px; }
#dc-tick-results.show, #dc-mc-results.show, #dc-cmp-results.show { display: block; }

/* Charts */
.dmg-chart-wrap { margin-top: 12px; }
.dmg-chart-canvas { width: 100% !important; max-height: 180px; }

/* ── DMG header block (standalone page) ── */
.dmg-hdr { text-align: center; padding: 46px 20px 26px; border-bottom: 1px solid rgba(196,168,74,.2); }
.dmg-hdr .hdr-sigil { color: rgba(220,192,100,.8); }
.dmg-hdr .hdr-eye { color: rgba(220,192,100,.55); }
.dmg-hdr .hdr-title { color: #faecc8; text-shadow: 0 0 30px rgba(196,168,74,.25); }
.dmg-hdr .hdr-sub { color: rgba(250,236,200,.65); }
.dmg-hdr .hdr-rule::before,
.dmg-hdr .hdr-rule::after { background: linear-gradient(to right,transparent,rgba(196,168,74,.35),transparent); }
.dmg-hdr .hdr-rule span { color: rgba(220,192,100,.65); }
.dmg-hdr .nav-back {
  color: rgba(220,192,100,.8); border-color: rgba(196,168,74,.25);
  background: rgba(196,168,74,.06);
}
.dmg-hdr .nav-back:hover { color: #faecc8; border-color: rgba(196,168,74,.6); }

/* ══ DMG KEYFRAMES ══ */
@keyframes dmg-fogFloat {
  0% { transform: translate(0, 0) rotate(0deg); }
  100% { transform: translate(4%, 3%) rotate(2deg); }
}

@keyframes dmg-fadeInUp {
  0% { opacity: 0; transform: translateY(20px); }
  100% { opacity: 1; transform: translateY(0); }
}

@keyframes dmg-shimmer {
  0% { left: -100%; }
  100% { left: 200%; }
}

@keyframes dmg-glowPulse {
  0%, 100% { box-shadow: 0 0 5px rgba(212,184,90,0.2); }
  50% { box-shadow: 0 0 15px rgba(212,184,90,0.5); }
}
