/* ============================================================
   Aura Project — design tokens
   ============================================================ */
:root {
  --bg:#0b0d12;
  --bg-2:#11141b;
  --panel:#161a23;
  --card:#1a1f2b;
  --card-2:#212635;
  --line:#252b3b;
  --line-2:#2f364a;
  --fg:#e8eaf2;
  --muted:#8b93a8;
  --accent:#7c8cff;
  --accent-2:#a18bff;
  --ok:#3fd68b;
  --warn:#f5a623;
  --danger:#ef4f6f;
  --info:#5ec4ff;
  --shadow: 0 8px 24px rgba(0,0,0,.32);
  --radius: 10px;
  --radius-lg: 14px;
}
* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: ui-sans-serif, -apple-system, "Segoe UI", Roboto, "Inter", sans-serif;
  font-size: 14.5px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }
code, .mono { font-family: ui-monospace, "JetBrains Mono", "Fira Code", Consolas, monospace; }
hr { border: none; border-top: 1px solid var(--line); margin: 1rem 0; }
small { font-size: .8em; }

/* ============================================================
   Layout
   ============================================================ */
body.app { display: flex; min-height: 100vh; background: linear-gradient(180deg, #0b0d12 0%, #0d1018 100%); }
body.centered { display: flex; align-items: center; justify-content: center; padding: 2rem; }
body.public { display: block; background: radial-gradient(1000px 500px at 50% -200px, rgba(124,140,255,.15), transparent 70%), var(--bg); }

/* ----- Sidebar ----- */
.sidebar {
  width: 248px;
  background: var(--panel);
  border-right: 1px solid var(--line);
  padding: 1.25rem 1rem;
  display: flex; flex-direction: column;
  position: sticky; top: 0;
  height: 100vh;
  overflow-y: auto;
}
.brand { display: flex; align-items: center; gap: .65rem; margin-bottom: 1.5rem; }
.brand.center { flex-direction: column; gap: .25rem; text-align: center; margin-bottom: 1rem; }
.brand-logo {
  width: 36px; height: 36px; border-radius: 9px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; font-weight: 700; font-size: 1.05rem;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px rgba(124,140,255,.35);
}
.brand-logo.big { width: 56px; height: 56px; font-size: 1.6rem; }
.brand h1 { font-size: 1.05rem; margin: 0; }
.sidebar nav { flex: 1; display: flex; flex-direction: column; gap: .15rem; }
.sidebar nav a {
  display: flex; align-items: center; gap: .65rem;
  padding: .55rem .75rem;
  color: var(--fg); text-decoration: none;
  border-radius: 8px;
  font-size: .92rem;
}
.sidebar nav a:hover { background: var(--card); text-decoration: none; }
.sidebar nav a.active { background: linear-gradient(90deg, rgba(124,140,255,.18), transparent); color: var(--accent); }
.sidebar nav .ic { width: 18px; text-align: center; opacity: .9; }
.sidebar-foot { display: flex; justify-content: space-between; align-items: center; padding-top: 1rem; border-top: 1px solid var(--line); }
.btn-ghost { background: transparent; color: var(--muted); padding: .35rem .65rem; border: 1px solid var(--line); border-radius: 6px; cursor: pointer; }
.btn-ghost:hover { color: var(--fg); border-color: var(--line-2); }

.content { flex: 1; padding: 2rem 2.25rem; max-width: 1200px; }
.page-head { margin-bottom: 1.5rem; }
.page-head h2 { margin: .25rem 0; font-size: 1.65rem; }

/* ----- Cards ----- */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.35rem;
  margin-bottom: 1.25rem;
  box-shadow: var(--shadow);
}
.card-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.card-head h3 { margin: 0; font-size: 1.02rem; }
.cards-2col { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-bottom: 1.25rem; }
@media (max-width: 880px) { .cards-2col { grid-template-columns: 1fr; } }
.card.narrow { max-width: 480px; }

/* ----- Buttons ----- */
button, .btn {
  background: var(--card-2);
  color: var(--fg);
  border: 1px solid var(--line-2);
  padding: .55rem 1rem;
  border-radius: 8px;
  cursor: pointer;
  font: inherit;
  font-weight: 500;
  text-decoration: none;
  display: inline-flex; align-items: center; gap: .35rem;
  transition: filter .12s, transform .12s;
}
button:hover, .btn:hover { filter: brightness(1.15); text-decoration: none; }
button:active, .btn:active { transform: translateY(1px); }
.btn.primary { background: linear-gradient(135deg, var(--accent), var(--accent-2)); border-color: transparent; color: #fff; }
.btn.ok { background: var(--ok); color: #062a17; border: none; }
.btn.warn { background: var(--warn); color: #2a1d00; border: none; }
.btn.danger { background: var(--danger); color: #fff; border: none; }
.btn.ghost { background: transparent; }
.btn.block { display: flex; width: 100%; justify-content: center; padding: .7rem 1rem; }
.btn-sm { font-size: .82rem; padding: .35rem .65rem; border-radius: 6px; background: var(--card-2); border: 1px solid var(--line-2); color: var(--fg); cursor: pointer; }
.btn-sm.warn { background: var(--warn); color: #2a1d00; border: none; }
.btn-sm.danger { background: var(--danger); color: #fff; border: none; }
.row { display: flex; gap: .5rem; flex-wrap: wrap; align-items: center; }
.row.gap { gap: .65rem; }
.grow { flex: 1; min-width: 120px; }
.inline { display: inline-flex; align-items: center; gap: .35rem; }

/* ----- Inputs ----- */
input, textarea, select {
  background: var(--bg-2);
  color: var(--fg);
  border: 1px solid var(--line-2);
  border-radius: 8px;
  padding: .55rem .75rem;
  font: inherit;
  width: 100%;
}
input[type=checkbox], input[type=radio] { width: auto; }
input:focus, textarea:focus, select:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
textarea.mono { font-family: ui-monospace, monospace; font-size: .82rem; }
label { display: block; }
.field { margin-bottom: .9rem; display: block; }
.field strong { display: block; margin-bottom: .25rem; font-weight: 500; }

/* toggle row */
.toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: .65rem .85rem;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  margin-bottom: .55rem;
  cursor: pointer;
}
.toggle-row input { transform: scale(1.25); }
.toggle-row strong { font-weight: 500; }

/* slider */
.slider-field input[type=range] {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 6px; background: var(--line-2); border-radius: 3px;
  outline: none; padding: 0; margin: .5rem 0;
}
.slider-field input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--accent); cursor: pointer;
  box-shadow: 0 0 0 4px rgba(124,140,255,.18);
}
.slider-field output { font-variant-numeric: tabular-nums; color: var(--accent); font-weight: 600; }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: .75rem; }
@media (max-width: 720px) { .grid-2 { grid-template-columns: 1fr; } }

/* ----- Tabs ----- */
.tabs {
  display: flex; gap: .25rem; flex-wrap: wrap;
  border-bottom: 1px solid var(--line);
  margin-bottom: 1.25rem;
  padding-bottom: .25rem;
}
.tabs a {
  padding: .55rem .9rem; border-radius: 8px 8px 0 0;
  color: var(--muted); text-decoration: none;
  border: 1px solid transparent;
  border-bottom: none;
  font-size: .92rem;
}
.tabs a:hover { color: var(--fg); text-decoration: none; }
.tabs a.active { background: var(--card); color: var(--fg); border-color: var(--line); border-bottom-color: var(--card); margin-bottom: -1px; }

/* ----- Banners ----- */
.banner { padding: .75rem 1rem; border-radius: 10px; border: 1px solid; margin-bottom: 1rem; }
.banner.ok { background: rgba(63,214,139,.1); border-color: var(--ok); color: #b5f0d2; }
.banner.error { background: rgba(239,79,111,.1); border-color: var(--danger); color: #ffc4d2; }
.banner.warn { background: rgba(245,166,35,.1); border-color: var(--warn); color: #ffd58e; }
.banner.info { background: rgba(94,196,255,.08); border-color: var(--info); color: #b4dffd; }

/* ----- Status bits ----- */
.status-pill {
  display: inline-block;
  padding: .15rem .65rem;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .04em;
}
.status-pill.on { background: rgba(63,214,139,.15); color: var(--ok); border: 1px solid rgba(63,214,139,.4); }
.status-pill.off { background: rgba(239,79,111,.15); color: var(--danger); border: 1px solid rgba(239,79,111,.4); }
.badge { display: inline-block; padding: .1rem .5rem; border-radius: 999px; font-size: .7rem; background: var(--card-2); border: 1px solid var(--line-2); }
.badge.ok { background: rgba(63,214,139,.15); color: var(--ok); border-color: rgba(63,214,139,.4); }
.badge.danger { background: rgba(239,79,111,.15); color: var(--danger); border-color: rgba(239,79,111,.4); }
.role { display: inline-block; padding: .1rem .55rem; border-radius: 999px; font-size: .7rem; font-weight: 600; letter-spacing: .03em; }
.role-admin { background: rgba(245,166,35,.18); color: var(--warn); }
.role-friend { background: rgba(124,140,255,.2); color: var(--accent); }
.role-default { background: rgba(255,255,255,.06); color: var(--muted); }

.grid-stats { display: grid; grid-template-columns: repeat(auto-fit, minmax(120px, 1fr)); gap: 1rem; }
.stat { background: var(--bg-2); border: 1px solid var(--line); border-radius: 10px; padding: .75rem .9rem; }
.stat-label { display: block; font-size: .75rem; color: var(--muted); text-transform: uppercase; letter-spacing: .04em; }
.stat-value { display: block; font-size: 1.45rem; font-weight: 600; margin-top: .15rem; font-variant-numeric: tabular-nums; }
.stat-value.small { font-size: .95rem; line-height: 1.3; }

/* ----- Players ----- */
.players-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: .75rem; }
.players-grid.wide { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
.player-card {
  display: flex; gap: .75rem; align-items: center;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: .65rem .8rem;
  text-decoration: none; color: var(--fg);
}
.player-card.link:hover { border-color: var(--accent); text-decoration: none; }
.avatar { width: 42px; height: 42px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.avatar.tiny { width: 26px; height: 26px; border-radius: 5px; }
.avatar.xl { width: 96px; height: 96px; border-radius: 12px; }
.avatar.placeholder {
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  color: #fff; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
}
.player-hero { display: flex; gap: 1.25rem; align-items: flex-start; }

/* ----- Tables ----- */
table { width: 100%; border-collapse: collapse; background: var(--card); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); }
th, td { text-align: left; padding: .6rem .85rem; border-bottom: 1px solid var(--line); vertical-align: middle; }
th { background: var(--bg-2); color: var(--muted); font-weight: 600; font-size: .75rem; text-transform: uppercase; letter-spacing: .05em; }
tbody tr:hover { background: rgba(124,140,255,.04); }

/* ----- Console ----- */
.console-bar { display: flex; gap: .5rem; align-items: center; margin-bottom: .75rem; }
.console {
  background: #050608; color: #cdd6e4;
  font-family: ui-monospace, monospace; font-size: .82rem;
  padding: 1rem; border-radius: 10px;
  height: 70vh; overflow: auto;
  white-space: pre-wrap; word-break: break-word;
  border: 1px solid var(--line);
}
.console div { padding: .05rem 0; }
.console .err { color: #ff96a8; }
.console .warn { color: #ffd58e; }
.console .ok { color: #9af0bf; }

pre.big-code { background: var(--bg-2); padding: .9rem 1.2rem; border-radius: 8px; font-size: 1.1rem; border: 1px solid var(--line); display: inline-block; }

/* ----- Login card ----- */
.login-card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 16px;
  padding: 2.25rem 2rem 2rem;
  width: 100%;
  max-width: 380px;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

/* ----- Sticky save bar ----- */
.sticky-actions {
  position: sticky; bottom: 0;
  background: linear-gradient(180deg, transparent 0%, var(--bg) 50%);
  padding: 1rem 0 .25rem;
  display: flex; gap: .65rem; flex-wrap: wrap;
  z-index: 5;
}

/* ----- Events list ----- */
.event-list { list-style: none; padding: 0; margin: 0; }
.event-list li {
  display: flex; align-items: center; gap: .65rem;
  padding: .55rem .25rem;
  border-bottom: 1px solid var(--line);
  font-size: .9rem;
}
.event-list li:last-child { border-bottom: none; }
.dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.dot.green { background: var(--ok); box-shadow: 0 0 8px var(--ok); }
.dot.red { background: var(--danger); box-shadow: 0 0 8px var(--danger); }
.dot.gray { background: var(--muted); }

/* ============================================================
   Public landing
   ============================================================ */
.public-nav {
  display: flex; align-items: center; justify-content: space-between;
  padding: 1rem 2rem;
  border-bottom: 1px solid var(--line);
  background: rgba(11,13,18,.7);
  backdrop-filter: blur(10px);
  position: sticky; top: 0; z-index: 10;
}
.public-nav nav { display: flex; gap: 1.25rem; }
.public-nav nav a { color: var(--muted); }
.public-nav nav a:hover { color: var(--fg); text-decoration: none; }

.hero { padding: 4rem 2rem; max-width: 1200px; margin: 0 auto; }
.hero-grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 3rem; align-items: center; }
@media (max-width: 880px) { .hero-grid { grid-template-columns: 1fr; } }
.kicker { color: var(--accent); text-transform: uppercase; letter-spacing: .12em; font-size: .8rem; margin: 0; }
.hero h1 { font-size: 3rem; margin: .5rem 0 .75rem; line-height: 1.1; background: linear-gradient(135deg, #fff, var(--accent)); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.lead { color: var(--muted); font-size: 1.1rem; max-width: 540px; }
.hero-cta { margin-top: 1.5rem; display: flex; gap: .75rem; flex-wrap: wrap; }
.hero-status .big-number { font-size: 4rem; font-weight: 700; line-height: 1; margin: .5rem 0; font-variant-numeric: tabular-nums; }
.hero-status .big-number small { font-size: 1.4rem; }
.kv { display: grid; grid-template-columns: max-content 1fr; gap: .35rem 1rem; margin: 1rem 0 0; }
.kv dt { color: var(--muted); }

.card-section { max-width: 1100px; margin: 0 auto; padding: 2rem 2rem 1rem; }
.card-section h2 { font-size: 1.5rem; margin: 0 0 1rem; }
.steps { padding-left: 1.5rem; line-height: 2; font-size: 1rem; }
.copy {
  background: var(--bg-2); border: 1px solid var(--line-2);
  padding: .35rem .65rem; border-radius: 6px; cursor: pointer;
  margin-left: .25rem;
}
.copy code { font-size: 1.05rem; }
pre.rules {
  background: var(--card); border: 1px solid var(--line);
  padding: 1rem 1.25rem; border-radius: 10px;
  white-space: pre-wrap; font-family: inherit;
  margin: 0;
}
.public-foot { text-align: center; padding: 3rem 1rem 2rem; border-top: 1px solid var(--line); margin-top: 3rem; }

/* ----- Misc ----- */
.muted { color: var(--muted); }
.small { font-size: .82rem; }
.center { text-align: center; }
.action { font-family: ui-monospace, monospace; font-size: .82rem; padding: .15rem .5rem; background: var(--bg-2); border-radius: 4px; }
.qr { background: #fff; padding: 8px; border-radius: 8px; display: inline-block; margin: 0 0 1rem; }
.group-card { padding: 1.5rem; }

/* ============================================================
   Server switcher (sidebar)
   ============================================================ */
.server-switcher {
  margin: 0 0 1.25rem;
  padding: .75rem;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 10px;
}
.server-switcher .muted { display: block; margin-bottom: .35rem; letter-spacing: .08em; text-transform: uppercase; font-size: .68rem; }
.srv-pills { display: flex; flex-direction: column; gap: .35rem; }
.srv-pill {
  --c: var(--accent);
  display: flex; align-items: center; gap: .5rem;
  padding: .4rem .65rem;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--fg);
  font-size: .85rem;
  text-decoration: none;
  transition: border-color .2s, background .2s;
}
.srv-pill:hover { border-color: var(--c); text-decoration: none; }
.srv-pill.active { background: color-mix(in oklab, var(--c) 14%, transparent); border-color: var(--c); }
.srv-dot {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--c);
  box-shadow: 0 0 8px var(--c);
}

/* ============================================================
   Servers manager page
   ============================================================ */
.server-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(380px, 1fr)); gap: 1.25rem; }
.server-tile {
  --c: var(--accent);
  background: linear-gradient(160deg, color-mix(in oklab, var(--c) 8%, var(--card)) 0%, var(--card) 100%);
  border: 1px solid var(--line-2);
  border-top: 2px solid var(--c);
  border-radius: var(--radius-lg);
  padding: 1.25rem 1.35rem;
  box-shadow: var(--shadow);
}
.server-tile .srv-dot { background: var(--c); box-shadow: 0 0 10px var(--c); }
.server-tile h3 { display: flex; align-items: center; gap: .5rem; margin: 0; }
.grid-stats.compact .stat { padding: .5rem .65rem; }
.grid-stats.compact .stat-value { font-size: 1.1rem; }
.server-edit summary { list-style: none; cursor: pointer; }
.server-edit summary::-webkit-details-marker { display: none; }
.server-edit[open] summary { margin-bottom: .5rem; }

/* ============================================================
   Player moderation actions
   ============================================================ */
.action-block { margin-bottom: .75rem; border: 1px solid var(--line); border-radius: 10px; padding: .25rem; }
.action-block summary {
  list-style: none; cursor: pointer; padding: .55rem .9rem;
  border-radius: 8px; user-select: none;
}
.action-block summary::-webkit-details-marker { display: none; }
.action-block[open] { padding: 1rem 1.25rem; background: var(--bg-2); }
.action-block[open] summary { margin-bottom: .75rem; }

.player-card.with-actions { padding-right: .35rem; align-items: stretch; }
.player-card-main { display: flex; gap: .65rem; align-items: center; flex: 1; text-decoration: none; color: inherit; padding: .65rem .8rem; }
.player-card-main:hover { text-decoration: none; }
.quick-actions {
  display: flex; gap: .25rem; align-items: center;
  padding-right: .55rem;
  opacity: .6; transition: opacity .2s;
}
.player-card.with-actions:hover .quick-actions { opacity: 1; }
.quick-actions .btn-sm { padding: .35rem .55rem; font-size: 1rem; }
