:root {
  --bg: #f4efe4;
  --ink: #172018;
  --muted: #55645a;
  --panel: rgba(255,255,255,0.74);
  --line: rgba(23,32,24,0.12);
  --forest: #1f5c4a;
  --moss: #6b8f71;
  --clay: #a65f3f;
  --sand: #d8b879;
  --danger: #9c3b2d;
  --shadow: 0 22px 50px rgba(44, 41, 32, 0.12);
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; min-height: 100%; }
body {
  font-family: "Noto Sans Lao", "Phetsarath OT", "Noto Sans", "Avenir Next", sans-serif;
  color: var(--ink);
  background: radial-gradient(circle at top left, rgba(31,92,74,0.18), transparent 28%), radial-gradient(circle at top right, rgba(166,95,63,0.18), transparent 24%), linear-gradient(180deg, #f7f2e9 0%, #efe8da 100%);
}
body.login-locked { overflow: hidden; }
button, input { font: inherit; }


.scope-note { margin: 0 0 16px; color: var(--muted); line-height: 1.65; }

.ghost-btn { border: 1px solid var(--line); background: rgba(255,255,255,0.6); color: var(--ink); border-radius: 16px; padding: 12px 16px; }
.admin-auth { display: grid; grid-template-columns: 1fr auto auto; gap: 10px; margin-bottom: 14px; }
.admin-auth input { border: 1px solid var(--line); border-radius: 16px; padding: 12px 14px; background: rgba(255,255,255,0.8); }
.admin-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-bottom: 14px; }
.admin-btn { border: 0; border-radius: 16px; padding: 14px 12px; background: #173d33; color: #fff; font-weight: 700; }
.admin-btn.danger { background: var(--danger); }
.admin-output { margin: 0; padding: 14px; border-radius: 18px; background: rgba(23,32,24,0.92); color: #f5f1e8; min-height: 180px; max-height: 360px; overflow: auto; font-family: ui-monospace, SFMono-Regular, Menlo, monospace; white-space: pre-wrap; word-break: break-word; }
@media (max-width: 640px) { .admin-auth { grid-template-columns: 1fr; } .admin-grid { grid-template-columns: 1fr; } }

.admin-auth--stack {
  grid-template-columns: 1fr;
}

[hidden] { display: none !important; }

.admin-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin-bottom: 14px; }
@media (max-width: 640px) { .admin-row { grid-template-columns: 1fr; } }
