/*
 * admin.css — Publisher console (admin.skerply.com).
 *
 * Loads after brand/tokens.css and css/site.css. Denser than the
 * customer portal: table-first, mono font on identifiers, single
 * "PRODUCTION" pill in the top bar to keep the operator aware they
 * are on live infrastructure. Class names prefixed `admin-`.
 */

.admin-shell {
  min-height: 100dvh;
  display: grid;
  grid-template-columns: 14rem 1fr;
  grid-template-rows: auto 1fr;
  grid-template-areas:
    "rail topbar"
    "rail content";
  background: var(--color-bg);
}

@media (max-width: 920px) {
  .admin-shell {
    grid-template-columns: 1fr;
    grid-template-areas: "topbar" "rail" "content";
  }
}

/* --- Left rail --- */
.admin-rail {
  grid-area: rail;
  background: #14334A; /* one shade deeper than brand navy */
  color: #FFFFFF;
  padding: var(--space-4) var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  border-right: 1px solid #0E283C;
}

.admin-rail-brand {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: #FFFFFF;
  text-decoration: none;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  letter-spacing: var(--tracking-tight);
}

.admin-rail-brand svg {
  color: var(--color-highlight);
}

.admin-rail-subtitle {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-fg-subtle);
  margin: 2px 0 var(--space-4);
}

.admin-rail-nav {
  display: flex;
  flex-direction: column;
  gap: 2px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.admin-rail-nav a {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  color: var(--color-fg-subtle);
  text-decoration: none;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: 500;
  transition: background var(--duration-120) var(--ease-standard),
              color var(--duration-120) var(--ease-standard);
}

.admin-rail-nav a:hover {
  background: rgba(255, 255, 255, 0.04);
  color: #FFFFFF;
}

.admin-rail-nav a[aria-current="page"] {
  background: rgba(245, 205, 27, 0.12);
  color: var(--color-highlight);
}

.admin-rail-footer {
  margin-top: auto;
  font-size: var(--text-xs);
  color: var(--color-fg-subtle);
  padding-top: var(--space-3);
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}

/* --- Top bar --- */
.admin-topbar {
  grid-area: topbar;
  background: var(--color-bg);
  border-bottom: 1px solid var(--color-border);
  padding: var(--space-3) var(--space-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.admin-environment-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 4px 12px;
  border-radius: var(--radius-full);
  background: var(--color-highlight);
  color: var(--color-fg);
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.10em;
}

.admin-environment-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--color-fg);
}

.admin-user {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-fg-muted);
}

.admin-signin-cta {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  background: var(--color-fg);
  color: #FFFFFF;
  text-decoration: none;
  border: 1px solid var(--color-fg);
}

/* --- Content --- */
.admin-content {
  grid-area: content;
  padding: var(--space-6) var(--space-6);
  max-width: 96rem;
  width: 100%;
  margin: 0 auto;
}

.admin-content h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  letter-spacing: var(--tracking-tight);
  color: var(--color-fg);
  margin: 0 0 var(--space-2);
}

.admin-content > .admin-page-lede {
  color: var(--color-fg-muted);
  font-size: var(--text-base);
  margin: 0 0 var(--space-6);
  max-width: 60ch;
}

.admin-content h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  margin: var(--space-6) 0 var(--space-3);
}

/* --- KPI grid --- */
.admin-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(13rem, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}

.admin-kpi {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.admin-kpi-label {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-fg-muted);
}

.admin-kpi-value {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  color: var(--color-fg);
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--tracking-tight);
}

.admin-kpi-value--signal { color: #6B5A0A; }
.admin-kpi-value--good   { color: var(--color-success); }
.admin-kpi-value--bad    { color: var(--color-danger); }

.admin-kpi-meta {
  font-size: var(--text-xs);
  color: var(--color-fg-subtle);
  margin-top: var(--space-1);
}

/* --- Data tables --- */
.admin-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.admin-table thead {
  background: var(--color-bg-elevated);
}

.admin-table th {
  text-align: left;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-fg-muted);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  white-space: nowrap;
}

.admin-table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  color: var(--color-fg);
}

.admin-table tbody tr:hover {
  background: var(--color-bg-elevated);
}

.admin-table tbody tr:last-child td {
  border-bottom: none;
}

.admin-id-mono {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-fg-muted);
}

/* --- Action pills (e.g. "Disabled in this slice") --- */
.admin-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.admin-pill--disabled { background: var(--color-bg-inset); color: var(--color-fg-muted); }
.admin-pill--active   { background: rgba(31, 122, 77, 0.14); color: var(--color-success); }
.admin-pill--warning  { background: rgba(180, 83, 9, 0.12); color: var(--color-warning); }
.admin-pill--danger   { background: rgba(185, 28, 28, 0.10); color: var(--color-danger); }

/* --- Sign-in hero (anonymous landing) --- */
.admin-hero {
  display: grid;
  place-items: center;
  text-align: center;
  padding: var(--space-10) var(--space-5);
  gap: var(--space-4);
  min-height: 65dvh;
}

.admin-hero-mark {
  color: var(--color-highlight);
  width: 72px;
  height: 72px;
}

.admin-hero h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  margin: 0;
  color: var(--color-fg);
}

.admin-hero p {
  color: var(--color-fg-muted);
  font-size: var(--text-base);
  max-width: 44ch;
  margin: 0;
}

@media (prefers-reduced-motion: reduce) {
  .admin-rail-nav a,
  .admin-signin-cta { transition: none; }
}

/* ── Tier D additions ───────────────────────────────────────── */

.admin-page-header {
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-5);
}
.admin-page-header h1 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  letter-spacing: var(--tracking-tight);
  color: var(--color-fg);
  margin: 0 0 var(--space-2) 0;
}
.admin-page-header p {
  color: var(--color-fg-muted);
  max-width: 70ch;
  margin: 0;
}
.admin-page-eyebrow {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: var(--color-fg-muted);
  margin: 0 0 var(--space-1) 0;
}
.admin-page-eyebrow a { color: var(--color-fg-muted); text-decoration: underline; }

.admin-loading {
  color: var(--color-fg-muted);
  font-style: italic;
  padding: var(--space-4) 0;
}

.admin-toolbar {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}
.admin-search {
  flex: 1 1 24rem;
  min-width: 0;
  padding: var(--space-2) var(--space-3);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--color-fg);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.admin-search:disabled {
  background: var(--color-bg-inset);
  color: var(--color-fg-subtle);
  cursor: not-allowed;
}

.admin-table-num { text-align: right; font-variant-numeric: tabular-nums; }

.admin-pill--good    { background: rgba(31, 122, 77, 0.14); color: var(--color-success); }
.admin-pill--bad     { background: rgba(185, 28, 28, 0.12); color: var(--color-danger); }
.admin-pill--neutral { background: var(--color-bg-inset); color: var(--color-fg-muted); }

.admin-table--audit td code,
.admin-table td code {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  background: var(--color-bg-inset);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  color: var(--color-fg);
}

.admin-tabstrip {
  display: flex;
  gap: var(--space-4);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-5);
  flex-wrap: wrap;
}
.admin-tabstrip a {
  padding: var(--space-2) 0;
  font-family: var(--font-display);
  font-size: var(--text-sm);
  color: var(--color-fg-muted);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color var(--duration-1) var(--ease-standard), border-color var(--duration-1) var(--ease-standard);
}
.admin-tabstrip a:hover { color: var(--color-fg); border-bottom-color: var(--color-border-strong); }

.admin-section {
  padding: var(--space-5) 0;
  border-top: 1px solid var(--color-border);
}
.admin-section:first-of-type { border-top: none; padding-top: 0; }
.admin-section h2 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  margin: 0 0 var(--space-3) 0;
  color: var(--color-fg);
}
.admin-section p { color: var(--color-fg-muted); max-width: 70ch; margin: 0 0 var(--space-2) 0; }

.admin-deflist {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
  margin: 0;
}
.admin-deflist > div {
  display: grid;
  grid-template-columns: 12rem 1fr;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px dashed var(--color-border);
}
.admin-deflist > div:last-child { border-bottom: none; }
.admin-deflist dt { color: var(--color-fg-muted); font-size: var(--text-sm); margin: 0; }
.admin-deflist dd { color: var(--color-fg); font-size: var(--text-sm); margin: 0; }

.admin-support-pin {
  font-size: var(--text-2xl);
  letter-spacing: 0.15em;
}
.admin-support-pin .admin-id-mono {
  font-size: var(--text-2xl);
  color: var(--color-fg);
}

.admin-fineprint {
  color: var(--color-fg-subtle);
  font-size: var(--text-xs);
  margin-top: var(--space-3);
}
.admin-fineprint code {
  font-family: var(--font-mono);
  background: var(--color-bg-inset);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
}

/* Tier E: theme toggle in rail footer */
.admin-rail-theme { margin-top: var(--space-3); }
.portal-rail-theme { margin-top: var(--space-3); }

