* { box-sizing: border-box; }
:root {
  --bg: #090111;
  --bg2: #260747;
  --panel: rgba(27, 8, 46, 0.84);
  --panel2: rgba(44, 13, 75, 0.74);
  --stroke: rgba(212, 140, 255, 0.28);
  --purple: #a653ff;
  --purple-hot: #d48cff;
  --gold: #ffb000;
  --text: #fbf7ff;
  --muted: #dfc9f4;
  --bad: #ff6b7a;
  --good: #9dffbf;
}
body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 15% 6%, rgba(212, 140, 255, 0.34), transparent 25%),
    radial-gradient(circle at 82% 12%, rgba(255, 176, 0, 0.12), transparent 22%),
    linear-gradient(135deg, var(--bg) 0%, var(--bg2) 54%, #120021 100%);
  min-height: 100vh;
}
.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 14px 22px;
  background: rgba(9, 1, 17, 0.80);
  border-bottom: 1px solid var(--stroke);
  backdrop-filter: blur(12px);
}
.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--text);
  text-decoration: none;
}
.brand img { width: 52px; height: 52px; object-fit: contain; }
.brand strong { display: block; font-size: 1.08rem; }
.brand small { color: var(--gold); text-transform: uppercase; letter-spacing: 0.16em; font-weight: 800; }
.topbar nav { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 8px; }
.topbar button, .topbar a, .submit, .admin-key-row button {
  border: 1px solid var(--stroke);
  border-radius: 999px;
  padding: 10px 14px;
  background: rgba(255,255,255,0.06);
  color: var(--text);
  text-decoration: none;
  font-weight: 800;
  cursor: pointer;
}
.topbar button.active, .topbar button:hover, .topbar a:hover, .submit:hover, .admin-key-row button:hover {
  border-color: rgba(255,176,0,0.75);
  box-shadow: 0 0 18px rgba(166,83,255,0.28);
}
main { width: min(1180px, calc(100% - 32px)); margin: 0 auto; padding: 38px 0 60px; }
.tab { display: none; }
.tab.active { display: block; }
.hero { text-align: center; margin: 22px auto 36px; }
.eyebrow { margin: 0 0 10px; color: var(--purple-hot); text-transform: uppercase; letter-spacing: 0.28em; font-weight: 900; }
h1 { margin: 0; font-size: clamp(2.5rem, 6vw, 5.6rem); line-height: .94; letter-spacing: -0.055em; text-shadow: 0 0 38px rgba(166,83,255,.35); }
h2 { margin: 0 0 18px; font-size: 1.2rem; }
.hero p:not(.eyebrow), .section-head p { color: var(--muted); font-size: 1.1rem; }
.cards { display: grid; grid-template-columns: repeat(4, minmax(140px, 1fr)); gap: 16px; margin-bottom: 20px; }
.card, .panel, .form-panel, .char-card {
  background: var(--panel);
  border: 1px solid var(--stroke);
  border-radius: 24px;
  box-shadow: 0 22px 60px rgba(0,0,0,.35);
}
.card { padding: 20px; }
.card span { display: block; color: var(--muted); font-size: .88rem; text-transform: uppercase; letter-spacing: .12em; font-weight: 800; }
.card strong { display: block; margin-top: 6px; font-size: 2.4rem; color: var(--gold); }
.panel-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.panel { padding: 22px; }
.panel.wide { grid-column: 1 / -1; }
.bar-row { display: grid; grid-template-columns: 170px 1fr 42px; align-items: center; gap: 10px; margin: 10px 0; }
.bar-label { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--muted); }
.bar-track { height: 12px; border-radius: 999px; background: rgba(255,255,255,.08); overflow: hidden; }
.bar-fill { height: 100%; background: linear-gradient(90deg, var(--purple), var(--gold)); border-radius: 999px; }
.skill-cloud { display: flex; flex-wrap: wrap; gap: 10px; }
.skill-pill { padding: 8px 10px; border: 1px solid var(--stroke); background: rgba(255,255,255,.055); border-radius: 999px; color: var(--muted); }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 18px; margin-bottom: 24px; }
.section-head h1 { font-size: clamp(2.2rem, 5vw, 4.6rem); }
input, select, textarea {
  width: 100%;
  border: 1px solid var(--stroke);
  border-radius: 14px;
  padding: 12px;
  color: var(--text);
  background: rgba(10, 2, 18, 0.72);
  outline: none;
}
input:focus, select:focus, textarea:focus { border-color: var(--purple-hot); }
#rosterSearch { max-width: 420px; }
.roster { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.char-card { padding: 20px; }
.char-card header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.char-card h3 { margin: 0; font-size: 1.35rem; }
.char-card .discord { color: var(--muted); }
.badge { display: inline-block; padding: 6px 9px; border-radius: 999px; color: var(--gold); border: 1px solid rgba(255,176,0,.42); font-size: .78rem; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.detail-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; color: var(--muted); }
.detail-grid strong { display:block; color: var(--text); }
.skill-list { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.skill-list span { padding: 6px 9px; border-radius: 999px; background: rgba(255,255,255,.07); color: var(--muted); font-size: .86rem; }
.form-panel { padding: 22px; }
.form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
label { color: var(--muted); font-weight: 800; }
label input, label select, label textarea { margin-top: 8px; }
.full { display: block; margin-top: 16px; }
.points-box { display:flex; justify-content: space-between; align-items:center; gap: 16px; margin: 20px 0; padding: 14px; border-radius: 16px; background: rgba(255,255,255,.06); border: 1px solid var(--stroke); }
.points-box strong { color: var(--gold); }
.skills { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.skill-group { padding: 16px; border: 1px solid var(--stroke); border-radius: 18px; background: var(--panel2); }
.skill-group h3 { margin: 0 0 12px; }
.skill-choice { display:flex; align-items:center; justify-content: space-between; gap: 12px; padding: 8px 0; color: var(--muted); }
.skill-choice input { width: auto; margin: 0; }
.errors { color: var(--bad); margin: 14px 0; font-weight: 800; }
.submit { margin-top: 18px; color: var(--gold); }
.admin-key-row { display: flex; gap: 10px; margin-bottom: 20px; }
.admin-key-row input { max-width: 360px; }
.toast { position: fixed; right: 22px; bottom: 22px; padding: 14px 16px; border-radius: 16px; background: var(--panel); border: 1px solid var(--stroke); box-shadow: 0 18px 44px rgba(0,0,0,.35); }
@media (max-width: 920px) {
  .topbar { align-items: flex-start; flex-direction: column; }
  .cards, .panel-grid, .roster, .form-grid, .skills { grid-template-columns: 1fr; }
  .panel.wide { grid-column: auto; }
  .section-head { display: block; }
  #rosterSearch { max-width: none; margin-top: 12px; }
}


.admin-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.submit.danger {
  color: var(--bad);
  border-color: rgba(255, 107, 138, 0.72);
}
.submit.danger:hover {
  box-shadow: 0 0 18px rgba(255, 107, 138, 0.28);
}
#logoutAccess {
  color: var(--gold);
}


/* Hierarchy */
.hierarchy-root { display: grid; gap: 24px; }
.command-tree { display: grid; justify-items: center; gap: 12px; margin-bottom: 8px; }
.tree-connector { width: 2px; height: 28px; background: linear-gradient(var(--purple-hot), var(--gold)); opacity: .85; }
.tree-split { width: min(520px, 90%); height: 22px; border-top: 2px solid rgba(255,176,0,.45); border-left: 2px solid rgba(255,176,0,.45); border-right: 2px solid rgba(255,176,0,.45); border-radius: 18px 18px 0 0; }
.hier-node, .branch-card, .small-btn {
  border: 1px solid var(--stroke);
  color: var(--text);
  background: linear-gradient(135deg, rgba(166,83,255,.20), rgba(255,176,0,.055)), var(--panel);
  border-radius: 22px;
  cursor: pointer;
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.hier-node { min-width: min(360px, 100%); padding: 18px 20px; text-align: center; box-shadow: 0 18px 46px rgba(0,0,0,.32); }
.hier-node:hover, .branch-card:hover, .small-btn:hover { transform: translateY(-3px); border-color: rgba(255,176,0,.74); box-shadow: 0 0 24px rgba(166,83,255,.30); }
.hier-node.crown { border-color: rgba(255,176,0,.56); }
.hier-node.second { min-width: min(330px, 100%); }
.hier-node.branch-head { border-color: rgba(212,140,255,.55); }
.hier-node strong { display:block; font-size: 1.18rem; margin: 4px 0; }
.hier-node small { display:block; color: var(--muted); line-height: 1.35; }
.hier-node em { display:block; margin-top: 8px; color: var(--gold); font-style: normal; font-weight: 900; }
.node-kicker { display:block; color: var(--purple-hot); text-transform: uppercase; letter-spacing: .14em; font-size: .72rem; font-weight: 900; }
.elders-node { margin-top: -4px; }
.branch-grid { display: grid; grid-template-columns: repeat(5, minmax(130px, 1fr)); gap: 12px; }
.branch-card { padding: 16px; text-align: left; min-height: 112px; }
.branch-card.active { border-color: rgba(255,176,0,.80); box-shadow: 0 0 22px rgba(255,176,0,.15); }
.branch-card span { display:block; color: var(--muted); font-weight: 900; min-height: 38px; }
.branch-card strong { display:block; color: var(--gold); font-size: 2rem; line-height: 1; margin-top: 10px; }
.branch-card small { color: var(--purple-hot); font-weight: 800; }
.branch-view { margin-top: 20px; }
.hierarchy-panel { padding: 24px; }
.branch-headline { display:flex; justify-content: space-between; align-items: flex-start; gap: 16px; margin-bottom: 18px; }
.branch-headline h2 { font-size: clamp(1.7rem, 4vw, 3rem); margin: 0; }
.small-btn { padding: 10px 14px; color: var(--gold); font-weight: 900; }
.branch-tree { display: grid; gap: 18px; }
.position-cluster { display: grid; justify-items: center; gap: 14px; }
.child-grid { width: 100%; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; padding-top: 12px; border-top: 1px solid rgba(212,140,255,.18); }
.elder-list { display:grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-top: 18px; }
.elder-card, .mini-holder, .history-row, .elder-badge { border: 1px solid var(--stroke); background: rgba(255,255,255,.055); border-radius: 18px; padding: 14px; }
.elder-card h3 { margin: 0 0 8px; }
.elder-card p { margin: 0; color: var(--muted); }
.elder-card strong { display:block; margin-top: 8px; color: var(--gold); }
.elder-card small { display:block; margin-top: 8px; color: var(--muted); }
.elder-badge { margin-bottom: 14px; display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.elder-badge strong { color: var(--gold); text-transform: uppercase; letter-spacing: .12em; }
.elder-badge span { color: var(--muted); }
.position-dialog { width: min(780px, calc(100% - 28px)); border: 1px solid var(--stroke); border-radius: 26px; background: #140322; color: var(--text); padding: 28px; box-shadow: 0 28px 90px rgba(0,0,0,.58); }
.position-dialog::backdrop { background: rgba(0,0,0,.68); backdrop-filter: blur(4px); }
.dialog-close { position:absolute; right: 18px; top: 14px; border: 0; background: transparent; color: var(--muted); font-size: 2rem; cursor: pointer; }
.position-dialog h1 { font-size: clamp(2rem, 5vw, 4.2rem); }
.dialog-subtitle { color: var(--gold); font-weight: 900; text-transform: uppercase; letter-spacing: .08em; }
.dialog-section { margin-top: 24px; }
.dialog-section h2 { color: var(--purple-hot); }
.mini-holder { display:grid; gap: 4px; margin: 8px 0; }
.mini-holder span { color: var(--muted); }
.history-row { display:grid; grid-template-columns: 120px 1fr; gap: 8px 14px; margin: 8px 0; align-items: baseline; }
.history-row strong { color: var(--gold); }
.history-row small { grid-column: 2; color: var(--muted); }
.vacant { color: var(--bad); font-weight: 900; }
.admin-tools { display:grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; margin-top: 22px; }
.compact-form { display:grid; gap: 12px; }
.compact-form .full { margin-top: 0; }
.check-row { display:flex; align-items:center; gap: 10px; }
.check-row input { width:auto; margin: 0; }
.muted { color: var(--muted); }

@media (max-width: 920px) {
  .branch-grid, .admin-tools { grid-template-columns: 1fr; }
  .history-row { grid-template-columns: 1fr; }
  .history-row small { grid-column: auto; }
}
