/* Zelazny Services — public site
 * Design goals: professional, conservative, fast on iPhone, prints clean.
 * No JS framework. No web fonts (system stack). Single CSS file.
 */

:root {
  --ink: #0d1117;
  --ink-2: #1f2937;
  --muted: #4b5563;
  --line: #e5e7eb;
  --bg: #ffffff;
  --bg-alt: #f7f8fa;
  --accent: #0b3a66;   /* deep aviation blue */
  --accent-2: #1457a3;
  --warn: #b45309;
  --ok: #15803d;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  line-height: 1.55;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}

a { color: var(--accent-2); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: 980px; margin: 0 auto; padding: 0 24px; }

/* Header */
header.site {
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  position: sticky; top: 0; z-index: 10;
}
header.site .container {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 14px; padding-bottom: 14px;
}
header.site .brand {
  display: flex; align-items: center; gap: 10px;
  font-weight: 700; color: var(--ink); font-size: 1.05em;
}
header.site .brand img { height: 28px; width: auto; }
header.site nav a {
  margin-left: 22px; color: var(--ink-2); font-weight: 500; font-size: 0.95em;
}
header.site nav a.cta {
  background: var(--accent); color: white;
  padding: 8px 14px; border-radius: 6px;
}
header.site nav a.cta:hover { background: var(--accent-2); text-decoration: none; }

/* Hero */
.hero { padding: 64px 0 48px; background: var(--bg-alt); border-bottom: 1px solid var(--line); }
.hero h1 { font-size: 2.4em; line-height: 1.15; margin: 0 0 16px; color: var(--ink); }
.hero p.lead { font-size: 1.2em; color: var(--muted); max-width: 680px; margin: 0 0 24px; }
.hero .actions a { margin-right: 12px; }

/* Generic sections */
main { padding: 48px 0; }
section { padding: 32px 0; }
section + section { border-top: 1px solid var(--line); }
h2 { font-size: 1.6em; margin: 0 0 16px; }
h3 { font-size: 1.15em; margin: 0 0 8px; color: var(--ink); }
p { margin: 8px 0; }
ul, ol { margin: 8px 0 16px; padding-left: 22px; }
li { margin: 4px 0; }

.subtitle { color: var(--muted); margin-top: -8px; }

/* Buttons */
.btn {
  display: inline-block; padding: 10px 18px; border-radius: 6px;
  background: var(--accent); color: white !important; font-weight: 600;
  border: 0; cursor: pointer; font-size: 1em;
}
.btn:hover { background: var(--accent-2); text-decoration: none; }
.btn.secondary { background: white; color: var(--accent) !important; border: 1px solid var(--accent); }
.btn.secondary:hover { background: var(--bg-alt); }
.btn:disabled { opacity: 0.5; cursor: wait; }

/* Service grid */
.grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 16px; }
.service {
  border: 1px solid var(--line); border-radius: 8px; padding: 20px;
  background: var(--bg); transition: border-color 0.15s, transform 0.15s;
}
.service:hover { border-color: var(--accent); transform: translateY(-1px); }
.service h3 { margin-bottom: 6px; color: var(--accent); }
.service p { font-size: 0.95em; color: var(--ink-2); margin: 0; }

/* Callout */
.callout {
  background: #fffbeb; border: 1px solid #fde68a; border-left: 4px solid var(--warn);
  padding: 14px 18px; border-radius: 6px; margin: 16px 0;
  color: #78350f; font-size: 0.95em;
}

/* Form */
form.intake { display: grid; gap: 14px; max-width: 640px; }
form.intake label { display: block; font-weight: 600; font-size: 0.9em; color: var(--ink-2); margin-bottom: 4px; }
form.intake input, form.intake select, form.intake textarea {
  width: 100%; padding: 10px 12px; border: 1px solid var(--line); border-radius: 6px;
  font: inherit; color: var(--ink); background: var(--bg);
}
form.intake textarea { min-height: 120px; resize: vertical; }
form.intake input:focus, form.intake select:focus, form.intake textarea:focus {
  outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px rgba(20,87,163,0.15);
}
form.intake .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
form.intake .row3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 14px; }
.form-status { padding: 12px 14px; border-radius: 6px; }
.form-status.ok { background: #f0fdf4; border: 1px solid #bbf7d0; color: var(--ok); }
.form-status.error { background: #fef2f2; border: 1px solid #fecaca; color: #b91c1c; }
.form-status.busy { background: var(--bg-alt); border: 1px solid var(--line); color: var(--muted); }

/* Report viewer */
.report-meta { background: var(--bg-alt); border: 1px solid var(--line); border-radius: 8px; padding: 16px; margin-bottom: 24px; }
.report-meta dl { display: grid; grid-template-columns: max-content 1fr; gap: 4px 14px; margin: 0; }
.report-meta dt { font-weight: 600; color: var(--muted); }
.report-meta dd { margin: 0; }
.scoreboard .pill { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 0.85em; margin-right: 4px; border: 1px solid var(--line); background: var(--bg); }
.scoreboard .pill.green { color: var(--ok); border-color: #bbf7d0; }
.scoreboard .pill.yellow { color: var(--warn); border-color: #fde68a; }
.scoreboard .pill.red { color: #b91c1c; border-color: #fecaca; }
.scoreboard .pill.grey { color: var(--muted); }
table.findings { width: 100%; border-collapse: collapse; margin-top: 12px; }
table.findings th, table.findings td { text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--line); font-size: 0.95em; vertical-align: top; }
table.findings th { background: var(--bg-alt); font-weight: 600; }

/* Footer */
footer.site {
  background: var(--ink); color: #cbd5e1; padding: 32px 0;
  font-size: 0.9em; margin-top: 64px;
}
footer.site a { color: #e5e7eb; }
footer.site .footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 24px; }
footer.site .legal { color: #94a3b8; margin-top: 24px; font-size: 0.85em; }

@media (max-width: 700px) {
  .hero { padding: 40px 0 32px; }
  .hero h1 { font-size: 1.8em; }
  header.site nav a { margin-left: 12px; font-size: 0.9em; }
  form.intake .row2, form.intake .row3 { grid-template-columns: 1fr; }
  footer.site .footer-grid { grid-template-columns: 1fr; }
}

@media print {
  header.site, footer.site, .hero .actions, form.intake { display: none; }
  body { color: black; background: white; }
  a { color: black; text-decoration: none; }
}
