/*
 * static/app.css
 * nle-admin-portal — Northern Lights Epoxy admin CMS
 * (C) 2026 Chena Innovations LLC
 * Intellectual Property of Chena Innovations LLC & Northern Lights Epoxy
 * Created by Billy Jack Wiglesworth on April 20, 2026.
 *
 * Aurora-industrial: dark forest base, aurora-green accent, sharp edges,
 * monospaced data, system fonts only (no external font loads — fits the
 * "no external repos at runtime" rule).
 */

:root {
  --bg:         #0a0e0a;
  --bg-elev:    #121712;
  --bg-card:    #ffffff;
  --bg-hover:   #1a221a;
  --bg-active:  rgba(95, 255, 175, 0.07);

  --border:     #1f2820;
  --border-hi:  #2c3a2c;

  --fg:         #e6f0e6;
  --fg-strong:  #ffffff;
  --fg-dim:     #8a9a8a;
  --fg-faint:   #5a6a5a;

  --accent:     #5fffaf;
  --accent-dim: #3fcc8c;
  --accent-bg:  rgba(95, 255, 175, 0.12);

  --warn:       #ffb95f;
  --danger:     #ff5f7a;

  --font-sans:  ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  --font-mono:  ui-monospace, "SF Mono", "Cascadia Mono", "JetBrains Mono", Menlo, Consolas, monospace;

  --t-xs:   11px;
  --t-sm:   13px;
  --t-base: 14px;
  --t-md:   15px;
  --t-lg:   18px;
  --t-xl:   22px;
  --t-2xl:  28px;

  --radius:    4px;
  --radius-sm: 2px;

  --sidebar-w: 248px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--font-sans);
  font-size: var(--t-base);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Aurora glow at the top of the page — subtle, on every page. */
body::before {
  content: "";
  position: fixed;
  top: -120px; left: 50%;
  width: 1200px; height: 320px;
  transform: translateX(-50%);
  background: radial-gradient(
    ellipse at center,
    rgba(95, 255, 175, 0.06) 0%,
    rgba(95, 255, 175, 0.02) 35%,
    transparent 70%
  );
  pointer-events: none;
  z-index: 0;
}

body { display: flex; min-height: 100vh; }
body.page-blank { display: block; }

/* ============================================================ Sidebar */

.sidebar {
  width: var(--sidebar-w);
  flex-shrink: 0;
  background: var(--bg-elev);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
}

.brand {
  padding: 24px 20px 20px;
  border-bottom: 1px solid var(--border);
}
.brand-mark {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: var(--accent);
  text-shadow: 0 0 24px rgba(95, 255, 175, 0.25);
}
.brand-mark-lg {
  font-size: 32px;
  letter-spacing: 0.08em;
}
.brand-sub {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  color: var(--fg-faint);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-top: 2px;
}

.nav {
  display: flex;
  flex-direction: column;
  padding: 12px 8px;
  flex: 1;
}
.nav a, .nav-disabled {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  color: var(--fg-dim);
  text-decoration: none;
  font-size: var(--t-base);
  border-radius: var(--radius);
  transition: background 80ms, color 80ms;
}
.nav a:hover {
  color: var(--fg);
  background: var(--bg-hover);
}
.nav a.is-active {
  color: var(--accent);
  background: var(--accent-bg);
}
.nav-disabled {
  color: var(--fg-faint);
  cursor: default;
}
.nav-disabled em {
  margin-left: auto;
  font-size: var(--t-xs);
  font-style: normal;
  font-family: var(--font-mono);
  color: var(--fg-faint);
  opacity: 0.7;
}
.nav-key {
  display: inline-block;
  width: 18px; height: 18px;
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  text-align: center;
  line-height: 18px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--fg-faint);
}
.nav a.is-active .nav-key {
  border-color: var(--accent);
  color: var(--accent);
}

.who {
  padding: 16px 20px;
  border-top: 1px solid var(--border);
}
.who-name { font-weight: 600; font-size: var(--t-sm); }
.who-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 4px 0 12px;
  font-size: var(--t-xs);
  color: var(--fg-dim);
}
.who-email { font-family: var(--font-mono); }

/* ============================================================ Main */

.main {
  flex: 1;
  padding: 32px 40px;
  max-width: 1280px;
  position: relative;
  z-index: 1;
}

.page-head {
  margin-bottom: 28px;
}
.page-head h1 {
  margin: 0;
  font-size: var(--t-2xl);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--fg-strong);
}
.page-head p { margin: 4px 0 0; }
.page-head .back {
  display: inline-block;
  margin-bottom: 6px;
  font-size: var(--t-sm);
  color: var(--fg-dim);
  text-decoration: none;
  font-family: var(--font-mono);
}
.page-head .back:hover { color: var(--accent); }

/* ============================================================ Stats */

.stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 16px;
  margin-bottom: 32px;
}
.stat {
  display: block;
  padding: 20px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  text-decoration: none;
  color: inherit;
  transition: border-color 100ms, transform 100ms;
}
.stat:hover {
  border-color: var(--border-hi);
  transform: translateY(-1px);
}
.stat-num {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 600;
  color: var(--accent);
  line-height: 1;
  margin-bottom: 8px;
}
.stat-muted .stat-num { color: var(--fg-dim); }
.stat-label { font-size: var(--t-sm); color: var(--fg); }
.stat-cta {
  font-size: var(--t-xs);
  color: var(--fg-dim);
  font-family: var(--font-mono);
  margin-top: 12px;
  letter-spacing: 0.04em;
}

/* ============================================================ Card */

.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 24px;
  overflow: hidden;
}
.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
}
.card-head h2 {
  margin: 0;
  font-size: var(--t-md);
  font-weight: 600;
  letter-spacing: -0.005em;
}

/* ============================================================ Table */

table.data {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--t-sm);
}
table.data th, table.data td {
  text-align: left;
  padding: 10px 20px;
  border-bottom: 1px solid var(--border);
}
table.data th {
  font-weight: 500;
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--fg-dim);
  background: var(--bg-elev);
}
table.data tbody tr {
  transition: background 80ms;
}
table.data tbody tr:hover { background: var(--bg-hover); cursor: pointer; }
table.data tbody tr:last-child td { border-bottom: none; }
table.data .num { text-align: right; }
table.data .actions { text-align: right; }
table.data .actions a {
  color: var(--accent);
  text-decoration: none;
  font-family: var(--font-mono);
  font-size: var(--t-xs);
}

/* ============================================================ Status pills */

.status {
  display: inline-block;
  padding: 2px 8px;
  font-size: var(--t-xs);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-radius: var(--radius-sm);
  background: var(--bg-elev);
  color: var(--fg-dim);
  border: 1px solid var(--border);
}
.status-new      { color: var(--accent); border-color: var(--accent); background: var(--accent-bg); }
.status-progress { color: var(--warn); border-color: rgba(255, 185, 95, 0.4); background: rgba(255, 185, 95, 0.08); }
.status-sent     { color: #5fc6ff; border-color: rgba(95, 198, 255, 0.4); background: rgba(95, 198, 255, 0.08); }
.status-good     { color: var(--accent); border-color: var(--accent); }
.status-bad      { color: var(--danger); border-color: rgba(255, 95, 122, 0.4); background: rgba(255, 95, 122, 0.06); }
.status-muted    { color: var(--fg-faint); }

.role {
  display: inline-block;
  padding: 1px 6px;
  font-size: 10px;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: var(--radius-sm);
  background: var(--bg);
  border: 1px solid var(--border);
  color: var(--fg-faint);
}
.role-admin { color: var(--accent); border-color: var(--accent); }
.role-staff { color: var(--warn); border-color: rgba(255, 185, 95, 0.4); }

/* ============================================================ Filterbar */

.filterbar {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  padding: 4px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  width: fit-content;
}
.filterbar a {
  padding: 6px 14px;
  font-size: var(--t-sm);
  color: var(--fg-dim);
  text-decoration: none;
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  text-transform: lowercase;
  letter-spacing: 0.02em;
}
.filterbar a:hover { color: var(--fg); background: var(--bg-hover); }
.filterbar a.is-active {
  background: var(--accent-bg);
  color: var(--accent);
}

/* ============================================================ Forms */

label {
  display: block;
  margin-bottom: 16px;
  font-size: var(--t-sm);
}
label > span {
  display: block;
  margin-bottom: 6px;
  font-weight: 500;
  color: var(--fg);
}
label em {
  font-style: normal;
  color: var(--fg-faint);
  font-size: var(--t-xs);
  font-family: var(--font-mono);
  margin-left: 6px;
}
label.inline {
  display: flex;
  align-items: center;
  gap: 8px;
}
label.inline > span {
  margin: 0;
}
label.inline input { margin: 0; }

input[type="text"], input[type="password"], input[type="email"],
input[type="number"], select, textarea {
  width: 100%;
  padding: 9px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--fg-strong);
  font-family: var(--font-sans);
  font-size: var(--t-base);
  transition: border-color 100ms, box-shadow 100ms;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-bg);
}

textarea { resize: vertical; min-height: 96px; }
textarea.code-area {
  font-family: var(--font-mono);
  font-size: var(--t-sm);
  line-height: 1.6;
  background: var(--bg);
  tab-size: 2;
}

.stacked { padding: 20px; }
.actions-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-top: 16px;
}

/* ============================================================ Buttons */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 18px;
  font-family: var(--font-sans);
  font-size: var(--t-sm);
  font-weight: 500;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: transparent;
  color: var(--fg);
  text-decoration: none;
  cursor: pointer;
  transition: all 100ms;
}
.btn:hover { border-color: var(--border-hi); background: var(--bg-hover); }
.btn-primary {
  background: var(--accent);
  color: var(--bg);
  border-color: var(--accent);
  font-weight: 600;
}
.btn-primary:hover {
  background: var(--accent-dim);
  border-color: var(--accent-dim);
}
.btn-ghost {
  background: transparent;
  color: var(--fg-dim);
}
.btn-ghost:hover { color: var(--fg); }
.btn-sm { padding: 4px 10px; font-size: var(--t-xs); }
.btn-block { width: 100%; padding: 12px; }

/* ============================================================ Login */

.login-shell {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 32px;
}
.login-card {
  width: 100%;
  max-width: 380px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 40px 32px;
}
.login-card header { text-align: center; margin-bottom: 28px; }
.login-card h1 {
  margin: 8px 0 4px;
  font-size: var(--t-md);
  font-weight: 500;
  text-transform: lowercase;
  letter-spacing: 0.06em;
  color: var(--fg-dim);
}
.login-foot {
  margin-top: 24px;
  text-align: center;
  color: var(--fg-faint);
  font-size: var(--t-xs);
}
.login-foot code {
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  letter-spacing: 0.02em;
}

/* ============================================================ kv list */

dl.kv {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 8px 16px;
  padding: 20px;
  margin: 0;
  font-size: var(--t-sm);
}
dl.kv dt {
  color: var(--fg-dim);
  font-family: var(--font-mono);
  font-size: var(--t-xs);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding-top: 2px;
}
dl.kv dd { margin: 0; }
.prewrap { white-space: pre-wrap; }

/* ============================================================ Misc */

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

.empty {
  padding: 60px 20px;
  text-align: center;
  color: var(--fg-dim);
}
.empty p { margin: 0 0 6px; }

.flash {
  margin-bottom: 16px;
  padding: 10px 14px;
  border-radius: var(--radius);
  font-size: var(--t-sm);
  border: 1px solid;
}
.flash-ok  { color: var(--accent); border-color: var(--accent); background: var(--accent-bg); }
.flash-err { color: var(--danger); border-color: rgba(255, 95, 122, 0.4); background: rgba(255, 95, 122, 0.08); }

.muted    { color: var(--fg-dim); }
.dim      { color: var(--fg-faint); }
.mono     { font-family: var(--font-mono); }
.num      { text-align: right; }

code { font-family: var(--font-mono); font-size: 0.92em; }

/* === Light-card override: white surfaces with dark text on the aurora shell === */
.card,
.stat,
.login-card {
  background: #ffffff;
  color: #14181a;
  border-color: rgba(0, 0, 0, 0.08);
}

.card-head {
  background: #fafbfc;
  border-bottom-color: rgba(0, 0, 0, 0.06);
}
.card-head h2 { color: #14181a; }

/* Tables inside white cards */
.card table.data th {
  background: #f6f7f9;
  color: #5a6470;
  border-bottom-color: rgba(0, 0, 0, 0.06);
}
.card table.data td {
  color: #14181a;
  border-bottom-color: rgba(0, 0, 0, 0.05);
}
.card table.data tbody tr:hover { background: #f4f8f5; }

/* Stat cards */
.stat-num   { color: #0a8757; }       /* aurora green, darker for contrast on white */
.stat-label { color: #14181a; }
.stat-cta   { color: #5a6470; }
.stat-muted .stat-num { color: #5a6470; }

/* Definition lists inside white cards */
.card dl.kv dt { color: #5a6470; }
.card dl.kv dd { color: #14181a; }

/* Form inputs on white cards */
.card input[type="text"],
.card input[type="password"],
.card input[type="email"],
.card input[type="number"],
.card select,
.card textarea {
  background: #ffffff;
  color: #14181a;
  border-color: rgba(0, 0, 0, 0.15);
}
.card input:focus,
.card select:focus,
.card textarea:focus {
  border-color: #0a8757;
  box-shadow: 0 0 0 3px rgba(10, 135, 87, 0.15);
}
.card label > span { color: #14181a; }
.card label em    { color: #6a7480; }

/* Status pills get a light-card variant — outline against white */
.card .status                 { background: #f6f7f9; color: #5a6470; border-color: rgba(0,0,0,0.1); }
.card .status-new             { color: #0a8757; border-color: #0a8757; background: #e6f9f0; }
.card .status-progress        { color: #b56c00; border-color: #f0b75a; background: #fff4e0; }
.card .status-sent            { color: #1d4d8c; border-color: #93b8e0; background: #e8f0fa; }
.card .status-good            { color: #0a8757; border-color: #0a8757; }
.card .status-bad             { color: #b3203b; border-color: #e69aa8; background: #fde8ec; }
.card .status-muted           { color: #6a7480; }

/* Role pill on the white admin-portal context still lives in the dark sidebar
 * — leave .role rules alone, they were designed for dark bg. */

/* Empty state in white card */
.card .empty       { color: #5a6470; }

/* Mono dim/dim helpers inside cards: re-tone for contrast */
.card .dim         { color: #6a7480; }
.card .muted       { color: #5a6470; }

/* Login card — explicit since it doesn't inherit .card */
.login-card header h1   { color: #5a6470; }
.login-card .muted      { color: #5a6470; }
.login-card .login-foot { color: #6a7480; }
.login-card label > span { color: #14181a; }
.login-card input        {
  background: #ffffff; color: #14181a;
  border-color: rgba(0, 0, 0, 0.15);
}
.login-card input:focus  {
  border-color: #0a8757;
  box-shadow: 0 0 0 3px rgba(10, 135, 87, 0.15);
}

/* Filterbar stays dark — it's outside the cards. Leave alone. */

/* Code blocks inside cards */
.card code { color: #14181a; background: #f6f7f9; padding: 1px 4px; border-radius: 2px; }


.inline-form {
  display: flex;
  gap: 8px;
  align-items: center;
}
.inline-form input[type="text"] {
  width: 220px;
  padding: 5px 10px;
  font-size: var(--t-sm);
  font-family: var(--font-mono);
}

/* ============================================================ Danger surfaces */

.card-danger {
  border-color: rgba(255, 95, 122, 0.3);
  margin-top: 24px;
}
.card-danger .card-head h2 { color: var(--danger); }

.btn-danger {
  background: var(--danger);
  border-color: var(--danger);
  color: var(--bg);
}
.btn-danger:hover {
  background: #ff7a92;
  border-color: #ff7a92;
}