html, body {
  margin: 0;
  padding: 0;
}

body {
  background: #fff;
}

/* LP全体は画像の実寸幅を上限にセンタリング（大画面での引き伸ばし防止） */
.main {
  max-width: 641px;
  margin: 0 auto;
}

/* 画像A：横幅100%で表示（mainのmax-width内で可変） */
.lp-image {
  display: block;
  width: 100%;
  height: auto;
}

/* 固定バナー：上に貼り付け（最初は非表示） */
.fixed-banner {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9999;

  opacity: 0;
  transform: translateY(-8px);
  pointer-events: none;

  transition: opacity 200ms ease, transform 200ms ease;
}

.fixed-banner.is-visible {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.fixed-banner__link {
  display: block;
  max-width: 641px;
  margin: 0 auto;
}

.fixed-banner__img {
  display: block;
  width: 100%;
  height: auto;
}
