* { box-sizing: border-box; margin: 0; padding: 0; }
:root {
  --bg: #1a1a2e; --bg2: #16213e; --bg3: #0f3460;
  --fg: #e0e0e0; --fg2: #a0a0b0; --accent: #e94560;
  --accent2: #0f3460; --green: #4ecca3; --yellow: #f0c040;
  --border: #2a2a4a; --hover: #1a1a3e;
  --radius: 6px;
}
body { font-family: 'Segoe UI', system-ui, sans-serif; background: var(--bg); color: var(--fg); line-height: 1.5; }
a { color: var(--green); text-decoration: none; cursor: pointer; }
a:hover { text-decoration: underline; }

/* Layout */
.app { display: flex; min-height: 100vh; }
.sidebar { width: 200px; background: var(--bg2); border-right: 1px solid var(--border); padding: 16px 0; flex-shrink: 0; position: fixed; top: 0; left: 0; bottom: 0; overflow-y: auto; }
.sidebar h2 { padding: 0 16px 12px; font-size: 14px; color: var(--accent); text-transform: uppercase; letter-spacing: 1px; }
.sidebar a { display: block; padding: 8px 16px; color: var(--fg2); font-size: 14px; }
.sidebar a:hover, .sidebar a.active { background: var(--bg3); color: var(--fg); text-decoration: none; }
.main { margin-left: 200px; flex: 1; padding: 24px; min-width: 0; }
.page { display: none; }
.page.active { display: block; }
h1 { font-size: 22px; margin-bottom: 16px; color: var(--fg); }
h2 { font-size: 18px; margin: 16px 0 8px; color: var(--fg); }
h3 { font-size: 15px; margin: 12px 0 6px; color: var(--fg2); }

/* Controls */
input, select, button { font-family: inherit; font-size: 14px; }
input[type="text"], input[type="number"], select {
  background: var(--bg2); border: 1px solid var(--border); color: var(--fg);
  padding: 6px 10px; border-radius: var(--radius); outline: none;
}
input:focus, select:focus { border-color: var(--green); }
button {
  background: var(--bg3); border: 1px solid var(--border); color: var(--fg);
  padding: 6px 14px; border-radius: var(--radius); cursor: pointer;
}
button:hover { background: var(--accent2); border-color: var(--green); }
button.primary { background: var(--green); color: var(--bg); border-color: var(--green); font-weight: 600; }
button.primary:hover { opacity: 0.85; }
.search-bar { display: flex; gap: 8px; margin-bottom: 16px; align-items: center; }
.search-bar input { flex: 1; max-width: 400px; }

/* Tables */
table { width: 100%; border-collapse: collapse; margin: 8px 0 16px; }
th, td { padding: 6px 10px; text-align: left; border-bottom: 1px solid var(--border); font-size: 13px; }
th { background: var(--bg2); color: var(--fg2); font-weight: 600; position: sticky; top: 0; }
tr:hover { background: var(--hover); }
td.num { text-align: right; font-variant-numeric: tabular-nums; }

/* Cards */
.card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin-bottom: 16px; }
.card-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.card-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 12px; }
.stat-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 4px 16px; }
.stat-row { display: flex; justify-content: space-between; }
.stat-label { color: var(--fg2); }
.stat-value { font-weight: 600; }

/* Tags */
.tag { display: inline-block; padding: 2px 8px; border-radius: 12px; font-size: 12px; margin: 2px; }
.tag-slot { background: var(--bg3); color: var(--green); }
.tag-class { background: #2a1a3e; color: #c0a0e0; }
.tag-effect { background: #1a2e3e; color: #80c0e0; }

/* Detail panel */
.detail-panel { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px; margin-top: 12px; }

/* EQ2-style item examine — colors/fonts from EQ2U */
.eq2-item {
  background-color: #0d1014; border: 1px solid #d4a037; border-radius: 5px;
  padding: 12px; width: 328px;
  color: #c7cfc7; font: bold 13px 'Times New Roman', Times, serif; line-height: 17px; text-align: left;
}
.eq2-item h2 { color: white; font-size: 15px; margin-bottom: 12px; width: 250px; font-family: inherit; }
.eq2-item .eq2-green { color: #22ff22; }
.eq2-item .eq2-blue { color: #5ce6fe; }
.eq2-item .eq2-orange { color: #f5650f; }
.eq2-item .eq2-white { color: white; }
.eq2-item .eq2-stats { display: flex; flex-wrap: wrap; }
.eq2-item .eq2-stats > div { width: 145px; }
.eq2-item .eq2-spacer { height: 6px; }
.eq2-item .eq2-flags { color: #fee65c; font-size: 14px; font-weight: bold; margin-top: 12px; }
.eq2-item .eq2-effect-label { color: #e6e970; margin-top: 12px; margin-bottom: 2px; }
.eq2-item .eq2-effect-name { font-weight: bold; cursor: pointer; margin-bottom: 2px; }
.eq2-item .eq2-effect-desc { font-weight: normal; padding-left: 21px; text-indent: -8px; padding-top: 3px; }
.eq2-item .eq2-bullet { color: #fdf87c; }
.eq2-item .eq2-adorn-label { color: #e6e970; margin-top: 8px; margin-bottom: 2px; }
.eq2-item .eq2-adorn-white { color: white; }
.eq2-item .eq2-adorn-purple { color: purple; text-shadow: -1px 0 #c0a090, 0 1px #c0a090, 1px 0 #c0a090, 0 -1px #c0a090; }
.eq2-item .eq2-adorn-cyan { color: cyan; }
.eq2-item .eq2-adorn-green { color: #22ff22; }
.eq2-item .eq2-adorn-orange { color: orange; }
.eq2-item .eq2-adorn-yellow { color: yellow; }
.eq2-item .eq2-adorn-black { color: #999; }
/* Tier colors with glow — from EQ2U CSS */
.eq2-tier { font-size: 14px; font-weight: bold; margin-bottom: 2px; }
.eq2-tier-fabled { color: #ff939d; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #DF535F, 0 0 4px #DF535F; }
.eq2-tier-legendary { color: #ffc993; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #D56900, 0 0 4px #ffc993; }
.eq2-tier-mythical { color: #d99fe9; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #C859E6, 0 0 4px #C859E6; }
.eq2-tier-celestial { color: #22ff22; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #1cb91c, 0 0 4px #1cb91c; }
.eq2-tier-treasured { color: #93d9ff; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #D56900, 0 0 4px #93d9ff; }
.eq2-tier-mastercrafted { color: #92d7fd; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #D56900, 0 0 4px #92d7fd; }
.eq2-tier-ethereal { color: #ff8c00; text-shadow: -1px 0 #000, 0 1px #000, 1px 0 #000, 0 -1px #000, 0 0 4px #D56900, 0 0 4px #D56900; }
.eq2-tier-uncommon { color: #beff93; }
.eq2-item-wrapper { display: flex; gap: 16px; align-items: flex-start; }
.eq2-item-side { flex-shrink: 0; }
.detail-panel .close-btn { float: right; cursor: pointer; color: var(--fg2); font-size: 18px; }
.detail-panel .close-btn:hover { color: var(--accent); }

/* Equipment slots — 3 column layout */
.equip-columns { display: flex; gap: 16px; }
.equip-col { flex: 1; min-width: 0; }
.equip-col h3 { color: var(--fg2); font-size: 12px; text-transform: uppercase; margin-bottom: 6px; letter-spacing: 0.5px; }
.equip-slot { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 8px 10px; margin-bottom: 4px; }
.equip-slot .slot-label { color: var(--fg2); font-size: 11px; text-transform: uppercase; }
.equip-slot .item-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.equip-slot .item-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.equip-slot .score { font-weight: 600; color: var(--green); font-size: 12px; white-space: nowrap; }
.equip-slot button { font-size: 10px; padding: 2px 6px; }
/* Character page with side panel */
.char-layout { display: flex; gap: 16px; }
.char-main { flex: 1; min-width: 0; }
.char-side { width: 380px; flex-shrink: 0; position: sticky; top: 24px; max-height: calc(100vh - 48px); overflow-y: auto; }

/* Drag list */
.drag-list { list-style: none; }
.drag-item { display: flex; align-items: center; gap: 10px; padding: 8px 12px; margin: 2px 0; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); cursor: grab; }
.drag-item:active { cursor: grabbing; }
.drag-item .drag-handle { color: var(--fg2); cursor: grab; }
.drag-item .effect-name { flex: 1; }
.drag-item .mult-value { font-weight: 600; color: var(--yellow); min-width: 60px; text-align: right; }
.drag-item input[type="number"] { width: 80px; text-align: right; }
.drag-over { border-color: var(--green); background: var(--hover); }

/* Upgrade list */
.upgrade-list { margin-top: 8px; }
.upgrade-item { display: flex; justify-content: space-between; padding: 4px 0; font-size: 13px; }
.upgrade-delta { color: var(--green); font-weight: 600; }

/* Charts */
.chart-container { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 16px; margin-bottom: 16px; }
canvas { width: 100% !important; max-height: 300px; }

/* Loading */
.loading { color: var(--fg2); padding: 20px; text-align: center; }
.error { color: var(--accent); padding: 8px; }

/* Inventory config */
.config-form { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-top: 8px; }
.config-form label { color: var(--fg2); font-size: 13px; }
.config-form input[type="number"] { width: 70px; }

.filter-btn { padding: 4px 12px; font-size: 13px; background: var(--bg3); color: var(--fg2); border: 1px solid var(--border); border-radius: 4px; cursor: pointer; }
.filter-btn.on { background: var(--accent); color: #fff; border-color: var(--accent); }
.loot-panel-open .loot-extra { display: none; }
.tell-row { padding: 6px 10px; border-bottom: 1px solid var(--border); font-size: 13px; display: flex; gap: 10px; align-items: baseline; }
.tell-row.tell-outgoing { background: rgba(15, 52, 96, 0.3); }
.tell-row.tell-incoming { background: rgba(78, 204, 163, 0.08); }
.tell-from { font-weight: 600; min-width: 120px; flex-shrink: 0; }
.tell-outgoing .tell-from { color: #6ca0dc; }
.tell-incoming .tell-from { color: #4ecca3; }
.tell-arrow { color: var(--fg2); flex-shrink: 0; }
.tell-to { min-width: 120px; flex-shrink: 0; color: var(--fg2); }
.tell-msg { flex: 1; color: var(--fg); }
.tell-time { color: var(--fg2); font-size: 11px; flex-shrink: 0; white-space: nowrap; }

/* Lockouts */
.lockout-chars { width: 220px; flex-shrink: 0; }
.lockout-detail { flex: 1; min-width: 0; }
.lockout-char-btn { display: block; width: 100%; text-align: left; padding: 8px 12px; margin-bottom: 2px; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); cursor: pointer; color: var(--fg); font-size: 13px; }
.lockout-char-btn:hover { background: var(--bg3); border-color: var(--green); }
.lockout-char-btn.active { background: var(--bg3); border-color: var(--green); color: var(--green); }
.lockout-char-btn .char-sub { color: var(--fg2); font-size: 11px; }
.lockout-char-btn .lockout-count { float: right; color: var(--fg2); font-size: 12px; }
.lockout-row { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; border-bottom: 1px solid var(--border); font-size: 13px; }
.lockout-row:hover { background: var(--hover); }
.lockout-zone { flex: 1; }
.lockout-timer { font-weight: 600; white-space: nowrap; margin-left: 12px; }
.lockout-timer.active { color: var(--accent); }
.lockout-timer.resettable { color: var(--yellow); }
.lockout-timer.expired { color: var(--fg2); }
.lockout-expac { color: var(--fg2); font-size: 11px; margin-left: 12px; white-space: nowrap; }
.lockout-section-label { padding: 6px 12px; font-size: 11px; text-transform: uppercase; letter-spacing: 0.5px; color: var(--fg2); background: var(--bg2); border-bottom: 1px solid var(--border); font-weight: 600; }

/* Responsive */
@media (max-width: 900px) {
  .sidebar { width: 160px; }
  .main { margin-left: 160px; }
}
