/* Init8 admin panel styles — DESIGN.md v1.0 tokens only.
   No raw hex; every color/spacing/radius references a token from
   _tokens.css. The admin page is intentionally austere — it's an
   internal control surface, not a marketing page. */

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  background: var(--color-surface-canvas, #06090f);
  color: var(--color-text-primary, #e8edf5);
  font-family: var(--typography-body-fontfamily, system-ui, sans-serif);
  font-size: 16px; line-height: 1.6;
}
.container { max-width: 980px; margin: 0 auto; padding: 48px 24px; }
header { border-bottom: 1px solid var(--color-border-hairline, rgba(125, 211, 252, 0.08)); padding-bottom: 24px; margin-bottom: 32px; display: flex; align-items: center; gap: 16px; }
.logo { font-size: 1.4rem; font-weight: 700; letter-spacing: -0.5px; }
.admin-eyebrow { font-family: var(--typography-eyebrow-fontfamily, monospace); font-size: 0.78rem; font-weight: 500; letter-spacing: 0.16em; text-transform: uppercase; color: var(--color-accent-emphasis, #c47a6e); margin-left: 8px; }
h1 { font-size: 1.8rem; margin: 16px 0 8px; font-weight: 600; letter-spacing: -0.018em; }
h2 { font-size: 1.2rem; margin: 24px 0 12px; font-weight: 600; }
h3 { font-size: 1.0rem; margin: 18px 0 8px; font-weight: 600; }
.lede { color: var(--color-text-muted, #8a96a8); margin-bottom: 24px; }
.hint { color: var(--color-text-muted, #8a96a8); font-size: 0.88rem; margin-bottom: 12px; }

.section-marker {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 16px;
  align-items: center;
  margin: 32px 0 12px;
}
.section-marker .marker-label {
  font-family: var(--typography-eyebrow-fontfamily, monospace);
  font-size: 0.74rem;
  font-weight: 500;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-accent-emphasis, #c47a6e);
  white-space: nowrap;
}
.section-marker .marker-rule {
  height: 1px;
  background: linear-gradient(90deg,
    var(--color-border-emphasis, rgba(196, 122, 110, 0.28)) 0%,
    var(--color-border-emphasis, rgba(196, 122, 110, 0.28)) 70%,
    transparent 100%);
}

.admin-empty {
  background: var(--color-surface-card, #0e131c);
  border: 1px solid var(--color-border-subtle, rgba(125, 211, 252, 0.16));
  border-radius: var(--rounded-lg, 10px);
  padding: 24px;
  margin: 24px 0;
}
.admin-empty h2 { margin-top: 0; }
.admin-cta {
  background: var(--color-action-primary, #7dd3fc);
  color: var(--color-text-on-accent, #03050a);
  border: none;
  border-radius: var(--rounded-md, 6px);
  padding: 10px 20px;
  font-weight: 600;
  cursor: pointer;
  min-height: 44px;
  font-family: inherit;
}
.admin-cta:hover { background: var(--color-action-primary-strong, #38bdf8); }

.admin-section {
  background: var(--color-surface-card, #0e131c);
  border: 1px solid var(--color-border-subtle, rgba(125, 211, 252, 0.16));
  border-radius: var(--rounded-lg, 10px);
  padding: 24px;
  margin: 24px 0;
}

.admin-flag-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.admin-flag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 1px solid var(--color-border-hairline, rgba(125, 211, 252, 0.08));
  border-radius: var(--rounded-md, 6px);
  background: var(--color-surface-canvas, #06090f);
}
.admin-flag-row[data-prominent="true"] {
  border-color: var(--color-accent-emphasis, #c47a6e);
}
.admin-flag-name { font-weight: 600; font-family: var(--typography-code-fontfamily, monospace); flex: 0 0 auto; min-width: 200px; }
.admin-flag-value { font-family: var(--typography-code-fontfamily, monospace); color: var(--color-text-soft, #c7d0dd); flex: 1 1 auto; word-break: break-word; overflow-wrap: anywhere; min-width: 0; }
.admin-flag-toggle {
  background: transparent;
  color: var(--color-action-primary, #7dd3fc);
  border: 1px solid var(--color-border-strong, rgba(125, 211, 252, 0.30));
  border-radius: var(--rounded-md, 6px);
  padding: 6px 14px;
  font-weight: 600;
  cursor: pointer;
  min-height: 36px;
  font-family: inherit;
}
.admin-flag-toggle:hover { background: var(--color-action-primary-soft, rgba(125, 211, 252, 0.10)); }

.admin-readonly-config { display: flex; flex-direction: column; gap: 10px; }
.admin-readonly-config details {
  background: var(--color-surface-canvas, #06090f);
  border: 1px solid var(--color-border-hairline, rgba(125, 211, 252, 0.08));
  border-radius: var(--rounded-md, 6px);
  padding: 10px 14px;
}
.admin-readonly-config summary { cursor: pointer; font-weight: 600; font-family: var(--typography-code-fontfamily, monospace); }
.admin-readonly-config pre {
  margin: 12px 0 0;
  padding: 12px;
  background: var(--color-surface-card-elevated, #141b27);
  color: var(--color-text-soft, #c7d0dd);
  border-radius: var(--rounded-sharp, 2px);
  overflow-x: auto;
  font-family: var(--typography-code-fontfamily, monospace);
  font-size: 0.86rem;
  line-height: 1.5;
  white-space: pre-wrap;
  word-break: break-word;
}

.admin-tenant-meta { display: grid; grid-template-columns: max-content 1fr; gap: 6px 16px; margin: 0 0 16px; }
.admin-tenant-meta dt { color: var(--color-text-muted, #8a96a8); }
.admin-tenant-meta dd { margin: 0; font-weight: 500; word-break: break-word; overflow-wrap: anywhere; }

.admin-tenant-members, .admin-tenant-prefs { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 6px; }
.admin-tenant-members li, .admin-tenant-prefs li {
  padding: 8px 12px;
  background: var(--color-surface-canvas, #06090f);
  border: 1px solid var(--color-border-hairline, rgba(125, 211, 252, 0.08));
  border-radius: var(--rounded-md, 6px);
  display: flex;
  gap: 12px;
  align-items: center;
  flex-wrap: wrap;
  word-break: break-word;
  overflow-wrap: anywhere;
}

.live-region { min-height: 1.5em; padding: 12px; border-radius: var(--rounded-md, 6px); margin-top: 12px; }
#admin-status { background: var(--color-surface-card, #0e131c); border: 1px solid var(--color-border-subtle, rgba(125, 211, 252, 0.16)); }
#admin-error { background: var(--color-surface-card, #0e131c); border: 1px solid var(--color-status-error, #f87171); color: var(--color-status-error, #f87171); }
#admin-status:empty, #admin-error:empty { display: none; }

footer { margin-top: 48px; padding-top: 24px; border-top: 1px solid var(--color-border-hairline, rgba(125, 211, 252, 0.08)); color: var(--color-text-muted, #8a96a8); font-size: 0.88rem; }
footer a { color: var(--color-action-primary, #7dd3fc); }

@media (max-width: 520px) {
  .container { padding: 28px 16px 48px; }
  .admin-flag-name { min-width: 100%; }
  .admin-flag-row { flex-direction: column; align-items: flex-start; }
}
