:root {
  --bg: #0e1014;
  --panel: #171a21;
  --panel-2: #1e222b;
  --line: #2a2f3a;
  --txt: #e6e9ef;
  --dim: #9aa3b2;
  --accent: #7cc0ff;
  --accent-2: #b48cff;
  --good: #6ddf9c;
  --warn: #ffce6b;
  --bad: #ff8a8a;
  --tap: 44px;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body {
  margin: 0;
  background: var(--bg);
  color: var(--txt);
  font: 16px/1.45 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
}

body { padding-bottom: env(safe-area-inset-bottom); }

/* ---- Top bar ---- */
.topbar {
  position: sticky; top: 0; z-index: 20;
  background: linear-gradient(180deg, #14171e, #101319);
  border-bottom: 1px solid var(--line);
  padding: 10px 14px calc(10px + env(safe-area-inset-top));
  padding-top: max(10px, env(safe-area-inset-top));
}
.title { display: flex; align-items: center; gap: 10px; }
.title .ghost { font-size: 28px; filter: drop-shadow(0 0 6px rgba(124,192,255,.4)); }
.title p { margin: 0; font-size: 12px; color: var(--dim); }
.who { display: flex; flex-direction: column; gap: 1px; min-width: 0; }
#charsel {
  appearance: none; -webkit-appearance: none;
  background: transparent url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%237cc0ff' d='M0 0l5 6 5-6z'/%3E%3C/svg%3E") no-repeat right center;
  border: 0; color: var(--txt); font-size: 20px; font-weight: 700; letter-spacing: .5px;
  padding: 0 18px 0 0; margin: 0; cursor: pointer; max-width: 70vw;
  font-family: inherit; outline: none;
}
#charsel:focus-visible { outline: 2px solid var(--accent); border-radius: 4px; }
#charsel option { background: var(--panel); color: var(--txt); font-size: 16px; }

.statline {
  display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px;
}
.statline .chip {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 999px;
  padding: 3px 9px; font-size: 12px; color: var(--dim);
}
.statline .chip b { color: var(--txt); font-weight: 700; }

/* ---- Search ---- */
.searchwrap {
  position: sticky; top: 0; z-index: 19;
  padding: 10px 14px; background: var(--bg);
  display: flex; gap: 8px; align-items: center;
}
#search {
  flex: 1; height: var(--tap); border-radius: 12px;
  border: 1px solid var(--line); background: var(--panel);
  color: var(--txt); padding: 0 14px; font-size: 16px; outline: none;
}
#search:focus { border-color: var(--accent); }
.clear {
  height: var(--tap); width: var(--tap); border-radius: 12px;
  border: 1px solid var(--line); background: var(--panel); color: var(--dim);
  font-size: 16px;
}

/* ---- Tabs ---- */
.tabs {
  display: flex; gap: 6px; padding: 0 14px 8px; overflow-x: auto;
}
.tabs button {
  flex: 1; min-width: max-content; height: 38px; padding: 0 14px;
  border-radius: 10px; border: 1px solid var(--line);
  background: var(--panel); color: var(--dim); font-size: 14px; font-weight: 600;
}
.tabs button.active {
  background: linear-gradient(180deg, #243049, #1b2436);
  color: var(--txt); border-color: var(--accent);
}

/* ---- Lists ---- */
main { padding: 4px 12px 40px; }

.collegehead {
  margin: 16px 4px 6px; font-size: 12px; letter-spacing: 1px;
  text-transform: uppercase; color: var(--accent-2); font-weight: 700;
}

.entry {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; margin: 8px 0; overflow: hidden;
}
.entry > summary {
  list-style: none; cursor: pointer; padding: 12px 14px;
  display: flex; align-items: center; gap: 10px;
}
.entry > summary::-webkit-details-marker { display: none; }
.entry .nm { flex: 1; font-weight: 600; }
.entry .nm small { display: block; color: var(--dim); font-weight: 400; font-size: 12px; margin-top: 2px; }

.lvl {
  flex: none; text-align: center; min-width: 42px;
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 9px;
  padding: 4px 6px;
}
.lvl b { display: block; font-size: 17px; line-height: 1; color: var(--accent); }
.lvl span { font-size: 9px; color: var(--dim); text-transform: uppercase; letter-spacing: .5px; }

.cost {
  flex: none; font-size: 12px; color: var(--warn);
  border: 1px solid var(--line); border-radius: 8px; padding: 3px 7px; background: var(--panel-2);
}
.cost.free { color: var(--good); border-color: var(--good); }

.note {
  margin: 8px 4px 4px; padding: 8px 11px; font-size: 12px; line-height: 1.4;
  color: var(--dim); background: var(--panel); border: 1px solid var(--line);
  border-left: 3px solid var(--warn); border-radius: 8px;
}
.note b { color: var(--txt); }

.entry .body { padding: 0 14px 14px; border-top: 1px solid var(--line); }
.entry .body p { margin: 10px 0; }
.entry .body .desc { color: var(--txt); }

.kv { display: grid; grid-template-columns: auto 1fr; gap: 4px 12px; margin: 10px 0; font-size: 14px; }
.kv dt { color: var(--dim); }
.kv dd { margin: 0; }

.tag {
  display: inline-block; font-size: 11px; padding: 2px 7px; border-radius: 6px;
  background: var(--panel-2); border: 1px solid var(--line); color: var(--dim); margin-right: 6px;
}
.flag-low { color: var(--bad); border-color: var(--bad); }
.flag-med { color: var(--warn); border-color: var(--warn); }
.page { color: var(--dim); font-size: 12px; }

.empty { text-align: center; color: var(--dim); padding: 40px 20px; }

/* ---- Combat / attributes grid ---- */
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(86px, 1fr)); gap: 8px; margin: 8px 0 16px; }
.cell { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 10px; text-align: center; }
.cell b { display: block; font-size: 22px; color: var(--accent); }
.cell span { font-size: 11px; color: var(--dim); text-transform: uppercase; letter-spacing: .5px; }

table.atk { width: 100%; border-collapse: collapse; margin: 8px 0 18px; font-size: 14px; }
table.atk th, table.atk td { text-align: left; padding: 8px 6px; border-bottom: 1px solid var(--line); }
table.atk th { color: var(--dim); font-weight: 600; font-size: 12px; text-transform: uppercase; }

.foot { text-align: center; color: var(--dim); font-size: 11px; padding: 20px 16px 30px; line-height: 1.6; }

mark { background: rgba(124,192,255,.28); color: inherit; border-radius: 3px; }
