/* Park WiFi captive portal — shared brand styles
   Used by login.html, alogin.html, status.html, logout.html, error.html. */

/* ─── self-hosted brand fonts ──────────────────────────────────────────── */
@font-face {
  font-family: "Inter";
  src: url("Inter-Variable.woff2") format("woff2-variations"),
       url("Inter-Variable.woff2") format("woff2");
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Mono";
  src: url("SpaceMono-Regular.woff2") format("woff2");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Space Mono";
  src: url("SpaceMono-Bold.woff2") format("woff2");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

/* ─── tokens ──────────────────────────────────────────────────────────── */
:root {
  --bg: #f6f4ee;
  --fg: #1a1a1a;
  --fg-muted: #5b5a55;
  --green: #0e7a3a;
  --green-deep: #0a5b2b;
  --green-soft: #e8efe1;
  --card: #fbfaf5;
  --border: rgba(0, 0, 0, 0.10);
  --border-strong: rgba(0, 0, 0, 0.18);
  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --mono: "Space Mono", ui-monospace, "SF Mono", "Cascadia Mono", Menlo, Consolas, "Liberation Mono", monospace;
}

/* ─── reset + base ────────────────────────────────────────────────────── */
* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body {
  margin: 0;
  padding: 0;
  min-height: 100%;
  background: var(--bg);
  color: var(--fg);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  font-synthesis: none;
}
body {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 22px 40px;
}
@media (min-width: 720px) {
  body { padding: 0 36px 60px; }
}

/* ─── shared header/footer rails ──────────────────────────────────────── */
.top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 20px 0;
  border-bottom: 1px solid var(--border);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--fg-muted);
}
.top .left { color: var(--green); }
.top svg { display: block; height: 18px; width: auto; }

.foot {
  padding: 22px 0 4px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fg-muted);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}

/* ─── typography primitives ───────────────────────────────────────────── */
.eyebrow {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--green);
  margin: 0 0 18px;
}
.eyebrow.muted { color: var(--fg-muted); }

h1.headline {
  margin: 0 0 18px;
  font-family: var(--sans);
  font-weight: 800;
  font-size: clamp(44px, 11vw, 88px);
  line-height: 0.9;
  letter-spacing: -0.025em;
  text-transform: uppercase;
  color: var(--fg);
}
h1.headline .accent { color: var(--green); }

h2.subheadline {
  margin: 0 0 20px;
  font-size: clamp(28px, 6vw, 42px);
  line-height: 0.95;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-transform: uppercase;
}

p.lede {
  margin: 0 0 24px;
  font-size: 15px;
  line-height: 1.55;
  max-width: 38ch;
  color: var(--fg);
}

/* ─── CTA button ──────────────────────────────────────────────────────── */
.cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  width: 100%;
  max-width: 360px;
  padding: 18px 24px;
  background: var(--fg);
  color: var(--bg);
  border: 1px solid var(--fg);
  border-radius: 0;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease, border-color 0.12s ease;
  font-synthesis: none;
  text-decoration: none;
}
.cta:hover { background: var(--green); border-color: var(--green); }
.cta:disabled { background: #999; border-color: #999; cursor: wait; }
.cta .arrow { font-family: var(--sans); font-weight: 400; font-size: 18px; }

.cta.danger { background: #b91c1c; border-color: #b91c1c; }
.cta.danger:hover { background: #7f1d1d; border-color: #7f1d1d; }

/* ─── error block ─────────────────────────────────────────────────────── */
.error {
  border: 1px solid var(--border-strong);
  border-left: 3px solid #b91c1c;
  background: #fff;
  padding: 12px 14px;
  margin: 0 0 18px;
  font-family: var(--mono);
  font-size: 12px;
  color: #7f1d1d;
  max-width: 38ch;
}
.error::before {
  content: "// error ";
  color: #b91c1c;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

/* ─── ViewEngine logo helpers ─────────────────────────────────────────── */
.ve-logo {
  display: block;
  width: clamp(180px, 42vw, 280px);
  height: auto;
}
.ve-logo path { fill: var(--fg); }

.ve-icon {
  display: block;
  width: 28px;
  height: auto;
}
.ve-icon path { fill: var(--green); }

/* ─── reusable hero/section padding ───────────────────────────────────── */
.hero {
  padding: 44px 0 36px;
  border-bottom: 1px solid var(--border);
}
.section {
  padding: 36px 0;
  border-bottom: 1px solid var(--border);
}
@media (min-width: 720px) {
  .hero { padding: 64px 0 56px; }
}
