:root {
  --night: #0B0F22;
  --night-2: #0E1430;
  --panel: #161D3D;
  --panel-2: #1B2348;
  --edge: #2B3568;
  --edge-soft: #222a52;
  --gold: #ECC976;
  --poring: #FF8FB1;
  --poring-dim: #c96e8c;
  --ink: #EAEDF8;
  --muted: #8A92BC;
  --field: #0E1430;
  --success: #7BE0A8;
  --danger: #FF7A85;
  --discord: #5865F2;
  --radius: 16px;
  --radius-sm: 9px;
  --maxw: 680px;
  --tap: 46px;
}

* { box-sizing: border-box; }
html { color-scheme: dark; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--night);
  color: var(--ink);
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  background-image:
    radial-gradient(900px 460px at 50% -120px, rgba(255,143,177,.13), transparent 70%),
    radial-gradient(800px 500px at 100% 110%, rgba(236,201,118,.08), transparent 65%);
  background-attachment: fixed;
  padding-bottom: env(safe-area-inset-bottom);
}
a { color: inherit; text-decoration: none; }
h1, h2, p { margin: 0; }

.mono { font-family: "JetBrains Mono", ui-monospace, monospace; }
.pix { font-family: "Silkscreen", monospace; font-size: 11px; letter-spacing: .07em; }
.muted { color: var(--muted); }
.ink { color: var(--ink); }
.gold-text { color: var(--gold); }
.small { font-size: 12.5px; }
.mb { margin-bottom: 16px; }
.mt { margin-top: 12px; }

/* ---------- layout ---------- */
.container {
  width: 100%;
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 16px;
  padding-left: max(16px, env(safe-area-inset-left));
  padding-right: max(16px, env(safe-area-inset-right));
}
main.container { padding-top: 22px; padding-bottom: 24px; }
.foot { padding: 18px 16px 28px; text-align: center; color: var(--muted); font-size: 11px; }
.narrow { max-width: 400px; margin: 28px auto 0; }

/* ---------- header ---------- */
.hdr {
  position: sticky; top: 0; z-index: 20;
  background: rgba(14,20,48,.82);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--edge-soft);
}
.hdr-inner {
  max-width: var(--maxw); margin: 0 auto;
  padding: 0 16px;
  padding-left: max(16px, env(safe-area-inset-left));
  padding-right: max(16px, env(safe-area-inset-right));
  height: 56px; display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.hdr-left { display: flex; align-items: center; gap: 18px; min-width: 0; }
.brand { font-family: "Silkscreen", monospace; font-size: 15px; white-space: nowrap; }
.brand .x { color: var(--poring); }
.nav { display: flex; gap: 14px; }
.nav a { font-size: 14px; color: var(--muted); padding: 6px 0; }
.nav a:hover, .nav a:active { color: var(--ink); }
.gm-link { color: var(--gold); }
.hdr-right { display: flex; align-items: center; gap: 10px; min-width: 0; }
.avatar { width: 30px; height: 30px; border-radius: 50%; object-fit: cover; flex: 0 0 auto; }
.avatar.blank { background: rgba(255,143,177,.3); }
.tag { font-size: 14px; max-width: 120px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.signout { font-size: 12.5px; color: var(--muted); padding: 8px 4px; }
.signout:hover { color: var(--ink); }

/* ---------- panels ---------- */
.window {
  background: linear-gradient(180deg, var(--panel-2), var(--panel));
  border: 1px solid var(--edge);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(255,255,255,.03) inset, 0 18px 40px -28px rgba(0,0,0,.9);
}
.titlebar {
  display: flex; align-items: center; gap: 9px;
  padding: 12px 16px;
  background: rgba(9,13,32,.55);
  border-bottom: 1px solid var(--edge-soft);
}
.titlebar.between { justify-content: space-between; }
.pad { padding: 18px 16px; }
.chars { display: flex; flex-direction: column; gap: 8px; }
.dot { width: 9px; height: 9px; border-radius: 50%; display: inline-block; background: var(--edge); flex: 0 0 auto; box-shadow: 0 0 8px rgba(0,0,0,.4); }
.dot.pink { background: var(--poring); box-shadow: 0 0 10px rgba(255,143,177,.6); }
.dot.on { background: var(--success); box-shadow: 0 0 10px rgba(123,224,168,.6); }
.dot.off { background: var(--edge); }

.page-title { font-family: "Silkscreen", monospace; font-size: 19px; margin-bottom: 14px; }
.acct-head { display: flex; align-items: baseline; justify-content: space-between; gap: 10px; flex-wrap: wrap; }
.acct-head .page-title { margin-bottom: 4px; }
.note { margin-bottom: 16px; }

/* ---------- badges ---------- */
.badge { border-radius: 999px; font-size: 12px; padding: 4px 11px; white-space: nowrap; font-weight: 500; }
.badge.gold  { background: rgba(236,201,118,.14); color: var(--gold); border: 1px solid rgba(236,201,118,.25); }
.badge.pink  { background: rgba(255,143,177,.14); color: var(--poring); border: 1px solid rgba(255,143,177,.28); }
.badge.plain { background: rgba(138,146,188,.14); color: var(--muted); border: 1px solid var(--edge-soft); }

/* ---------- characters ---------- */
.char {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  background: var(--field); border: 1px solid var(--edge-soft); border-radius: var(--radius-sm); padding: 10px 12px;
}
.char-left { display: flex; align-items: center; gap: 8px; min-width: 0; flex-wrap: wrap; }
.char-left .mono { font-size: 14px; }

/* ---------- forms ---------- */
.form { display: flex; flex-direction: column; gap: 11px; }
.field {
  width: 100%;
  background: var(--field); border: 1px solid var(--edge);
  border-radius: var(--radius-sm); padding: 13px 14px; color: var(--ink);
  font-size: 16px; /* >=16px stops iOS zoom-on-focus */
  transition: border-color .15s, box-shadow .15s;
}
.field::placeholder { color: var(--muted); }
.field:focus { outline: none; border-color: var(--poring); box-shadow: 0 0 0 3px rgba(255,143,177,.22); }
.sex { display: flex; gap: 10px; }
.sex-opt {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px;
  min-height: var(--tap);
  border: 1px solid var(--edge); border-radius: var(--radius-sm); padding: 10px; font-size: 14px;
  color: var(--muted); cursor: pointer; transition: .15s;
}
.sex-opt:has(input:checked) { border-color: var(--poring); background: rgba(255,143,177,.12); color: var(--ink); }
.sex-opt input { accent-color: var(--poring); }

/* ---------- buttons ---------- */
.btn-primary, .btn-discord, .btn-tier {
  min-height: var(--tap);
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  border-radius: var(--radius-sm); font-size: 15px; font-weight: 600; cursor: pointer;
  border: 1px solid transparent; padding: 0 16px; transition: filter .15s, transform .05s;
}
.btn-primary:active, .btn-discord:active, .btn-tier:active { transform: translateY(1px); }
.btn-primary { background: var(--poring); color: #1a0f16; border: none; }
.btn-primary:hover { filter: brightness(1.07); }
.btn-discord { background: var(--discord); color: #fff; }
.btn-discord:hover { filter: brightness(1.1); }
.btn-discord.full { width: 100%; margin-top: 10px; }
.btn-discord.sm { min-height: 38px; font-size: 13.5px; padding: 0 14px; }
.btn-tier {
  font-size: 14px; font-weight: 500; min-height: 42px;
  border-color: var(--gold); background: rgba(236,201,118,.12); color: var(--gold);
}
.btn-tier.pro { border-color: var(--poring); background: rgba(255,143,177,.12); color: var(--poring); }
.btn-tier.ghost { border-color: var(--edge); background: transparent; color: var(--muted); }
.btn-tier:hover { filter: brightness(1.12); }

/* ---------- messages ---------- */
.error { color: var(--danger); font-size: 13.5px; }
.success {
  border: 1px solid rgba(123,224,168,.4); background: rgba(123,224,168,.1);
  border-radius: var(--radius-sm); padding: 13px 16px; margin-bottom: 16px;
}
.success-title { color: var(--success); font-weight: 600; }

/* ---------- change password ---------- */
.pw { margin-top: 4px; border-top: 1px solid var(--edge-soft); padding-top: 10px; }
.pw summary { cursor: pointer; color: var(--muted); font-size: 13px; padding: 6px 0; list-style: none; }
.pw summary::-webkit-details-marker { display: none; }
.pw summary::before { content: "🔑 "; }
.pw summary:hover { color: var(--ink); }
.pw-form { margin-top: 10px; }

/* ---------- GM ---------- */
.row { display: flex; gap: 10px; }
.row .field { flex: 1; }
.gm-result { border-top: 1px solid var(--edge-soft); padding-top: 14px; margin-top: 14px; }
.gm-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.gm-actions { display: flex; gap: 8px; margin-top: 12px; flex-wrap: wrap; }
.gm-actions form { margin: 0; flex: 1 1 auto; }
.gm-actions .btn-tier { width: 100%; }
.mail-send { border-top: 1px solid var(--edge-soft); margin-top: 16px; padding-top: 14px; }
.mail-h { font-size: 11px; margin-bottom: 10px; }
.mail-form { display: flex; gap: 10px; flex-wrap: wrap; align-items: stretch; }
.mail-set { flex: 1 1 160px; }
.mail-src { flex: 1; min-width: 150px; }
.mail-rm { margin: 0; }
.mail-rm .btn-tier { min-height: 34px; font-size: 12px; padding: 0 12px; }
select.field { -webkit-appearance: none; appearance: none; color: var(--ink); background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%); background-position: calc(100% - 16px) calc(50% - 2px), calc(100% - 11px) calc(50% - 2px); background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: 32px; }
.gm-log { display: flex; flex-direction: column; gap: 7px; }
.gm-log-row, .mail-row {
  display: flex; flex-wrap: wrap; align-items: center; gap: 5px 10px;
  background: var(--field); border: 1px solid var(--edge-soft); border-radius: var(--radius-sm); padding: 9px 11px;
}
.gm-log-row > :nth-child(2), .mail-row > :nth-child(3) { flex: 1 1 100%; }

/* ---------- wider screens ---------- */
@media (min-width: 560px) {
  .page-title { font-size: 21px; }
  .gm-log-row { display: grid; grid-template-columns: auto 1fr auto; }
  .gm-log-row > :nth-child(2) { flex: none; }
  .mail-row { display: grid; grid-template-columns: auto auto 1fr auto; }
  .mail-row > :nth-child(3) { flex: none; }
  .gm-actions .btn-tier { width: auto; }
  .gm-actions form { flex: 0 0 auto; }
}

@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; }
}

/* GM sub-tabs */
.gm-tabs { display: flex; gap: 8px; margin: -6px 0 16px; flex-wrap: wrap; }
.gm-tabs a {
  font-size: 13.5px; color: var(--muted); padding: 8px 14px; min-height: 40px;
  display: inline-flex; align-items: center;
  border: 1px solid var(--edge-soft); border-radius: 999px; background: var(--field);
}
.gm-tabs a:hover { color: var(--ink); }
.gm-tabs a.on { color: var(--night); background: var(--gold); border-color: var(--gold); font-weight: 600; }

/* textarea */
textarea.field { resize: vertical; line-height: 1.5; min-height: 96px; }

/* promotion set cards */
.set-list { display: flex; flex-direction: column; gap: 10px; }
.set-card { background: var(--field); border: 1px solid var(--edge-soft); border-radius: var(--radius-sm); padding: 12px; }
.set-card.retired { opacity: .62; }
.set-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.set-meta { margin-top: 3px; }
.set-items { display: flex; flex-wrap: wrap; gap: 6px; }
.item-chip { background: var(--panel-2); border: 1px solid var(--edge-soft); border-radius: 6px; padding: 2px 7px; color: var(--muted); }
.set-actions { display: flex; gap: 8px; margin-top: 11px; }
.set-actions form { margin: 0; }
.set-actions .btn-tier { min-height: 36px; font-size: 12.5px; padding: 0 14px; }
.btn-tier.danger { border-color: rgba(255,122,133,.5); color: var(--danger); }
.btn-tier.danger:hover { background: rgba(255,122,133,.12); }

/* leaderboards */
.rank-list { display: flex; flex-direction: column; gap: 6px; }
.rank-row {
  display: flex; align-items: center; gap: 11px;
  background: var(--field); border: 1px solid var(--edge-soft); border-radius: var(--radius-sm); padding: 9px 11px;
}
.rank-no { width: 26px; text-align: center; color: var(--muted); font-size: 13px; flex: 0 0 auto; }
.rank-main { display: flex; flex-direction: column; gap: 1px; min-width: 0; flex: 1; }
.rank-main .mono { font-size: 13.5px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.rank-val { flex: 0 0 auto; font-size: 13px; }

/* item editor (per-set) */
.item-editor { display: flex; flex-direction: column; gap: 8px; }
.item-edit-row { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.item-edit-form { display: flex; align-items: center; gap: 6px; margin: 0; flex: 1; min-width: 0; flex-wrap: wrap; }
.item-edit-form .x { flex: 0 0 auto; }
.item-id { flex: 1 1 90px; min-width: 0; padding: 9px 10px; font-size: 14px; }
.item-amt { flex: 1 1 70px; min-width: 0; padding: 9px 10px; font-size: 14px; }
.item-edit-form .btn-tier { min-height: 38px; font-size: 12.5px; padding: 0 12px; flex: 0 0 auto; }
.item-del-form { margin: 0; flex: 0 0 auto; }
.del-x { min-height: 38px; min-width: 38px; padding: 0 10px; font-size: 13px; }
.add-item { border-top: 1px dashed var(--edge-soft); padding-top: 10px; margin-top: 2px; }

/* directory */
.dir-id { flex: 0 0 auto; min-width: 64px; }
.dir-dot { flex: 0 0 auto; }
