:root {
  --bg: #f4f2ec;
  --ink: #3a3733;
  --muted: #8a8175;
  --faint: #b3a99c;
  --hair: rgba(58, 55, 51, 0.10);
  --dot: rgba(58, 55, 51, 0.10);
  --accent: #d9a283;
  --logo: #bcb3a6;
  --radar-axis: rgba(58, 55, 51, 0.12);
  --radar-label: #c4bbae;

  --font-display: 'Syne', system-ui, sans-serif;
  --font-mono: 'IBM Plex Mono', ui-monospace, monospace;

  /* motion tokens — keep transforms/opacity only, custom easing over linear */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-draw: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-draw: 1.6s;
  --dur-fade: 0.4s;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; }

body {
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-display);
  -webkit-font-smoothing: antialiased;
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}

/* dot grid — radial-gradient dots, barely perceptible */
.dotgrid {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image: radial-gradient(var(--dot) 1px, transparent 1.4px);
  background-size: 26px 26px;
  background-position: 0 0;
}

header, main, footer { position: relative; z-index: 1; }

header {
  padding: 30px 40px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.logo {
  display: block;
  width: 104px;
  height: auto;
}
.logo path { fill: var(--logo); }

.tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--faint);
  text-transform: uppercase;
}

main {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 32px 24px;
  text-align: center;
}

.radar { display: block; width: 252px; height: 252px; }

h1 {
  font-family: var(--font-display);
  font-size: 25px;
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.02;
  margin: 18px 0 10px;
  color: var(--ink);
}

.sub {
  font-family: var(--font-display);
  font-size: 13px;
  font-weight: 400;
  line-height: 1.35;
  color: var(--muted);
  max-width: 400px;
}

/* headline + sub rise in on load — transform/opacity only */
.reveal {
  opacity: 0;
  transform: translateY(8px);
  animation: rise 0.7s var(--ease-out) forwards;
}
h1.reveal { animation-delay: 0.15s; }
p.reveal { animation-delay: 0.3s; }

@keyframes rise {
  to { opacity: 1; transform: translateY(0); }
}

footer {
  border-top: 0.5px solid var(--hair);
  padding: 14px 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
footer span {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--faint);
}

@media (max-width: 520px) {
  header, footer { padding-left: 22px; padding-right: 22px; }
  footer { flex-direction: column; gap: 6px; }
  .radar { width: 220px; height: 220px; }
  h1 { font-size: 22px; }
}

@media (prefers-reduced-motion: reduce) {
  .reveal { animation: none; opacity: 1; transform: none; }
}
