/* Landing stage */

.landing-stage {
  min-height: calc(100dvh - var(--header-h));
  display: grid;
  place-items: center;
  padding: var(--sp-5) var(--sp-3);
  background:
    radial-gradient(ellipse at 50% -10%, color-mix(in srgb, var(--c-primary) 22%, transparent) 0%, transparent 60%),
    radial-gradient(ellipse at 20% 100%, color-mix(in srgb, var(--c-primary) 8%, transparent) 0%, transparent 50%),
    var(--c-bg);
}

.landing-inner {
  width: min(100%, 480px);
  display: grid;
  gap: var(--sp-5);
}

/* Hero */

.landing-hero {
  text-align: center;
  display: grid;
  gap: var(--sp-2);
}

.landing-emblem {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--sp-2);
  color: var(--c-primary);
  filter: drop-shadow(0 0 12px color-mix(in srgb, var(--c-primary) 55%, transparent));
}

.landing-emblem svg {
  width: 100%;
  height: 100%;
}

.landing-wordmark {
  font-family: var(--font-fantasy-display);
  font-size: clamp(2.4rem, 9vw, 3.8rem);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin: 0;
  line-height: 1;
  color: var(--c-text);
  text-shadow:
    0 0 48px color-mix(in srgb, var(--c-primary) 50%, transparent),
    0 2px 0 rgba(0, 0, 0, 0.35);
}

.landing-tagline {
  font-family: var(--font-fantasy);
  font-style: italic;
  color: var(--c-muted);
  font-size: var(--text-sm);
  margin: var(--sp-1) 0 0;
  letter-spacing: 0.06em;
}

/* Decorative rule under tagline */
.landing-rule {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  margin-top: var(--sp-1);
  color: var(--c-primary);
  opacity: 0.55;
}

.landing-rule::before,
.landing-rule::after {
  content: '';
  flex: 1;
  height: 1px;
  background: currentColor;
}

/* Diamond rune in center of rule */
.landing-rule::before {
  background: linear-gradient(to right, transparent, currentColor);
}

.landing-rule::after {
  background: linear-gradient(to left, transparent, currentColor);
}

/* Cards */

.landing-cards {
  display: grid;
  gap: 0;
}

.landing-card {
  background: var(--c-surface);
  border: var(--border-1);
  border-top: 2px solid var(--c-primary);
  padding: var(--sp-4) var(--sp-5);
  box-shadow: var(--shadow-2);
  display: grid;
  gap: var(--sp-3);
}

.landing-card + .landing-card {
  border-top: var(--border-1);
  box-shadow: none;
}

.landing-card__header h2 {
  font-family: var(--font-fantasy);
  font-size: var(--text-lg);
  font-weight: 600;
  margin: 0 0 var(--sp-1);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.landing-card__header p {
  color: var(--c-muted);
  font-size: var(--text-sm);
  margin: 0;
}

.landing-card__actions {
  display: grid;
  gap: var(--sp-2);
}

/* Shared elements */

.landing-btn {
  width: 100%;
  justify-content: center;
}

.landing-form {
  display: grid;
  gap: var(--sp-2);
}

/* Or separator */

.landing-sep {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
  color: var(--c-muted);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-family: var(--font-fantasy);
  background: var(--c-surface-2);
  border: var(--border-1);
  border-top: none;
  border-bottom: none;
  padding: var(--sp-2) var(--sp-5);
}

.landing-sep::before,
.landing-sep::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--c-border);
}

/* Responsive */

@media (max-width: 480px) {
  .landing-card {
    padding: var(--sp-3) var(--sp-3);
  }

  .landing-sep {
    padding: var(--sp-2) var(--sp-3);
  }
}
