/* public.css — shared chrome for the public-facing JAP pages
   (home landing, business marketing, read-only job detail).

   Ported from the design mockups, scoped under `.jpub` (set via the
   root.html `body_class` block) so these hand-authored styles never leak
   into the Tailwind-driven in-app pages. Reuses the sign-in colour family;
   typography stays on the app's Inter (no Space Grotesk / Hanken Grotesk).

   Tailwind's preflight (app.css) already provides box-sizing + margin
   resets, so no universal reset is needed here. */

.jpub {
  --navy: #06243b;
  --navy-2: #0a3050;
  --blue: #1a5b8a;
  --blue-link: #2563eb;
  --slate-900: #0f1d2b;
  --slate-700: #334155;
  --slate-500: #64748b;
  --slate-400: #94a3b8;
  --slate-300: #cbd5e1;
  --slate-200: #e2e8f0;
  --slate-100: #f1f5f9;
  --slate-50: #f8fafc;
  --danger: #dc2626;
  --danger-bg: #fef1f1;
  --warn: #b45309;
  --warn-bg: #fdf4e3;

  color: var(--slate-900);
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.jpub .shell {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1148px;
  margin: 0 auto;
  padding: 0 32px;
}

/* ---------- navy hero band ---------- */
.jpub .band {
  background: linear-gradient(180deg, var(--navy) 0%, var(--navy-2) 100%);
  position: relative;
  overflow: hidden;
}

/* ---------- nav ---------- */
.jpub .nav {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 20px 0 14px;
}
.jpub .nav > a:first-child { flex: none; }   /* logo link keeps its size, never squished by the links */
.jpub .nav .logo-img { width: 132px; height: auto; display: block; }
.jpub .nav-links { display: flex; align-items: center; gap: 10px; margin-left: auto; }
.jpub .nav-link {
  font-weight: 600; font-size: 14.5px; letter-spacing: -0.01em;
  color: rgba(255, 255, 255, 0.85); text-decoration: none;
  padding: 9px 14px; border-radius: 10px; white-space: nowrap;
}
.jpub .nav-link:hover { background: rgba(255, 255, 255, 0.08); }
.jpub .nav-cta {
  font-weight: 600; font-size: 14.5px; letter-spacing: -0.01em;
  color: var(--navy); background: #fff; text-decoration: none;
  padding: 10px 18px; border-radius: 11px; white-space: nowrap;
  box-shadow: 0 10px 18px -10px rgba(0, 0, 0, 0.5);
}

/* ---------- chips ---------- */
.jpub .chip {
  font-weight: 600; font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--slate-700); background: var(--slate-100); border-radius: 7px; padding: 5px 9px;
}
.jpub .chip.loc {
  display: inline-flex; align-items: center; gap: 5px;
  text-transform: none; letter-spacing: 0; font-size: 12px; font-weight: 600;
  background: transparent; border: 1px solid var(--slate-200); color: var(--slate-500);
}
.jpub .chip.loc svg { width: 11px; height: 11px; stroke: var(--slate-400); fill: none; stroke-width: 2; }

/* ---------- step card (shared: home "steps" + business "how it works") ---------- */
.jpub .step {
  display: flex; align-items: flex-start; gap: 12px;
  background: #fff; border: 1px solid var(--slate-200); border-radius: 14px;
  padding: 15px 16px;
  box-shadow: 0 1px 2px rgba(15, 29, 43, 0.04), 0 18px 36px -28px rgba(6, 36, 59, 0.35);
}
.jpub .step .num {
  flex: none; width: 27px; height: 27px; border-radius: 50%;
  background: var(--navy); color: #fff;
  font-weight: 600; font-size: 13px;
  display: grid; place-items: center; margin-top: 1px;
}
.jpub .step h3 { font-weight: 600; font-size: 14.5px; color: var(--slate-900); letter-spacing: -0.01em; }
.jpub .step p { font-size: 13px; line-height: 1.45; color: var(--slate-500); margin-top: 3px; text-wrap: pretty; }

/* ---------- closing badge ---------- */
.jpub .closes {
  font-size: 12.5px; font-weight: 600; color: var(--slate-500);
  background: var(--slate-100); border-radius: 8px; padding: 5px 10px;
}
.jpub .closes.warn { color: var(--warn); background: var(--warn-bg); }
.jpub .closes.urgent { color: var(--danger); background: var(--danger-bg); }

/* ---------- footer ---------- */
.jpub .footer { margin-top: 72px; border-top: 1px solid var(--slate-200); background: #fff; }
.jpub .footer .shell { display: flex; justify-content: space-between; gap: 40px; padding-top: 36px; padding-bottom: 30px; }
.jpub .footer .logo-img { width: 118px; height: auto; }
.jpub .f-brand p { font-size: 13.5px; color: var(--slate-500); margin-top: 12px; max-width: 320px; text-wrap: pretty; }
.jpub .f-links { display: flex; gap: 56px; }
.jpub .f-col h4 { font-weight: 600; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--slate-400); margin-bottom: 12px; }
.jpub .f-col a { display: block; font-size: 14px; color: var(--slate-700); text-decoration: none; margin-top: 8px; }
.jpub .f-col a:hover { color: var(--blue-link); }
.jpub .copyright { border-top: 1px solid var(--slate-100); padding: 14px 0 18px; }
.jpub .copyright .shell { padding-top: 0; padding-bottom: 0; }
.jpub .copyright span { font-size: 12.5px; color: var(--slate-400); }
.jpub .copyright a { color: inherit; text-decoration: none; }
.jpub .copyright a:hover { color: var(--blue-link); }

/* ---------- footer responsive ---------- */
@media (max-width: 720px) {
  .jpub .footer .shell { flex-direction: column; gap: 28px; }
  .jpub .f-links { gap: 40px; }
}

/* ---------- mobile chrome ---------- */
@media (max-width: 560px) {
  .jpub .shell { padding: 0 18px; }
  .jpub .nav { padding: 16px 0 12px; }
  .jpub .nav .logo-img { width: 112px; }
  .jpub .nav-link { padding: 8px 9px; font-size: 14px; }
  .jpub .nav-cta { padding: 9px 13px; font-size: 14px; }
}
