/* Canonical Hank palette — dark dev surface, cyan accent (onboarding step 15b). */
:root {
  --bg-primary: #0a0e14;
  --bg-elevated: #151b23;
  --bg-card: #1a222d;
  --text-primary: #e6edf3;
  --text-secondary: #8b949e;
  --text-muted: #484f58;
  --accent-cyan: #00d9ff;
  --accent-cyan-dim: rgba(0, 217, 255, 0.15);
  --accent-cyan-glow: rgba(0, 217, 255, 0.4);
  --accent-success: #00f5a0;
  --accent-error: #ff6b6b;
  --accent-warning: #ffd93d;
  --border-subtle: #21262d;
  --border-default: #30363d;
  --font-mono: "JetBrains Mono", "Fira Code", "SF Mono", monospace;
  --font-sans: "DM Sans", system-ui, sans-serif;
  --radius: 10px;
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: var(--font-sans);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  line-height: 1.55;
}
a { color: var(--accent-cyan); text-decoration: none; }
a:hover { text-decoration: underline; }
code { font-family: var(--font-mono); background: var(--bg-elevated); padding: 0.1em 0.35em; border-radius: 5px; }

/* ---- Header (full-bleed) ---- */
.app-header {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; flex-wrap: wrap;
  padding: 0.85rem 1.4rem;
  border-bottom: 1px solid var(--border-default);
  background: var(--bg-primary);
}
.brand { font-family: var(--font-mono); font-weight: 700; font-size: 1.05rem; letter-spacing: 0.01em; }
.brand .logo, .brand .logo-2 { color: var(--text-primary); }
.brand .logo-mark { color: var(--accent-cyan); }
.brand .release-badge {
  font-family: var(--font-mono); font-style: italic; font-weight: 600;
  font-size: 0.5em; letter-spacing: 0.02em; text-transform: lowercase;
  text-decoration: none; color: var(--accent-cyan);
  text-shadow: 0 0 9px var(--accent-cyan-glow);
  position: relative; top: -0.9em; margin-left: 0.16em;
}
.brand .release-badge:hover { text-shadow: 0 0 14px var(--accent-cyan-glow); }
.meta { display: flex; align-items: center; gap: 0.5rem; flex-wrap: wrap; }
.pill {
  font-family: var(--font-mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.03em;
  padding: 0.28rem 0.6rem; border: 1px solid var(--border-default); border-radius: 999px;
  color: var(--text-secondary); background: var(--bg-elevated);
}
button.pill { cursor: pointer; transition: border-color 0.12s, color 0.12s; }
button.pill:hover { border-color: var(--accent-cyan); color: var(--accent-cyan); }
button.pill:active { transform: translateY(1px); }
.pill.identity { color: var(--text-primary); border-color: var(--border-default); text-transform: none; }
.pill.login { color: var(--accent-cyan); border-color: var(--accent-cyan); }

/* ---- Main ---- */
main { flex: 1; width: 100%; max-width: 60rem; margin: 0 auto; padding: 1.8rem 1.4rem; }

/* FOUC guard: server-rendered body.anon shows the landing, hides the app. */
#anon-landing { display: none; }
body.anon #anon-landing { display: block; }
body.anon main > .topgroup { display: none !important; }

#anon-landing h1 { font-family: var(--font-mono); font-weight: 700; }
#anon-landing .u { color: var(--accent-cyan); }
.lede { font-size: 1.05rem; max-width: 42rem; }
.features { list-style: none; padding: 0; max-width: 42rem; }
.features li { padding: 0.5rem 0; border-top: 1px solid var(--border-subtle); }
.muted { color: var(--text-muted); font-size: 0.9rem; }
.cta {
  font-family: var(--font-mono); font-weight: 600; cursor: pointer;
  background: var(--accent-cyan); color: #04222b; border: none;
  padding: 0.7rem 1.3rem; border-radius: var(--radius); margin: 0.6rem 0;
  transition: box-shadow 0.15s, transform 0.05s;
}
.cta:hover { box-shadow: 0 0 18px var(--accent-cyan-glow); }
.cta:active { transform: translateY(1px); }

/* ---- App cards ---- */
.card {
  background: var(--bg-card); border: 1px solid var(--border-default);
  border-radius: var(--radius); padding: 1.1rem 1.2rem; margin-bottom: 1.2rem;
}
.card h2 { margin: 0 0 0.7rem; font-size: 1rem; }
textarea, input[type="file"] {
  width: 100%; font-family: var(--font-mono); font-size: 0.9rem;
  background: var(--bg-primary); color: var(--text-primary);
  border: 1px solid var(--border-default); border-radius: 7px; padding: 0.6rem;
}
textarea:focus { outline: none; border-color: var(--accent-cyan); }
.row { display: flex; align-items: center; gap: 0.8rem; margin-top: 0.7rem; }
button.primary {
  font-family: var(--font-mono); font-weight: 600; cursor: pointer;
  background: var(--accent-cyan-dim); color: var(--accent-cyan);
  border: 1px solid var(--accent-cyan); border-radius: 7px; padding: 0.5rem 1rem;
  transition: box-shadow 0.15s, transform 0.05s;
}
button.primary:hover { box-shadow: 0 0 14px var(--accent-cyan-glow); }
button.primary:active { transform: translateY(1px); }
button[disabled] { opacity: 0.5; cursor: progress; }
.status { color: var(--text-secondary); font-size: 0.85rem; font-family: var(--font-mono); }
.status.error { color: var(--accent-error); }
/* Processing state: a pulsing dot prefix while a job is pending/running. */
.status.processing::before {
  content: "";
  display: inline-block;
  width: 0.55em; height: 0.55em; margin-right: 0.5em;
  border-radius: 50%;
  background: var(--accent-cyan, #00d9ff);
  animation: sh-pulse 1s ease-in-out infinite;
}
@keyframes sh-pulse {
  0%, 100% { opacity: 0.25; transform: scale(0.7); }
  50% { opacity: 1; transform: scale(1); }
}
@media (prefers-reduced-motion: reduce) {
  .status.processing::before { animation: none; opacity: 0.8; }
}
.out {
  margin-top: 0.9rem; background: var(--bg-primary); border: 1px solid var(--border-subtle);
  border-radius: 7px; padding: 0.8rem; white-space: pre-wrap; word-break: break-word;
  font-family: var(--font-mono); font-size: 0.85rem; max-height: 26rem; overflow: auto;
}
.meta-line { margin-top: 0.5rem; color: var(--text-secondary); font-family: var(--font-mono); font-size: 0.8rem; }

/* ---- Credit bar + rate banner ---- */
.credit-bar { display: flex; align-items: center; gap: 0.6rem; margin-bottom: 1rem; font-family: var(--font-mono); font-size: 0.8rem; }
.cb-label { color: var(--text-secondary); text-transform: uppercase; letter-spacing: 0.04em; }
.cb-track { flex: 0 0 200px; height: 7px; background: var(--bg-elevated); border-radius: 999px; overflow: hidden; }
.cb-fill { display: block; height: 100%; width: 0; background: var(--accent-cyan); transition: width 0.3s; }
.cb-fill.over { background: var(--accent-error); }
.cb-text { color: var(--text-secondary); font-variant-numeric: tabular-nums; }
.banner { padding: 0.6rem 0.9rem; border-radius: 7px; margin-bottom: 1rem; font-size: 0.9rem; }
.banner.warn { background: rgba(255, 217, 61, 0.12); border: 1px solid var(--accent-warning); color: var(--accent-warning); }

/* ---- Footer (full-bleed) ---- */
.app-footer { margin-top: auto; border-top: 1px solid var(--border-default); padding: 1rem 1.4rem; background: var(--bg-primary); }
.footer-row { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; }
.footer-build { margin-bottom: 0.5rem; }
.footer-legal { color: var(--text-muted); font-size: 0.82rem; font-family: var(--font-mono); }
