/* ────────────────────────────────────────────────────────────
   JBNY light theme — shared palette + components.
   Import this BEFORE any template-specific overrides:
     <link href="https://api.fontshare.com/v2/css?f[]=nexa@400,500,600,700,800&display=swap" rel="stylesheet">
     <link href="https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;700&display=swap" rel="stylesheet">
     <link rel="stylesheet" href="/static/jbny-light.css">

   Then templates can scope tweaks in their own <style> block.
   Palette tokens are CSS custom properties — override in :root
   on a per-template basis if needed.
   ──────────────────────────────────────────────────────────── */

:root {
  /* Ink / paper */
  --ink: #0a0a0a;
  --ink-soft: #2a2a2a;
  --paper: #ffffff;
  --paper-soft: #fafafa;
  --rule: #ebebeb;
  --rule-strong: #d6d6d6;

  /* JB brand */
  --jb-blue: #2A3B8E;
  --jb-blue-deep: #1a2566;
  --jb-blue-soft: #f0f4ff;
  --jb-red: #DA2342;
  --jb-red-deep: #9c1731;
  --jb-red-soft: #fff0f1;
  --jb-yellow: #FAED31;
  --jb-yellow-soft: #fef9c8;

  /* Status */
  --good: #1f7a3e;
  --good-soft: #ebfaef;
  --warn: #b8740a;
  --warn-soft: #fff4d9;
  --err: #b3122c;
  --err-soft: #fff0f1;
  --dim: #6a6a6a;

  /* Legacy aliases (so dark-theme templates can be migrated without
     touching every reference). Keep these as we migrate. */
  --black: var(--ink);
  --white: var(--paper);
  --smoke: var(--paper-soft);
  --gold: var(--jb-blue);
  --gold-dim: var(--dim);
  --border: var(--rule);
  --cloud: var(--ink);
  --navy: var(--jb-blue);
  --yellow: var(--jb-yellow);
  --red: var(--jb-red);
  --ember: var(--jb-red);
}

* { box-sizing: border-box; margin: 0; padding: 0; -webkit-tap-highlight-color: transparent; }
html, body { overscroll-behavior-x: none; }
body {
  background: var(--paper);
  color: var(--ink);
  font-family: 'Nexa', 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  min-height: 100vh;
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ───── Brand bar ───── */
.brand-bar {
  background: var(--paper);
  padding: 18px 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--rule);
  position: sticky;
  top: 0;
  z-index: 50;
  gap: 14px;
  flex-wrap: wrap;
}
.brand-bar .logo-wrap { display: flex; align-items: center; gap: 14px; text-decoration: none; }
.brand-bar img.logo { height: 42px; width: auto; transition: transform 0.25s ease; cursor: pointer; }
.brand-bar img.logo:hover { transform: rotate(-2deg) scale(1.04); }
.brand-bar .meta {
  font-size: 10px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--dim); font-weight: 700; line-height: 1; padding-left: 14px;
  border-left: 1px solid var(--rule); display: none;
}
@media (min-width: 640px) { .brand-bar .meta { display: block; } }
.brand-bar .nav { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; }
.brand-bar .nav-link, .brand-bar a.nav-link {
  font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--ink); text-decoration: none; font-weight: 700;
  padding: 8px 16px; border-radius: 999px;
  border: 2px solid var(--ink); transition: all 0.18s;
  background: var(--paper);
  cursor: pointer;
}
.brand-bar .nav-link:hover { background: var(--ink); color: var(--paper); }
.brand-bar .nav-link.current { background: var(--ink); color: var(--paper); }
.brand-bar .nav-link.primary { background: var(--jb-red); color: var(--paper); border-color: var(--jb-red); }
.brand-bar .nav-link.primary:hover { background: var(--jb-red-deep); border-color: var(--jb-red-deep); }
.brand-bar .nav-link.secondary { background: var(--paper); color: var(--jb-blue); border-color: var(--jb-blue); }
.brand-bar .nav-link.secondary:hover { background: var(--jb-blue); color: var(--paper); }

/* ───── Typography ───── */
h1, h2, h3 { font-family: 'Nexa', 'Inter', sans-serif; color: var(--ink); letter-spacing: -0.005em; }
h1 { font-size: clamp(28px, 4vw, 44px); line-height: 1.05; font-weight: 800; margin-bottom: 8px; }
h2 { font-size: 22px; line-height: 1.15; font-weight: 800; margin-bottom: 8px; }
h3 { font-size: 16px; line-height: 1.2; font-weight: 800; margin-bottom: 6px; }
.lede { font-size: 16px; line-height: 1.5; color: var(--ink-soft); font-weight: 500; }
.eyebrow {
  display: inline-block; font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--paper); font-weight: 800; background: var(--jb-blue);
  padding: 5px 11px; border-radius: 4px; margin-bottom: 14px;
}
.eyebrow.red { background: var(--jb-red); }
.eyebrow.yellow { background: var(--jb-yellow); color: var(--ink); }

/* ───── Layout ───── */
.wrap { max-width: 1180px; margin: 0 auto; padding: 28px 24px; }
.wrap.narrow { max-width: 720px; }
.wrap.wide { max-width: 1400px; }

/* ───── Cards / sections ───── */
.card {
  background: var(--paper); border: 1px solid var(--rule); border-radius: 12px;
  padding: 22px;
  transition: transform 0.15s, box-shadow 0.18s, border-color 0.18s;
}
.card.flat { box-shadow: none; }
.card:hover.card-hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(42,59,142,0.10), 0 4px 10px rgba(0,0,0,0.04);
  border-color: var(--jb-blue);
}
.panel {
  background: var(--paper-soft); border: 1px solid var(--rule); border-radius: 14px; padding: 24px;
}
.section-title {
  font-family: 'Nexa', sans-serif; font-size: 12px; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--dim); margin-bottom: 14px; font-weight: 800;
}

/* ───── Form fields ───── */
.field { margin-bottom: 14px; text-align: left; }
.field label, label.field-label {
  display: block; font-size: 10px; letter-spacing: 0.16em;
  color: var(--dim); text-transform: uppercase; margin-bottom: 6px; font-weight: 700;
}
.field input, .field select, .field textarea,
input[type="text"]:not(.naked), input[type="email"]:not(.naked), input[type="tel"]:not(.naked),
input[type="password"]:not(.naked), input[type="number"]:not(.naked), input[type="url"]:not(.naked),
select.themed, textarea.themed {
  width: 100%; background: var(--paper); border: 1.5px solid var(--rule);
  color: var(--ink); font-family: 'Nexa', 'Inter', sans-serif;
  font-size: 16px; /* prevents iOS zoom-in-on-focus → keyboard bounce */
  padding: 12px 14px; outline: none; transition: border-color 0.18s, box-shadow 0.18s;
  -webkit-appearance: none; border-radius: 8px; font-weight: 500;
}
@media (min-width: 768px) {
  .field input, .field select, .field textarea,
  input[type="text"]:not(.naked), input[type="email"]:not(.naked), input[type="tel"]:not(.naked),
  input[type="password"]:not(.naked), input[type="number"]:not(.naked), input[type="url"]:not(.naked) {
    font-size: 14px;
  }
}
.field input:focus, .field select:focus, .field textarea:focus,
input:focus:not(.naked), select.themed:focus, textarea.themed:focus {
  border-color: var(--jb-blue);
  box-shadow: 0 0 0 3px rgba(42,59,142,0.12);
}
.field input::placeholder { color: #b8b8b8; }
.row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.row-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }

/* ───── Buttons ───── */
.btn {
  display: inline-block; padding: 13px 24px; border-radius: 8px;
  font-family: 'Nexa', sans-serif; font-size: 13px; font-weight: 800;
  letter-spacing: 0.14em; text-transform: uppercase; cursor: pointer;
  text-decoration: none; border: 2px solid transparent;
  transition: transform 0.1s, box-shadow 0.18s, background 0.18s, color 0.18s, border-color 0.18s;
  line-height: 1.2;
}
.btn-primary {
  background: var(--jb-red); color: var(--paper); border-color: var(--jb-red);
  box-shadow: 0 4px 14px rgba(218,35,66,0.22);
}
.btn-primary:hover { background: var(--jb-red-deep); border-color: var(--jb-red-deep); transform: translateY(-1px); }
.btn-primary:active { transform: translateY(0); }
.btn-secondary {
  background: var(--paper); color: var(--jb-blue); border-color: var(--jb-blue);
}
.btn-secondary:hover { background: var(--jb-blue); color: var(--paper); }
.btn-ghost {
  background: transparent; color: var(--ink); border-color: var(--rule-strong);
}
.btn-ghost:hover { border-color: var(--ink); }
.btn-dark {
  background: var(--ink); color: var(--paper); border-color: var(--ink);
}
.btn-dark:hover { background: var(--ink-soft); border-color: var(--ink-soft); }
.btn:disabled, .btn[disabled] { opacity: 0.45; cursor: not-allowed; transform: none; }
.btn-block { display: block; width: 100%; text-align: center; }

/* ───── Messages / badges ───── */
.msg { font-size: 13px; padding: 12px 14px; margin-bottom: 14px; border-radius: 8px; font-weight: 500; }
.msg-error { background: var(--err-soft); color: var(--err); border: 1px solid #f5b8be; }
.msg-success { background: var(--good-soft); color: var(--good); border: 1px solid #b6e3c1; }
.msg-info { background: var(--jb-blue-soft); color: var(--jb-blue-deep); border: 1px solid #c4d0f0; }
.msg-warn { background: var(--warn-soft); color: var(--warn); border: 1px solid #f0d894; }

.badge {
  display: inline-block; font-size: 9px; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 4px 8px; border-radius: 4px; font-weight: 800;
}
.badge-public  { background: var(--paper-soft); color: var(--dim); border: 1px solid var(--rule); }
.badge-gated   { background: var(--jb-blue-soft); color: var(--jb-blue); border: 1px solid #c4d0f0; }
.badge-admin   { background: var(--jb-red-soft); color: var(--jb-red); border: 1px solid #f5b8be; }
.badge-good    { background: var(--good-soft); color: var(--good); border: 1px solid #b6e3c1; }
.badge-warn    { background: var(--warn-soft); color: var(--warn); border: 1px solid #f0d894; }

/* ───── Tables ───── */
table.themed { width: 100%; border-collapse: collapse; font-size: 13px; }
table.themed th {
  text-align: left; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--dim); font-weight: 800; background: var(--paper-soft);
  padding: 12px 14px; border-bottom: 1px solid var(--rule);
}
table.themed td {
  padding: 11px 14px; border-bottom: 1px solid var(--rule); color: var(--ink); font-weight: 500;
}
table.themed tr:hover td { background: var(--paper-soft); }

/* ───── Code / mono ───── */
code, kbd, .mono { font-family: 'JetBrains Mono', monospace; font-size: 12px; }
code {
  background: var(--paper-soft); border: 1px solid var(--rule);
  padding: 2px 7px; border-radius: 4px; color: var(--ink);
}

/* ───── Utility ───── */
.text-blue { color: var(--jb-blue); }
.text-red  { color: var(--jb-red); }
.text-dim  { color: var(--dim); }
.bg-blue   { background: var(--jb-blue); color: var(--paper); }
.bg-red    { background: var(--jb-red); color: var(--paper); }
.bg-yellow { background: var(--jb-yellow); color: var(--ink); }
.divider { border-top: 1px solid var(--rule); margin: 24px 0; }

footer {
  border-top: 1px solid var(--rule); padding: 24px;
  text-align: center; color: var(--dim); font-size: 12px;
}
footer a { color: var(--ink); text-decoration: none; font-weight: 700; }
footer a:hover { color: var(--jb-red); }
