/* Landing page (index) — bespoke hero layout.
   Extracted from the inline <style> block during the Eleventy migration so the
   home page can share the same <head> layout as every other page. Consumes the
   --cw-* design tokens from colour-within.css. */

.hero-min {
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto 1fr auto;
}

.hero-min .topbar {
  max-width: 1080px;
  width: 100%;
  margin: 0 auto;
  padding: 28px 32px 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.hero-min .topbar .lockup {
  display: inline-flex; align-items: center; gap: 12px;
}
.hero-min .topbar img.mark {
  width: 32px; height: 32px;
  border-radius: 7px;
}
.hero-min .topbar .name {
  font-family: var(--cw-font-serif);
  font-size: 17px;
  letter-spacing: -0.005em;
  color: var(--cw-text-primary);
}
.hero-min .topbar nav {
  display: inline-flex; flex-wrap: wrap; justify-content: flex-end; gap: 4px;
}
.hero-min .topbar nav a {
  font-family: var(--cw-font-rounded);
  font-weight: 500;
  font-size: 14px;
  color: var(--cw-text-secondary);
  text-decoration: none;
  padding: 8px 14px;
  border-radius: var(--cw-r-pill);
  transition: background .15s ease, color .15s ease;
}
.hero-min .topbar nav a:hover {
  background: var(--cw-accent-soft);
  color: var(--cw-text-primary);
}

.hero-min .stage {
  display: grid;
  place-items: center;
  padding: 32px 24px 48px;
}

.hero-min .center {
  max-width: 760px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 28px;
}

.hero-min .icon-large {
  width: 132px; height: 132px;
  border-radius: 30px;
  box-shadow: var(--cw-shadow-card-lg);
  display: block;
}

.hero-min .wordmark-img {
  width: min(560px, 78%);
  height: auto;
  display: block;
  filter: drop-shadow(0 1px 0 rgba(0,0,0,0.02));
}

.hero-min .tagline {
  font-family: var(--cw-font-serif);
  font-weight: 400;
  font-size: clamp(28px, 4.4vw, 42px);
  line-height: 1.18;
  letter-spacing: -0.015em;
  color: var(--cw-text-primary);
  margin: 4px 0 0;
  text-wrap: balance;
  max-width: 620px;
}

.hero-min .sub {
  font-family: var(--cw-font-rounded);
  font-weight: 400;
  font-size: 18px;
  line-height: 1.55;
  color: var(--cw-text-secondary);
  margin: 0;
  max-width: 520px;
  text-wrap: pretty;
}

.hero-min .appstore-badge {
  display: inline-block;
  line-height: 0;
  border-radius: 9px;
  transition: transform .15s ease, box-shadow .15s ease;
}
.hero-min .appstore-badge img {
  height: 56px;
  width: auto;
  display: block;
}
.hero-min .appstore-badge:hover {
  transform: translateY(-1px);
  box-shadow: var(--cw-shadow-card);
}
.hero-min .appstore-badge:active { transform: scale(0.98); }

.hero-min .pill-row {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 4px;
}
.hero-min .coming {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: var(--cw-r-pill);
  padding: 12px 20px;
  background: var(--cw-card-solid);
  border: 1px solid var(--cw-card-border);
  box-shadow: var(--cw-shadow-card);
  font-family: var(--cw-font-rounded);
  font-weight: 500;
  font-size: 15px;
  color: var(--cw-text-primary);
}
.hero-min .coming .dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--cw-success);
  box-shadow: 0 0 0 4px color-mix(in oklab, var(--cw-success) 22%, transparent);
}
.hero-min .secondary {
  font-family: var(--cw-font-rounded);
  font-weight: 500;
  font-size: 14px;
  color: var(--cw-text-secondary);
  text-decoration: none;
  padding: 12px 16px;
  border-radius: var(--cw-r-pill);
  transition: background .15s ease, color .15s ease;
}
.hero-min .secondary:hover { background: var(--cw-accent-soft); color: var(--cw-text-primary); }

@media (max-width: 600px) {
  .hero-min .topbar { padding: 20px 20px 0; }
  .hero-min .topbar nav a { padding: 7px 10px; }
  .hero-min .icon-large { width: 104px; height: 104px; border-radius: 24px; }
  .hero-min .center { gap: 22px; }
  .hero-min .stage { padding: 24px 20px 40px; }
}

/* Dark-mode logo swap */
.wordmark-img.is-dark { display: none; }
@media (prefers-color-scheme: dark) {
  .wordmark-img.is-light { display: none; }
  .wordmark-img.is-dark { display: block; }
}
