/* ATM10 Tracker — styled after SB4 Tracker */
:root {
  color-scheme: dark;
  --bg: #0a0c10;
  --panel: rgba(18, 22, 30, 0.97);
  --panel-border: rgba(100, 120, 160, 0.30);
  --cell: rgba(22, 27, 36, 0.95);
  --cell-alt: rgba(28, 34, 44, 0.95);
  --header-bg: rgba(34, 40, 54, 0.98);
  --text: #d8e4f0;
  --muted: #7a90a8;
  --accent: #5a9adf;
  --accent-strong: #8ec4ff;
  --shadow: rgba(0,0,0,0.60);
  --danger: #d97777;
  --row-border: rgba(70, 90, 120, 0.22);
  --detail-bg: rgba(12, 16, 24, 0.98);
  --body-grad-a: rgba(40, 90, 160, 0.09);
  --body-grad-top: #0d1018;
  --body-grad-bot: #060708;

  /* aliases used by extras / tab-nav */
  --bg:        #0a0c10;
  --fg:        #d8e4f0;
  --surface:   rgba(18, 22, 30, 0.97);
  --surface-hi:rgba(34, 40, 54, 0.98);
  --border:    rgba(100, 120, 160, 0.30);

  /* category badge colors */
  --cat-nest:       #7ee87e; --cat-nest-bg:       rgba(50,160,50,0.15); --cat-nest-border:       rgba(80,200,80,0.38);
  --cat-breeding:   #e8c87e; --cat-breeding-bg:   rgba(160,120,30,0.15); --cat-breeding-border:   rgba(200,160,40,0.38);
  --cat-conversion: #7ec8e8; --cat-conversion-bg: rgba(30,120,160,0.15); --cat-conversion-border: rgba(50,160,200,0.38);
  --cat-eggrecipe:  #d07ee8; --cat-eggrecipe-bg:  rgba(130,40,180,0.15); --cat-eggrecipe-border:  rgba(170,70,220,0.38);
  --cat-fishing:    #7ee8c8; --cat-fishing-bg:    rgba(30,160,120,0.15); --cat-fishing-border:    rgba(50,200,160,0.38);
  --cat-misc:       #e87e7e; --cat-misc-bg:       rgba(160,40,40,0.15);  --cat-misc-border:       rgba(200,70,70,0.38);
}

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

body {
  font-family: "Segoe UI", system-ui, sans-serif;
  font-size: 0.88rem;
  color: var(--text);
  background:
    radial-gradient(ellipse at top, var(--body-grad-a) 0%, transparent 55%),
    linear-gradient(180deg, var(--body-grad-top) 0%, var(--body-grad-bot) 100%);
  min-height: 100vh;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.08;
  background:
    linear-gradient(45deg,  rgba(255,255,255,.04) 25%, transparent 25%),
    linear-gradient(-45deg, rgba(255,255,255,.04) 25%, transparent 25%),
    linear-gradient(45deg,  transparent 75%, rgba(255,255,255,.04) 75%),
    linear-gradient(-45deg, transparent 75%, rgba(255,255,255,.04) 75%);
  background-size: 24px 24px;
  background-position: 0 0, 0 12px, 12px -12px, -12px 0;
}

.app-shell {
  position: relative;
  z-index: 1;
  max-width: 1600px;
  margin: 0 auto;
  padding: 12px 14px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* ── header / footer ── */
.app-header, .app-footer {
  background: var(--panel);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  box-shadow: 0 6px 22px var(--shadow);
  padding: 8px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.brand { display: flex; align-items: baseline; gap: 8px; white-space: nowrap; }
.eyebrow { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent-strong); }
h1 { font-size: 1.15rem; font-weight: 700; }

.toolbar { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; margin-left: auto; }
.app-footer .toolbar { margin-left: 0; }

/* ── buttons ── */
button {
  appearance: none;
  border: 1px solid rgba(90,154,223,0.38);
  background: linear-gradient(180deg, rgba(40,80,140,0.22), rgba(20,40,80,0.34));
  color: var(--text);
  border-radius: 7px;
  padding: 5px 11px;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .12s, background .12s, transform .1s;
  white-space: nowrap;
}
button:hover { border-color: rgba(142,196,255,0.65); background: linear-gradient(180deg, rgba(60,110,190,0.32), rgba(30,60,110,0.44)); transform: translateY(-1px); }
button:active { transform: translateY(0); }
button.btn-danger { border-color: rgba(200,100,100,0.38); background: linear-gradient(180deg, rgba(110,44,44,0.22), rgba(72,28,28,0.34)); }
button.btn-danger:hover { border-color: rgba(220,120,120,0.6); background: linear-gradient(180deg, rgba(130,54,54,0.34), rgba(88,36,36,0.44)); }

.status-pill {
  display: inline-flex; align-items: center; padding: 4px 11px;
  border-radius: 999px; border: 1px solid rgba(90,154,223,0.26);
  background: rgba(20,40,80,0.3); color: var(--accent-strong);
  font-size: 0.8rem; font-weight: 600; white-space: nowrap;
}
.status-pill.error { color: var(--danger); border-color: rgba(210,100,100,0.32); background: rgba(72,26,26,0.28); }

/* ── Tab bar ── */
.tab-bar {
  display: flex;
  gap: 4px;
  padding: 0 4px;
}

.tab-btn {
  padding: 8px 22px;
  font-size: 0.88rem;
  font-weight: 700;
  border-radius: 10px 10px 0 0;
  border: 1px solid rgba(90,120,160,0.28);
  background: rgba(10,13,18,0.7);
  color: var(--muted);
  cursor: pointer;
  transition: color .12s, border-color .12s, background .12s;
}
.tab-btn:hover { color: var(--text); border-color: rgba(90,154,223,0.4); transform: none; }
.tab-btn.active {
  color: var(--accent-strong);
  border-color: rgba(100,165,235,0.55);
  background: var(--panel);
  border-bottom-color: var(--panel);
  position: relative;
  z-index: 2;
}

/* ── Tab panels ── */
.tab-panel { display: contents; }
.tab-panel.hidden { display: none; }

/* ── search ── */
.search-input {
  background: rgba(8,11,18,0.9);
  border: 1px solid rgba(90,110,140,0.38);
  color: var(--text);
  border-radius: 7px;
  padding: 5px 11px;
  font-size: 0.84rem;
  font-family: inherit;
  min-width: 200px;
}
.search-input:focus { outline: 2px solid rgba(90,154,223,0.4); border-color: rgba(90,154,223,0.55); }
.search-input::placeholder { color: var(--muted); }

/* ── filter bar ── */
.filter-bar {
  background: var(--panel);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  box-shadow: 0 4px 14px var(--shadow);
  padding: 10px 14px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
}

.filter-group { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.filter-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--muted); white-space: nowrap; }
.filter-btns { display: flex; flex-wrap: wrap; gap: 4px; }

.filter-btn {
  padding: 3px 9px;
  font-size: 0.78rem;
  font-weight: 600;
  border-radius: 5px;
  border: 1px solid rgba(80,100,130,0.28);
  background: rgba(10,13,18,0.7);
  color: var(--muted);
  cursor: pointer;
  transition: all .12s;
}
.filter-btn:hover { color: var(--text); border-color: rgba(90,154,223,0.4); transform: none; }
.filter-btn.active { color: var(--accent-strong); border-color: rgba(100,165,235,0.55); background: rgba(20,50,100,0.4); }

/* category filter buttons colored when active */
.filter-btn[data-cat="nest"].active       { color: var(--cat-nest);       border-color: var(--cat-nest-border);       background: var(--cat-nest-bg); }
.filter-btn[data-cat="breeding"].active   { color: var(--cat-breeding);   border-color: var(--cat-breeding-border);   background: var(--cat-breeding-bg); }
.filter-btn[data-cat="conversion"].active { color: var(--cat-conversion); border-color: var(--cat-conversion-border); background: var(--cat-conversion-bg); }
.filter-btn[data-cat="eggRecipe"].active  { color: var(--cat-eggrecipe);  border-color: var(--cat-eggrecipe-border);  background: var(--cat-eggrecipe-bg); }
.filter-btn[data-cat="fishing"].active    { color: var(--cat-fishing);    border-color: var(--cat-fishing-border);    background: var(--cat-fishing-bg); }
.filter-btn[data-cat="misc"].active       { color: var(--cat-misc);       border-color: var(--cat-misc-border);       background: var(--cat-misc-bg); }

.summary-bar { margin-left: auto; }
.summary-text { font-size: 0.8rem; color: var(--muted); font-weight: 500; }

/* ── table panel ── */
.table-panel {
  background: var(--panel);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  box-shadow: 0 6px 22px var(--shadow);
  overflow: hidden;
}
.table-scroll { overflow-x: auto; }

table {
  width: 100%;
  min-width: 560px;
  border-collapse: collapse;
}

/* ── thead ── */
thead th {
  position: sticky;
  top: 0;
  z-index: 3;
  background: var(--header-bg);
  color: var(--accent-strong);
  font-size: 0.73rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  padding: 8px 10px;
  border-bottom: 1px solid rgba(90,120,160,0.4);
  text-align: center;
  white-space: nowrap;
}
.col-name { text-align: left; min-width: 200px; }
.col-cat  { min-width: 140px; }
.col-check { min-width: 80px; }
.col-count { min-width: 72px; }

/* ── category group headers ── */
.cat-group-header td {
  padding: 0;
  border: none;
  border-top: 2px solid rgba(70,90,130,0.3);
}

.cat-header-inner {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  cursor: pointer;
  user-select: none;
  transition: background .12s;
}
.cat-header-inner:hover { background: rgba(255,255,255,0.03); }

.cat-chevron { font-size: 0.7rem; color: var(--muted); width: 12px; flex-shrink: 0; transition: transform .15s; }
.cat-group-header.collapsed .cat-chevron { transform: rotate(-90deg); }

.cat-label { font-weight: 700; font-size: 0.9rem; }
.cat-stats { margin-left: auto; font-size: 0.78rem; color: var(--muted); font-weight: 500; }

/* ── progress bar ── */
.cat-progress-bar { display: flex; align-items: center; gap: 6px; }
.cat-progress-track {
  width: 80px; height: 5px;
  background: rgba(255,255,255,0.07);
  border-radius: 999px; overflow: hidden;
}
.cat-progress-fill {
  height: 100%;
  border-radius: 999px;
  background: var(--accent);
  transition: width .3s;
}

/* ── category badge ── */
.cat-badge {
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 0.72rem; font-weight: 800; letter-spacing: 0.04em;
  padding: 2px 7px; border-radius: 5px; border: 1px solid;
  white-space: nowrap;
}
.cat-badge[data-cat="nest"]       { color: var(--cat-nest);       background: var(--cat-nest-bg);       border-color: var(--cat-nest-border); }
.cat-badge[data-cat="breeding"]   { color: var(--cat-breeding);   background: var(--cat-breeding-bg);   border-color: var(--cat-breeding-border); }
.cat-badge[data-cat="conversion"] { color: var(--cat-conversion); background: var(--cat-conversion-bg); border-color: var(--cat-conversion-border); }
.cat-badge[data-cat="eggRecipe"]  { color: var(--cat-eggrecipe);  background: var(--cat-eggrecipe-bg);  border-color: var(--cat-eggrecipe-border); }
.cat-badge[data-cat="fishing"]    { color: var(--cat-fishing);    background: var(--cat-fishing-bg);    border-color: var(--cat-fishing-border); }
.cat-badge[data-cat="misc"]       { color: var(--cat-misc);       background: var(--cat-misc-bg);       border-color: var(--cat-misc-border); }

/* ── bee rows ── */
.bee-row td {
  border-bottom: 1px solid var(--row-border);
  padding: 6px 10px;
  background: var(--cell);
  text-align: center;
  vertical-align: middle;
}
.bee-row:nth-child(even) td { background: var(--cell-alt); }
.bee-row.expanded td { background: rgba(20,34,54,0.6); }
.bee-row td:first-child { text-align: left; }

/* ── bee icon ── */
.bee-icon { width: 32px; height: 32px; object-fit: contain; vertical-align: middle; }
.bee-icon-placeholder { font-size: 1.2rem; line-height: 1; }

/* ── name button ── */
.name-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 600;
  padding: 2px 4px;
  border-radius: 5px;
  cursor: pointer;
  transition: color .12s, background .12s;
  text-align: left;
}
.name-btn:hover { color: var(--accent-strong); background: rgba(60,120,200,0.1); transform: none; }

.expand-arrow { font-size: 0.6rem; color: var(--muted); flex-shrink: 0; transition: transform .15s; width: 10px; }
.bee-row.expanded .expand-arrow { transform: rotate(90deg); color: var(--accent); }

/* ── checkboxes ── */
.check-cell { text-align: center !important; }
input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--accent); cursor: pointer; }

/* ── count input ── */
input[type="number"].count-input {
  width: 56px;
  padding: 3px 6px;
  text-align: center;
  background: rgba(8,12,20,0.8);
  border: 1px solid rgba(80,110,150,0.38);
  border-radius: 5px;
  color: var(--text);
  font-size: 0.84rem;
  font-family: inherit;
}

/* ── detail rows ── */
.detail-row td {
  background: var(--detail-bg) !important;
  padding: 0;
  border-bottom: 1px solid rgba(60,100,160,0.2);
}

.detail-inner {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 10px;
  padding: 10px 40px;
  border-left: 3px solid rgba(90,154,223,0.4);
}

.detail-label { font-size: 0.78rem; font-weight: 700; color: var(--accent-strong); white-space: nowrap; padding-top: 2px; }
.detail-text  { font-size: 0.86rem; color: var(--text); line-height: 1.5; white-space: pre-wrap; }
.detail-img   { margin-top: 6px; max-width: 220px; max-height: 130px; border-radius: 6px; object-fit: contain; border: 1px solid var(--panel-border); }

/* ── empty row ── */
.empty-row td {
  text-align: center;
  color: var(--muted);
  padding: 32px 16px;
  font-size: 0.9rem;
  background: var(--cell);
}

/* ── toggle-all ── */
.toggle-all-btn { min-width: 110px; }

@media (max-width: 700px) {
  .toolbar { margin-left: 0; }
  .filter-bar { gap: 8px; }
  .detail-inner { padding: 8px 16px; }
}

/* ══════════════════════════════════════════════════════════════════════
   THEME OVERRIDES  (data-theme on <html>)
   ══════════════════════════════════════════════════════════════════════ */

/* ── Default = ATM10 (steel blue) — same as :root, explicit for completeness */
[data-theme="atm10"] {
  --bg: #0a0c10;
  --panel: rgba(18, 22, 30, 0.97);
  --panel-border: rgba(100, 120, 160, 0.30);
  --cell: rgba(22, 27, 36, 0.95);
  --cell-alt: rgba(28, 34, 44, 0.95);
  --header-bg: rgba(34, 40, 54, 0.98);
  --text: #d8e4f0;
  --muted: #7a90a8;
  --accent: #5a9adf;
  --accent-strong: #8ec4ff;
  --shadow: rgba(0,0,0,0.60);
  --danger: #d97777;
  --row-border: rgba(70, 90, 120, 0.22);
  --detail-bg: rgba(12, 16, 24, 0.98);
  --body-grad-a: rgba(40, 90, 160, 0.09);
  --body-grad-top: #0d1018;
  --body-grad-bot: #060708;
  --surface: rgba(18, 22, 30, 0.97);
  --surface-hi: rgba(34, 40, 54, 0.98);
  --border: rgba(100, 120, 160, 0.30);
  --fg: #d8e4f0;
}

/* ── Bee — honey amber / wax gold */
[data-theme="bee"] {
  --bg: #100c02;
  --panel: rgba(28, 20, 4, 0.97);
  --panel-border: rgba(200, 150, 20, 0.32);
  --cell: rgba(32, 24, 6, 0.95);
  --cell-alt: rgba(40, 30, 8, 0.95);
  --header-bg: rgba(58, 40, 8, 0.98);
  --text: #f8e8b0;
  --muted: #a08840;
  --accent: #d4960c;
  --accent-strong: #ffc020;
  --shadow: rgba(0,0,0,0.65);
  --danger: #e06060;
  --row-border: rgba(200, 150, 20, 0.2);
  --detail-bg: rgba(14, 10, 2, 0.98);
  --body-grad-a: rgba(210, 150, 10, 0.10);
  --body-grad-top: #140e03;
  --body-grad-bot: #080500;
  --surface: rgba(28, 20, 4, 0.97);
  --surface-hi: rgba(58, 40, 8, 0.98);
  --border: rgba(200, 150, 20, 0.32);
  --fg: #f8e8b0;
}

/* ── Overworld — forest / grass */
[data-theme="overworld"] {
  --bg: #081408;
  --panel: rgba(12, 22, 12, 0.97);
  --panel-border: rgba(55, 125, 40, 0.32);
  --cell: rgba(14, 26, 14, 0.95);
  --cell-alt: rgba(18, 32, 18, 0.95);
  --header-bg: rgba(24, 46, 20, 0.98);
  --text: #d8f0cc;
  --muted: #6e9060;
  --accent: #50a028;
  --accent-strong: #78c845;
  --shadow: rgba(0,0,0,0.50);
  --danger: #d97777;
  --row-border: rgba(55, 125, 40, 0.22);
  --detail-bg: rgba(9, 18, 9, 0.98);
  --body-grad-a: rgba(40, 130, 20, 0.10);
  --body-grad-top: #0c1a08;
  --body-grad-bot: #040a03;
  --surface: rgba(12, 22, 12, 0.97);
  --surface-hi: rgba(24, 46, 20, 0.98);
  --border: rgba(55, 125, 40, 0.32);
  --fg: #d8f0cc;
}

/* ── Nether — fiery crimson */
[data-theme="nether"] {
  --bg: #120405;
  --panel: rgba(26, 8, 8, 0.97);
  --panel-border: rgba(190, 60, 28, 0.36);
  --cell: rgba(30, 10, 10, 0.95);
  --cell-alt: rgba(40, 14, 12, 0.95);
  --header-bg: rgba(58, 16, 12, 0.98);
  --text: #f0d5c0;
  --muted: #a06858;
  --accent: #d05820;
  --accent-strong: #ff7030;
  --shadow: rgba(0,0,0,0.65);
  --danger: #ff5555;
  --row-border: rgba(190, 60, 28, 0.20);
  --detail-bg: rgba(16, 5, 5, 0.98);
  --body-grad-a: rgba(200, 48, 8, 0.10);
  --body-grad-top: #160507;
  --body-grad-bot: #080203;
  --surface: rgba(26, 8, 8, 0.97);
  --surface-hi: rgba(58, 16, 12, 0.98);
  --border: rgba(190, 60, 28, 0.36);
  --fg: #f0d5c0;
}

/* ── The End — void purple */
[data-theme="the-end"] {
  --bg: #07060e;
  --panel: rgba(12, 10, 26, 0.97);
  --panel-border: rgba(130, 60, 210, 0.30);
  --cell: rgba(14, 12, 30, 0.95);
  --cell-alt: rgba(18, 16, 38, 0.95);
  --header-bg: rgba(28, 20, 56, 0.98);
  --text: #e8d8ff;
  --muted: #8878a8;
  --accent: #8855d8;
  --accent-strong: #b888ff;
  --shadow: rgba(0,0,0,0.65);
  --danger: #e06060;
  --row-border: rgba(110, 50, 190, 0.20);
  --detail-bg: rgba(9, 8, 18, 0.98);
  --body-grad-a: rgba(100, 50, 200, 0.08);
  --body-grad-top: #090711;
  --body-grad-bot: #030205;
  --surface: rgba(12, 10, 26, 0.97);
  --surface-hi: rgba(28, 20, 56, 0.98);
  --border: rgba(130, 60, 210, 0.30);
  --fg: #e8d8ff;
}

/* ── Deep Dark — sculk / ancient city */
[data-theme="deep-dark"] {
  --bg: #02080c;
  --panel: rgba(5, 14, 20, 0.97);
  --panel-border: rgba(0, 150, 170, 0.28);
  --cell: rgba(6, 16, 24, 0.95);
  --cell-alt: rgba(8, 20, 30, 0.95);
  --header-bg: rgba(10, 28, 40, 0.98);
  --text: #c0eaf0;
  --muted: #507880;
  --accent: #00aabf;
  --accent-strong: #00d8ee;
  --shadow: rgba(0,0,0,0.70);
  --danger: #e06060;
  --row-border: rgba(0, 130, 150, 0.20);
  --detail-bg: rgba(3, 10, 15, 0.98);
  --body-grad-a: rgba(0, 160, 190, 0.07);
  --body-grad-top: #030c12;
  --body-grad-bot: #010508;
  --surface: rgba(5, 14, 20, 0.97);
  --surface-hi: rgba(10, 28, 40, 0.98);
  --border: rgba(0, 150, 170, 0.28);
  --fg: #c0eaf0;
}

/* ── Theme picker widget ── */
.theme-picker {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 0.82rem;
  white-space: nowrap;
  color: var(--muted);
}
.theme-select {
  background: var(--panel);
  color: var(--text);
  border: 1px solid var(--panel-border);
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 0.82rem;
  cursor: pointer;
  transition: border-color .12s;
}
.theme-select:hover { border-color: var(--accent); }
.theme-select:focus { outline: none; border-color: var(--accent-strong); }

/* Make buttons & accent elements adopt the active theme's accent color */
button {
  border-color: color-mix(in srgb, var(--accent) 55%, transparent);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--accent) 22%, transparent),
    color-mix(in srgb, var(--accent) 12%, transparent));
}
button:hover {
  border-color: color-mix(in srgb, var(--accent-strong) 70%, transparent);
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--accent) 34%, transparent),
    color-mix(in srgb, var(--accent) 20%, transparent));
}
.tab-btn.active { color: var(--accent); }
.status-pill { color: var(--accent-strong); border-color: color-mix(in srgb, var(--accent) 35%, transparent); background: color-mix(in srgb, var(--accent) 12%, transparent); }
.cat-progress-fill { background: var(--accent) !important; }
.filter-btn.active {
  background: color-mix(in srgb, var(--accent) 22%, transparent) !important;
  border-color: color-mix(in srgb, var(--accent) 65%, transparent) !important;
  color: var(--accent-strong) !important;
}

