@layer components {
  /* Main needs to be flex container for landing to fill it */
  main:has(.landing) {
    display: flex;
    flex-direction: column;
  }

  .landing {
    display: flex;
    flex: 1;
    flex-direction: column;
  }

  .landing__hero {
    align-items: flex-start;
    display: flex;
    flex: 1;
    justify-content: center;
    padding: 15vh var(--main-padding) var(--block-space-double);
  }

  .landing__content {
    max-inline-size: 36rem;
    position: relative;
    text-align: center;
  }

  .landing__eyebrow {
    animation: landing-fade-in 800ms var(--ease-out-expo) backwards;
    animation-delay: 100ms;
    color: var(--color-primary);
    font-family: var(--font-sans);
    font-size: var(--text-small);
    font-weight: 600;
    letter-spacing: 0.08em;
    margin: 0 0 var(--block-space);
    text-transform: uppercase;
  }

  .landing__headline {
    animation: landing-fade-in 800ms var(--ease-out-expo) backwards;
    animation-delay: 200ms;
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 8vw, 4rem);
    font-weight: 400;
    letter-spacing: -0.02em;
    line-height: 1.2;
    margin: 0 0 var(--block-space-double);

    /* Subtle text gradient for polish */
    background: linear-gradient(
      180deg,
      var(--color-ink) 0%,
      var(--color-ink-darker) 100%
    );
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .landing__description {
    animation: landing-fade-in 800ms var(--ease-out-expo) backwards;
    animation-delay: 300ms;
    color: var(--color-ink-dark);
    font-family: var(--font-serif);
    font-size: var(--text-medium);
    line-height: 1.6;
    margin: 0 auto var(--block-space-double);
    max-inline-size: 28rem;
  }

  .landing__actions {
    animation: landing-fade-in 800ms var(--ease-out-expo) backwards;
    animation-delay: 400ms;
    margin-block-end: var(--block-space);

    .btn {
      min-inline-size: 12rem;
    }
  }

  .landing__login {
    animation: landing-fade-in 800ms var(--ease-out-expo) backwards;
    animation-delay: 500ms;
    color: var(--color-ink-medium);
    font-family: var(--font-sans);
    font-size: var(--text-small);
    margin: 0;

    a {
      color: var(--color-link);
      font-weight: 500;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 2px;
      transition: text-decoration-thickness 150ms ease;

      @media (any-hover: hover) {
        &:hover {
          text-decoration-thickness: 2px;
        }
      }
    }
  }

  .landing__footer {
    margin-block-start: auto;
    padding: var(--block-space) var(--main-padding);
    text-align: center;

    p {
      color: var(--color-ink-light);
      font-family: var(--font-sans);
      font-size: var(--text-x-small);
      margin: 0;
    }
  }

  /* Animation */
  @keyframes landing-fade-in {
    from {
      opacity: 0;
      transform: translateY(1rem);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  html[data-theme="dark"] .landing__headline {
    background: linear-gradient(
      180deg,
      var(--color-ink) 0%,
      var(--color-ink-darker) 100%
    );
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  @media (prefers-color-scheme: dark) {
    html:not([data-theme]) .landing__headline {
      background: linear-gradient(
        180deg,
        var(--color-ink) 0%,
        var(--color-ink-darker) 100%
      );
      background-clip: text;
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
    }
  }

  /* Reduced motion */
  @media (prefers-reduced-motion: reduce) {
    .landing__eyebrow,
    .landing__headline,
    .landing__description,
    .landing__actions,
    .landing__login {
      animation: none;
    }
  }
}
