
/* Stage 1 - Input contrast fix + robust theming (keeps nav styles) */
/* ===== THEME TOKENS ===== */
:root {
  --bg: #0b0e14; --fg: #e6e6e6; --card: #141a22; --muted: #94a3b8;
  --accent: #4f46e5; --accent-2: #22d3ee; --ok: #16a34a; --warn: #d97706; --bad: #dc2626;

  /* Nav (dark) */
  --nav-border: #1f2937;
  --nav-bg: transparent;
  --nav-text: var(--fg);
  --nav-hover-bg: #0e1726;
  --nav-hover-text: var(--fg);
  --nav-active-bg: #0e1726;
  --nav-active-text: #ffffff;
  --pill-bg: #0e1726; /* for .btn-secondary */
  --pill-text: var(--fg);

  /* Inputs (dark) */
  --input-bg: #0e1726;
  --input-fg: var(--fg);
  --input-border: var(--nav-border);
  --input-placeholder: var(--muted);
  --input-focus-border: var(--accent);
  --input-focus-ring: rgba(79,70,229,.32);
}
html.theme-light {
  --bg: #f7fafc; --fg: #0b0e14; --card: #ffffff; --muted: #475569;
  --accent: #4338ca; --accent-2: #0891b2; --ok: #15803d; --warn: #a16207; --bad: #b91c1c;

  /* Light theme nav: EXACT same light blue for all states */
  --nav-border: #c7ddff;
  --nav-text: #0b0e14;
  --nav-same-blue: #e8f1ff;

  --nav-bg: var(--nav-same-blue);
  --nav-hover-bg: var(--nav-same-blue);
  --nav-active-bg: var(--nav-same-blue);
  --nav-hover-text: var(--nav-text);
  --nav-active-text: var(--nav-text);

  --pill-bg: var(--nav-same-blue);
  --pill-text: var(--nav-text);

  /* Inputs (light) */
  --input-bg: #ffffff;          /* solid white to contrast dark text */
  --input-fg: #0b0e14;
  --input-border: #c7ddff;      /* match nav border */
  --input-placeholder: #6b7280; /* slate-ish */
  --input-focus-border: #4338ca;
  --input-focus-ring: rgba(67,56,202,.25);
}

/* ===== BASE ===== */
* { box-sizing: border-box; }
body { margin: 0; padding: 0; font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial, "Apple Color Emoji","Segoe UI Emoji"; background: var(--bg); color: var(--fg); }
a { color: var(--accent-2); text-decoration: none; }
a:hover { text-decoration: underline; }

.header { border-bottom: 1px solid var(--nav-border); background: var(--card); }
.container { max-width: 1200px; margin: 0 auto; padding: 16px; }

/* ===== BRAND ROW ===== */
.header .stack { display: grid; gap: 12px; padding-top: 8px; padding-bottom: 8px; }
.brand { display: flex; align-items: center; justify-content: center; gap: 12px; }
.brand .logo { width: 56px; height: 56px; border-radius: 16px; background: linear-gradient(135deg, var(--accent), var(--accent-2)); display: inline-flex; align-items: center; justify-content: center; font-weight: 800; color: white; font-size: 28px; }
.brand .name { font-size: 24px; font-weight: 800; letter-spacing: .3px; }

/* ===== NAV + USERMENU ROW ===== */
.navrow { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.nav { display: flex; flex-wrap: wrap; gap: 10px; }
.nav a {
  padding: 10px 12px; border-radius: 10px;
  background: var(--nav-bg); color: var(--nav-text);
  border: 1px solid var(--nav-border);
}
.nav a:hover { background: var(--nav-hover-bg); color: var(--nav-hover-text); }
.nav a.active { background: var(--nav-active-bg); color: var(--nav-active-text); }

.usermenu { display: flex; gap: 10px; align-items: center; margin-left: auto; }
.badge { padding: 6px 10px; border-radius: 999px; font-size: 12px; border: 1px solid var(--nav-border); color: var(--muted); }
.btn { background: var(--accent); color: white; border: none; border-radius: 10px; padding: 10px 14px; font-weight: 600; cursor: pointer; }
.btn-secondary { background: var(--pill-bg); color: var(--pill-text); }
.theme-toggle { background: transparent; border: 1px solid var(--nav-border); border-radius: 10px; padding: 6px 10px; color: var(--fg); cursor: pointer; }
.btn:disabled { opacity: .6; cursor: not-allowed; }

/* ===== LAYOUT ===== */
.layout { display: grid; grid-template-columns: 240px 1fr; gap: 18px; margin-top: 16px; }
.sidebar { background: var(--card); border: 1px solid var(--nav-border); border-radius: 14px; padding: 12px; }
.sidebar h3 { margin: 8px 8px 12px; font-size: 14px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; }
.sidebar a { display: block; padding: 10px 12px; border-radius: 10px; color: var(--fg); }
.sidebar a:hover { background: var(--nav-hover-bg); }
.card { background: var(--card); border: 1px solid var(--nav-border); border-radius: 14px; padding: 16px; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { padding: 10px 8px; border-bottom: 1px solid var(--nav-border); text-align: left; }
.kv { display: grid; grid-template-columns: 200px 1fr; gap: 8px; }
.footer { color: var(--muted); border-top: 1px solid var(--nav-border); background: var(--card); margin-top: 24px; }

.alert { padding: 12px; border-radius: 10px; margin: 10px 0; }
.alert.ok { background: rgba(22,163,74,.15); border: 1px solid rgba(22,163,74,.35); }
.alert.warn { background: rgba(217,119,6,.15); border: 1px solid rgba(217,119,6,.35); }
.alert.bad { background: rgba(220,38,38,.15); border: 1px solid rgba(220,38,38,.35); }

/* ===== FORMS ===== */
.form { display: grid; gap: 12px; }
.input,
input.input, select.input, textarea.input {
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--input-border);
  background: var(--input-bg);
  color: var(--input-fg);
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease, color .15s ease;
}
.input::placeholder { color: var(--input-placeholder); }
.input:focus { outline: none; border-color: var(--input-focus-border); box-shadow: 0 0 0 3px var(--input-focus-ring); }

/* Fix WebKit autofill overriding colors */
input.input:-webkit-autofill,
select.input:-webkit-autofill,
textarea.input:-webkit-autofill {
  -webkit-text-fill-color: var(--input-fg) !important;
  -webkit-box-shadow: 0 0 0px 1000px var(--input-bg) inset !important;
  transition: background-color 5000s ease-in-out 0s;
}

/* ===== MISC ===== */
hr.sep { border: none; border-top: 1px solid var(--nav-border); margin: 12px 0; }
.small { font-size: 12px; color: var(--muted); }
.token-list { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); gap: 12px; }
@media (min-width: 700px) { .token-list { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (min-width: 1000px) { .token-list { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

/* ===== MOBILE NAV ===== */
@media (max-width: 720px) {
  .usermenu { margin-left: 0; justify-content: center; }
  .nav { justify-content: center; }
  .navrow { justify-content: center; }
}
